pyhton +opencv图像处理(十五)——图像二值化

本文详细介绍了图像处理中的二值化技术,包括全局阈值、局部阈值和自定义阈值方法。通过OpenCV库的函数实现不同类型的二值化,如THRESH_BINARY、THRESH_OTSU和自适应阈值ADAPTIVE_THRESH_MEAN_C,展示了如何选择合适的阈值以优化图像分割效果。

二值图像(Binary Image)
彩色图像:三个通道:0-255,0-255,0-255,有2^24位空间
灰度图像:一个通道:0-255,共有256种颜色
二值图像:只有两种颜色,黑色和白色(0和1)

图像二值化方法:
1、全局阈值
2、局部阈值

from matplotlib import pyplot as plt 
from cv2 import cv2 as cv
import numpy as np 

# 整体阈值
def threshold_demo(image):
    gray = cv.cvtColor(image,cv.COLOR_BGR2GRAY)  # 变成灰度图像
    #ret,binary = cv.threshold(gray,0,255,cv.THRESH_BINARY|cv.THRESH_OTSU)# 这个好一点
    #ret,binary = cv.threshold(gray,0,255,cv.THRESH_BINARY|cv.THRESH_TRIANGLE)#三角阈值法
    ret,binary = cv.threshold(gray,127,255,cv.THRESH_BINARY)   # 自己指定阈值 为127
    # 还有其他方法
    '''
    OpenC的threshold函数进行全局阈值。其函数原型为:threshold(src, thresh, maxval, type[, dst]) -> retval, dst
    src参数表示输入图像(多通道,8位或32位浮点)。
    thresh参数表示阈值。
    maxval参数表示与THRESH_BINARY和THRESH_BINARY_INV阈值类型一起使用设置的最大值。
    type参数表示阈值类型。
    retval参数表示返回的阈值。若是全局固定阈值算法,则返回thresh参数值。若是全局自适应阈值算法,则返回自适应计算得出的合适阈值。
    dst参数表示输出与src相同大小和类型以及相同通道数的图像。
    '''    
    print("threshold value %s "%ret)
    cv.imshow("binary",binary)
    

# 局部阈值(自适应阈值)
def local_threshold(image):
    gray = cv.cvtColor(image,cv.COLOR_BGR2GRAY)
    dst = cv.adaptiveThreshold(gray,255,cv.ADAPTIVE_THRESH_MEAN_C,cv.THRESH_BINARY,25,10)
    # 还有其他的方法
    cv.imshow("local_threshold",dst)

# 自己计算阈值
def custom_threshold(image):
    gray = cv.cvtColor(image,cv.COLOR_RGB2GRAY)   #要二值化图像,要先进行灰度化处理
    h,w = gray.shape[:2]  #求宽高
    m = np.reshape(gray,[1,w*h])    #将图像转一维数组,一行,w*h列,转换维度要保证其size不变
    mean = m.sum() / (w*h)  #求平均值来当做阈值,来分割图像
    print("mean :",mean)
    ret,binary = cv.threshold(gray,mean,255,cv.THRESH_BINARY)
    cv.imshow("custom_threshold",binary)
    cv.imwrite("C:\\pictures\\123.jpg",binary) # 存图

if __name__ == "__main__":
	filepath = "C:\\pictures\\012345.jpg"
	img = cv.imread(filepath)       # blue green red
	cv.namedWindow("input image",cv.WINDOW_AUTOSIZE)
	cv.imshow("input image",img)
	
	# threshold_demo(img)
	# local_threshold(img)
	custom_threshold(img)
	'''
	# 图片相与
	img1 = cv.imread("C:\\pictures\\123.jpg")
	dst = cv.bitwise_and(img,img1)
	cv. imshow("and",dst)
	'''
	cv.waitKey(0)
	cv.destroyAllWindows()

二值化后的图像,其中一个函数例子,效果不太好
在这里插入图片描述
THRESH_OTSU(大律法)和THRESH_TRIANGLE(三角形)都是自动获取阈值

自己直接指定阈值:
①THRESH_BINARY_INV 大于阈值的都为0
②THRESH_TRUNC 截断大于127的值都为127
③THRESH_TOZERO 小于阈值为0
cv.THRESH_TRIANGLE类型(有丢失)适用于单个波峰
cv.THRESH_OTSU类型最适用于双波峰

局部阈值:
cv.ADAPTIVE_THRESH_GAUSSIAN_C轮廓更加清晰


adaptiveThreshold方法:
adpativeThreshold(src,maxValue,adaptiveMerhod,thersholdType,blockSize,C[,dst])
src:表示输入图像(8位单通道图像)

maxValue:表示使用THRESH_BINARY和THRESH_BINARY_INV的最大值

adaptiveMerhod:表示自适应阈值算法,平均(ADAPTIVE_THRESH_MEAN_C)或高斯(ADAPTIVE_THRESH_GAUSSIAN_C)

thersholdType:表示阈值类型,必须为THRESH_BINARY或THRESH_BINARY_INV的类型

blockSize:表示块大小(奇数且大于1)

C:常数,表示平均值或加权平均值中减去的数,通常情况下是正值,但也有可能为零或负值


reshape方法:
numpy的reshape函数是给数组一个新的形状而不改变其数据

reshape(a,newshape,oeder=‘C’)
a:表示需要重新形成的原始数组

newshape:表示int或int类型数组(taple),若为(1,3)表示生成的新数组是1行3列

order:表示使用此索引顺序读取a的元素,并使用此索引顺序将元素放置到新形成的数组中

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

xiao黄

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值