查找轮廓总结
来源:互联网 发布:手机数字键盘钢琴软件 编辑:程序博客网 时间:2024/06/07 16:10
轮廓到底是什么东西?一个轮廓一般对应一系列的点,也就是图像中的一条曲线,以序列的形式存储,序列的每一个元素是曲线中一个点的位置。
findContours()从二值图像中查找轮廓,图像可以是从canny()函数得到,或者是threshold函数得到。
首先有轮廓树的概念,c代表的是轮廓,h代表的是孔,opencv的findcontours(),可以区分内部和外部边界。
包含的概念在很多应用中都非常重要。(这个以后估计会有所体会的!)
opencv允许得到的轮廓被聚合成一个轮廓树,从而把包含关系编码到树结构中。例如轮廓数的根节点的轮廓叫c0,孔h00和h01是它的子节点。这些轮廓中直接包含的轮廓成为他们的子节点,依次类推。
hierarchy[idx][0]是轮廓树遍历的方式,每个contours[i]中对应了4个hierarchy元素,hierarchy[i][0]~hierarchy[i][3],分别代表后一个轮廓,前一个轮廓,父轮廓,内嵌轮廓。
这个是推酷上看到的一种轮廓遍历的例子,挺能表达轮廓遍历的意思的,还得多用才能熟练掌握轮廓的遍历。
//---------------------------------------------------------------------------------------------------------------------------------------------
//轮廓模式为CV_RETR_CCOMP,第一层为连通域的外围边界,因为我们前景颜色值为255,背景为0
//所以得到的轮廓为外围边界,所以我们只需要第一层,hierarchy[idx][0]表示为下一个轮廓的索引
//如果到达最后一个轮廓,则hierarchy[idx][0]=-1;
for (; idx >= 0; idx = hierarchy[idx][0])
{
const vector<Point>& c = contours[idx];
double area = fabs(contourArea(Mat(c)));
if (area > maxArea)
{
maxArea = area;
largestComp = idx;//找出包含面积最大的轮廓
}
}
- 查找轮廓总结
- 轮廓 - 查找轮廓、表示轮廓、绘制轮廓
- 轮廓 - 查找轮廓、表示轮廓、绘制轮廓
- 轮廓 - 查找轮廓、表示轮廓、绘制轮廓
- 轮廓查找
- opencv 查找轮廓 绘制轮廓
- 第八章 - 轮廓 - 查找轮廓、表示轮廓、绘制轮廓
- OpenCV查找轮廓
- OpenCV笔记: 查找轮廓
- opencv查找轮廓
- opencv 轮廓查找 findContours
- 轮廓查找问题小记
- OpenCV 查找图像轮廓
- Opencv轮廓查找检测
- findContours 轮廓查找
- Atitit 查找轮廓 findContours
- opencv--查找图像轮廓
- findcontours查找轮廓函数
- php如何处理这样的数据?
- iOS 第三方支付 支付宝支付
- leetcode笔记:Number of 1 Bits
- JS私有变量和静态私有变量
- leetcode——219—— Contains Duplicate II
- 查找轮廓总结
- ofstream和ifstream详细用法
- JAVA struts2框架下zip打包文件下载
- 【Android Framework】 Android Binder 机制解析
- Ubuntu使用caore dump定位程序错误
- Java maven 环境下使用proguard-maven-plugin 插件混淆代码
- 【JQuery】:visible过滤选择器
- JPA
- iOS 上架app的过程当中出现the Info.plist is missing or could not be parsed.经历