OpenCV-Python图像轮廓之轮廓特征详解

yizhihongxing

下面是详细讲解“OpenCV-Python图像轮廓之轮廓特征详解”的完整攻略。

一、背景介绍

在图像处理领域中,轮廓是很常见的概念。轮廓是用于表示图像中物体形状的连续曲线。轮廓可以很好地帮助我们对图像中的对象进行识别和检测。本文主要介绍OpenCV-Python中的轮廓特征。

二、轮廓基础

轮廓可以认为是一系列像素坐标点的集合,因此我们可以对轮廓进行计算并得到一些数值特征。轮廓通常是通过对图像进行阈值化和腐蚀处理得到的。

import cv2
import numpy as np

img = cv2.imread('contour.png')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
ret, thresh = cv2.threshold(gray, 127, 255, 0)
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)

cv2.drawContours(img, contours, -1, (0, 255, 0), 3)
cv2.imshow('contour', img)
cv2.waitKey(0)

以上是绘制轮廓的基础代码,其中contour.png是原始图像的路径。这段代码逐行解释如下:

  1. cv2.imread()函数用于读取原始图像。

  2. cv2.cvtColor()用于将彩色图像转换为灰度图像。

  3. cv2.threshold()用于将灰度图像进行二值化处理。

  4. cv2.findContours()用于从二值化图像中查找轮廓。

  5. cv2.drawContours()用于绘制轮廓。

三、轮廓面积

轮廓面积是指轮廓所覆盖的像素面积。OpenCV提供了函数cv2.contourArea()来计算轮廓面积,其参数为轮廓。下面是示例代码:

import cv2
import numpy as np

img = cv2.imread('contour.png')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
ret, thresh = cv2.threshold(gray, 127, 255, 0)
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)

for contour in contours:
    area = cv2.contourArea(contour)
    print(area)

以上代码用于计算每个轮廓的面积,并输出结果。

四、轮廓周长

轮廓周长是指轮廓的长度。OpenCV提供了函数cv2.arcLength()来计算轮廓周长,其参数为轮廓、轮廓是否闭合、近似精度。下面是示例代码:

import cv2
import numpy as np

img = cv2.imread('contour.png')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
ret, thresh = cv2.threshold(gray, 127, 255, 0)
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)

for contour in contours:
    perimeter = cv2.arcLength(contour, True)
    print(perimeter)

以上代码用于计算每个轮廓的周长,并输出结果。

五、轮廓近似

轮廓近似是指对轮廓进行简化处理,以达到减少轮廓数据量和降低处理复杂度的目的。OpenCV提供了函数cv2.approxPolyDP()来进行轮廓近似,其参数为原始轮廓、距离阈值。下面是示例代码:

import cv2
import numpy as np

img = cv2.imread('contour.png')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
ret, thresh = cv2.threshold(gray, 127, 255, 0)
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)

for contour in contours:
    epsilon = 0.1 * cv2.arcLength(contour, True)
    approx = cv2.approxPolyDP(contour, epsilon, True)
    cv2.drawContours(img, [approx], -1, (0, 0, 255), 2)

cv2.imshow('approx', img)
cv2.waitKey(0)

以上代码用于对轮廓进行简化,并将结果绘制在原始图像上。

六、轮廓凸包

凸包是用于包含轮廓所有点的最小凸形状。OpenCV提供了函数cv2.convexHull()来计算轮廓的凸包,其参数为轮廓、方向(默认是检测凸包的方向)和返回凸包结果类型(默认是NDArray),可以使用返回值判断点是否在凸包内。下面是示例代码:

import cv2
import numpy as np

img = cv2.imread('contour.png')
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
ret, thresh = cv2.threshold(gray, 127, 255, 0)
contours, hierarchy = cv2.findContours(thresh, cv2.RETR_TREE, cv2.CHAIN_APPROX_SIMPLE)

for contour in contours:
    hull = cv2.convexHull(contour)
    cv2.drawContours(img, [hull], -1, (0, 0, 255), 2)

cv2.imshow('convex', img)
cv2.waitKey(0)

以上代码用于计算轮廓的凸包,并将结果绘制在原始图像上。

七、小结

