【opencv】轮廓相关
IplImage* contours_rect;
IplImage* contours;
CvMemStorage* countours_storage=NULL;
if(contours_rect==NULL)
{
contours_rect=cvCreateImage(cvSize(video_width,video_height),IPL_DEPTH_8U,);
}
if(contours==NULL)
{
contours=cvCreateImage(cvSize(video_width,video_height),IPL_DEPTH_8U,);
}else{
memcpy(contours->imageData,fgedge->imageData,fgedge->height*fgedge->width);
}
if(countours_storage==NULL)
{
countours_storage=cvCreateMemStorage();
}else{
cvClearMemStorage(countours_storage);
}
CvSeq* firstContour=NULL;
int contours_num=cvFindContours(contours,countours_storage,&firstContour); //查找所有轮廓
cvZero(contours); //图像置为全黑
CvSeq* contourlonger=NULL; //虽然赋值为NULL 但是实际上不是的
CvSeq* temp=NULL;
int n_contours=;
for(;firstContour->h_next!=NULL;firstContour=firstContour->h_next)
{
double contours_length=cvContourPerimeter(firstContour); //获取每个轮廓的长度信息
double contours_area=cvContourArea(firstContour); //获取每个轮廓的面积值
//cout<<contours_length<<endl;
if(contours_length>&&contours_length<&&contours_area>/*&&contours_length/contours_area<4*/) //根据长度面积信息挑选符合条件的序列重组
{
if(n_contours==)
{
temp=cvCloneSeq(firstContour); //直接等于会使原来的序列被破坏
contourlonger=temp;
}else{
temp->h_next=cvCloneSeq(firstContour);
temp=temp->h_next;
}
n_contours++;
} } if(contourlonger)
{
cvDrawContours(contours,contourlonger,cvScalarAll(),cvScalarAll(),);//第5个参数-1表示采用填充的方式
}
cvShowImage("Contours",contours); //获取边界框
memcpy(contours_rect->imageData,contours->imageData,fgedge->height*fgedge->width);
if(contourlonger!=NULL)
{
for(;contourlonger->h_next!=NULL;contourlonger=contourlonger->h_next)
{
//得到不一定平行于图片的最小面积矩形框
CvBox2D contours_box=cvMinAreaRect2(contourlonger);
CvPoint2D32f point4[];
cvBoxPoints(contours_box,point4); //得到contours_box四个角的坐标
CvPoint pt[];
for(int i=;i<;i++)
pt[i]=cvPoint((int)point4[i].x,point4[i].y);
CvPoint* ppt=pt;
int count=;
cvPolyLine(contours_rect,&ppt,&count,,,cvScalarAll(),);
//下面得到的是平行于图片的矩形框
//CvRect contours_boundary=cvBoundingRect(contourlonger); //这样得到的矩形坐标和长宽都是0 不知道为什么
//cvRectangle(contourlonger,cvPoint(contours_boundary.x,contours_boundary.y),cvPoint(contours_boundary.x+contours_boundary.width,contours_boundary.y+contours_boundary.height),cvScalarAll(255));
}
}
cvShowImage("Contours_boundary",contours_rect);
我已经通过其他方法提取了轮廓 用OPENCV的函数查找更完整的轮廓 并且根据轮廓的长度和面积信息将轮廓序列做一个选择性处理 最后画出外接矩形框。
在对轮廓做选择性处理的时候 发现虽然新建CvSeq* 赋值为了NULL 但实际上不是的 它本身有一个地址值 因此 不能通过(指针!=NULL )来初始化第一个序列 因此引入了n_contours。 CvCloneSeq函数也仅仅是复制当前的序列,它的前驱和后继是没有被复制过来的,需要每一次都使用复制函数。
first 3 5 2 9 1 7 8 2 设序列长度 //若只要大于5的
---》---》---》--》-》--》--》---》
temp:clone(5)-->clone(9)--->clone(7)-->clone(8)-->NULL
↑
contours :指向新建的头指针
【opencv】轮廓相关的更多相关文章
- 学习opencv跟轮廓相关的
查找轮廓 轮廓到底是什么?一个轮廓一般对应一系列的点,也就是图像中的一条曲线.表示的方法可能根据不同情况而有所不同.有多重方法可以表示曲线.在openCV中一般用序列来存储轮廓信息.序列中的每一个元素 ...
- OpenCV 轮廓基本特征
http://blog.csdn.net/tiemaxiaosu/article/details/51360499 OpenCV 轮廓基本特征 2016-05-10 10:26 556人阅读 评论( ...
- css中的大小、定位、轮廓相关属性
css中的大小.定位.轮廓相关属性 1.通过height.width属性控制组件大小 height:高度,可以设置任何有效的距离值: width:宽度,可以设置任何有效的属性值: max-height ...
- OpenCV轮廓vectorvector
OpenCV轮廓vectorvector,vector,vector,vector https://blog.csdn.net/Ahuuua/article/details/80593388 轮廓 ...
- opencv轮廓提取、轮廓识别相关要点
1.轮廓提取 src = cv2.imread("***.jpg", cv2.IMREAD_COLOR) gray = cv2.cvtColor(src ,cv2.COLOR_BG ...
- opencv轮廓外接矩形
1.寻找轮廓 api void cv::findContours( InputOutputArray image, OutputArrayOfArrays contours, OutputArray ...
- 【转载】openCV轮廓操作
声明:非原创,转载自互联网,有问题联系博主 1.轮廓的提取 从图片中将目标提取出来,常常用到的是提取目标的轮廓. OpenCV里提取目标轮廓的函数是findContours(), 它的输入图像是一幅二 ...
- opencv轮廓处理函数详细
ApproxChains 用多边形曲线逼近 Freeman 链 CvSeq* cvApproxChains( CvSeq* src_seq, CvMemStorage* storage, int me ...
- OpenCV 轮廓检测
使用OpenCV可以对图像的轮廓进行检测.这是之前用过的代码,挺简单的,回顾一下.主要要进行以下2步操作: 1.cvThreshold():对图像进行二值化处理 2.cvFindContours(): ...
随机推荐
- Windows Server 2008 R2 IIS7.5下PHP、MySQL快速环境配置【图】
众所周知,win平台的服务器版本默认是不能运行php的,需要对服务器进行环境配置. 而许多朋友纠结如何配置,在百度上搜索出的教程一大堆,基本步骤复杂,新手配置容易出错. 今天,邹颖峥教大家一种快速配置 ...
- OC第八节——目录操作和文件管理
1.需要理解的知识 通常程序在运行中或者程序结束之后,需要保存一些信息,而且需要持久化存储信息,比如登陆信息.视频播放记录.收藏记录等等,那么我们可以采用以下几种方式对数据进行持 ...
- 6.3.28微信需群主确认才可进群&发GIF动图功能内测开始了
昨天下午有网友收到微信6.3.28新版内测邀请,不过这个内部体验目前貌似只对安卓手机开放,苹果的IOS系统还不支持,会提示“你当前使用的是非安卓设备,不建议下载安卓体验包,但你仍可邀请朋友尝鲜”.最新 ...
- MongoDB的索引(三)
MongoDB的索引: 1. _id索引 该索引是大多数集合默认创建的索引,也就是说用户每插入一个数据,MongoDB会自动生成一条唯一的_id字段. 2. 单键索引 单键索引是最普通的索引,它不会自 ...
- word文档的生成、修改、渲染、打印,使用Aspose.Words
无需MS Word也可执行各种文档处理任务,包括文档的生成.修改.渲染.打印,文档格式转换和邮件合并等文档处理.
- NumPy的详细教程
原文 http://blog.csdn.net/lsjseu/article/details/20359201 主题 NumPy 先决条件 在阅读这个教程之前,你多少需要知道点python.如果你想 ...
- 剑指Offer 斐波那契数列
题目描述 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项. n<=39 思路: 不考虑递归 用递推的思路 AC代码: class Solution { public ...
- 有关lucene的问题
1.异常:Lock obtain timed out: NativeFSLock 原因:没有及时关闭indexWriter或者indexReader,lucene进行读写的时候会在文件夹里面创建loc ...
- Python学习笔记一
原来Python的文件配置好环境变量直接双击就可以运行,当然也可以控制台+编辑器 first try: import turtle window=turtle.Screen() babbage=tur ...
- wamp开机自启动
其实非常简单!打开服务管理,把以下两个服务,由手动(默认状态)改为自动即可: wampapache wampmysqld