在OpenCV中,比较常见的是矩形遮罩CvRect,没有专门提供圆形的mask,那么我们只能自己写一个来模拟圆形mask的函数,需要提供的参数为原图的大小,以及圆形mask的圆心位置和半径即可,返回一个cv::Mat型的mask,参见代码如下:
cv::Mat extractCircularMask(IplImage *img, int col, int row, int r) { IplImage *roi, *res; roi = cvCreateImage(cvGetSize(img), 8, 1); cvZero(roi); cvCircle(roi, cvPoint(col, row), r, CV_RGB(255, 255, 255), -1, 8, 0); return cv::Mat(roi); }
时间: 2025-01-17 13:53:30