OpenCV编程案例:使用轮廓函数检测连通区域
2010-10-13 16:43
801 查看
转自:http://www.aiseminar.cn/bbs/thread-617-1-1.html
此案例位于CXCORE中cvDrawContours函数介绍部分给出。此程序首先载入一个二值图像文件,然后使用函数再次二值化确认。接着使用cvFindContours找到轮廓,然后使用填充方式绘制轮廓线内部区域,由此得到的彩色区域便是联连通区域。其中,黑色是0值区域,彩色区域便是连通区域。连通区域的色彩是使用随机数生成的。
// bwlabel.cpp
#include <cv.h>
#include <highgui.h>
int main( int argc, char** argv)
{
IplImage* src;
// the first command line parameter must be file name of binary (black-n-white) image
if( argc == 2 && (src=cvLoadImage(argv[1], 0))!= 0)
{
IplImage* dst = cvCreateImage( cvGetSize(src), 8, 3 );
CvMemStorage* storage = cvCreateMemStorage(0);
CvSeq* contour = 0;
cvThreshold( src, src, 1, 255, CV_THRESH_BINARY );
cvNamedWindow( "Source", 1 );
cvShowImage( "Source", src );
cvFindContours( src, storage, &contour, sizeof(CvContour), CV_RETR_CCOMP, CV_CHAIN_APPROX_SIMPLE );
cvZero( dst );
for( ; contour != 0; contour = contour->h_next )
{
CvScalar color = CV_RGB( rand()&255, rand()&255, rand()&255 );
/* replace CV_FILLED with 1 to see the outlines */
cvDrawContours( dst, contour, color, color, -1, CV_FILLED, 8 );
}
cvNamedWindow( "Components", 1 );
cvShowImage( "Components", dst );
cvWaitKey(0);
}
return 0;
}
在OpenCV 1.1、VC6.0编译运行通过。实验过程如下:
1. 选择OpenCV sample/c中的一个二值图像。
2. 运行中输入cmd,使用命令行进入程序编译结果debug文件夹(即exe所在目录),将图片文件放入此文件夹。
3. 使用命令,运行程序:bwlabel pic1.png
此案例位于CXCORE中cvDrawContours函数介绍部分给出。此程序首先载入一个二值图像文件,然后使用函数再次二值化确认。接着使用cvFindContours找到轮廓,然后使用填充方式绘制轮廓线内部区域,由此得到的彩色区域便是联连通区域。其中,黑色是0值区域,彩色区域便是连通区域。连通区域的色彩是使用随机数生成的。
// bwlabel.cpp
#include <cv.h>
#include <highgui.h>
int main( int argc, char** argv)
{
IplImage* src;
// the first command line parameter must be file name of binary (black-n-white) image
if( argc == 2 && (src=cvLoadImage(argv[1], 0))!= 0)
{
IplImage* dst = cvCreateImage( cvGetSize(src), 8, 3 );
CvMemStorage* storage = cvCreateMemStorage(0);
CvSeq* contour = 0;
cvThreshold( src, src, 1, 255, CV_THRESH_BINARY );
cvNamedWindow( "Source", 1 );
cvShowImage( "Source", src );
cvFindContours( src, storage, &contour, sizeof(CvContour), CV_RETR_CCOMP, CV_CHAIN_APPROX_SIMPLE );
cvZero( dst );
for( ; contour != 0; contour = contour->h_next )
{
CvScalar color = CV_RGB( rand()&255, rand()&255, rand()&255 );
/* replace CV_FILLED with 1 to see the outlines */
cvDrawContours( dst, contour, color, color, -1, CV_FILLED, 8 );
}
cvNamedWindow( "Components", 1 );
cvShowImage( "Components", dst );
cvWaitKey(0);
}
return 0;
}
在OpenCV 1.1、VC6.0编译运行通过。实验过程如下:
1. 选择OpenCV sample/c中的一个二值图像。
2. 运行中输入cmd,使用命令行进入程序编译结果debug文件夹(即exe所在目录),将图片文件放入此文件夹。
3. 使用命令,运行程序:bwlabel pic1.png
相关文章推荐
- OpenCV编程案例:使用轮廓函数检测连通区域
- opencv轮廓检测之 drawContours 函数 使用样例
- OpenCV2编程手册笔记之 7.2使用Canny算子检测轮廓
- 使用opencv编写函数 删除二值图像中面积较小的连通区域
- 使用OpenCV中cvFindContour函数检测轮廓的心得
- opencv结构分析与形状识别-轮廓检测和填充(连通区域-边缘与整个图像的目标)
- 使用OpenCv的cvMinAreaRect2函数获取轮廓的可倾斜最小矩形区域
- OpenCV中寻找轮廓函数cvFindContours的使用说明以及序列cvSeq的用法说明
- matlab 中如何使用bwboundaries获取连通区域并求取其轮廓
- opencv自动光学检测、目标分割和检测(连通区域和findContours)
- OpenCV 使用 findContours 函数 Note1: 利用各个轮廓的相互阶层(hierarchy)关系
- Opencv2系列学习笔记10(提取连通区域轮廓)
- 使用opencv编写的删除面积过小的轮廓的函数
- 【OpenCV+Python】轮廓检测及绘制,可用以生成对应于不规则形状ROI区域的mask
- 【OpenCV学习笔记 010】提取直线、轮廓及连通区域
- 【转】Opencv2系列学习笔记10(提取连通区域轮廓)
- 使用OpenCV查找二值图中最大连通区域
- OpenCV-Python教程(9)(10)(11): 使用霍夫变换检测直线 直方图均衡化 轮廓检测
- 【OpenCV学习笔记 010】提取直线、轮廓及连通区域
- C++与opencv的一些编程和函数的使用错误总结