逐点绘出检测出的轮廓图

#include <cxcore.h>  
#include <cv.h>
#include <highgui.h> 
#include <iostream.h>

int main( int argc, char* argv[] )  
{  
//	int i;
	int mode = CV_RETR_EXTERNAL;//提取轮廓的模式
	int contours_num = 0;//图像中提取轮廓的数目
	CvMemStorage* storage = cvCreateMemStorage(0);//开辟64K的存储空间
	CvSeq* contour = 0;//存储提取轮廓的序列指针
	IplImage* bin_img = cvLoadImage("C:\\Users\\xht\\Desktop\\open\\ba.jpg",0);//读入要检测的图像
	cvThreshold(bin_img,bin_img,128,255,CV_THRESH_BINARY);//二值化

	IplImage* pContourImg = cvCreateImage(cvGetSize(bin_img),8,3);
	//显示原始图像
	cvNamedWindow("bin_img",1);
	cvShowImage("bin_img",bin_img);
	//找到轮廓数目
	mode = CV_RETR_EXTERNAL;
	contours_num = cvFindContours(bin_img,storage,&contour,sizeof(CvContour),mode,CV_CHAIN_APPROX_NONE);
	cout<<contours_num<<endl;//输出轮廓的数目
	/************************************************************************/
	/*                逐点绘出轮廓                                          */
	/************************************************************************/
	CvSeqReader reader;//读序列
	int count = 0;
	if(contour != 0)//输出组成轮廓的点的数目
	{
		count = contour->total;
		cout<<count<<endl;
	}
	cvStartReadSeq(contour,&reader,0);
	CvPoint pt1;
	CvScalar color = CV_RGB(255,255,255);
	cvNamedWindow("contour",1);
	cvShowImage("contour",pContourImg);
	for (int i = 1;i<count;i++)//逐点将轮廓的点绘出
	{
		CV_READ_SEQ_ELEM(pt1,reader);
		cvCircle(pContourImg,pt1,1,color);
		cvShowImage("contour",pContourImg);
		cvWaitKey(5);
	}

	cvWaitKey(0);//等待
	cvReleaseImage(&bin_img);
	cvReleaseImage(&pContourImg);
	cvReleaseMemStorage(&storage);
	return 0;
} 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值