inf*_*rno 15 c++ opencv image-processing
我正在为形状检测编写小应用程序.我首先需要做的是找到图像上最重要的形状.我从一些预处理开始,包括将图像转换为灰度,阈值和边缘检测.这些操作之前和之后的图像如下所示
之前

后

因此,您可以看到主要形状是可见的(但它有点散乱),还有一些噪音(小树等).我需要做的是以某种方式提取最重要的形状(最大的形状) - 在这种情况下它是一个塔.我想要做的是在opencv中使用轮廓查找功能,然后以某种方式使用多边形找到conturs.然后我会(不知何故)计算countours的面积并选择最大的面积.到目前为止,我只能(仅)使用找到轮廓
cvFindContours(crated,g_storage,&contours);
Run Code Online (Sandbox Code Playgroud)
我知道有一个
cvApproxPoly
Run Code Online (Sandbox Code Playgroud)
函数,但是我无法获得有关此函数结果的任何有用信息.有人可以告诉我是否可以计算轮廓的面积或用多边形逼近轮廓.也许你有更好的想法如何只提取最重要的形状?
如果你总是有一个受控的背景,我会采取这些步骤(由@damian建议):
你的主要问题是塔的轮廓是分散的.从那些小碎片中重建整个轮廓将很困难.优化边缘检测阶段(尝试cvAdaptiveThreshold),或使用不同的方法(可能像对象分割)
将轮廓合成为一体后,可以检查其区域如下:
CvSeq* convex_hull=cvConvexHull2( contour, storage, CV_CLOCKWISE, 2 );
CvSeq* quad=cvApproxPoly(convex_hull, sizeof(CvContour), storage, CV_POLY_APPROX_DP, cvContourPerimeter(contour)*0.02, 0);
float size=fabs(cvContourArea( quad,CV_WHOLE_SEQ,0 ));
Run Code Online (Sandbox Code Playgroud)
您需要调整参数.它用于检测矩形.