漫水填充是一种用特定的颜色填充连通区域,通过设置可连通像素的上下限以及连通方式来达到不同的填充效果的方法。漫水填充被 用来标记或分离图像的一部分,以便对其进行一步处理或分析 ,也可以用来从输入图像获取掩码区域,掩码会加速处理过程,或只处理掩码指定的像素点, 操作的结果总是某个连续的区域。漫水填充(FloodFill)是查找和种子点联通的颜色相同的点,魔术棒选择工具则是查找和种子点联通的颜色相近的点,将和初始种子像素颜色相近的点压进栈作为新种子。
FloodFill函数:用指定的颜色从种子点开始填充一个连接域。连通性由像素值的接近程度来衡量。
不带掩膜mask:
int floodFill(InputOutputArray image, Point seedPoint, Scalar newVal, Rect* rect = 0, Scalar loDiff = Scalar(), Scalar upDiff = Scalar(), int flags=4 ) int cv::floodFill( InputOutputArray _image,Point seedPoint, Scalar newVal, Rect* rect, Scalar loDiff, Scalar upDiff, int flags ) { CvConnectedComp ccomp; CvMat c_image = _image.getMat(); cvFloodFill(&c_image, seedPoint, newVal, loDiff, upDiff, &ccomp,flags, 0); if( rect ) *rect = ccomp.rect; return cvRound(ccomp.area); }
带mask:
int floodFill(InputOutputArray image, InputOutputArray mask, Point seedPoint, Scalar newVal, Rect* rect=0, Scalar loDiff = Scalar(), Scalar upDiff = Scalar(), int flags = 4 ) int cv::floodFill( InputOutputArray _image, InputOutputArray _mask, Point seedPoint, ScalarnewVal, Rect* rect, Scalar loDiff, Scalar upDiff, int flags ) { CvConnectedComp ccomp; CvMat c_image = _image.getMat(), c_mask = _mask.getMat(); cvFloodFill(&c_image, seedPoint, newVal,loDiff, upDiff, &ccomp, flags, c_mask.data.ptr ? &c_mask : 0); if( rect ) *rect = ccomp.rect; return cvRound(ccomp.area); }
这个掩膜 mask ,用于进一步控制哪些区域将被填充颜色 (比如:当对同一图像进行多次填充时)。
参数1,输入/输出1通道或3通道,8位或浮点图像。Mat类型
参数2,InputOutputArray类型的mask,这是第二个版本的floodFill独享的参数,表示操作掩 模。它应该为单通道、8位、长和宽上都比输入图像 image 大两个像素点的图像。第 二个版本的floodFill需要使用以及更新掩膜,所以这个mask参数我们一定要将其准备 好并填在此处。需要注意的是,漫水填充不会填充掩膜mask的非零像素区域。例 如
一个边缘检测算子的输出可以用来作为掩膜,以防止填充到边缘。同样的,也可以在
多次的函数调用中使用同一个掩膜,以保证填充的区域不会重叠。另外需要注意的是
,掩膜mask会比需填充的图像大,所以 mask 中与输入图像(x,y)像素点相对应的点的
坐标为(x + 1, y + 1)。
参数3,Point类型的seedPoint,漫水填充算法的起始点。
参数4,Scalar类型的newVal,像素点被染色的值,即在重绘区域像素的新值。
参数5,Rect* 类型的rect,有默认值0,一个可选的参数,用于设置floodFill函数将要重绘
区域的最小边界矩形区域。
参数6,Scalar类型的loDiff,有默认值Scalar( ),表示当前观察像素值与其部件邻域像素值
或者待加入该部件的种子像素之间的亮度或颜色之负差(lower brightness/color
difference)的最大值。
参数7,Scalar类型的upDiff,有默认值Scalar( ),表示当前观察像素值与其部件邻域像素
值或者待加入该部件的种子像素之间的亮度或颜色之正差(lower brightness/color
difference)的最大值。
参数8,int类型的flags,操作标志符,此参数包含三个部分:
低八位:(第0~7位)用于控制算法的连通性,可取4 (默认值) 或者 8。如果设为4,表示填
充算法只考虑当前像素水平方向和垂直方向的相邻点;如果设为 8,除上述相邻点
外,还会包含对角线方向的相邻点。
高八位部分:(16~23位)可以为0 或者如下两种选项标识符的组合:
FLOODFILL_FIXED_RANGE - 如果设置为这个标识符的话,就会考虑当前像素与种子
像素之间的差,否则,考虑当前像素与其相邻像素的差。
也就是说,这个范围是浮动的。
FLOODFILL_MASK_ONLY - 如果设置为这个标识符的话,函数不会去填充改变原始图
像 (也就是忽略第三个参数newVal), 而是去填充掩模图像
(mask)。这个标识符只对第二个版本的floodFill有用,因第
一个版本里面压根就没有mask参数。
中间八位部分:上面关于高八位FLOODFILL_MASK_ONLY标识符中已经说的很明显,需要
输入符合要求的掩码。Floodfill的flags参数的中间八位的值就是用于指定填充
掩码图像的值的。但如果flags中间八位的值为0,则掩码会用1来填充。
而所有flags可以用or操作符连接起来,即“|”。例如,如果想用8邻域填充,并
填充固定像素值范围,填充掩码而不是填充源图像,以及设填充值为38,
那么输入的参数是这样:
flags = 8 | FLOODFILL_MASK_ONLY | FLOODFILL_FIXED_RANGE | (38<<8)
显示效果:
代码:
Mat srcImg1; srcImg1 = imread("E:\\img\\logo6.png"); imshow("源图srcImg1", srcImg1); Rect rect; floodFill(srcImg1, Point(30, 30), Scalar(155, 255, 55), &rect, Scalar(20, 20, 20), Scalar(20, 20, 20)); imshow("漫水填充srcImg2", srcImg1);
《opencv学习笔记》-- 漫水填充
最新推荐文章于 2023-09-13 16:03:52 发布