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代码(逐级优化)
May 25 Python
在Python中使用正则表达式的方法
Aug 13 Python
Python OpenCV读取png图像转成jpg图像存储的方法
Oct 28 Python
使用django-guardian实现django-admin的行级权限控制的方法
Oct 30 Python
Python从list类型、range()序列简单认识类(class)【可迭代】
May 31 Python
python如何删除文件中重复的字段
Jul 16 Python
Python aiohttp百万并发极限测试实例分析
Oct 26 Python
python中for循环变量作用域及用法详解
Nov 05 Python
了解一下python内建模块collections
Sep 07 Python
Django模板报TemplateDoesNotExist异常(亲测可行)
Dec 18 Python
python制作图形界面的2048游戏, 基于tkinter
Apr 06 Python
Django开发RESTful API实现增删改查(入门级)
May 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
音乐朗读剧《MARS RED》2021年TV动画化决定!
2020/03/06 日漫
php文件怎么打开 如何执行php文件
2011/12/21 PHP
Centos PHP 扩展Xchche的安装教程
2016/07/09 PHP
js版本A*寻路算法
2006/12/22 Javascript
jQuery 第二课 操作包装集元素代码
2010/03/14 Javascript
javascript正则表达式中参数g(全局)的作用
2010/11/11 Javascript
根据经纬度计算地球上两点之间的距离js实现代码
2013/03/05 Javascript
JQuery onload、ready概念介绍及使用方法
2013/04/27 Javascript
js实现select组件的选择输入过滤代码
2014/10/14 Javascript
JsRender实用入门教程
2014/10/31 Javascript
将JavaScript的jQuery库中表单转化为JSON对象的方法
2015/11/17 Javascript
利用Javascript仿Excel的数据透视分析功能
2016/09/07 Javascript
玩转NODE.JS(四)-搭建简单的聊天室的代码
2016/11/11 Javascript
JS 终止执行的实现方法
2016/11/24 Javascript
基于Node的React图片上传组件实现实例代码
2017/05/10 Javascript
jQuery操作css样式
2017/05/15 jQuery
vue项目环境变量配置的实现方法
2018/10/12 Javascript
JQuery+Bootstrap 自定义全屏Loading插件的示例demo
2019/07/03 jQuery
微信小程序点击图片实现长按预览、保存、识别带参数二维码、转发等功能
2019/07/20 Javascript
jQuery+ThinkPHP实现图片上传
2020/07/23 jQuery
python中使用smtplib和email模块发送邮件实例
2014/04/22 Python
python数据结构之二叉树的遍历实例
2014/04/29 Python
Python简单爬虫导出CSV文件的实例讲解
2018/07/06 Python
Python3操作Excel文件(读写)的简单实例
2019/09/02 Python
Python Selenium 设置元素等待的三种方式
2020/03/18 Python
斯凯奇新西兰官网:SKECHERS新西兰
2018/02/22 全球购物
Java中会存在内存泄漏吗,请简单描述
2016/12/22 面试题
考博自荐信
2013/10/25 职场文书
中专生毕业自我鉴定
2013/11/01 职场文书
党员创先争优承诺书
2014/03/26 职场文书
个人课题方案
2014/05/08 职场文书
诚实守信演讲稿
2014/09/01 职场文书
2016五一劳动节慰问信
2015/11/30 职场文书
比赛口号霸气押韵
2015/12/24 职场文书
《搭石》教学反思
2016/02/18 职场文书
创业计划书之酒店
2019/08/30 职场文书