OpenCV图像轮廓检测
轮廓检测:
轮廓检测的原理通俗的说就是掏空内部点,比如原图中有3*3的矩形点。那么就可以将中间的那一点去掉。
一.关键函数
1.1 cvFindContours
函数功能:对图像进行轮廓检测,这个函数将生成一条链表以保存检测出的各个轮廓信息,并传出指向这条链表表头的指针。
函数原型:
int cvFindContours(
CvArr* image, 第一个参数表示输入图像,必须为一个8位的二值图像
CvMemStorage* storage, 第二参数表示存储轮廓的容器。为CvMemStorage类型,定义在OpenCV的\core\types_c.h中
CvSeq** first_contour, 第三个参数为输出参数,这个参数将指向用来存储轮廓信息的链表表头
int header_size=sizeof(CvContour), 第四个参数表示存储轮廓链表的表头大小,当第六个参数传入CV_CHAIN_CODE时,
要设置成sizeof(CvChain),其它情况统一设置成sizeof(CvContour)。
int mode= CV_RETR_LIST, 第五个参数为轮廓检测的模式,有如下取值:
CV_RETR_EXTERNAL : 只检索最外面的轮廓;
CV_RETR_LIST: 检索所有的轮廓,并将其保存到一条链表当中;
CV_RETR_CCOMP: 检索所有的轮廓,并将他们组织为两层:顶层是各部分的外部边界,第二层是空洞的边界;
CV_RETR_TREE: 检索所有的轮廓,并重构嵌套轮廓的整个层次;
int method= CV_CHAIN_APPROX_SIMPLE, 第六个参数用来表示轮廓边缘的近似方法的,常用值如下所示:
CV_CHAIN_CODE: 以Freeman链码的方式输出轮廓,所有其他方法输出多边形(顶点的序列)。
CV_CHAIN_APPROX_SIMPLE: 压缩水平的、垂直的和斜的部分,也就是,函数只保留他们的终点部分。
CvPoint offset=cvPoint(0,0) 第七个参数表示偏移量,比如你要从图像的(100, 0)开始进行轮廓检测,那么就传入(100, 0)。
);
--->使用cvFindContours函数能检测出图像的轮廓,将轮廓绘制出来则需要另一函数——cvDrawContours来配合了。下面介绍cvDrawContours函数。
1.2 cvDrawContours
函数功能:在图像上绘制外部和内部轮廓
函数原型:
void cvDrawContours(
CvArr *img, 第一个参数表示输入图像,函数将在这张图像上绘制轮廓。
CvSeq* contour, 第二个参数表示指向轮廓链表的指针
CvScalar external_color,
CvScalar hole_color, 第三个参数和第四个参数表示颜色,绘制时会根据轮廓的层次来交替使用这二种颜色
int max_level, 第五个参数表示绘制轮廓的最大层数,如果是0,只绘制contour;如果是1,追加绘制和
contour同层的所有轮廓;如果是2,追加绘制比contour低一层的轮廓,以此类推;如果
值是负值,则函数并不绘制contour后的轮廓,但是将画出其子轮廓,一直到abs(max_level) - 1层。
int thickness=1, 第六个参数表示轮廓线的宽度,如果为CV_FILLED则会填充轮廓内部
int line_type=8, 第七个参数表示轮廓线的类型。
CvPoint offset=cvPoint(0,0) 第八个参数表示偏移量,如果传入(10,20),那绘制将从图像的(10,20)处开始
);
// ConsoleApplication1.cpp : 定义控制台应用程序的入口点。
// #include "stdafx.h"
#include "iostream"
using namespace std;
#include "opencv2/opencv.hpp" const char *pImagePath = "E:/C_VC_code/Text_Photo/girl005.jpg";
const char *pWindowsTitle = "原图";
const char *pWindowsGrayTitle = "灰度图";
const char *pWindowsBinaryTitle = "二值图";
const char *pWindowsOutLineTitle = "轮廓图";
const char *pWindowsToolBar = "阀值";
IplImage *pImage=NULL,*pGrayImage, *pBinaryImage, *pOutLineImage;
CvMemStorage *pMemStorage;
CvSeq *pSeq;
int nLevels = ;
void functionCallback(int pos)
{
cvThreshold(pGrayImage, pBinaryImage, pos, , CV_THRESH_BINARY);
cvFindContours(pBinaryImage, pMemStorage, &pSeq ,sizeof(CvContour), CV_RETR_TREE,CV_CHAIN_APPROX_SIMPLE,cvPoint(,));
cvDrawContours(pOutLineImage, pSeq, CV_RGB(,,), CV_RGB(,,), nLevels, , );
cvShowImage(pWindowsBinaryTitle, pBinaryImage);
cvShowImage(pWindowsOutLineTitle, pOutLineImage);
}
void main()
{ //SourceImage turn to GrayImage pImage = cvLoadImage(pImagePath, CV_LOAD_IMAGE_UNCHANGED); pGrayImage = cvCreateImage(cvGetSize(pImage), IPL_DEPTH_8U, );
cvCvtColor(pImage, pGrayImage, CV_BGR2GRAY); //create window
cvNamedWindow(pWindowsTitle, CV_WINDOW_AUTOSIZE);
cvNamedWindow(pWindowsGrayTitle, CV_WINDOW_AUTOSIZE);
cvNamedWindow(pWindowsBinaryTitle, CV_WINDOW_AUTOSIZE);
cvNamedWindow(pWindowsOutLineTitle, CV_WINDOW_AUTOSIZE); //为二值图创建滑动条
int nPos = ;
cvCreateTrackbar(pWindowsToolBar,pWindowsBinaryTitle,&nPos,,functionCallback); //GrayImage turn into BinaryImage
pBinaryImage = cvCreateImage(cvGetSize(pGrayImage), IPL_DEPTH_8U, ); //检索轮廓并返回检测到的轮廓的个数
pMemStorage = cvCreateMemStorage();
pSeq = NULL; //Create and show OutLineImage
pOutLineImage = cvCreateImage(cvGetSize(pBinaryImage), IPL_DEPTH_8U, ); //填充成白色
cvRectangle(pOutLineImage, cvPoint(,),cvPoint(pImage->width,pImage->height), CV_RGB(,,), CV_FILLED);
cvDrawContours(pOutLineImage, pSeq, CV_RGB(,,), CV_RGB(,,), nLevels, ); cvShowImage(pWindowsTitle, pImage);
cvShowImage(pWindowsGrayTitle, pGrayImage);
cvShowImage(pWindowsBinaryTitle, pBinaryImage);
cvShowImage(pWindowsOutLineTitle, pOutLineImage); functionCallback(); //destroy object and release space
cvWaitKey();
cvDestroyWindow(pWindowsTitle);
cvDestroyWindow(pWindowsGrayTitle);
cvDestroyWindow(pWindowsBinaryTitle);
cvDestroyWindow(pWindowsOutLineTitle);
cvReleaseImage(&pImage);
cvReleaseImage(&pGrayImage);
cvReleaseImage(&pBinaryImage);
cvReleaseImage(&pOutLineImage); }
OpenCV图像轮廓检测的更多相关文章
- OpenCV—Python 轮廓检测 绘出矩形框(findContours\ boundingRect\rectangle
千万注意opencv的轮廓检测和边缘检测是两码事 本文链接:https://blog.csdn.net/wsp_1138886114/article/details/82945328 1 获取轮廓 O ...
- 第十七节,OpenCV(学习六)图像轮廓检测
1.检测轮廓 轮廓检测是图像处理中经常用到的,OpenCV-Python接口中使用cv2.findContours()函数查找检测物体的轮廓. cv2.findContours(image, mode ...
- OpenCV 矩形轮廓检测
转载请注明出处:http://blog.csdn.net/wangyaninglm/article/details/44151213, 来自:shiter编写程序的艺术 基础介绍 OpenCV里提取目 ...
- opencv 图像轮廓
图片解析: 原图: code: #include <opencv\cv.h> #include <opencv\highgui.h> #include <opencv\c ...
- OpenCV 闭合轮廓检测
这个好像是骨头什么的,但是要求轮廓闭合,于是对图片进行一下膨胀操作,再次检测轮廓就好了. // A closed contour.cpp : 定义控制台应用程序的入口点. // #include &q ...
- Python-OpenCV中的图像轮廓检测
目录 cv2.findContours() 主要记录Python-OpenCV中的cv2.findContours()方法:官方文档: cv2.findContours() 在二值图像中寻找图 ...
- opencv 图像阴影检测
参数说明: IplImage *workImg-当前全局变量,表示正在显示的图片. downleft, upright- 检测出的阴影部分矩形框的两个对角顶点. /****************** ...
- OpenCV: 图像连通域检测的递归算法
序言:清除链接边缘,可以使用数组进行递归运算; 连通域检测的递归算法是定义级别的检测算法,且是无优化和无语义失误的. 同样可用于寻找连通域 void ClearEdge(CvMat* MM,CvPoi ...
- OpenCV 轮廓检测
使用OpenCV可以对图像的轮廓进行检测.这是之前用过的代码,挺简单的,回顾一下.主要要进行以下2步操作: 1.cvThreshold():对图像进行二值化处理 2.cvFindContours(): ...
随机推荐
- cmd chcp命令切换字符格式UTF8
cmd chcp命令切换字符格式 命令介绍: chcp 65001 #换成utf-8代码页 chcp 936 #换成默认的gbk chcp 437 #美国英 ...
- UIView UIwindow
UI:用户界面,用户能看到的各种各样的页面元素 UIview :代表屏幕上的一个矩形区域,管理界面上的内容 创建UIview 1.开辟空间并初始化视图(初始化时,给出视图位置和大小 2.对 ...
- CodeForces 710CMagic Odd Square(经典-奇数个奇数&偶数个偶数)
题目链接:http://codeforces.com/problemset/problem/710/C 题目大意:输入一个奇数n,则生成n*n矩阵,要求矩阵的行.列还有斜着,所有元素之和为奇数. 解题 ...
- JS实现的一个query字符串转Json格式数据的方法
输入字符串的格式是 a=1&b=2&c=3 $.par2Json = function (string, overwrite) { var obj = {}, pairs = stri ...
- jquery实现图片预加载
使用jquery实现图片预加载提高页面加载速度和用户体,本就为大家详细分析jquery图片预加载的实现原理. 什么时候使用图片预加载? 如果页面使用了很多不是最初加载便可见的图片,有必要进行预加载: ...
- System.BadImageFormatException : 未能加载文件或程序集“Medici.PaymentRecover, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null”或它的某一个依赖项。试图加载格式不正确的程序。
System.BadImageFormatException : 未能加载文件或程序集“xxxxx.xxxxx, Version=1.0.0.0, Culture=neutral, PublicKey ...
- tmux常用命令
tmux命令可以启动一个tmux服务,tmux服务包含多个session,session包含多个window,window包含多个pane. 常用命令tmux ls #显示已有tmux列表(C-b s ...
- android-获取当前屏幕尺寸信息
方法有两种一: DisplayMetrics metrics = new DisplayMetrics(); getWindowManager().getDefaultDisplay().getMet ...
- 【转】【整理】将Linux脚本中的正常输出,警告,错误等信息输出到文件中
本文来自:http://blog.csdn.net/woshinia/article/details/18040063 很早以前 编译的时候 就在用 2>&1,但是一直没有生成一 ...
- winxp可以禁用的服务
要注意的是: 虽然某个服务你设置成了手动, 而且在services.msc中好像也没有启动, 但是并不表示这个服务不可以被启动 因为某些软件, 可能在程序内部进行了编程的设置, 它可以在内部去启动 服 ...