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 列表排序方法reverse、sort、sorted详解
Jan 22 Python
用matplotlib画等高线图详解
Dec 14 Python
Python中的groupby分组功能的实例代码
Jul 11 Python
对python的unittest架构公共参数token提取方法详解
Dec 17 Python
python调用百度地图WEB服务API获取地点对应坐标值
Jan 16 Python
对python字典过滤条件的实例详解
Jan 22 Python
使用Python检测文章抄袭及去重算法原理解析
Jun 14 Python
Django 开发调试工具 Django-debug-toolbar使用详解
Jul 23 Python
python文字转语音实现过程解析
Nov 12 Python
Python模块的制作方法实例分析
Dec 21 Python
解决python调用自己文件函数/执行函数找不到包问题
Jun 01 Python
基于python爬取链家二手房信息代码示例
Oct 21 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&MYSQL留言板源码
2020/07/19 PHP
PHP严重致命错误处理:php Fatal error: Cannot redeclare class or function
2017/02/05 PHP
PHP编程快速实现数组去重的方法详解
2017/07/22 PHP
Javascript 跨域访问解决方案
2009/02/14 Javascript
根据经纬度计算地球上两点之间的距离js实现代码
2013/03/05 Javascript
jquery indexOf使用方法
2013/08/19 Javascript
jQuery学习笔记之 Ajax操作篇(二) - 数据传递
2014/06/23 Javascript
Eclipse编辑jsp、js文件时卡死现象的解决办法汇总
2016/02/02 Javascript
jQuery下拉框的简单应用
2016/06/24 Javascript
vue轮播图插件vue-concise-slider的使用
2018/03/13 Javascript
Vue-cropper 图片裁剪的基本原理及思路讲解
2018/04/17 Javascript
Vue中使用vue-i18插件实现多语言切换功能
2018/04/25 Javascript
代码实例ajax实现点击加载更多数据图片
2018/10/12 Javascript
vue离开当前页面触发的函数代码
2020/09/01 Javascript
python实现异步回调机制代码分享
2014/01/10 Python
Python开发的单词频率统计工具wordsworth使用方法
2014/06/25 Python
Tornado Web服务器多进程启动的2个方法
2014/08/04 Python
python处理图片之PIL模块简单使用方法
2015/05/11 Python
python opencv实现切变换 不裁减图片
2018/07/26 Python
Jupyter notebook在mac:linux上的配置和远程访问的方法
2019/01/14 Python
Python中三元表达式的几种写法介绍
2019/03/04 Python
Django使用redis缓存服务器的实现代码示例
2019/04/28 Python
python 判断文件还是文件夹的简单实例
2019/06/10 Python
使用Python计算玩彩票赢钱概率
2019/06/26 Python
Python批量修改图片分辨率的实例代码
2019/07/04 Python
三步解决python PermissionError: [WinError 5]拒绝访问的情况
2020/04/22 Python
pycharm 2018 激活码及破解补丁激活方式
2020/09/21 Python
Python如何向SQLServer存储二进制图片
2020/06/08 Python
pandas to_excel 添加颜色操作
2020/07/14 Python
django教程如何自学
2020/07/31 Python
收集的7个CSS3代码生成工具
2010/04/17 HTML / CSS
美国存储和组织商店:The Container Store
2017/08/16 全球购物
Expedia意大利旅游网站:酒店、机票和租车预订
2017/10/30 全球购物
采购部经理岗位职责
2014/02/10 职场文书
员工家属慰问信
2015/03/24 职场文书
机关干部正风肃纪心得体会
2016/01/15 职场文书