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中使用md5sum检查目录中相同文件代码分享
Feb 02 Python
Python实现发送QQ邮件的封装
Jul 14 Python
Python使用requests及BeautifulSoup构建爬虫实例代码
Jan 24 Python
Python 访问限制 private public的详细介绍
Oct 16 Python
python设定并获取socket超时时间的方法
Jan 12 Python
Python提取支付宝和微信支付二维码的示例代码
Feb 15 Python
python库matplotlib绘制坐标图
Oct 18 Python
在jupyter notebook中调用.ipynb文件方式
Apr 14 Python
Python csv文件记录流程代码解析
Jul 16 Python
Java爬虫技术框架之Heritrix框架详解
Jul 22 Python
详解Pycharm与anaconda安装配置指南
Aug 25 Python
django中websocket的具体使用
Jan 22 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
PHP生成便于打印的网页
2006/10/09 PHP
php gzip压缩输出的实现方法
2013/04/27 PHP
PHP提示Warning:phpinfo() has been disabled函数禁用的解决方法
2014/12/17 PHP
php使用MySQL保存session会话的方法
2015/06/18 PHP
详解PHP中的序列化、反序列化操作
2017/03/21 PHP
javascript 获取表单file全路径
2009/12/31 Javascript
Jquery 实现Tab效果 思路是js思路
2010/03/02 Javascript
DIY jquery plugin - tabs标签切换实现代码
2010/12/11 Javascript
js 通过cookie实现刷新不变化树形菜单
2014/10/30 Javascript
JavaScript中的splice方法用法详解
2016/07/20 Javascript
jquery实现网页定位导航
2016/08/23 Javascript
js判断出两个字符串最大子串的函数实现方法
2016/11/01 Javascript
js中创建对象的几种方式
2017/02/05 Javascript
selenium 与 chrome 进行qq登录并发邮件操作实例详解
2017/04/06 Javascript
基于JavaScript实现评论框展开和隐藏功能
2017/08/25 Javascript
react-router4 配合webpack require.ensure 实现异步加载的示例
2018/01/18 Javascript
浅析微信小程序modal弹窗关闭默认会执行cancel问题
2019/10/14 Javascript
微信小程序实现点击按钮后修改颜色
2019/12/05 Javascript
[04:09]2018年度DOTA2社区贡献奖-完美盛典
2018/12/16 DOTA
Python中内建函数的简单用法说明
2016/05/05 Python
Python中的数学运算操作符使用进阶
2016/06/20 Python
Python 实现选择排序的算法步骤
2018/04/22 Python
Python实现查询某个目录下修改时间最新的文件示例
2018/08/29 Python
python数据批量写入ScrolledText的优化方法
2018/10/11 Python
python之拟合的实现
2019/07/19 Python
应用OpenCV和Python进行SIFT算法的实现详解
2019/08/21 Python
基于SpringBoot构造器注入循环依赖及解决方式
2020/04/26 Python
Ubuntu20下的Django安装的方法步骤
2021/01/24 Python
科沃斯机器人官网商城:Ecovacs
2016/08/29 全球购物
KIKO MILANO荷兰网上商店:意大利专业化妆品品牌
2017/05/12 全球购物
西班牙国家航空官方网站:Iberia
2017/11/16 全球购物
Android面试宝典
2013/08/06 面试题
2016年春季运动会广播稿
2015/08/19 职场文书
七年级思品教学反思
2016/02/20 职场文书
深度学习tensorflow基础mnist
2021/04/14 Python
浅析Python实现DFA算法
2021/06/26 Python