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 24 Python
Django开发中的日志输出的方法
Jul 02 Python
python在OpenCV里实现投影变换效果
Aug 30 Python
Python3 sys.argv[ ]用法详解
Oct 24 Python
Python中__repr__和__str__区别详解
Nov 07 Python
tensorflow 实现打印pb模型的所有节点
Jan 23 Python
python实现ip地址的包含关系判断
Feb 07 Python
Python-jenkins 获取job构建信息方式
May 12 Python
解决python图像处理图像赋值后变为白色的问题
Jun 04 Python
记录一下scrapy中settings的一些配置小结
Sep 28 Python
Pyhton模块和包相关知识总结
May 12 Python
如何使用Tkinter进行窗口的管理与设置
Jun 30 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 isset()与empty()的使用区别详解
2010/08/29 PHP
PHP使用星号隐藏用户名,手机和邮箱的实现方法
2016/09/22 PHP
php实现自定义中奖项数和概率的抽奖函数示例
2017/05/26 PHP
PHP实现webshell扫描文件木马的方法
2017/07/31 PHP
基于Laravel5.4实现多字段登录功能方法示例
2017/08/11 PHP
PHP+iframe模拟Ajax上传文件功能示例
2019/07/02 PHP
Javascript 二维数组
2009/11/26 Javascript
JavaScript原型继承之基础机制分析
2011/08/26 Javascript
JavaScript不使用prototype和new实现继承机制
2014/12/29 Javascript
解决ueditor jquery javascript 取值问题
2014/12/30 Javascript
javascript常用正则表达式汇总
2015/07/31 Javascript
JS实现超精简的链接列表在固定区域内滚动效果代码
2015/11/04 Javascript
浅析如何利用JavaScript进行语音识别
2016/10/27 Javascript
jQuery插件Echarts实现的渐变色柱状图
2017/03/23 jQuery
Vue form 表单提交+ajax异步请求+分页效果
2017/04/22 Javascript
详解Vue-cli 创建的项目如何跨域请求
2017/05/18 Javascript
基于jQuery中ajax的相关方法汇总(必看篇)
2017/11/08 jQuery
js+html获取系统当前时间
2017/11/10 Javascript
vue生成文件本地打开查看效果的实例
2018/09/06 Javascript
详解Vue内部怎样处理props选项的多种写法
2018/11/06 Javascript
JS拖拽排序插件Sortable.js用法实例分析
2019/02/20 Javascript
[01:01:51]EG vs VG Supermajor小组赛B组 BO3 第二场 6.2
2018/06/03 DOTA
[04:09]2018年度DOTA2社区贡献奖-完美盛典
2018/12/16 DOTA
优化Python代码使其加快作用域内的查找
2015/03/30 Python
在Python的Flask框架中实现单元测试的教程
2015/04/20 Python
Python获取二维矩阵每列最大值的方法
2018/04/03 Python
Python图像处理之图像的读取、显示与保存操作【测试可用】
2019/01/04 Python
linux下安装python3和对应的pip环境教程详解
2019/07/01 Python
详解Python模块化编程与装饰器
2021/01/16 Python
香港No.1得奖零食网:香港零食大王
2016/07/22 全球购物
意大利在线眼镜精品店:Ottica Lipari
2019/11/11 全球购物
土木工程建筑专业毕业生求职信
2013/10/21 职场文书
小学语文业务学习材料
2014/06/02 职场文书
博士生专家推荐信
2014/09/26 职场文书
2014年数学教研组工作总结
2014/12/06 职场文书
2015年六一儿童节活动总结
2015/02/11 职场文书