图像的二值化或阈值化(Binarization)旨在提取图像中的目标物体,将背景以及噪声区分开来。通常会设定一个阈值T,通过T将图像的像素划分为两类:大于T的像素群和小于T的像素群。
灰度转换处理后的图像中,每个像素都只有一个灰度值,其大小表示明暗程度。二值化处理可以将图像中的像素划分为两类颜色,常用的二值化算法如公式1所示:
{Y=0,gray<TY=255,gray>=T
{Y=0,gray<TY=255,gray>=T"text-align: center">
二进制阈值化
该方法先要选定一个特定的阈值量,比如127
1) 大于等于127的像素点的灰度值设定为最大值
2) 灰度值小于127的像素点的灰度值设置为0
例如: 156->255 89->0
关键字为cv2.THRESH_BINARY,完整代码如下
import cv2 def test22(): src = cv2.imread("rose.jpg") # 灰度图片转换 GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA) # 二进制阈值化处理 r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_BINARY) # 显示图像 cv2.imshow("src", src) cv2.imshow("result", b) if cv2.waitKey(0) == 27: cv2.destroyAllWindows() test22()
效果如下:
反二进制阈值化
该方法与二进制阈值化方法相似,先要选定一个特定的灰度值作为阈值,比如127
1) 大于127的像素点的灰度值设定为0
2) 小于该阈值的灰度值设定为255
例如:156->0 89->255
关键字为cv2.THRESH_BINARY_INV
代码如下:
import cv2 def test22(): src = cv2.imread("rose.jpg") # 灰度图片转换 GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA) # 二进制阈值化处理 r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_BINARY_INV) # 显示图像 cv2.imshow("src", src) cv2.imshow("result", b) if cv2.waitKey(0) == 27: cv2.destroyAllWindows() test22()
效果如下:
截断阈值化
该方法需要选定一个阈值,图像中大于该阈值的像素点被设定为该阈值,小于该阈值的保持不变。
1) 大于等于127像素点的灰度值设定为该阈值127
2) 小于该阈值的灰度值不变
例如: 163-> 127 89->89
关键字cv2.THRESH_TRUNC,完整代码如下
import cv2 def test22(): src = cv2.imread("rose.jpg") # 灰度图片转换 GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA) # 二进制阈值化处理 r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_TRUNC) # 显示图像 cv2.imshow("src", src) cv2.imshow("result", b) if cv2.waitKey(0) == 27: cv2.destroyAllWindows() test22()
效果如下:
反阈值化为0
该方法先选定一个阈值,比如127
(1) 大于等于阈值127的像素点变为0
(2) 小于该阈值的像素点值保持不变
例如: 128->0 89->89
关键字为cv2.THRESH_TOZERO_INV,完整代码如下:
import cv2 def test22(): src = cv2.imread("rose.jpg") # 灰度图片转换 GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA) # 二进制阈值化处理 r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_TOZERO_INV) # 显示图像 cv2.imshow("src", src) cv2.imshow("result", b) if cv2.waitKey(0) == 27: cv2.destroyAllWindows() test22()
效果如下:
阈值为0
该方法先选定一个阈值,比如127
(1) 大于等于阈值127的像素点,值保持不变
(2) 小于该阈值的像素点值设置为0
例如: 163->163 102->0
关键字为cv2.THRESH_TOZERO,完整代码如下:
import cv2 def test22(): src = cv2.imread("rose.jpg") # 灰度图片转换 GrayImage = cv2.cvtColor(src, cv2.COLOR_BGR2BGRA) # 二进制阈值化处理 r, b = cv2.threshold(GrayImage, 127, 255, cv2.THRESH_TOZERO) # 显示图像 cv2.imshow("src", src) cv2.imshow("result", b) if cv2.waitKey(0) == 27: cv2.destroyAllWindows() test22()
效果如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
更新日志
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]