python3 opencv 图像二值化笔记(cv2.adaptiveThreshold)

前一篇研究了opencv二值化方法threshold的使用,但是这个方法也存在一定的局限性,假如有一张图存在明显的明暗不同的区域,如下图

可以看到左边部分因为整体偏暗,导致二值化后变成全黑,丢失了所有细节,这显然不是我们想要的结果。

原因threshold函数使用一个阈值对图像进行二值化,导致小于这个阈值的像素点全都变成0。因此使用一个阈值的二值化方法并不适用于上面的这张图。那怎么搞?

很明显,上面这张图只有左右两个区域明显亮度不同,最简单的方法就是把图分成两个区域,每个区域分别进行二值化,也就是说二值化上面这张图需要两个不同的阈值。那如果亮度不同的地方有三个,四个或者更多呢?那就每个区域用一个阈值来进行二值化。按照这个思想,因此有了cv2.adaptiveThreshold函数。

先看一下adaptiveThreshold二值化的使用效果。

明显还是有效果的,至少左边部分不是全黑。

接下来简单说一下adaptiveThreshold方法

cv2.adaptiveThreshold(src, maxValue, adaptiveMethod, thresholdType, blockSize, C, dst=None)

这个函数大致意思就是把图片每个像素点作为中心取N*N的区域,然后计算这个区域的阈值,来决定这个像素点变0还是变255

src:需要进行二值化的一张灰度图像

maxValue:满足条件的像素点需要设置的灰度值。(将要设置的灰度值)

adaptiveMethod:自适应阈值算法。可选ADAPTIVE_THRESH_MEAN_C 或 ADAPTIVE_THRESH_GAUSSIAN_C

thresholdType:opencv提供的二值化方法,只能THRESH_BINARY或者THRESH_BINARY_INV

blockSize:要分成的区域大小,上面的N值,一般取奇数

C:常数,每个区域计算出的阈值的基础上在减去这个常数作为这个区域的最终阈值,可以为负数

dst:输出图像,可以忽略

前两个参数与threshold的src和maxval一样相同

第三个参数adaptiveMethod

提供两种不同的计算阈值的方法,按照网上其他大佬的解释

ADAPTIVE_THRESH_MEAN_C,为局部邻域块的平均值,该算法是先求出块中的均值。

ADAPTIVE_THRESH_GAUSSIAN_C,为局部邻域块的高斯加权和。该算法是在区域中(x, y)周围的像素根据高斯函数按照他们离中心点的距离进行加权计算。

 第四个参数thresholdType

只能THRESH_BINARY或者THRESH_BINARY_INV

第5个参数blockSize

上述算法计算邻域时的领邻域大小,一般选择为3、5、7......等

第6个参数C

每个邻域计算出阈值后再减去C作为最终阈值

演示一下blockSize和C对二值化结果的影响,以THRESH_BINARY,ADAPTIVE_THRESH_GAUSSIAN_C为例

blockSize=3,C=1

blockSize=25,C=1
blockSize=3,C=10

blockSize=15,C=10

blockSize=15,C=21
blockSize=15,C=1

blockSize=15,C=1

 可以看到,当blockSize越大,参与计算阈值的区域也越大,细节轮廓就变得越少,整体轮廓越粗越明显

当C越大,每个像素点的N*N邻域计算出的阈值就越小,中心点大于这个阈值的可能性也就越大,设置成255的概率就越大,整体图像白色像素就越多,反之亦然。

这种二值化有点类似canny边缘检测,用来找轮廓或者特征点也挺不错。

import cv2
import numpy as np

blocksize = 3
C=0
def adaptive_demo(gray, blocksize, C):
    binary = cv2.adaptiveThreshold(gray, 255, cv2.ADAPTIVE_THRESH_GAUSSIAN_C, cv2.THRESH_BINARY, blocksize, C)
    # binary = cv2.GaussianBlur(binary, (15,15), 0)
    cv2.imshow('binary', binary)

