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 相关文章推荐
django输出html内容的实例
May 27 Python
django+xadmin+djcelery实现后台管理定时任务
Aug 14 Python
使用python判断你是青少年还是老年人
Nov 29 Python
pandas进行时间数据的转换和计算时间差并提取年月日
Jul 06 Python
python 设置xlabel,ylabel 坐标轴字体大小,字体类型
Jul 23 Python
python3应用windows api对后台程序窗口及桌面截图并保存的方法
Aug 27 Python
解决Django删除migrations文件夹中的文件后出现的异常问题
Aug 31 Python
python如何把字符串类型list转换成list
Feb 18 Python
opencv 图像加法与图像融合的实现代码
Jul 08 Python
Python 高效编程技巧分享
Sep 10 Python
浅析python 字典嵌套
Sep 29 Python
使用numpngw和matplotlib生成png动画的示例代码
Jan 24 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设计模式 Visitor 访问者模式
2011/06/28 PHP
PHP调用存储过程返回值不一致问题的解决方法分析
2016/04/26 PHP
tp5.1 框架join方法用法实例分析
2020/05/26 PHP
PHP生成图表pChart的示例解析
2020/07/31 PHP
jQuery UI Dialog 创建友好的弹出对话框实现代码
2012/04/12 Javascript
jQuery的Ajax的自动完成功能控件简要说明
2013/02/22 Javascript
对于this和$(this)的个人理解
2013/09/08 Javascript
jquery()函数的三种语法介绍
2013/10/09 Javascript
JS判断两个时间大小的示例代码
2014/01/28 Javascript
JavaScript获取当前页面上的指定对象示例代码
2014/02/28 Javascript
在JS数组特定索引处指定位置插入元素的技巧
2014/08/24 Javascript
jQuery搜索子元素的方法
2015/02/10 Javascript
鼠标悬停小图标显示大图标
2016/01/22 Javascript
JavaScript性能优化总结之加载与执行
2016/08/11 Javascript
vue实现长图垂直居上 vue实现短图垂直居中
2017/10/18 Javascript
详解extract-text-webpack-plugin 的使用及安装
2018/06/12 Javascript
详解解决Vue相同路由参数不同不会刷新的问题
2018/10/12 Javascript
在vue中使用el-tab-pane v-show/v-if无效的解决
2020/08/03 Javascript
[02:41]DOTA2英雄基础教程 亚巴顿
2014/01/02 DOTA
[43:51]2014 DOTA2国际邀请赛中国区预选赛 Dream Times VS TongFu
2014/05/22 DOTA
[57:18]DOTA2上海特级锦标赛主赛事日 - 1 败者组第一轮#3VP VS VG
2016/03/03 DOTA
[02:19]2018年度DOTA2最佳核心位选手-完美盛典
2018/12/17 DOTA
python smtplib模块发送SSL/TLS安全邮件实例
2015/04/08 Python
Python with用法实例
2015/04/14 Python
Python设计模式之模板方法模式实例详解
2019/01/17 Python
PyQt5实现让QScrollArea支持鼠标拖动的操作方法
2019/06/19 Python
使用OpenCV获取图像某点的颜色值,并设置某点的颜色
2020/06/02 Python
英国性能汽车零件和发动机配件在线:Maxpeedingrods
2019/11/05 全球购物
党校培训思想汇报
2013/12/30 职场文书
《谁的本领大》教后反思
2014/04/25 职场文书
国旗下的演讲稿
2014/05/08 职场文书
初中军训感想
2015/08/07 职场文书
2016年“9.22”世界无车日活动小结
2016/04/05 职场文书
世界各国短波电台对东亚播送时间频率表(SW)
2021/06/28 无线电
Redis的字符串是如何实现的
2021/10/24 Redis
海贼王十大逆天果实 魂魂果实上榜,岩浆果实攻击力最强
2022/03/18 日漫