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

2023-12-17Python编程
18

下面是详细讲解“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中的轮廓特征,并给出了轮廓面积、轮廓周长、轮廓近似、轮廓凸包等示例。了解这些特征可以大大提高图像处理的效率和准确性。

The End

相关推荐

解析Python中的eval()、exec()及其相关函数
Python中有三个内置函数eval()、exec()和compile()来执行动态代码。这些函数能够从字符串参数中读取Python代码并在运行时执行该代码。但是,使用这些函数时必须小心,因为它们的不当使用可能会导致安全漏洞。...
2023-12-18 Python编程
117

Python下载网络文本数据到本地内存的四种实现方法示例
在Python中,下载网络文本数据到本地内存是常见的操作之一。本文将介绍四种常见的下载网络文本数据到本地内存的实现方法,并提供示例说明。...
2023-12-18 Python编程
101

Python 二进制字节流数据的读取操作(bytes与bitstring)
来给你详细讲解下Python 二进制字节流数据的读取操作(bytes与bitstring)。...
2023-12-18 Python编程
120

Python3.0与2.X版本的区别实例分析
Python 3.x 是 Python 2.x 的下一个重大版本,其中有一些值得注意的区别。 Python 3.0中包含了许多不兼容的变化,这意味着在迁移到3.0之前,必须进行代码更改和测试。本文将介绍主要的差异,并给出一些实例来说明不同点。...
2023-12-18 Python编程
34

python如何在终端里面显示一张图片
要在终端里显示图片,需要使用一些Python库。其中一种流行的库是Pillow,它有一个子库PIL.Image可以加载和处理图像文件。要在终端中显示图像,可以使用如下的步骤:...
2023-12-18 Python编程
91

Python图像处理实现两幅图像合成一幅图像的方法【测试可用】
在Python中,我们可以使用Pillow库来进行图像处理。具体实现两幅图像合成一幅图像的方法如下:...
2023-12-18 Python编程
103