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 random模块(获取随机数)常用方法和使用例子
May 13 Python
使用Python的Tornado框架实现一个一对一聊天的程序
Apr 25 Python
在Django的URLconf中进行函数导入的方法
Jul 18 Python
Python DataFrame 设置输出不显示index(索引)值的方法
Jun 07 Python
Python 3.x基于Xml数据的Http请求方法
Dec 28 Python
详解pandas使用drop_duplicates去除DataFrame重复项参数
Aug 01 Python
Python3安装pip工具的详细步骤
Oct 14 Python
python DataFrame转dict字典过程详解
Dec 26 Python
Python的赋值、深拷贝与浅拷贝的区别详解
Feb 12 Python
Python编程快速上手——正则表达式查找功能案例分析
Feb 28 Python
keras导入weights方式
Jun 12 Python
pandas DataFrame运算的实现
Jun 14 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数据库备份与还原类实例
2014/12/09 PHP
php数组去除空值函数分享
2015/02/02 PHP
PHP简单操作MongoDB的方法(安装及增删改查)
2016/05/26 PHP
php实现的redis缓存类定义与使用方法示例
2017/08/09 PHP
Yii2.0框架实现带分页的多条件搜索功能示例
2019/02/20 PHP
再次分享18个非常棒的jQuery表格插件
2011/04/10 Javascript
JavaScript高级程序设计 阅读笔记(七) ECMAScript中的语句
2012/02/27 Javascript
ScrollDown的基本操作示例
2013/06/09 Javascript
ParseInt函数参数设置介绍
2014/01/02 Javascript
jQuery多级弹出菜单插件ZoneMenu
2014/12/18 Javascript
jQuery+ajax实现动态执行脚本的方法
2015/01/27 Javascript
jquery实现的代替传统checkbox样式插件
2015/06/19 Javascript
理解Javascript图片预加载
2016/02/23 Javascript
基于HTML模板和JSON数据的JavaScript交互(移动端)
2016/04/06 Javascript
NodeJS创建基础应用并应用模板引擎
2016/04/12 NodeJs
浅谈Javascript中的12种DOM节点类型
2016/08/19 Javascript
Vuejs第八篇之Vuejs组件的定义实例解析
2016/09/05 Javascript
jQuery实现点击某个div打开层,点击其他div关闭层实例分析(阻止冒泡)
2016/11/18 Javascript
JS简单实现获取元素的封装操作示例
2017/04/07 Javascript
jQuery Dom元素操作技巧
2018/02/04 jQuery
Vue数据双向绑定原理及简单实现方法
2018/05/18 Javascript
详解VUE项目中安装和使用vant组件
2019/04/28 Javascript
浅谈Vuex注入Vue生命周期的过程
2019/05/20 Javascript
Vue 实现点击空白处隐藏某节点的三种方式(指令、普通、遮罩)
2019/10/23 Javascript
Python实现同时兼容老版和新版Socket协议的一个简单WebSocket服务器
2014/06/04 Python
python利用sklearn包编写决策树源代码
2017/12/21 Python
python 定时修改数据库的示例代码
2018/04/08 Python
iphoneX 适配客户端H5页面的方法教程
2017/12/08 HTML / CSS
创业计划书的主要内容有哪些
2014/01/29 职场文书
八项规定整改方案
2014/02/21 职场文书
二手房购房意向书范本
2014/04/01 职场文书
综合内勤岗位职责
2014/04/14 职场文书
企业宣传工作方案
2014/06/02 职场文书
教师个人成长总结
2015/02/11 职场文书
哈姆雷特读书笔记
2015/06/29 职场文书
大学班长竞选稿
2015/11/20 职场文书