opencv python 图像轮廓/检测轮廓/绘制轮廓的方法


Posted in Python onJuly 03, 2019

图像的轮廓检测,如计算多边形外界、形状毕竟、计算感兴趣区域等。

Contours : Getting Started

轮廓

简单地解释为连接所有连续点(沿着边界)的曲线,具有相同的颜色或强度.
轮廓是形状分析和物体检测和识别的有用工具

NOTE

  • 为获得更好的准确性,请使用二值图,在找到轮廓之前,应用阈值法或canny边缘检测
  • 从OpenCV 3.2开始,findContours()不再修改源图像,而是将修改后的图像作为三个返回参数中的第一个返回
  • 在OpenCV中,查找轮廓是从黑色背景中查找白色对象

findContours(image, mode, method[, contours[, hierarchy[, offset]]])

  • image:原图像
  • mode:轮廓检索模式
  • method:轮廓近似方法

输出为: 修改后的图像,轮廓,层次结构

轮廓是所有轮廓的列表.每个单独的轮廓是对象边界点的坐标.

轮廓检索模式 含义
cv2.RETR_EXTERNAL 只检测外轮廓
cv2.RETR_LIST 提取所有轮廓并将其放入列表,不建立等级关系
cv2.RETR_CCOMP 建立两个等级的轮廓,上面的一层为外边界,里面的一层为内孔的边界信息。如果内孔内还有一个连通物体,这个物体的边界也在顶层
cv2.RETR_TREE 建立一个等级树结构的轮廓

轮廓逼近方法 含义
cv2.CHAIN_APPROX_NONE 存储所有的轮廓点,相邻的两个点的像素位置差不超过1,即max(abs(x1-x2),abs(y2-y1))==1
cv2.CHAIN_APPROX_SIMPLE 压缩水平方向,垂直方向,对角线方向的元素,只保留该方向的终点坐标,例如一个矩形轮廓只需4个点来保存轮廓信息
cv2.CHAIN_APPROX_TC89_L1 或 cv2.CHAIN_APPROX_TC89_KCOS 应用Teh-Chin链近似算法

代码:

import cv2
import numpy as np

img = cv2.imread('img.jpg')
imgray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
ret, thresh = cv2.threshold(imgray, 127, 255, 0)
im2, contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)

绘制轮廓

cv2.drawContours(image, contours, contourIdx, color[, thickness[, lineType[, hierarchy[, maxLevel[, offset]]]]])

  • image:原图像
  • contours:作为Python列表传递的轮廓
  • contourIdx:轮廓索引(在绘制单个轮廓时很有用。绘制所有轮廓,传递-1)

要绘制图像中的所有轮廓:
cv.drawContours(img,contours,-1,(0,255,0),3)

要绘制单个轮廓,比如第4个轮廓:
cv.drawContours(img,contours,3,(0,255,0),3)

但大多数情况下,绘制第4个轮廓,以下方法将非常有用:
cnt = contours[4]
cv.drawContours(img,[cnt],0,(0,255,0),3)

代码:

import cv2
import numpy as np

img = cv2.imread('img7.png')
imgray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
ret, thresh = cv2.threshold(imgray, 127, 255, 0)
im2, contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)
cnt = contours[0]
cv2.drawContours(img,[cnt],0,(0,255,0),3)

cv2.imshow('src',img)

cv2.waitKey()

opencv python 图像轮廓/检测轮廓/绘制轮廓的方法

opencv python 图像轮廓/检测轮廓/绘制轮廓的方法

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
python数据结构之二叉树的建立实例
Apr 29 Python
Python基于递归算法实现的汉诺塔与Fibonacci数列示例
Apr 18 Python
Python 内置函数进制转换的用法(十进制转二进制、八进制、十六进制)
Apr 30 Python
在python中利用最小二乘拟合二次抛物线函数的方法
Dec 29 Python
基于django channel实现websocket的聊天室的方法示例
Apr 11 Python
python3 小数位的四舍五入(用两种方法解决round 遇5不进)
Apr 11 Python
解决pycharm 工具栏Tool中找不到Run manager.py Task的问题
Jul 01 Python
Python3简单爬虫抓取网页图片代码实例
Aug 26 Python
matplotlib.pyplot.matshow 矩阵可视化实例
Jun 16 Python
python字典通过值反查键的实现(简洁写法)
Sep 30 Python
Python爬取酷狗MP3音频的步骤
Feb 26 Python
python 下载文件的几种方式分享
Apr 07 Python
在cmd中查看python的安装路径方法
Jul 03 #Python
python动态进度条的实现代码
Jul 03 #Python
OpenCV 轮廓检测的实现方法
Jul 03 #Python
python实现文本进度条 程序进度条 加载进度条 单行刷新功能
Jul 03 #Python
Python Pandas数据结构简单介绍
Jul 03 #Python
如何通过雪花算法用Python实现一个简单的发号器
Jul 03 #Python
Python实现个人微信号自动监控告警的示例
Jul 03 #Python
You might like
Discuz!5的PHP代码高亮显示插件(黑暗中的舞者更新)
2007/01/29 PHP
PHP学习之字符串比较和查找
2011/04/17 PHP
7个超级实用的PHP代码片段
2011/07/11 PHP
PHP持久连接mysql_pconnect()函数使用介绍
2012/02/05 PHP
php笔记之:php数组相关函数的使用
2013/04/26 PHP
PHP冒泡算法详解(递归实现)
2014/11/10 PHP
php中mail函数发送邮件失败的解决方法
2014/12/24 PHP
PHP strip_tags保留多个HTML标签的方法
2016/05/22 PHP
laravel 使用事件系统统计浏览量的实现
2019/10/16 PHP
javascript获取隐藏dom的宽高 具体实现
2013/07/14 Javascript
jQuery插件expander实现图片翻转特效
2015/05/21 Javascript
Javascript实现的Map集合工具类完整实例
2015/07/31 Javascript
Jquery实现仿京东商城省市联动菜单
2015/11/19 Javascript
js定时器实例分享
2016/12/20 Javascript
JS简单获取当前日期时间的方法(如:2017-03-29 11:41:10 星期四)
2017/03/29 Javascript
ES7中利用Await减少回调嵌套的方法详解
2017/11/01 Javascript
解决vue+element 键盘回车事件导致页面刷新的问题
2018/08/25 Javascript
Vue通过ref父子组件拿值方法
2018/09/12 Javascript
js console.log打印对象时属性缺失的解决方法
2019/05/23 Javascript
vue.config.js常用配置详解
2019/11/14 Javascript
javascript数组元素删除方法delete和splice解析
2019/12/09 Javascript
js实现双色球效果
2020/08/02 Javascript
JS实现页面鼠标点击出现图片特效
2020/08/19 Javascript
在antd Form表单中select设置初始值操作
2020/11/02 Javascript
python中利用Future对象异步返回结果示例代码
2017/09/07 Python
win7+Python3.5下scrapy的安装方法
2018/07/31 Python
windows下python虚拟环境virtualenv安装和使用详解
2019/07/16 Python
开启Django博客的RSS功能的实现方法
2020/02/17 Python
如何导出python安装的所有模块名称和版本号到文件中
2020/06/05 Python
基于keras中的回调函数用法说明
2020/06/17 Python
Html5踩坑记之mandMobile使用小记
2020/04/02 HTML / CSS
节能环保标语
2014/06/12 职场文书
公司副总经理岗位职责
2015/04/08 职场文书
三八节祝酒词
2015/08/11 职场文书
学法用法心得体会(2016推荐篇)
2016/01/21 职场文书
springboot中一些比较常用的注解总结
2021/06/11 Java/Android