博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
OpenCV_基于局部自适应阈值的图像二值化
阅读量:6039 次
发布时间:2019-06-20

本文共 1364 字,大约阅读时间需要 4 分钟。

在图像处理应用中二值化操作是一个很常用的处理方式,例如零器件图片的处理、文本图片和验证码图片中字符的提取、车牌识别中的字符分割,以及视频图像中的运动目标检测中的前景分割,等等。

 

较为常用的图像二值化方法有:1)全局固定阈值;2)局部自适应阈值;3)OTSU等。

 

全局固定阈值很容易理解,就是对整幅图像都是用一个统一的阈值来进行二值化;

 

局部自适应阈值则是根据像素的邻域块的像素值分布来确定该像素位置上的二值化阈值。这样做的好处在于每个像素位置处的二值化阈值不是固定不变的,而是由其周围邻域像素的分布来决定的。亮度较高的图像区域的二值化阈值通常会较高,而亮度较低的图像区域的二值化阈值则会相适应地变小。不同亮度、对比度、纹理的局部图像区域将会拥有相对应的局部二值化阈值。常用的局部自适应阈值有:1)局部邻域块的均值;2)局部邻域块的高斯加权和。

 

 

OpenCV中实现了以上几种二值化方法。

 

下面这段代码对比了全局固定阈值与局部自适应阈值的二值化结果。

 

[cpp] 
 
  1. //  基于局部自适应阈值的图像二值化  
  2. //  Author:www.icvpr.com  
  3. //  Blog:   http://blog.csdn.net/icvpr    
  4.   
  5. #include <iostream>  
  6. #include <opencv2/opencv.hpp>  
  7.   
  8. int main(int argc, char** argv)  
  9. {  
  10.     cv::Mat image = cv::imread("../test.bmp", CV_LOAD_IMAGE_GRAYSCALE);  
  11.     if (image.empty())  
  12.     {  
  13.         std::cout<<"read image failure"<<std::endl;  
  14.         return -1;  
  15.     }  
  16.   
  17.     // 全局二值化  
  18.     int th = 100;   
  19.     cv::Mat global;  
  20.     cv::threshold(image, global, th, 255, CV_THRESH_BINARY_INV);  
  21.   
  22.   
  23.     // 局部二值化  
  24.   
  25.     int blockSize = 25;  
  26.     int constValue = 10;  
  27.     cv::Mat local;  
  28.     cv::adaptiveThreshold(image, local, 255, CV_ADAPTIVE_THRESH_MEAN_C, CV_THRESH_BINARY_INV, blockSize, constValue);  
  29.   
  30.   
  31.     cv::imwrite("global.jpg", global);  
  32.     cv::imwrite("local.jpg", local);  
  33.   
  34.     cv::imshow("globalThreshold", global);  
  35.     cv::imshow("localThreshold", local);  
  36.     cv::waitKey(0);  
  37.   
  38.   
  39.     return 0;  
  40. }  

 

 

 

 

 

 

原图:

 

全局固定阈值二值化结果(T = 100)

 

 

局部自适应阈值二值化结果(块大小 = 25)

 

 

 

 

相关内容:

-------------------------------------------------------

< 转载请注明: >

转载于:https://www.cnblogs.com/pengkunfan/p/3526091.html

你可能感兴趣的文章
浅谈js闭包(closure)
查看>>
【regex】POSIX标准正则表达式库
查看>>
C#集成FastReport.Net并将模板保存到数据库
查看>>
编程能力与编程年龄
查看>>
Hibernate中分页
查看>>
13_sqoop数据迁移概述
查看>>
函数嵌套-名称空间与作用域-函数对象-闭包函数
查看>>
机会啊,游戏啊,转吧,
查看>>
解决Windows10时间快和Ubuntu时间差
查看>>
流水灯实验
查看>>
让我们写的程序生成单个的exe文件(C#winform程序举例)
查看>>
可跨域的单点登录(SSO)实现方案【附.net代码】
查看>>
JAVA 设计模式 解释器模式
查看>>
InternetOpen|InternetOpenUrl|InternetReadFile-获取网页源代码
查看>>
【HDOJ】2103 Family planning
查看>>
Pentaho BIServer Community Edtion 6.1 使用教程 第二篇 迁移元数据 [HSQLDB TO MySQL]
查看>>
Zookeeper_CAP原则
查看>>
zabbix 监控ssh 登入与报警!!!!
查看>>
常用mysql记录
查看>>
float闭合(清除浮动)和CSS HACK
查看>>