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中用于处理字符串的center()方法
May 18 Python
python3基于OpenCV实现证件照背景替换
Jul 18 Python
在matplotlib的图中设置中文标签的方法
Dec 13 Python
python 自动重连wifi windows的方法
Dec 18 Python
使用PyQtGraph绘制精美的股票行情K线图的示例代码
Mar 14 Python
如何基于Python实现电子邮件的发送
Dec 16 Python
python实现一个猜拳游戏
Apr 05 Python
Python模拟登入的N种方式(建议收藏)
May 31 Python
Python实现Keras搭建神经网络训练分类模型教程
Jun 12 Python
Django ModelForm组件原理及用法详解
Oct 12 Python
详解numpy.ndarray.reshape()函数的参数问题
Oct 13 Python
Django contrib auth authenticate函数源码解析
Nov 12 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
PHP5与MySQL数据库操作常用代码 收集
2010/03/21 PHP
利用php绘制饼状图的实现代码
2013/06/07 PHP
初识Laravel
2014/10/30 PHP
Yii框架关联查询with用法分析
2014/12/02 PHP
ThinkPHP连接数据库的方式汇总
2014/12/05 PHP
thinkPHP+mysql+ajax实现的仿百度一下即时搜索效果详解
2019/07/15 PHP
mac pecl 安装php7.1扩展教程
2019/10/17 PHP
javascript 三种编解码方式
2010/02/01 Javascript
IE不支持getElementsByClassName最终完美解决方案
2012/12/17 Javascript
JS.elementGetStyle(element, style)应用示例
2013/09/24 Javascript
jQuery setTimeout传递字符串参数报错的解决方法
2014/06/09 Javascript
js实现可得到不同颜色值的颜色选择器实例
2015/02/28 Javascript
jquery解析XML及获取XML节点名称的实现代码
2016/05/18 Javascript
详解vue2.0 不同屏幕适配及px与rem转换问题
2018/02/23 Javascript
详解iview的checkbox多选框全选时校验问题
2019/06/10 Javascript
JS实现滚动条触底加载更多
2019/09/19 Javascript
vue实现随机验证码功能(完整代码)
2019/12/10 Javascript
vue 实现setInterval 创建和销毁实例
2020/07/21 Javascript
python list排序的两种方法及实例讲解
2017/03/20 Python
caffe binaryproto 与 npy相互转换的实例讲解
2018/07/09 Python
python实现斗地主分牌洗牌
2020/06/22 Python
Python3爬虫关于代理池的维护详解
2020/07/30 Python
Python matplotlib模块及柱状图用法解析
2020/08/10 Python
python单例模式的应用场景实例讲解
2021/02/24 Python
L*SPACE官网:比基尼、泳装和度假服装
2019/03/18 全球购物
中兴通讯全球官方网站:ZTE
2020/12/26 全球购物
小学门卫岗位职责
2013/12/17 职场文书
销售行政专员职责
2014/01/03 职场文书
中秋节超市促销方案
2014/01/30 职场文书
《都江堰》教学反思
2014/02/07 职场文书
装修设计师求职信
2014/02/26 职场文书
请假条怎么写
2014/04/10 职场文书
党的群众教育实践活动实施方案
2014/06/12 职场文书
2014年环保局工作总结
2014/12/11 职场文书
奖学金感谢信
2015/01/21 职场文书
专家推荐信怎么写
2015/03/25 职场文书