打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
【转】OpenCV计算连通区域数目与最大连通区域并标示出
#include <stdio.h>
#include <cv.h>
#include <highgui.h>

#pragma comment(lib, "cv.lib")
#pragma comment(lib, "cxcore.lib")
#pragma comment(lib, "highgui.lib")

int main( int argc, char** argv )  
{
IplImage* src = cvLoadImage(".\\wind.png", CV_LOAD_IMAGE_GRAYSCALE);
IplImage* dst = cvCreateImage(cvGetSize(src), 8, 3);
CvMemStorage* storage = cvCreateMemStorage(0);
CvSeq* contour = 0;
cvThreshold(src, src,120, 255, CV_THRESH_BINARY); // 二值化
cvNamedWindow("Source", 1);
cvShowImage("Source", src);
// 提取轮廓
int contour_num = cvFindContours(src, storage, &contour, sizeof(CvContour), CV_RETR_CCOMP, CV_CHAIN_APPROX_SIMPLE);
cvZero(dst); // 清空数组
CvSeq *_contour = contour; 
double maxarea = 0;
double minarea = 100;
int m = 0;
for( ; contour != 0; contour = contour->h_next )  
{  

double tmparea = fabs(cvContourArea(contour));
if(tmparea < minarea)   
{  
cvSeqRemove(contour, 0); // 删除面积小于设定值的轮廓
continue;
}  
CvRect aRect = cvBoundingRect( contour, 0 ); 
if ((aRect.width/aRect.height)<1)  
{  
cvSeqRemove(contour, 0); //删除宽高比例小于设定值的轮廓
continue;
}  
if(tmparea > maxarea)  
{  
maxarea = tmparea;
}  
m++;
// 创建一个色彩值
CvScalar color = CV_RGB( 0, 255, 255 );

//max_level 绘制轮廓的最大等级。如果等级为0,绘制单独的轮廓。如果为1,绘制轮廓及在其后的相同的级别下轮廓
//如果值为2,所有的轮廓。如果等级为2,绘制所有同级轮廓及所有低一级轮廓,诸此种种
//如果值为负数,函数不绘制同级轮廓,但会升序绘制直到级别为abs(max_level)-1的子轮廓
cvDrawContours(dst, contour, color, color, -1, 1, 8); //绘制外部和内部的轮廓
}  
contour = _contour;
int count = 0;
for(; contour != 0; contour = contour->h_next)
{  
count++;
double tmparea = fabs(cvContourArea(contour));
if (tmparea == maxarea)  
{  
CvScalar color = CV_RGB( 255, 0, 0);
cvDrawContours(dst, contour, color, color, -1, 1, 8);
}  
}  
printf("The total number of contours is:%d", count);
cvNamedWindow("Components", 1);
cvShowImage("Components", dst);
cvWaitKey(0);
cvDestroyWindow("Source");
cvReleaseImage(&src);
cvDestroyWindow("Components");
cvReleaseImage(&dst);

return 0;
}  

本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
OpenCv的连通域操作
基于distanceTransform-距离变换的区域中心提取
OpenCV(C++版)轮廓(contour)检测
OpenCV图像处理教程C++(二十)轮廓发现、凸包、轮廓周围绘制圆和矩形
OpenCV-清除小面积连通域
opencv实战机器视觉检测和计数(读入图像形态学二值化消除噪声)
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服