返回顶部
首页 > 资讯 > 后端开发 > Python >Python中OpenCV实现查找轮廓的实例
  • 792
分享到

Python中OpenCV实现查找轮廓的实例

2024-04-02 19:04:59 792人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

本文将结合实例代码,介绍 OpenCV 如何查找轮廓、获取边界框。 代码: contours.py OpenCV 提供了 findContours 函数查找轮廓,需要以二值化图像作为

本文将结合实例代码,介绍 OpenCV 如何查找轮廓、获取边界框。

代码: contours.py

OpenCV 提供了 findContours 函数查找轮廓,需要以二值化图像作为输入、并指定些选项调用即可。

我们以下图作为示例:

二值化图像

代码工程 data/ 提供了小狗和红球的二值化掩膜图像:

其使用预训练好的实例分割模型来生成的,脚本可见 detectron2_seg_threshold.py。模型检出结果,如下:

模型用的 Mask R-CNN 已有预测边框。但其他模型会有只出预测掩膜的,此时想要边框就可以使用 OpenCV 来提取。

本文代码也提供了根据色域来获取红球掩膜的办法:


import cv2 as cv
import numpy as np

# 读取图像
img = cv.imread(args.image, cv.IMREAD_COLOR)

# HSV 阈值,获取掩膜
def _threshold_hsv(image, lower, upper):
  hsv = cv.cvtColor(image, cv.COLOR_BGR2HSV)
  mask = cv.inRange(hsv, lower, upper)
  result = cv.bitwise_and(image, image, mask=mask)
  return result, mask

_, thres = _threshold_hsv(img, np.array([0,110,190]), np.array([7,255,255]))

# 清除小点(可选)
kernel = cv.getStructuringElement(cv.MORPH_RECT, (3, 3), (1, 1))
thres = cv.morphologyEx(thres, cv.MORPH_OPEN, kernel)

查找轮廓


# 查找轮廓
#  cv.RETR_EXTERNAL: 只查找外部轮廓
contours, hierarchy = cv.findContours(
  threshold, cv.RETR_EXTERNAL, cv.CHaiN_APPROX_SIMPLE)

# 近似轮廓,减点(可选)
contours_poly = [cv.approxPolyDP(c, 3, True) for c in contours]

# 绘制轮廓
h, w = threshold.shape[:2]
drawing = np.zeros((h, w, 3), dtype=np.uint8)
for i in range(len(contours)):
  cv.drawContours(drawing, contours_poly, i, (0, 255, 0), 1, cv.LINE_8, hierarchy)

获取边界框

boundingRect 获取边界框,并绘制:


for contour in contours_poly:
  rect = cv.boundingRect(contour)
  cv.rectangle(drawing,
                (int(rect[0]), int(rect[1])),
                (int(rect[0]+rect[2]), int(rect[1]+rect[3])),
                (0, 255, 0), 2, cv.LINE_8)

minEnclosinGCircle 获取边界圈,并绘制:


for contour in contours_poly:
  center, radius = cv.minEnclosingCircle(contour)
  cv.circle(drawing, (int(center[0]), int(center[1])), int(radius),
            (0, 255, 0), 2, cv.LINE_8)

参考

OpenCV Tutorials / Image Processing

到此这篇关于OpenCV实现查找轮廓的实例的文章就介绍到这了,更多相关OpenCV 查找轮廓内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: Python中OpenCV实现查找轮廓的实例