本文介绍了OpenCV-Python中的轮廓特征,并给出了轮廓面积、轮廓周长、轮廓近似、轮廓凸包等示例。了解这些特征可以大大提高图像处理的效率和准确性。

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:OpenCV-Python图像轮廓之轮廓特征详解 - Python技术站

(0)
上一篇 2023年5月18日
下一篇 2023年5月18日

相关文章

  • numpy排序与集合运算用法示例

    下面我将为大家详细讲解“numpy排序与集合运算用法示例”的完整攻略。 一、numpy排序用法示例 1.1 排序数组 在numpy中,可以使用sort()方法对数组进行排序,其默认排序方式为升序排序。下面是一个示例: import numpy as np arr = np.array([1, 5, 3, 9, 7]) arr.sort() print(arr…

    python 2023年5月13日
    00
  • Python实现的排列组合、破解密码算法示例

    Python实现排列组合算法示例 摘要 本文将介绍Python语言中如何实现排列组合算法。排列组合算法是密码学中重要的一部分,同时也被广泛应用于各种数值计算中。本文将通过一个示例来说明如何使用Python实现排列组合算法。 概述 在密码学中,排列组合算法通常用于破解密码。例如,如果一个用户的密码是由6个字符组成,由每个字符可以是0-9中的一个数字或a-z中的…

    python 2023年6月3日
    00
  • Python生成验证码实例

    生成验证码是一种常见的网络应用场景,可以用于用户注册、登录验证等等。下面是Python生成验证码的完整攻略。 1. 安装依赖库 Python生成验证码需要用到Pillow库,可以通过以下命令安装: pip install Pillow 2. 创建验证码生成函数 我们创建一个名为get_verify_code的函数,该函数可以生成4位随机字符,还会将字符绘制到…

    python 2023年6月3日
    00
  • python3 字符串/列表/元组(str/list/tuple)相互转换方法及join()函数的使用

    Python3字符串/列表/元组(str/list/tuple)相互转换方法及join()函数的使用 在Python3中,字符串、列表和元组是常用的数据类型。它们之间可以相互转换,方便在不同的场景中使用。本文将详细讲解这些数据类型之间的相互转换方法及join()函数的使用。 字符串、列表、元组之间的相互转换 字符串转列表/元组 在Python3中,可以使用s…

    python 2023年5月13日
    00
  • 零基础写python爬虫之urllib2使用指南

    下面为您详细讲解“零基础写python爬虫之urllib2使用指南”的完整攻略。 urllib2是什么? urllib2是Python中处理URL的扩展库,可以用来向一个url地址发送请求并返回响应的结果,它可以模拟浏览器的访问,支持发送请求、处理响应、设置http头、获取cookies等操作,是Python网络编程的重要组成部分。 urllib2的安装 u…

    python 2023年5月14日
    00
  • 如何使用Python连接MySQL数据库?

    使用Python连接MySQL数据库可以使用Python的mysql-connector模块。该模块提供了一个Python接口,用于连接和操作MySQL数据库。以下是使用Python连接数据库的完整攻略: 安装mysql-connector 在使用mysql-connector模块之前,需要先安装该模块。可以使用以下命令在命令行中安装: pip instal…

    python 2023年5月12日
    00
  • Mac上Go环境和VS Code的正确安装与配置方法

    Mac上Go环境和VS Code的正确安装与配置方法 本文将介绍如何在Mac上正确安装和配置Go环境以及使用VS Code进行Go代码开发。 安装Go环境 首先我们需要安装Go环境。我们推荐使用Homebrew进行安装,具体步骤如下: 打开终端,输入以下命令安装Homebrew: sh /bin/bash -c “$(curl -fsSL https://r…

    python 2023年6月3日
    00
  • python装饰器练习题及答案

    感谢您的提问,下面是关于Python装饰器练习题及答案的详细讲解攻略。 什么是Python装饰器? Python装饰器是一种用于在不改变已有代码的情况下,增加额外功能的语法结构。一个Python装饰器通常是一个函数,它接受一个函数作为参数,并返回另一个函数。在使用装饰器时,我们将目标函数作为参数传递给装饰器,装饰器会对目标函数进行一些修改或增强,然后返回一个…

    python 2023年6月3日
    00
合作推广
合作推广
分享本页
返回顶部