【OpenCV入门指南】第六篇 轮廓检测 下

上一篇OpenCV入门指南】第五篇轮廓检测上》介绍了cvFindContours函数和cvDrawContours函数,并作了一个简单的使用示范。本篇将展示一个实例,让大家对轮廓检测有个更加深入的认识。

 

代码如下:

[cpp]  view plain  copy
  1. //图像的轮廓检测下  
  2. //By MoreWindows (http://blog.csdn.net/MoreWindows)  
  3. #include <opencv2/opencv.hpp>  
  4. using namespace std;  
  5. #pragma comment(linker, "/subsystem:\"windows\" /entry:\"mainCRTStartup\"")  
  6. IplImage *g_pGrayImage = NULL;  
  7. const char *pstrWindowsBinaryTitle = "二值图(http://blog.csdn.net/MoreWindows)";  
  8. const char *pstrWindowsOutLineTitle = "轮廓图(http://blog.csdn.net/MoreWindows)";  
  9. CvSeq *g_pcvSeq = NULL;  
  10.   
  11. void on_trackbar(int pos)  
  12. {  
  13.     // 转为二值图  
  14.     IplImage *pBinaryImage = cvCreateImage(cvGetSize(g_pGrayImage), IPL_DEPTH_8U, 1);  
  15.     cvThreshold(g_pGrayImage, pBinaryImage, pos, 255, CV_THRESH_BINARY);  
  16.     // 显示二值图  
  17.     cvShowImage(pstrWindowsBinaryTitle, pBinaryImage);  
  18.   
  19.     CvMemStorage* cvMStorage = cvCreateMemStorage();  
  20.     // 检索轮廓并返回检测到的轮廓的个数  
  21.     cvFindContours(pBinaryImage,cvMStorage, &g_pcvSeq);  
  22.   
  23.     IplImage *pOutlineImage = cvCreateImage(cvGetSize(g_pGrayImage), IPL_DEPTH_8U, 3);  
  24.     int _levels = 5;  
  25.     cvZero(pOutlineImage);  
  26.     cvDrawContours(pOutlineImage, g_pcvSeq, CV_RGB(255,0,0), CV_RGB(0,255,0), _levels);  
  27.     cvShowImage(pstrWindowsOutLineTitle, pOutlineImage);  
  28.   
  29.     cvReleaseMemStorage(&cvMStorage);  
  30.     cvReleaseImage(&pBinaryImage);  
  31.     cvReleaseImage(&pOutlineImage);  
  32. }  
  33.   
  34. int main( int argc, char** argv )  
  35. {     
  36.     const char *pstrWindowsSrcTitle = "原图(http://blog.csdn.net/MoreWindows)";  
  37.     const char *pstrWindowsToolBarName = "二值化";  
  38.   
  39.     // 从文件中加载原图  
  40.     IplImage *pSrcImage = cvLoadImage("003.jpg", CV_LOAD_IMAGE_UNCHANGED);  
  41.     // 显示原图  
  42.     cvNamedWindow(pstrWindowsSrcTitle, CV_WINDOW_AUTOSIZE);  
  43.     cvShowImage(pstrWindowsSrcTitle, pSrcImage);  
  44.   
  45.     // 转为灰度图  
  46.     g_pGrayImage =  cvCreateImage(cvGetSize(pSrcImage), IPL_DEPTH_8U, 1);  
  47.     cvCvtColor(pSrcImage, g_pGrayImage, CV_BGR2GRAY);  
  48.   
  49.     // 创建二值图和轮廓图窗口  
  50.     cvNamedWindow(pstrWindowsBinaryTitle, CV_WINDOW_AUTOSIZE);  
  51.     cvNamedWindow(pstrWindowsOutLineTitle, CV_WINDOW_AUTOSIZE);  
  52.   
  53.   
  54.     // 滑动条    
  55.     int nThreshold = 0;  
  56.     cvCreateTrackbar(pstrWindowsToolBarName, pstrWindowsBinaryTitle, &nThreshold, 254, on_trackbar);  
  57.   
  58.     on_trackbar(1);  
  59.   
  60.     cvWaitKey(0);  
  61.   
  62.     cvDestroyWindow(pstrWindowsSrcTitle);  
  63.     cvDestroyWindow(pstrWindowsBinaryTitle);  
  64.     cvDestroyWindow(pstrWindowsOutLineTitle);  
  65.     cvReleaseImage(&pSrcImage);  
  66.     cvReleaseImage(&g_pGrayImage);  
  67.     return 0;  
  68. }  

程序运行结果如下所示:

可以明显看出,由于图像的二值化处理只是根据图像中单个像素的值来决定,因此这种最简单轮廓检测所产生的结果和人眼观测的实际感觉肯定是有比较大的区别的。

 

轮廓检测另外还有一个重要的函数cvApproxPoly,它的函数原型如下所示

CVAPI(CvSeq*)  cvApproxPoly(

  const voidsrc_seq,

  int header_size,

  CvMemStoragestorage,

  int method,

  double parameter,

  int parameter2 CV_DEFAULT(0)

);

由于篇幅问题,对于cvApproxPoly函数就不细讲了,有兴趣的读者可以参考下面这一篇博客:http://blog.csdn.net/bruce_zeng/article/details/8074253

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值