本文链接: https://lsjlt.com/news/127770.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Python中OpenCV实现查找轮廓的实例
    本文将结合实例代码,介绍 OpenCV 如何查找轮廓、获取边界框。 代码: contours.py OpenCV 提供了 findContours 函数查找轮廓,需要以二值化图像作为...
    99+
    2024-04-02
  • OpenCV-Python实现轮廓拟合
    目录前言绘制椭圆的矩形边界最小包围矩形框最小包围圆形框最优拟合椭圆最优拟合直线最小外包三角形逼近多边形前言 什么是轮廓? 轮廓可以简单认为成将连续的点(连着边界)连在一起的曲线,具有...
    99+
    2024-04-02
  • OpenCV-Python实现轮廓的特征值
    目录前言宽高比ExtendSolidity等效直径方向掩摸和像素点最大值,最小值以及它们的位置平均颜色及平均灰度极点前言 轮廓自身的一些属性特征及轮廓所包围对象的特征对于描述图像具有...
    99+
    2024-04-02
  • OpenCV-Python如何实现轮廓拟合
    这篇文章主要介绍OpenCV-Python如何实现轮廓拟合,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!前言什么是轮廓?轮廓可以简单认为成将连续的点(连着边界)连在一起的曲线,具有相同 的颜色或者灰度。轮廓在形状分析...
    99+
    2023-06-15
  • OpenCV图像轮廓提取的实现
    目录前言提取傅里叶变换的高频信息通过蚁群算法进行图片轮廓提取Canny边缘检测  使用cuda加速提取轮廓前言 常用的轮廓提取算法有:Canny、阈值分割、提取傅...
    99+
    2022-11-13
    OpenCV图像轮廓提取 OpenCV 轮廓提取
  • opencv实现图形轮廓检测
    要想实现轮廓检测,首先我们需要对待检测的图像进行图像处理: 图像灰度化、高斯滤波、Canny 边缘检测、边缘检测放大处理、提取轮廓。 一、实现简单的全图型检测 即只要将drawCon...
    99+
    2024-04-02
  • OpenCV实现轮廓外接多边形
    本文实例为大家分享了OpenCV实现轮廓外接多边形的具体代码,供大家参考,具体内容如下 取轮廓最大外接矩形 Rect boundingRect( InputArray array...
    99+
    2024-04-02
  • OpenCV实现轮廓检测与绘制
    图像的轮廓不仅能够提供物体的边缘,而且还能提供物体边缘之间的层次关系以及拓扑关系。 带有结构关系的边缘检测,这种结构关系可以表明图像中连通域或者某些区域之间的关系。 图为一个具有4个...
    99+
    2024-04-02
  • 怎么在python中使用opencv查找图像中的最大的轮廓
    本篇文章给大家分享的是有关怎么在python中使用opencv查找图像中的最大的轮廓,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。具体如下:import cv2imp...
    99+
    2023-06-09
  • 怎么在Python中使用OpenCV实现轮廓的特征值
    本篇文章给大家分享的是有关怎么在Python中使用OpenCV实现轮廓的特征值,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。宽高比在轮廓中,我们可以通过宽高比来描述轮廓,例如矩...
    99+
    2023-06-15
  • OpenCV实现绘制轮廓外接矩形
    目录1.寻找轮廓2.绘制轮廓外接矩形3.代码1.寻找轮廓 api void cv::findContours( InputOutputArray image, OutputArray...
    99+
    2022-12-29
    OpenCV绘制轮廓外接矩形 OpenCV轮廓外接矩形 OpenCV外接矩形
  • OpenCV中如何基于Hu矩实现轮廓匹配
    这篇文章将为大家详细讲解有关OpenCV中如何基于Hu矩实现轮廓匹配,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、查找轮廓原图测试图vector<vector<Point>>f...
    99+
    2023-06-26
  • OpenCV实战之基于Hu矩实现轮廓匹配
    目录前言一、查找轮廓二、计算Hu矩三、显示效果四、源码总结前言 本文将使用OpenCV C++ 基于Hu矩进行轮廓匹配。 一、查找轮廓 原图 测试图 vector<vect...
    99+
    2024-04-02
  • OpenCV如何实现绘制轮廓外接矩形
    本篇内容介绍了“OpenCV如何实现绘制轮廓外接矩形”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1.寻找轮廓apivoid cv...
    99+
    2023-07-04
  • python opencv 找出图像中的最大轮廓并填充(生成mask)
    本文主要介绍了python opencv 找出图像中的最大轮廓并填充,分享给大家,具体如下: import cv2 import numpy as np from PIL imp...
    99+
    2024-04-02
  • 怎么利用Python+OpenCV实现简易图像边缘轮廓检测
    本篇内容主要讲解“怎么利用Python+OpenCV实现简易图像边缘轮廓检测”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么利用Python+OpenCV实现简易图像边缘轮廓检测”吧!函数基础...
    99+
    2023-06-30
  • 如何利用Python+OpenCV实现简易图像边缘轮廓检测(零基础)
    目录前言函数基础与三方库cv.threshold(pic,thresh,maxvalue,model)cv.findContours(待处理图片,model(提取模式),method...
    99+
    2024-04-02
  • Python OpenCV 基于图像边缘提取的轮廓发现函数
    基础知识铺垫 在图像中,轮廓可以简单的理解为连接具有相同颜色的所有连续点(边界)的曲线,轮廓可用于形状分析和对象检测、识别等领域。 轮廓发现的原理:先通过阈值分割提取目标物体,再通过...
    99+
    2024-04-02
  • openCV中meanshift算法查找目标的实现
    目录一、简介二、实现过程1、设定感兴趣的区域2、获取脸部直方图并做归一化3、反向投影,用meanshift查找目标三、其他实验结果 四、部分原理补充五、完整代码一、简介 图...
    99+
    2024-04-02
  • c++和python实现顺序查找实例
    目录(1)python实现顺序查找(2)C++实现顺序查找如何在一堆数据中找到某个数值的位置? 数值型数据作为信息的基本载体,广泛用于各种信息的记录,这些数据不仅需要被存储,更需要被...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作