opencv 图像轮廓
图片解析:
原图:
code:
#include <opencv\cv.h>
#include <opencv\highgui.h>
#include <opencv\cxcore.h>
#include <stdlib.h>
#include <stdio.h> int main(int argc, char* argv[]){ #if 1 int i, j; CvMemStorage* storage = cvCreateMemStorage(0);
//以单通道方式加载图像
IplImage* img = cvLoadImage("C:\\Users\\zxl\\Desktop\\0.png",CV_LOAD_IMAGE_GRAYSCALE);
//常见一个等大小的3通道图像 (作为备份)
IplImage* imgColor = cvCreateImage(cvGetSize(img),8,3);
//用来显示轮廓的
IplImage* contoursImage = cvCreateImage(cvSize(img->width,img->height),8,1); CvSeq* contours = 0 , *contoursTemp=0;
cvZero(contoursImage); //对图像进行二值化
cvThreshold(img,img,100,255,CV_THRESH_BINARY); //img的备份
cvCvtColor(img,imgColor,CV_GRAY2BGR); // 提取图像img的轮廓信息函数 contours指向第一个轮廓 将轮廓存放在CvMemStorage类型的变量storage里面
//&contours =>表示指针 指向能够提取的第一个轮廓
//CV_RETR_CCOMP =>表示轮廓的排列方式 有4种
//-------------------------------------
//CV_RETR_EXTERNAL 只返回最外面的轮廓
//first=c0
//CV_RETR_CCOMP 把外轮廓用双向链表的方式存放,有顺序 <从里到外><从右到左>
//frist=c01001 <-> c01000 <-> c010 <-> c000 <-> c0
// | | |
// h0100 h0000 h01 <-> h00
//CV_RETR_LIST 所有的轮廓(无分内外轮廓)通过1个链表的方式存储,<从里到外><从右到左>
//first=c01001 <-> c01000 <-> h0100 <-> h0000 <-> c010 <-> c000 <-> h01 <-> h00 <-> c0
//
//
//CV_RETR_TREE 按照树形结构存储,
//first = c0
// |
// h00 <-> h01
// | |
// c000 c010
// | |
// h0000 c01000 <-> c01001
//-------------------------------------
//CV_CHAIN_APPROX_NONE=> 轮廓显示是坐标的形式还是点的形式
//提取轮廓后源图像会发生变化 所以需要用到开始生命的备份机制 /*
//备份机制检查原图
cvNamedWindow( "1");
cvShowImage( "1", img );
*/ int total = cvFindContours( img, storage, &contours, sizeof(CvContour),
CV_RETR_CCOMP, CV_CHAIN_APPROX_NONE, cvPoint(0,0) ); /*
//备份机制检查提取后
cvNamedWindow( "2");
cvShowImage( "2", img );
cvWaitKey(0);
*/ //提取指针所指的地方
contoursTemp = contours ; int count=0; //对轮廓进行循环
//h_next 表示水平的方向上轮廓链接
//v_next 表示垂直方向上的轮廓链接
for(;contoursTemp!=0 ; contoursTemp=contoursTemp->h_next){ //通过这个循环访问每一个轮廓
//提取外轮廓 上的所以坐标点
for( i=0; i<contoursTemp->total; i++) { //通过这个循环 得到坐标
CvPoint * pt = (CvPoint*)cvGetSeqElem(contoursTemp, i); // 读出第i个点。
//轮廓窗口让其显示为白色
cvSetReal2D(contoursImage , pt->y , pt->x , 255.0);
//在原窗口让其显示为红色
cvSet2D(imgColor,pt->y,pt->x,cvScalar(0,0,255,0));
}
count++; //提取内轮廓上的所以坐标点
CvSeq* InterCon = contoursTemp->v_next; for(;InterCon!=0;InterCon=InterCon->h_next){
for(i=0;i<InterCon->total;i++) {
CvPoint * pt = (CvPoint*)cvGetSeqElem(InterCon, i); // 读出第i个点。 cvSetReal2D(contoursImage , pt->y , pt->x , 255.0);
cvSet2D(imgColor,pt->y,pt->x,cvScalar(0,255,0,0));
}
}
} cvNamedWindow( "image", 1 );
cvShowImage( "image", imgColor ); cvNamedWindow( "contours");
cvShowImage("contours",contoursImage); cvWaitKey(0); cvReleaseMemStorage( &storage );
cvReleaseImage( &img );
cvReleaseImage(&contoursImage);
cvReleaseImage(&imgColor); #endif return 0;
}
效果:
opencv 图像轮廓的更多相关文章
- OpenCV图像轮廓检测
轮廓检测: 轮廓检测的原理通俗的说就是掏空内部点,比如原图中有3*3的矩形点.那么就可以将中间的那一点去掉. 一.关键函数1.1 cvFindContours函数功能:对图像进行轮廓检测,这个函数将 ...
- opencv 6 图像轮廓与图像分割修复 3 图像的矩,分水岭,图像修补
图像的矩 矩的计算:moments()函数 计算轮廓面积:contourArea()函数 #include "opencv2/highgui/highgui.hpp" #inclu ...
- OpenCV计算机视觉学习(8)——图像轮廓处理(轮廓绘制,轮廓检索,轮廓填充,轮廓近似)
如果需要处理的原图及代码,请移步小编的GitHub地址 传送门:请点击我 如果点击有误:https://github.com/LeBron-Jian/ComputerVisionPractice 1, ...
- OpenCV笔记(3)(Canny边缘检测、高斯金字塔、拉普拉斯金字塔、图像轮廓、模板匹配)
一.Canny边缘检测 Canny边缘检测是一系列方法综合的结果.其中主要包含以下步骤: 1.使用高斯滤波器,平滑图像,滤除噪声. 2.计算图像中每个像素点的梯度强度和方向. 3.应用非极大值抑制(N ...
- 【python+opencv】轮廓发现
python+opencv---轮廓发现 轮廓发现---是基于图像边缘提取的基础寻找对象轮廓的方法, 所有边缘提取的阈值选定会影响最终轮廓发现的结果. 介绍两种API使用: -cv.findConto ...
- OpenCV—Python 轮廓检测 绘出矩形框(findContours\ boundingRect\rectangle
千万注意opencv的轮廓检测和边缘检测是两码事 本文链接:https://blog.csdn.net/wsp_1138886114/article/details/82945328 1 获取轮廓 O ...
- OpenCV3入门(十)图像轮廓
1.图像轮廓 1.1图像轮廓与API函数 轮廓是一系列相连的点组成的曲线,代表了物体的基本外形,相对于边缘,轮廓是连续的,边缘并不全部连续.一般地,获取图像轮廓要经过下面几个步骤: 1) 读取 ...
- OpenCV图像处理中“投影技术”的使用
本文区分"问题引出"."概念抽象"."算法实现"三个部分由表及里具体讲解OpenCV图像处理中"投影技术" ...
- opencv——图像直方图与反向投影
引言 在图像处理中,对于直方图这个概念,肯定不会陌生.但是其原理真的可以信手拈来吗? 本文篇幅有点长,在此列个目录,大家可以跳着看: 分析图像直方图的概念,以及opencv函数calcHist()对于 ...
随机推荐
- [itint5]棋盘漫步
要注意dp[0][0]要初始化为1. int totalPath(vector<vector<bool> > &blocked) { int m = blocked.s ...
- spring aop环绕通知
[Spring实战]—— 9 AOP环绕通知 假如有这么一个场景,需要统计某个方法执行的时间,如何做呢? 典型的会想到在方法执行前记录时间,方法执行后再次记录,得出运行的时间. 如果采用Sprin ...
- 使用程序获取整型数据和浮点型数据在内存中的表示---gyy整理
使用程序获取整型数据和浮点型数据在内存中的表示. C++中整型(int).短整型(short int).单精度浮点数(float).双精度浮点数(double)在内存中所占字节数不同,因此取值范围也不 ...
- C#基础精华02(静态类,值类型,引用类型,枚举,结构,ref与out)
静态类 静态类不能被其他类继承,静态成员亦不能被继承(访问的是同一个),备注1. 静态类只能继承自Object类.(静态类不能继承自其它类.) 继承(多态).静态本身就是相反的. 静态类不能实现任何接 ...
- 最受欢迎的5个Android ORM框架
在开发Android应用时,保存数据有这么几个方式, 一个是本地保存,一个是放在后台(提供API接口),还有一个是放在开放云服务上(如 SyncAdapter 会是一个不错的选择). 对于第一种方式, ...
- margin,border,padding简介
站在图中心 Content 的角度理解: margin为外边框,border为边框,padding为内边框. 在xml中设置: 如果上下左右的距离都是相同可以通过 android:layout_mar ...
- WINCE6.0+IMX515通过cfimager.exe烧录镜像文件
WINCE6.0+IMX515通过cfimager.exe烧录镜像文件 freescale提供了cfimager.exe工具,可在SD/MMC卡中烧录系统镜像文件和创建FAT文件,这样,我们可以不需要 ...
- Python各种模块下载及安装配置
方式1 在Python官网https://www.python.org/或者是github搜索进行下载 ,解压缩之后通过命令提示符进入已经解压缩文件夹根目录,输入下面的命令: python setup ...
- Hive 接口介绍(Web UI/JDBC)
Hive 接口介绍(Web UI/JDBC) 实验简介 本次实验学习 Hive 的两种接口:Web UI 以及 JDBC. 一.实验环境说明 1. 环境登录 无需密码自动登录,系统用户名shiyanl ...
- 三个入侵的必备小工具-lcx.exe、nc.exe、sc.exe
lcx.exe的使用方法 以前抓肉鸡都是通过1433弱口令,然后.. 但是发现很多服务器开了1433,3389,但是终端是连不上的,因为服务器本身是在内网,只对外开放了1433端口,幸好有lcx. ...