[转载] python3 opencv 图像二值化笔记(cv2.adaptiveThreshold)
参考链接: python opencv 基础6: cv2.threshold()二值图像
前一篇研究了opencv二值化方法threshold的使用,但是这个方法也存在一定的局限性,假如有一张图存在明显的明暗不同的区域,如下图
可以看到左边部分因为整体偏暗,导致二值化后变成全黑,丢失了所有细节,这显然不是我们想要的结果。
原因threshold函数使用一个阈值对图像进行二值化,导致小于这个阈值的像素点全都变成0。因此使用一个阈值的二值化方法并不适用于上面的这张图。那怎么搞?
很明显,上面这张图只有左右两个区域明显亮度不同,最简单的方法就是把图分成两个区域,每个区域分别进行二值化,也就是说二值化上面这张图需要两个不同的阈值。那如果亮度不同的地方有三个,四个或者更多呢?那就每个区域用一个阈值来进行二值化。按照这个思想,因此有了cv2.adaptiveThreshold函数。
先看一下adaptiveThreshold二值化的使用效果。
明显还是有效果的,至少左边部分不是全黑。
接下来简单说一下adaptiveThreshold方法
cv2.adaptiveThreshold(src, maxValue, adaptiveMethod, thresholdType, blockSize, C, dst=None)
这个函数大致意思就是把图片每个像素点作为中心取N*N的区域,然后计算这个区域的阈值,来决定这个像素点变0还是变255
src:需要进行二值化的一张灰度图像
maxValue:满足条件的像素点需要设置的灰度值。(将要设置的灰度值)
adaptiveMethod:自适应阈值算法。可选ADAPTIVE_THRESH_MEAN_C 或 ADAPTIVE_THRESH_GAUSSIAN_C
thresholdType:opencv提供的二值化方法,只能THRESH_BINARY或者THRESH_BINARY_INV
blockSize:要分成的区域大小,上面的N值,一般取奇数
C:常数,每个区域计算出的阈值的基础上在减去这个常数作为这个区域的最终阈值,可以为负数
dst:输出图像,可以忽略
前两个参数与threshold的src和maxval一样相同
第三个参数adaptiveMethod
提供两种不同的计算阈值的方法,按照网上其他大佬的解释
ADAPTIVE_THRESH_MEAN_C,为局部邻域块的平均值,该算法是先求出块中的均值。
ADAPTIVE_THRESH_GAUSSIAN_C,为局部邻域块的高斯加权和。该算法是在区域中(x, y)周围的像素根据高斯函数按照他们离中心点的距离进行加权计算。
第四个参数thresholdType
只能THRESH_BINARY或者THRESH_BINARY_INV
第5个参数blockSize
上述算法计算邻域时的领邻域大小,一般选择为3、5、7......等
第6个参数C
每个邻域计算出阈值后再减去C作为最终阈值
演示一下blockSize和C对二值化结果的影响,以THRESH_BINARY,ADAPTIVE_THRESH_GAUSSIAN_C为例
blockSize=3,C=1
blockSize=25,C=1
blockSize=3,C=10
blockSize=15,C=10
blockSize=15,C=21
blockSize=15,C=1
blockSize=15,C=1
可以看到,当blockSize越大,参与计算阈值的区域也越大,细节轮廓就变得越少,整体轮廓越粗越明显
当C越大,每个像素点的N*N邻域计算出的阈值就越小,中心点大于这个阈值的可能性也就越大,设置成255的概率就越大,整体图像白色像素就越多,反之亦然。
这种二值化有点类似canny边缘检测,用来找轮廓或者特征点也挺不错。
import cv2
import numpy as np
blocksize = 3
C=0
def adaptive_demo(gray, blocksize, C):
binary = cv2.adaptiveThreshold(gray, 255, cv2.ADAPTIVE_THRESH_GAUSSIAN_C, cv2.THRESH_BINARY, blocksize, C)
# binary = cv2.GaussianBlur(binary, (15,15), 0)
cv2.imshow('binary', binary)
def C_changed(value):
global gray
global blocksize
global C
C = value - 30
print('C:', C)
adaptive_demo(gray, blocksize, C)
def blocksize_changed(value):
global gray
global blocksize
global C
blocksize = 2 * value + 1
print('blocksize:', blocksize)
adaptive_demo(gray, blocksize, C)
if __name__ == "__main__":
image_path = './img/1.jpg'
img = cv2.imread(image_path)
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
adaptive_demo(gray, 3, 0)
cv2.createTrackbar('C', 'binary',0, 60, C_changed)
cv2.createTrackbar('blocksize', 'binary',1, 20, blocksize_changed)
cv2.waitKey(0)
[转载] python3 opencv 图像二值化笔记(cv2.adaptiveThreshold)相关推荐
- python3 opencv 图像二值化笔记(cv2.adaptiveThreshold)
前一篇研究了opencv二值化方法threshold的使用,但是这个方法也存在一定的局限性,假如有一张图存在明显的明暗不同的区域,如下图 可以看到左边部分因为整体偏暗,导致二值化后变成全黑,丢失了所有 ...
- OpenCV图像二值化,Python
OpenCV图像二值化,Python 原图: 二值化处理(只有黑和白): import cv2if __name__=="__main__":image = cv2.imread( ...
- OpenCV-Python学习(10)—— OpenCV 图像二值化处理(cv.threshold)
1. 学习目标 理解图像的分类,不同类型的图像的区别: 对图像进行二值化处理,对[ cv.threshold ]函数的理解. 2. 图像分类 2.1 不同类型图像说明 按照颜色对图像进行分类,可以分为 ...
- python3 opencv 基于二值化图像素投影的图片切割方法
对于一些背景纯色,结构相对简单的图,可以利用传统的opencv图像处理进行分割.先来记录一下基于二值化图像素投影的图片切割方法的实现.比如下面这张图,可以利用这个算法进行切割.(源代码在最后面) 切割 ...
- python opencv图像二值化函数_python opencv 二值化 计算白色像素点的实例
python opencv 二值化 计算白色像素点的实例 贴部分代码 #! /usr/bin/env python # -*- coding: utf-8 -*- import cv2 import ...
- opencv 二值化 python_opencv-python图像二值化函数cv2.threshold函数详解及参数cv2.THRESH_OTSU使用...
cv2.threshold()函数的作用是将一幅灰度图二值化,基本用法如下: #ret:暂时就认为是设定的thresh阈值,mask:二值化的图像 ret,mask = cv2.threshold(i ...
- opencv 二值化 matlab,opencv-python图像二值化函数cv2.threshold函数详解及参数cv2.THRESH...
cv2.threshold()函数的作用是将一幅灰度图二值化,基本用法如下: #ret:暂时就认为是设定的thresh阈值,mask:二值化的图像 ret,mask = cv2.threshold(i ...
- opencv 二值化 python_Python OpenCV 图像二值化-阈值分割
1.二值化处理 # 手动二值化处理 # 设置阈值大小 threshold thresh = 125 # 设置超过阈值像素值的最大值 maxval = 255 # THRESH_BINARY:超过阈值为 ...
- OpenCV:二值化函数cv2.threshold
目录 功能作用: (一)简单阈值 (二)自适应阈值: (三)Otsu's二值化 功能作用: 二值化函数作用:图像的二值化就是将图像上的像素点的灰度值设置为0或255,这样将使整个图像呈现出明显的黑白效 ...
最新文章
- php 匿名方法,PHP基于Closure类创建匿名函数的方法详解
- sklearn数据预处理-scale
- [CareerCup] 9.5 Permutations 全排列
- C++ exception
- 多线程与并发编程实践
- SAP UI5 XML 视图里 label 和 text 控件文本对齐问题
- 为什么S/4HANA的销售订单创建会触发生产订单的创建 1
- live kalilinux能保存文件和设置
- 一加10 Pro首发定制X轴线性马达:Top级超大体积 安卓阵营马达天花板
- 怎么用计算机算密码,如何使用福特密码计算器来编程路虎揽胜2010年智能钥匙...
- Mycat安全权限配置privileges---MyCat分布式数据库集群架构工作笔记0032
- pwnable.kr lotto之write up
- 爱数助力国资委实现混合IT环境下的业务保护
- python美多商城项目百度网盘_美多商城项目(六)
- 北京圣思园Java教学视频全集迅雷下载
- 毕业设计/酒店管理系统
- 小鹤双拼学习指引-by小鹤双拼作者-散步的鹤
- 深度可分离卷积vs标准卷积
- 地质地貌卫星影像集锦(一 典型地貌篇)
- DaDa英语怎么样,给孩子报名哒哒英语上课好不好?
热门文章
- 【服务器】【私有云】宝塔安装KodExplorer
- 【NOIP2002】【Luogu1037】产生数(高精乘低精,DFS暴力搜索)
- css样式让样式失效,如何让css样式失效
- sudoers修改_为用户增加sudo权限(修改sudoers文件) | 学步园
- 模具计算机辅助设计笔试题,模具CADCAM试卷
- html文件中用import,@import引入CSS文件
- WPF仿微信保存与查看聊天记录
- 在PowerDesigner导出到数据库的方法
- leetcode 78.子集 dfs解法
- 2016蓝桥杯C++A:寒假作业(详细解析)