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函数返回多个值的示例方法
Dec 04 Python
python使用rabbitmq实现网络爬虫示例
Feb 20 Python
Python中将字典转换为列表的方法
Sep 21 Python
python使用邻接矩阵构造图代码示例
Nov 10 Python
Python实现的网页截图功能【PyQt4与selenium组件】
Jul 12 Python
tensorflow学习教程之文本分类详析
Aug 07 Python
使用pip发布Python程序的方法步骤
Oct 11 Python
Django之使用内置函数和celery发邮件的方法示例
Sep 16 Python
树莓派4B+opencv4+python 打开摄像头的实现方法
Oct 18 Python
Python selenium如何打包静态网页并下载
Aug 12 Python
Django如何使用asyncio协程和ThreadPoolExecutor多线程
Oct 12 Python
selenium携带cookies模拟登陆CSDN的实现
Jan 19 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读取msn上的用户信息类
2008/12/05 PHP
PHP中的traits实现代码复用使用实例
2015/05/13 PHP
Yii2汉字转拼音类的实例代码
2017/04/18 PHP
利用PHP计算有多少小于当前数字的数字方法示例
2020/08/26 PHP
javascript编程起步(第七课)
2007/01/10 Javascript
多种方式实现JS调用后台方法进行数据交互
2013/08/20 Javascript
jquery实现checkbox全选全不选的简单实例
2013/12/31 Javascript
javascript实现状态栏文字首尾相接循环滚动的方法
2015/07/22 Javascript
JS不完全国际化&本地化手册 之 理论篇
2016/09/27 Javascript
js移动焦点到最后位置的简单方法
2016/11/25 Javascript
jquery实现提示语淡入效果
2017/05/05 jQuery
vue刷新页面时去闪烁提升用户体验效果的实现方法
2018/12/10 Javascript
原生JS实现列表内容自动向上滚动效果
2019/05/22 Javascript
Vue实现根据hash高亮选项卡
2019/05/27 Javascript
vue.js iview打包上线后字体图标不显示解决办法
2020/01/20 Javascript
[40:55]DOTA2上海特级锦标赛主赛事日 - 2 败者组第二轮#4Newbee VS Fnatic
2016/03/03 DOTA
python中使用urllib2伪造HTTP报头的2个方法
2014/07/07 Python
Python脚本在Appium库上对移动应用实现自动化测试
2015/04/17 Python
python的多重继承的理解
2017/08/06 Python
使用Python制作简单的小程序IP查看器功能
2019/04/16 Python
python SQLAlchemy的Mapping与Declarative详解
2019/07/04 Python
TensorFlow tf.nn.max_pool实现池化操作方式
2020/01/04 Python
没编程基础可以学python吗
2020/06/17 Python
canvas 下载二维码和图片加水印的方法
2018/03/21 HTML / CSS
在线购买廉价折扣书籍和小说:BookOutlet.com
2018/02/19 全球购物
英国电气世界:Electrical World
2019/09/08 全球购物
中科创达面试题
2016/12/28 面试题
综合素质的自我鉴定
2013/10/07 职场文书
企业为何需要商业计划书
2013/12/26 职场文书
买房子个人收入证明
2014/01/16 职场文书
餐厅筹备计划书
2014/04/25 职场文书
党员对照检查材料思想汇报(党的群众路线)
2014/09/24 职场文书
2014年林业工作总结
2014/12/05 职场文书
2015年学校财务工作总结
2015/05/19 职场文书
小鞋子观后感
2015/06/05 职场文书
如何用RabbitMQ和Swoole实现一个异步任务系统
2021/05/29 PHP