CV2逐步学习-3:cv2.threshold()二值化详解

1.官方文档:在这里插入图片描述

从官方文档分析:

2.函数定义
cv2.threshold (src, thresh, maxval, type)
3.Args:
  1. src:源图像矩阵,单通道,8 位或 32 位浮点数据
    注意!:这里的单通道应是指.threshold()对图像处理时按单通道依次进行处理,待处理图像矩阵可以是单通道8位图像矩阵,也可以是32为RGBA图像矩阵,具体看下方实验(这里差点搞错,误以为该函数只能处理单通道图像矩阵,感谢 小伙伴提醒!!
    A是Alpha色彩空间:
      alpha通道一般用作不透明度参数。如果一个像素的alpha通道数值为0%,那它就是完全透明的(也就是看不见的),而数值为100%则意味着一个完全不透明的像素(传统的数字图像)。在0%和100%之间的值则使得像素可以透过背景显示出来,就像透过玻璃(半透明性),这种效果是简单的二元透明性(透明或不透明)做不到的。它使数码合成变得容易。alpha通道值可以用百分比、整数或者像RGB参数那样用0到1的实数表示。

  2. thresh:阈值,取值范围0~255

  3. maxval:与阈值类型配合使用的最大值,可理解为填充色,取值范围0~255

  4. type:阈值类型

4.返回值
  1. ret:即我们设置的阈值,此处并没有没有使用,但在自适应二值化中会使用到
  2. dst:二值化后的像素矩阵,与原像素矩阵同规格
4.函数解释(官方)

  该函数将固定级别阈值应用于单通道阵列。该函数通常用于从灰度图像中获取双层(二进制)图像(compare() 也可用于此目的)或用于去除噪声,即滤除过小或过大的像素值。该函数支持多种类型的阈值

  这里说的支持多种阈值即阈值类型的多种选取

5.五种阈值类型

  由上方官方文档截图:

阈值类型小于等于阈值的像素点大于阈值的像素点
THRESH_BINARY置0置maxval
THRESH_BINARY_INV置maxval置0
THRESH_TRUNC保持原样阈值
THRESH_TOZERO置0保持原样
THRESH_TOZERO_INV保持原样置0

实验:
选取阈值为50,maxal为100
实验一:读入单通道图像矩阵
原图:
在这里插入图片描述

import cv2
img=cv2.imread('aima_gray.jpg',0)
#cv2.imshow('img',img)
##这里的ret返回的是设置的阈值,此处为50
ret1,img1=cv2.threshold(img,50,100,cv2.THRESH_BINARY)
ret2,img2=cv2.threshold(img,50,100,cv2.THRESH_BINARY_INV)
ret3,img3=cv2.threshold(img,50,100,cv2.THRESH_TRUNC)
ret4,img4=cv2.threshold(img,50,100,cv2.THRESH_TOZERO)
ret5,img5=cv2.threshold(img,50,100,cv2.THRESH_TOZERO_INV)

cv2.imshow('THRESH_BINARY',img1)
cv2.imshow('THRESH_BINARY_INV',img2)
cv2.imshow('THRESH_TRUNC',img3)
cv2.imshow('THRESH_TOZERO',img4)
cv2.imshow('THRESH_TOZERO_INV',img5)
cv2.waitKey(0)

结果:(痛心,可怜的Emma Watson面目全非)
在这里插入图片描述
实验二:读入32位RGBA彩色图进行处理

.threshold() 处理彩色图像的机制说明如下:
  如果是32位彩色图像,则是以RGB每个通道的值单独与阈值进行比较,按每个通道进行阈值处理,返回的是一个阈值处理后的RGB各自的值,即还是32位图像。

原图:
在这里插入图片描述
代码:

import cv2
img=cv2.imread('aima.jpg')
#cv2.imshow('img',img)

ret1,img1=cv2.threshold(img,50,100,cv2.THRESH_BINARY)
ret2,img2=cv2.threshold(img,50,100,cv2.THRESH_BINARY_INV)
ret3,img3=cv2.threshold(img,50,100,cv2.THRESH_TRUNC)
ret4,img4=cv2.threshold(img,50,100,cv2.THRESH_TOZERO)
ret5,img5=cv2.threshold(img,50,100,cv2.THRESH_TOZERO_INV)

#观察图像矩阵形状
print('img_size',img.shape)
print('img1_size',img1.shape)
print('img2_size',img2.shape)
print('img3_size',img3.shape)
print('img4_size',img4.shape)
print('img5_size',img5.shape)

cv2.imshow('THRESH_BINARY',img1)
cv2.imshow('THRESH_BINARY_INV',img2)
cv2.imshow('THRESH_TRUNC',img3)
cv2.imshow('THRESH_TOZERO',img4)
cv2.imshow('THRESH_TOZERO_INV',img5)
print(ret1,ret2)
cv2.waitKey(0)

观察处理后图像及程序输出:
在这里插入图片描述
程序输出:处理前后图像均为三通道
在这里插入图片描述
观察函数是否对RGB均进行处理
  在五副处理过的图中抽取两副,选取同一可对比像素点进行对比,如选取点(187,191),观察RGB数值
  如图我们可以看到,确实是对RGB三通道分别进行了处理
(再次感谢评论区这位小伙伴,感谢!)

在这里插入图片描述
在这里插入图片描述

### CentOS 镜像中 README 文件的作用 README 文件通常作为文档的一部分,在操作系统或软件包的分发过程中起到指导和说明的作用。对于 CentOS 的镜像而言,其 README 文件的主要意义在于提供关于该版本的操作系统的关键信息以及安装指南。 #### 1. 提供版本信息 README 文件会明确指出当前镜像是哪个具体版本的 CentOS,例如 `CentOS Linux release 7.9.2009 (Core)`[^1]。这有助于用户确认所下载的是正确的发行版,并了解与其兼容的硬件和软件环境。 #### 2. 描述安装前准备事项 在实际部署之前,用户可能需要完成一些必要的准备工作,比如安装工具 Git 或者其他依赖项。这些内容往往会在 README 中有所提及,帮助新手快速上手。 #### 3. 解决常见问题 针对可能出现的问题,如文件上传验证通过后的反馈机制——返回文件名表示成功[^2];或者如何正确配置服务端口映射等复杂场景下的解决方案也可能被记录下来以便查阅。 #### 4. 列举第三方库源地址 有时为了扩展功能,官方文档还会给出获取额外资源的方法论实例:“`wget http://downloads.sourceforge.net/tcl/tcl8.6.1-src.tar.gz`” 就是用来示范怎样从外部站点拉取所需组件的例子之一[^3]。 #### 5. 展示高级设置教程 除了基本操作外,更深入的技术细节也会包含其中,例如为了让 NVM 成为全局变量而修改特定路径下的脚本文件 `/etc/profile.d/nvm.sh` [^4] ,或者是利用 FTP 协议传输大容量数据时推荐采用 Binary Mode 来保持文件完整性[^5]。 综上所述,README 不仅是一个简单的介绍性文本,更是连接开发者与最终用户的桥梁,它承载着丰富的背景资料和技术支持,使得整个安装过程更加顺畅高效。 ```bash # 示例命令展示如何查看本地是否存在类似的 readme 文档 ls /path/to/your/downloaded/image/*.txt | grep -i "readme" cat /path/to/found/readme.txt ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

涛涛ALG

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

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

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

打赏作者

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

抵扣说明:

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

余额充值