news 2026/4/18 7:31:07

OpenCV 学习9-灰度转黑白二值图像

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
OpenCV 学习9-灰度转黑白二值图像

1、为什么需要图像二值化?

场景说明
文字识别(OCR)当需要提取图片(比如扫描的文件、发票图片、身份证)中的文字内容时,将图像二值化后,提高字符边缘清晰度,减少背景干扰,用于给OCR程序 识别
条形码 / 二维码识别快速识别黑白条纹图案
医学图像处理比如X光片中提取骨骼轮廓
目标检测与分割定位图像中的特定区域,可用于质检环节检测缺陷区域

将复杂的灰度或彩色图像简化为只有黑白两种状态的图像(0 和 255)

图像二值化可达到 “化繁为简”,在保留关键结构的同时去除冗余信息,在 OCR、目标分割、形态学处理等场景中非常有效。
当需要从图像中快速提取有|没有在哪里信息时,就可以尝试使用二值化处理。

2、图像二值化(Binarization)函数 cv2.threshold()

cv2.threshold() 是 OpenCV的图像二值化函数,将灰度图像转换为黑白二值图像。
通过设定一个阈值(threshold),将像素点分为两类:

  • >阈值为某一个值(如 255,白色)
  • ≤ 阈值为另一值(如 0,黑色)

2.1 函数定义

retval, dst = cv2.threshold(src, thresh, maxval, type)
  • 返回值
    dst:新的二值图像
    retval: 实际使用的阈值
  • 参数说明
参数类型说明
srcNumPy 数组必须是灰度图像
threshfloat设定的阈值,比如128
maxvalfloat当像素满足条件时,设置的最大值(通常为 255)
typeint阈值类型
  • 阈值类型 type 说明
类型名称含义
cv2.THRESH_BINARY二进制阈值化if pixel > thresh: 255 else 0
cv2.THRESH_BINARY_INV反向二进制if pixel > thresh: 0 else 255
cv2.THRESH_TRUNC截断if pixel > thresh: thresh else pixel
cv2.THRESH_TOZERO低于阈值清零if pixel <= thresh: 0 else pixel
cv2.THRESH_TOZERO_INV高于阈值清零if pixel > thresh: 0 else pixel
cv2.THRESH_OTSU自动计算最优阈值(基于 Otsu 算法)需和上述类型 按位或组合使用,
如cv2.THRESH_BINARY + cv2.THRESH_OTSU

2.2 OTSU

OTSU(大津算法) 是一种经典的自动图像二值化方法,用于在灰度图像中自动选择最佳阈值,将图像分为前景和背景两部分。由日本学者 大津展之(Nobuyuki Otsu) 1979年提出。

算法解决的主要问题是:在不知道阈值的情况下,如何自动找出一个“最优”阈值来分割图像?

OTSU 算法的思路是:
最大化类间方差(Between-class Variance),让前景(目标)和背景之间的差异尽可能大,从而使分割最清晰。

2.3 代码示例

importcv2importnumpyasnpimportos# 1.读取图像img_path="img/dog.jpg"ifnotos.path.exists(img_path):raiseFileNotFoundError(f"未找到图像文件{img_path}")img=cv2.imread(img_path,cv2.IMREAD_GRAYSCALE)thresh,img1=cv2.threshold(img,128,255,cv2.THRESH_BINARY)cv2.imshow("Original",img)cv2.imshow("threshold",img1)cv2.waitKey(0)cv2.destroyAllWindows()

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/9 9:52:53

初级会计实务第二章真题汇编(含完整选项 + 答案 + 解析)

一、会计要素的计量属性相关真题&#xff08;一&#xff09;单选题&#xff08;2025 年&#xff09;题目&#xff1a;下列各项中&#xff0c;企业应采用重置成本计量的是&#xff08; &#xff09;A. 存货减值B. 固定资产减值C. 固定资产盘盈D. 固定资产盘亏答案&#xff1a;C解…

作者头像 李华
网站建设 2026/4/16 14:04:40

职业迷茫与协议化服务助力发展

毕业后的三年时光&#xff0c;许多人会经历从校园到职场的转变&#xff0c;但并非所有人都能顺利找到方向。面对职业发展的迷茫与不确定性&#xff0c;一部分人选择通过系统化的职业规划服务来重新定位自己的人生路径。在这一过程中&#xff0c;专业的人才服务平台发挥了关键作…

作者头像 李华
网站建设 2026/4/9 13:21:18

15-1.【Linux系统编程】进程信号 - 信号的产生(信号概念、自定义信号捕捉singal函数、前台/后台进程、系统调用kill发送信号)

目录1. 认识信号2. 信号的产生方式2.1 通过键盘给终端发送信号2.1.1 信号都有哪些2.1.2 自定义信号捕捉singal()函数&#xff08;证明ctrlc是2号信号编号&#xff09;2.1.3 前台进程(目标进程)&后台进程2.1.补&#xff1a;前后台相关命令2.1.4 给进程发送信号2.2 系统调用发…

作者头像 李华
网站建设 2026/4/16 11:59:02

baseimage-docker:专为容器环境优化的Ubuntu基础镜像实践指南

baseimage-docker&#xff1a;专为容器环境优化的Ubuntu基础镜像实践指南 【免费下载链接】baseimage-docker A minimal Ubuntu base image modified for Docker-friendliness 项目地址: https://gitcode.com/gh_mirrors/ba/baseimage-docker 在容器化技术日益普及的今天…

作者头像 李华
网站建设 2026/4/15 7:07:38

34、本地化与国际化文本函数详解

本地化与国际化文本函数详解 1. 焦点窗口相关操作 在输入方法的操作中,焦点窗口有着重要的作用。可以对焦点窗口进行以下操作: - 向其发送事件 - 修改其属性 - 在该窗口内获取键盘焦点 关联的值必须为 Window 类型。若焦点窗口在与输入方法关联的显示器上不是有效的窗…

作者头像 李华
网站建设 2026/4/15 2:08:56

一些指令替换记录

替换system直接写入#include <stdlib.h> #include <stdio.h>int main() {char user_input[100];printf("请输入一个字符串: ");fgets(user_input, sizeof(user_input), stdin);// 去除换行符user_input[strcspn(user_input, "\n")] 0;char c…

作者头像 李华