我正在使用OpenCV 3.0从文件加载图像,然后将该数据存储在数组中。
如果我使用:
cv::Mat image = cv::imread("myimage.png");
uchar pixel = image.at<uchar>(50, 100);
它将给出(x = 100,y = 50)图像坐标处的像素值。
但是,如果我现在将图像内存复制到数组:
uchar data[image.rows * image.cols];
memcpy(data, image.data, image.rows * image.cols);
然后从这个数组中读取像素值:
uchar pixel = data[100 * image.cols + 50];
然后它没有给我与以前相同的价值。
我想知道为什么会这样?是因为OpenCV不以这种方式将其内存存储为单个数组吗?如果是这样,我怎么能将内存复制到一个数组,然后直接从这个数组访问像素值?
谢谢:)
答案 0 :(得分:3)
这是因为OpenCV使用了填充 每行可能包含额外的字节以确保更好的对齐。
如果您需要这样的数据,请以这种方式复制数据。
for ( int i=0; i<image.rows; ++i )
memcpy( &data[i*100], image.data + image.step*i, 50);
此外,数据按水平线(行)排列。所以你应该这样访问它:
image.at<uchar>(Y,X).
uchar pixel = data[Y*image.cols + X];
或者你可以复制,如果包含填充:
memcpy( data, image.data, image.step*image.rows);
然后你必须使用大小为image.step(可能等于或大于image.cols)的行来访问它。
uchar pixel = data[Y*image.step + X];