入门OpenCV:图像阈值处理

基本概念

图像阈值是一种简单、高效的图像分割方法,目的是将图像转换成二值图像。这个过程涉及比较像素值和阈值,根据比较结果来确定每个像素点的状态(前景或背景)。图像阈值在处理二维码、文本识别、物体跟踪等领域中非常有用。本博客旨在简介OpenCV中的阈值处理方法,并提供实现代码,适合初学者学习。

理论介绍:

1. 阈值类型:

  • 二进制阈值:如果像素值高于阈值,则赋予一个新值(通常是白色),否则赋予另一个值(通常是黑色)。
  • 反二进制阈值:与二进制阈值相反,如果像素值高于阈值,则赋予黑色,否则赋予白色。
  • 截断阈值:如果像素值高于阈值,就赋予阈值,否则保持不变。
  • 阈值化为零:如果像素值高于阈值,则保持不变,否则赋予零。
  • 反阈值化为零:与阈值化为零相反,如果像素值高于阈值,则赋予零,否则保持不变。

2. 自适应阈值:

在不同区域的光照条件不一致的情况下,自适应阈值可以更好地处理图像,它会基于图像上的小区域(邻域)而不是整个图像来计算阈值。

示意图

放大了看看:

把关键的几个放大看看:


程序展示

Python程序

python 复制代码
# -*- coding: utf-8 -*-
"""
Created on Sat Feb 17 21:26:05 2024

@author: 李立宗

公众号:计算机视觉之光

知识星球:计算机视觉之光

"""


import cv2

# 读取图像
image = cv2.imread('lena.bmp', cv2.IMREAD_GRAYSCALE)

# 应用全局阈值处理
ret, binary_thresh = cv2.threshold(image, 127, 255, cv2.THRESH_BINARY)

# 应用自适应阈值处理
adaptive_thresh = cv2.adaptiveThreshold(image, 255, cv2.ADAPTIVE_THRESH_MEAN_C, cv2.THRESH_BINARY, 11, 2)

# 显示原始图像,全局阈值处理结果和自适应阈值处理结果
cv2.imshow('Original Image', image)
cv2.imshow('Binary Threshold', binary_thresh)
cv2.imshow('Adaptive Threshold', adaptive_thresh)
cv2.waitKey(0)
cv2.destroyAllWindows()

输出结果

相关知识点

理解并实现OpenCV中的图像平滑技术

OpenCV中的边缘检测技术及实现

OpenCV识别人脸案例实战

参考文献

1、OpenCV轻松入门

李立宗,OpenCV轻松入门,电子工业出版社,2023

2、计算机视觉40例

李立宗,计算机视觉40例,电子工业出版社,2022

相关推荐
西猫雷婶7 分钟前
神经网络|(十六)概率论基础知识-伽马函数·中
人工智能·深度学习·神经网络·学习·机器学习·概率论
Y|12 分钟前
XGBoost(eXtreme Gradient Boosting,优化分布式梯度提升库)总结梳理
人工智能·算法·机器学习
空白到白17 分钟前
机器学习-线性回归
人工智能·机器学习·线性回归
武汉格发Gofartlic22 分钟前
HFSS许可证状态查询与管理
大数据·运维·人工智能·数据分析·自动化
科士威传动24 分钟前
滚珠导轨如何赋能精密制造?
人工智能·科技·自动化·制造
OpenCSG27 分钟前
【活动回顾】“智驱未来,智领安全” AI+汽车质量与安全论坛
人工智能·安全·汽车
Francek Chen1 小时前
【深度学习计算机视觉】02:微调
人工智能·pytorch·深度学习·计算机视觉
岁月的眸1 小时前
根据并发和响应延迟,实现语音识别接口自动切换需求
人工智能·语音识别
fsnine2 小时前
机器学习回顾——逻辑回归
人工智能·机器学习·逻辑回归
智能物联实验室2 小时前
屏随人动+视觉魔方+多样主题+智能留言,涂鸦Wukong AI 2.0助力打造爆款带屏云台相机
图像处理·人工智能·嵌入式硬件·数码相机·智能硬件