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 01 Python
浅谈Python的文件类型
May 30 Python
django在接受post请求时显示403forbidden实例解析
Jan 25 Python
python实现Adapter模式实例代码
Feb 09 Python
Python continue继续循环用法总结
Jun 10 Python
Django添加favicon.ico图标的示例代码
Aug 07 Python
python dumps和loads区别详解
Feb 04 Python
pygame实现飞机大战
Mar 11 Python
Pyecharts地图显示不完成问题解决方案
May 11 Python
Python坐标轴操作及设置代码实例
Jun 04 Python
Python OpenCV形态学运算示例详解
Apr 07 Python
Django框架中模型的用法
Jun 10 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
ajax+php打造进度条 readyState各状态
2010/03/20 PHP
php函数之子字符串替换 str_replace
2011/03/23 PHP
js中访问html中iframe的文档对象的代码[IE6,IE7,IE8,FF]
2011/01/08 Javascript
jquery中的ajax方法怎样通过JSONP进行远程调用
2014/05/04 Javascript
2014年50个程序员最适用的免费JQuery插件
2014/12/15 Javascript
jQuery实现精美的多级下拉菜单特效
2015/03/14 Javascript
jQuery Html控件基本操作(日常收集整理)
2016/03/11 Javascript
JavaScript解八皇后问题的方法总结
2016/06/12 Javascript
全面解析Bootstrap表单样式的使用
2016/09/09 Javascript
Javascript的动态增加类的实现方法
2016/10/20 Javascript
微信小程序入门教程
2016/11/18 Javascript
利用jQuery实现简单的拖曳效果实例代码
2017/10/20 jQuery
layui动态绑定事件的方法
2019/09/20 Javascript
[19:59]2014DOTA2国际邀请赛 IG战队纪录片
2014/08/07 DOTA
[00:35]DOTA2上海特级锦标赛 EG战队宣传片
2016/03/04 DOTA
Python StringIO模块实现在内存缓冲区中读写数据
2015/04/08 Python
Python中for循环控制语句用法实例
2015/06/02 Python
CentOS 6.5下安装Python 3.5.2(与Python2并存)
2017/06/05 Python
python并发和异步编程实例
2018/11/15 Python
详解Python进阶之切片的误区与高级用法
2018/12/24 Python
Python列表常见操作详解(获取,增加,删除,修改,排序等)
2019/02/18 Python
详解Python循环作用域与闭包
2019/03/21 Python
Python面向对象思想与应用入门教程【类与对象】
2019/04/12 Python
Python使用numpy模块实现矩阵和列表的连接操作方法
2019/06/26 Python
python多线程实现同时执行两个while循环的操作
2020/05/02 Python
GAP欧盟网上商店:GAP EU
2016/09/13 全球购物
新西兰最大的在线设计师眼镜店:SmartBuyGlasses新西兰
2017/10/20 全球购物
雷曼兄弟的五金店:Lehman’s Hardware Store
2019/04/10 全球购物
HomeAway英国:全球领先的度假租赁在线市场
2020/02/03 全球购物
营销与策划专业毕业生求职信
2013/11/01 职场文书
四风问题个人自查剖析材料思想汇报
2014/09/21 职场文书
党员民主评议总结
2014/10/20 职场文书
省委召开党的群众路线教育实践活动总结大会报告
2014/10/21 职场文书
博士论文答辩开场白
2015/06/01 职场文书
如何正确理解python装饰器
2021/06/15 Python
Python中基础数据类型 set集合知识点总结
2021/08/02 Python