【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(): ...
随机推荐
- Request 传值 遇到的中文乱码问题
<%@ Page Language="C#" AutoEventWireup="true" CodeFile="xxxx.aspx.cs&quo ...
- ProgressBar样式(转)
普通圆形ProgressBar 该类型进度条也就是一个表示运转的过程,例如发送短信,连接网络等等,表示一个过程正在执行中. 一般只要在XML布局中定义就可以了. <progressBar and ...
- Swift3.0P1 语法指南——基本操作符
原档:https://developer.apple.com/library/prerelease/ios/documentation/Swift/Conceptual/Swift_Programmi ...
- appid 评价
//apple api #define kAppAppleId @"980883989" #define kAppRateUrl @"it ...
- MS Project 使用之创建项目信息
1. 我们打开MS Project 2013,创建一个空白文档. 2. 切换“项目”选项卡,点击“项目信息”,设置项目开始时间等信息,项目一般是需要设置开始时间和使用日历的,下面我们分别进行设置 如, ...
- OpenCV加载图像并显示
从文件中读取一直一张图片,并加载出来 代码: #include "stdafx.h" #include "iostream" using namespace s ...
- Delphi实现窗体内嵌其他应用程序窗体
实现原理是启动一个应用程序,通过ProcessID得到窗体句柄,然后对其设定父窗体句柄为本程序某控件句柄(本例是窗体内一个Panel的句柄),这样就达成了内嵌的效果. 本文实现的是内嵌一个记事本程序, ...
- Webclent基本操作
/** * @Title: webclientTest.java * @Package webclient * @Description: TODO(用一句话描述该文件做什么) * @author A ...
- extjs动态改变样式
{ width:438, height:440, name:'loginDiv', ui:'123', x: '50%' , y: 200, border:true, bodyStyle:{ 'bor ...
- 基于HTK语音工具包进行孤立词识别的使用教程
选自:http://my.oschina.net/jamesju/blog/116151 1前言 最近一直在研究HTK语音识别工具包,前几天完成了工具包的安装编译和测试,这几天又按耐不住好奇,决定自己 ...