为什么会写这个文章呢?是因为最近做一个opencv相关的项目,涉及到存储像素坐标,但是我并不知道像素的数量,所以想建立一个二维数组来动态存储像素的x,y坐标。由书上的知识可知,C++中的二维数组实质上是一维数组里存储的元素仍然是一维数组,而且在定义的时候必须指定数组的大小,很显然无法满足我们的需要。
经过查找网上的资料,发现还有一种方法是利用new运算符建立动态数组,但是并不好用。所以,尝试使用二维vector类模板。如下是我的代码,做个记录,以便日后查看。
#include "stdafx.h"
#include <vector>
#include <iostream>
#include <fstream>
#include <opencv2\opencv.hpp>
#include <opencv2\core\core.hpp>
#include <opencv2\imgproc\imgproc.hpp>
#include <opencv2\highgui\highgui.hpp>
using namespace std;
using namespace cv;
int main(int argc, _TCHAR* argv[])
{
//读入图片,注意图片路径
Mat src_image = imread("0_corrected_foreground.png", 1);
int rows = src_image.rows;//表示图像像素的行数,对应于图像坐标的y轴
int cols = src_image.cols;//表示图像像素的列数,对应于图像坐标的x轴
vector<int> vec10;//用于存放i = rows坐标
vector<int> vec11;//用于存放j < cols坐标
vector<vector<int>> vec2;
//图片读入成功与否判定
if (!src_image.data)
{
cout << "The image reading process is wrong!" << endl;
//等待按键
system("pause");
return -1;
}
imshow("原始图像", src_image);
ofstream savefile("results.txt",ios::out);//新建一个txt文件
for (int i = 0; i < rows; i++)//双层循环,遍历图像的像素点
{
for (int j = 0; j < cols; j++)
{
int bin_val = src_image.at<uchar>(i, j);
if (bin_val==255)//判断,如果此像素的灰度值是255,即白色的,保存对应的坐标。
{
savefile << i << ", " << j << endl;//保存到txt文件中
vec10.push_back(i);//push_back赋值
vec11.push_back(j);//push_back赋值
}
}
}
vec2.push_back(vec10);//将一维vector推入二维vector
vec2.push_back(vec11);//将一维vector推入二维vector
savefile.close();//txt文件关闭,保存
waitKey();
return 0;
}
感谢 https://ask.csdn.net/questions/246763
https://blog.csdn.net/liyuqian199695/article/details/63680514?locationNum=14
https://blog.csdn.net/abc8730866/article/details/62236040
https://blog.csdn.net/qq_20823641/article/details/51932798
https://blog.csdn.net/a819825294/article/details/52088732