在我们学习图像处理时,很多时候需要在一张图片中找到我们想要的一个区域,但是这个图片又是眼花缭乱的,我们该怎么做呢?
我在这里总结一下我在处理时的一个过程,前边的很多工作都是很简单的,比如:首先转为灰度图,然后二值化处理,接下来就是边缘检测,这里最好创建一个滑动调,可以找到最好的边缘,然后就是发现轮廓,到这里也就是到了最关键的地方,我在这里是采用的面积过滤的方法,也就是在发现轮廓后创建了一个for循环,在for循环里面采用一个面积函数contoursArea来计算每个轮廓的面积,
就是这个样子的,记住,定义一些接收发现轮廓里面的数集时,一定要定义在发现论库后面
就是这个样子,我这里贴一下我的代码,我当时是为了裁剪一个圆,然后通过:发现轮廓,面积筛选,半径筛选,最后才找到的
在找到的ROI位置,再画了一个矩形,我是为了获取矩形的左上角和宽高,以便再截取ROI是好定位和知道宽高,另一个关键步骤是ROI的截取,我这里用的是掩膜提取,什么意思呢?就是:定义一个mask掩膜模板
Mat mask=Mat::zeros(g_src.size(),CV_8UC1);
这里必须是单通道的,
然后就是
mask(mrect).setTo(255);
把掩膜的mrect区域全部设置成255,意思是黑色还是白色?我忘记了啥个啥了,反正就是255,mrect就是上边你感兴趣的ROI区域左上角左边和宽高,
最后就是把原图copyTo上
g_src.copyTo(g_can_out,mask);
这个最左边是原图,括号里面第一个是一个空白的模板,啥都没有,就是一开始你Mat dst,然后准备输出的东西,第而个就是你刚才创建的那个掩膜,
就是把掩膜放在原图片上,掩膜下对应原图片的内容复制到另一个模板上。
能力有限,表达可能不准确,希望大家批评指正,有问题可以讨论