I have successfully read a grayscale image with imread function and I am trying to access al pixel values and copy them to a 2D vector. I am getting this error:
gray image channels: 1
OpenCV Error: Assertion failed (dims <= 2 && data && (unsigned)i0 < (unsigned)si
ze.p[0] && (unsigned)(i1 * DataType<_Tp>::channels) < (unsigned)(size.p[1] * cha
nnels()) && ((((sizeof(size_t)<<28)|0x8442211) >> ((DataType<_Tp>::depth) & ((1
<< 3) - 1))*4) & 15) == elemSize1()) in cv::Mat::at, file C:\opencv_3\opencv\bui
ld\include\opencv2/core/mat.inl.hpp, line 894
I dont seem to understand what is wrong with the following code:
Mat img = imread("C:\\digitalImageProcessing\\lion2.png", 0);
if (!img.data)
{
cout << "Could not open or find the image" << std::endl;
return -1;
}
namedWindow("Gray image", CV_WINDOW_AUTOSIZE);
// know the number of channels the image has
cout << "gray image channels: " << img.channels() << endl;
// ******************* READ the Pixel intensity *********************
int no_of_cols = img.cols;
int no_of_rows = img.rows;
int initial_value = 0;
std::vector<std::vector<int>> image_matrix;
image_matrix.resize(no_of_rows, std::vector<int>(no_of_cols,initial_value));
for (int j = 0; j < img.rows; j++)
{
for (int i = 0; i < img.cols; i++)
{
Scalar value = img.at<uchar>(i, j);
cout << "value = " << endl << " " << value.val[0] << endl << endl;
image_matrix[i][j] = intensity.val[0];
}
}
may be there is some better way than my code below but i think it might be better than your per-pixel loop
#include "opencv2/opencv.hpp"
#include "iostream"
using namespace cv;
using namespace std;
int main()
{
Mat img = Mat(3,3,CV_8UC1);
randu(img,0,255);
cout << "img pixels \n\n" << img << endl;
vector<vector<int> > image_matrix;
vector<int> image_matrix_row;
for( int i = 0; i < img.rows; i++)
{
img.row(i).copyTo(image_matrix_row);
image_matrix.push_back(image_matrix_row);
}
cout << "\nimage_matrix[1][1] : " << image_matrix[1][1];
return 0;
}
output :
img pixels
[ 91, 2, 79;
179, 52, 205;
236, 8, 181]
image_matrix[1][1] : 52