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

下面是详细讲解“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日

相关文章

  • 利用Python自动化生成爱豆日历详解

    下面我将为你详细讲解利用Python自动化生成爱豆日历的完整攻略。 1. 准备工作 在开始之前,我们需要准备以下工具和文件: Python3:我们将使用Python3来编写代码。 中国节假日日历文件:如果需要在爱豆日历上标注节假日等特殊日期,可以使用中国节假日日历文件(例如:https://github.com/holidayjapan/chinese-ca…

    python 2023年5月19日
    00
  • Python中常用的字典键和值排的方法

    下面是详细讲解Python中常用的字典键和值排的方法的完整攻略: 1. 字典键排序 1.1. sorted函数 可以使用sorted函数来按照字典键进行排序。sorted函数可以接收一个字典作为参数,并利用其中的键来进行排序。 示例代码: my_dict = {‘apple’: 34, ‘banana’: 20, ‘orange’: 16, ‘peach’:…

    python 2023年5月13日
    00
  • Python 虚拟机集合set实现原理及源码解析

    Python 虚拟机集合 set 实现原理及源码解析 什么是 set set 是 Python 中的一种基本数据类型,用于存储无序、不重复的元素集合。set 的特点是: 无序性:set 中没有元素的顺序关系。 互异性:set 中的元素都是唯一的,重复的元素会被自动忽略。 set 中可以存储任意类型的数据,例如数字、字符串、元组等不可变类型,但是不能存储可变类…

    python 2023年6月7日
    00
  • python调用c++ ctype list传数组或者返回数组的方法

    以下是“Python调用C++ ctypes传数组或者返回数组的方法”的完整攻略。 1. 传递数组 在Python中,可以使用ctypes库调用C++函数,并递数组作为参数。以下是一个简单例。 示例1:传递整型数组 设我们有一个名为my_array的整型数组,我们想要将其传递给C++。我们可以使用以下代码来实现。 import ctypes # 加载动态链接…

    python 2023年5月13日
    00
  • Python Tkinter Canvas画布控件详解

    Python Tkinter Canvas是一个非常强大的绘图工具,能够让用户轻松创建图形界面应用程序。下面我们来详细探讨一下Tkinter Canvas画布控件的详细使用方法。 Canvas的基本使用 Canvas是用于绘制图形的画布控件,在程序中引用如下: from tkinter import * root = Tk() canvas = Canvas…

    python 2023年6月13日
    00
  • Python操作Excel之xlsx文件

    下面我会详细讲解Python操作Excel之xlsx文件的完整实例教程,让你学会基本的Excel操作。 一、安装必要的库 在Python操作Excel之前,我们需要先安装两个必要的库:openpyxl和pandas。 1.1 安装openpyxl openpyxl是一个Python库,用于读取和写入Excel 2010 xlsx /xlsm /xltx /x…

    python 2023年5月13日
    00
  • Python3.10新特性之match语句示例详解

    Python 3.10新特性之match语句示例详解 Python 3.10带来了许多新的特性和语法糖,其中一项比较引人注目的是match语句。 match语句是Python 3.10中新增的一种模式匹配语句,它可以取代一些情况下使用if语句的方式,使得代码更加简洁易读。本文将详细讲解match语句的使用方法和示例。 基本语法 下面是match语句的基本语法…

    python 2023年5月14日
    00
  • Python入门之模块与包

    Python入门之模块与包 当我们编写代码时,有些功能需要在多个程序中使用,为了不重复写代码,我们可以将这些功能封装到一个单独的.py文件中,然后在需要使用这些功能的程序中 import 这个文件,这个文件就称为模块(module),而多个模块放在一个文件夹中,这个文件夹就是一个包(package)。 定义模块 定义一个模块很简单,我们只需要在文件中编写我们…

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