我有一个关于如何定义与OpenCV的一个投资回报率的问题。 我知道这个函数的定义cvSetImageROI
,但我想知道是否可以定义与OpenCV的一个投资回报率比矩形不同的形状。 例如,在圆形或在不同的形式定义的ROI。
这是可能做到这一点?
cvSetImageROI(IMG1,cvRect(A,B,C,d));
我有一个关于如何定义与OpenCV的一个投资回报率的问题。 我知道这个函数的定义cvSetImageROI
,但我想知道是否可以定义与OpenCV的一个投资回报率比矩形不同的形状。 例如,在圆形或在不同的形式定义的ROI。
这是可能做到这一点?
cvSetImageROI(IMG1,cvRect(A,B,C,d));
下面的代码,你会发现在这里 ,甚至在这里设置使用图像上的位掩码的圆形ROI。
#include "cv.h"
#include "highgui.h"
int main(int argc, char** argv)
{
IplImage* src, * res, * roi;
/* usage: <prog_name> <image> */
if (argc < 2)
{
fprintf(stderr, "Usage: %s <image>\n", argv[0]);
return 1;
}
src = cvLoadImage(argv[1], 1);
res = cvCreateImage(cvGetSize(src), 8, 3);
roi = cvCreateImage(cvGetSize(src), 8, 1);
/* prepare the 'ROI' image */
cvZero(roi);
/* Note that you can use any shape for the ROI */
cvCircle(
roi,
cvPoint(130, 100),
50,
CV_RGB(255, 255, 255),
-1, 8, 0
);
/* extract subimage */
cvAnd(src, src, res, roi);
/*
* do the main processing with subimage here.
* in this example, we simply invert the subimage
*/
cvNot(res, res);
/* 'restore' subimage */
IplImage* roi_C3 = cvCreateImage(cvGetSize(src), 8, 3);
cvMerge(roi, roi, roi, NULL, roi_C3);
cvAnd(res, roi_C3, res, NULL);
/* merge subimage with original image */
cvNot(roi, roi);
cvAdd(src, res, res, roi);
/* show result */
cvNamedWindow(argv[1], 1);
cvNamedWindow("res", 1);
cvShowImage(argv[1], src);
cvShowImage("res", res);
cvWaitKey(0);
/* be tidy */
cvDestroyAllWindows();
cvReleaseImage(&src);
cvReleaseImage(&res);
cvReleaseImage(&roi);
return 0;
}
为五边形或六边形只是适应它,以便改变掩模的几何形状。 检查这太问题: 在使用OpenCV的投资回报率? 。
你应该使用口罩来模拟非矩形ROI。
以下为通知ROI的代码。 然而,要改变为不同的形状简单地与某些其它形状替代CvCircle()函数。 cvAnd(src, src, res, roi);
是这里最重要的掩蔽功能。
//(c) 2012 enthusiasticgeek for Stack overflow
#include "cv.h"
#include "highgui.h"
#define REQUIRED_RADIUS (100)
int main(int argc, char** argv)
{
IplImage* src, * res, * roi;
/* usage: <prog_name> <image> */
if (argc < 2)
{
fprintf(stderr, "Usage: %s <image>\n", argv[0]);
return 1;
}
src = cvLoadImage(argv[1], 1);
cvSetImageROI(src,cvRect(src->width/2-REQUIRED_RADIUS, src->height/2-REQUIRED_RADIUS,REQUIRED_RADIUS*2,REQUIRED_RADIUS*2));
res = cvCreateImage(cvGetSize(src), 8, 3);
roi = cvCreateImage(cvGetSize(src), 8, 1);
/* prepare the 'ROI' image */
cvZero(roi);
cvZero(res);
/* Note that you can use any shape for the ROI */
cvCircle(
roi,
cvPoint(REQUIRED_RADIUS,REQUIRED_RADIUS),//src->width/2, src->height/2),
REQUIRED_RADIUS,
CV_RGB(255, 255, 255),
-1, 8, 0
);
/* extract subimage */
cvAnd(src, src, res, roi);
/* show result */
cvNamedWindow("res", 1);
cvShowImage("res", res);
cvWaitKey(0);
/* be tidy */
cvDestroyAllWindows();
cvReleaseImage(&src);
cvReleaseImage(&res);
cvReleaseImage(&roi);
return 0;
}