目录
简述
1. 什么是二值化
2. 二值化接口
2.1 参数说明
2.2 示例代码
2.3 运行结果
3. 自适应阈值
3.1 参数说明
3.2 示例代码
3.3 运行结果
4. 总结
4.1 二值化
4.2 自适应阈值
相关阅读
OpenCV:图像的腐蚀与膨胀-CSDN博客
简述
图像二值化是图像处理中的基础操作,它将图像中的像素分为两类:前景和背景。二值化在很多图像分析任务中非常重要,如目标检测、形态学操作等。自适应阈值作为一种常用的阈值选择方法,可以根据图像局部的特性动态调整阈值,尤其适用于照明不均匀或噪声较多的图像。本文将详细介绍 OpenCV 中的二值化、自适应阈值以及相关接口的使用。
1. 什么是二值化
二值化是图像处理中一种简单的图像分割方法,其目标是将灰度图像转换成黑白图像。具体来说,它通过一个阈值将每个像素的灰度值与该阈值进行比较,如果像素值大于该阈值,则将其置为最大值(通常是 255);如果小于阈值,则将其置为最小值(通常是 0)。这样,图像就只有两种颜色:黑色和白色。
二值化的基本步骤:
- 将图像转换为灰度图像。
- 设置一个全局阈值,通常范围为 0 到 255。
- 根据阈值将图像分为两类:高于阈值的像素设置为白色(255),低于阈值的像素设置为黑色(0)。
2. 二值化接口
在 OpenCV 中,cv2.threshold 是实现二值化的函数。其基本语法如下:
retval, dst = cv2.threshold(src, thresh, maxval, type)
2.1 参数说明
- src: 输入图像,必须是灰度图像。
- thresh: 阈值,用于图像分割。
- maxval: 高于阈值的像素值设置为 maxval。
- type: 阈值类型,控制如何应用阈值,有多个选项:
cv2.THRESH_BINARY | 简单二值化,像素值大于阈值时为最大值,小于阈值时为 0。 |
cv2.THRESH_BINARY_INV | 与 cv2.THRESH_BINARY 相反。 |
cv2.THRESH_TRUNC | 大于阈值的像素被截断为阈值值。 |
cv2.THRESH_TOZERO | 大于阈值的像素保持不变,小于阈值的像素置为 0。 |
cv2.THRESH_TOZERO_INV | 与 cv2.THRESH_TOZERO 相反。 |
2.2 示例代码
import cv2
import numpy as np# 读取图像并转换为灰度图
image = cv2.imread('D:\\resource\\qt.jpg')
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# 设置阈值和最大值
thresh_value = 127
max_value = 255# 进行二值化操作
_, binary_image = cv2.threshold(gray_image, thresh_value, max_value, cv2.THRESH_BINARY)# 显示结果
cv2.imshow('Image', image)
#cv2.imshow('Gray Image', gray_image)
cv2.imshow('Binary Image', binary_image)
cv2.waitKey(0)
cv2.destroyAllWindows()
2.3 运行结果
说明:
- 原始图像:灰度图像
- 二值化结果:基于阈值 127 将图像转换为黑白图像。
3. 自适应阈值
在一些图像中,亮度和对比度可能在不同区域有很大变化,这使得使用全局阈值进行二值化变得不太有效。为了解决这个问题,OpenCV 提供了 自适应阈值 技术,它通过为每个像素选择局部阈值来进行二值化。
自适应阈值的计算方法是根据每个像素周围的邻域像素值来决定该像素的阈值。这对于光照不均匀的图像非常有用。
自适应阈值的基本方法:
- 局部区域:将图像分为小区域(通常是一个方块或矩形),对每个小区域计算阈值。
- 方法选择:常用的两种方法是计算局部区域的均值 和 使用高斯加权平均来计算局部区域的阈值。
OpenCV 中的 cv2.adaptiveThreshold 函数
cv2.adaptiveThreshold(src, maxValue, adaptiveMethod, thresholdType, blockSize, C)
3.1 参数说明
- src: 输入图像,必须是灰度图。
- maxValue: 输出图像的最大值,通常为 255。
- adaptiveMethod: 自适应方法,常用的有:
- cv2.ADAPTIVE_THRESH_MEAN_C: 使用局部区域的均值作为阈值。
- cv2.ADAPTIVE_THRESH_GAUSSIAN_C: 使用局部区域的高斯加权均值作为阈值。
- thresholdType: 阈值类型,通常为 cv2.THRESH_BINARY 或 cv2.THRESH_BINARY_INV。
- blockSize: 计算阈值时使用的邻域大小,必须是奇数。
- C: 常数,表示阈值的调整项,用于减去均值或高斯加权均值。
3.2 示例代码
import cv2
import numpy as np# 读取图像并转换为灰度图
image = cv2.imread('D:\\resource\\qt.jpg')
gray_image = cv2.cvtColor(image, cv2.COLOR_BGR2GRAY)# 设置阈值和最大值
thresh_value = 127
max_value = 255# 应用自适应阈值
result_adaptive = cv2.adaptiveThreshold(gray_image, 255, cv2.ADAPTIVE_THRESH_MEAN_C,cv2.THRESH_BINARY, 11, 2)# 显示结果
cv2.imshow('Image', image)
#cv2.imshow('Gray', gray_image)
cv2.imshow('Adaptive', result_adaptive)
cv2.waitKey(0)
cv2.destroyAllWindows()
3.3 运行结果
说明:
- 原始图像:灰度图像
- 自适应阈值结果:基于每个小区域计算阈值,从而解决了全局阈值方法无法处理的光照不均匀问题。
4. 总结
4.1 二值化
- 使用全局阈值将图像转换为黑白图像,适用于光照均匀或噪声较少的图像。
- OpenCV 提供的 cv2.threshold 函数能够方便地实现这种操作。
4.2 自适应阈值
- 对于光照不均匀或噪声较多的图像,自适应阈值方法会动态调整每个像素的阈值,适应不同区域的局部光照。
- OpenCV 提供的 cv2.adaptiveThreshold 函数能够根据局部区域计算阈值,常用于图像处理和文字识别等任务。
这两种方法在图像处理、图像分割、OCR(光学字符识别)等场景中都有广泛应用。通过调整阈值和自适应方法的参数,可以实现更加精确的二值化效果。