OpenCV断言对RECT ROI失败了

OpenCv assertion failed about rect ROI

本文关键字:失败 ROI RECT 断言 OpenCV      更新时间:2023-10-16

我正在尝试编写图像旋转,但是我现在有一些问题。这是我的代码:

Mat rotateMagnify (Mat& img, int degree){
double angle = degree  * CV_PI / 180.;
double a = sin(angle), b = cos(angle);
int width = img.cols, height = img.rows;
int width_rotate = int(height * fabs(b) - width * fabs(a) + width);
int height_rotate = int(width * fabs(a) + height * fabs(b) + height);
Mat img_rotate;
img_rotate.create((width_rotate, height_rotate), img.depth(), img.channels());

int tempLength = sqrt((double)width * width + (double)height *height) + 10;
int tempX = (tempLength + 1) / 2 - width / 2;
int tempY = (tempLength + 1) / 2 - height / 2;

Mat temp;
temp.create((tempLength, tempLength), img.depth(), img.channels());
//cvZero(&img_rotate);
Mat roiImage = temp(Rect(Point(tempX, tempY), Point(width, height)));
//roiImage.ResetImageROI(roiImage);
img.copyTo(roiImage);
float m[6];
int w = roiImage.cols;
int h = roiImage.rows;
m[0] = b;
m[1] = a;
m[3] = -m[1];
m[4] = m[0];
m[2] = w * 0.5f;
m[5] = h * 0.5f;
CvMat M = cvMat(2, 3, CV_32F, m);
cvGetQuadrangleSubPix(&roiImage, &img_rotate, &M);
roiImage.release();
return img_rotate;}

不幸的是,此代码不起作用。我得到这样的错误:

OpenCV Error: Assertion failed (0 <= roi.x && 0 <= roi.width && roi.x + 
roi.width <= m.cols && 0 <= roi.y && 0 <= roi.height && roi.y + roi.height 
<= m.rows) in cv::Mat::Mat, file C:buildsmaster_PackSlave-win32-vc12-
sharedopencvmodulescoresrcmatrix.cpp, line 495

如何解决此错误。谢谢大家的帮助!

当您尝试复制(裁剪(图像的一部分时,通常会出现此错误图像。添加断点和检查int tempX = (tempLength + 1) / 2 - width / 2; int tempY = (tempLength + 1) / 2 - height / 2; 的值,请尝试处理上述条件,然后再尝试

Mat roiimage = temp(rect(point(tempx,tempy(,点(宽度,高度((((;

//roiimage.resetimageroi(roiimage(;

img.copyto(roiimage(;