def C_changed(value):
    global gray
    global blocksize
    global C
    C = value - 30
    print('C:', C)
    adaptive_demo(gray, blocksize, C)

def blocksize_changed(value):
    global gray
    global blocksize
    global C
    blocksize = 2 * value + 1

    print('blocksize:', blocksize)
    adaptive_demo(gray, blocksize, C)

if __name__ == "__main__":
    image_path = './img/1.jpg'
    img = cv2.imread(image_path)

    gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)

    adaptive_demo(gray, 3, 0)
    cv2.createTrackbar('C', 'binary',0, 60, C_changed)
    cv2.createTrackbar('blocksize', 'binary',1, 20, blocksize_changed)

    cv2.waitKey(0)

### 回答1: cv2.adaptiveThreshold() 是 OpenCV 中的一个函数,可以用来对图像进行自适应阈值处理。该函数的参数包括输入图像、输出图像的最大值、阈值类型、自适应方法和自适应块大小。通过调整这些参数,可以获徖不同的图像二值化效果。 ### 回答2: cv2.adaptivethresholdOpenCV中的一个方法,用于对图像进行自适应阈值分割。该方法可以根据图像的局部区域来计算阈值,从而更好地适应图像的不同部分的亮度差异。 该方法的语法为: cv2.adaptivethreshold(src, maxValue, adaptiveMethod, thresholdType, blockSize, C) - src: 输入的灰度图像。 - maxValue: 输出像素的最大值。如果某个像素的灰度值超过最大值,则该像素被置为最大值。 - adaptiveMethod: 自适应方法的类型。有两种可选类型:cv2.ADAPTIVE_THRESH_MEAN_C和cv2.ADAPTIVE_THRESH_GAUSSIAN_C。前者是邻域内像素的均值作为阈值,后者是邻域内像素的高斯加权和作为阈值。 - thresholdType: 阈值的类型。有两种可选类型:cv2.THRESH_BINARY和cv2.THRESH_BINARY_INV。前者将大于阈值的像素置为最大值,后者则相反。 - blockSize: 用于计算阈值的像素邻域大小,一般为奇数。 - C: 从均值或加权和中减去的常数,用于调整阈值。 使用cv2.adaptivethreshold方法,可以通过分析局部像素的亮度差异,在不同区域上动态地计算出阈值,从而实现较好的图像分割效果。这对于有光照变化或者对比度较低的图像来说,可以提升分割的准确性。 需要注意的是,该方法只能处理灰度图像。如果要处理彩色图像,需要将其转换为灰度图像后再使用。 ### 回答3: cv2.adaptivethresholdOpenCV中的一个函数,用于对图像进行自适应阈值处理。 自适应阈值处理是一种根据图像的局部区域灰度值计算阈值的方法,可以有效地处理光照不均匀的图像。 函数的基本语法为: retval, threshold_img = cv2.adaptiveThreshold(src, max_value, adaptive_method, threshold_type, block_size, c) 参数说明: - src:输入图像,必须为单通道灰度图像。 - max_value:像素值超过阈值时设定的最大值。 - adaptive_method:自适应方法,可选的有cv2.ADAPTIVE_THRESH_MEAN_C和cv2.ADAPTIVE_THRESH_GAUSSIAN_C。前者用邻域内像素的平均值作为阈值,后者用邻域内像素的高斯加权和作为阈值。 - threshold_type:阈值化类型,可选的有cv2.THRESH_BINARY和cv2.THRESH_BINARY_INV。前者表示当像素值超过阈值时设定为max_value,否则为0;后者则相反。 - block_size:邻域大小,用于计算阈值的局部窗口大小(必须是奇数)。 - c:常数值,从阈值计算结果减去的常数。 函数将返回一个阈值化图像和一个返回值,返回值表示在该函数上执行的操作。阈值化图像将使用自适应阈值处理生成。 使用cv2.adaptivethreshold函数可以有效地处理光照不均匀的图像,得到清晰的目标轮廓。根据不同的自适应方法和阈值类型的选择,可以得到不同的阈值化效果,便于后续图像处理、目标检测等应用。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值