I'm trying to find the biggest square and draw it on the original image.
When I call
drawContours(input,(screenCnt),-1,Scalar(255,0,0),3);
the following error occurs:
E/cv::error(): OpenCV Error: Assertion failed (i < 0) in cv::Mat cv::InputArray::getMat(int) const, file /build/master_pack-android/opencv/modules/core/src/matrix.cpp, line 1260
I found a lot of stuff on Github and Google, But I couldn't find any related solutions.
Could you help someone who knows how to solve it?
Here is my code. (c++)
bool compareContourAreas(vector<Point> contour1, vector<Point> contour2){
double i = fabs(contourArea(Mat(contour1)));
double j = fabs(contourArea(Mat(contour2)));
return ( i < j );
}
Mat &input = *(Mat *) matAddrInput;
Mat &result = *(Mat *) matAddrResult;
Mat gray;
Mat edge;
resize(input,input, cv::Size(), 0.75, 0.75);
cvtColor(input,gray,CV_RGB2GRAY);
GaussianBlur(gray,gray,Size(3,3),0);
Canny(gray,edge,100,200,3, false);
vector<vector<Point>> contours;
vector<Vec4i> hierarchy;
findContours(edge,contours,hierarchy,CV_RETR_LIST,CHAIN_APPROX_SIMPLE);
sort(contours.begin(),contours.end(),compareContourAreas);
vector<Point> approx;
vector<Point> screenCnt;
for(size_t i = 0; i < contours.size(); i++){
approxPolyDP((Mat(contours[i])),approx,arcLength(Mat(contours[i]),true) * 0.02, true);
if(approx.size() == 4){
screenCnt = approx;
break;
}
}
if(screenCnt.size() != 0){
drawContours(input,(screenCnt),-1,Scalar(255,0,0),3); << error
}