OpenCV学习之阈值化
来源:互联网 发布:电脑网络枪战游戏 编辑:程序博客网 时间:2024/06/05 18:25
OpenCV中图像阈值处理有两个函数,cvThreshold和cvAdaptiveThreshold。图像处理中可能最重要的一步就是图像的二值化处理,既然需要将图像二之化,那么就不得不使用这两个函数。
1. cvThreshold
函数原型如下:
double cvThreshold( const void* srcarr, void* dstarr, double thresh, double maxval, int type );
srcarr源数组,dstarr为目标数组,thresh为阈值,maxval为欲设最大值,type为阈值处理的类型,有如下几种:
CV_THRESH_BINARY,表示dsti=(srci>T)?M:0。
CV_THRESH_BINARY_INV,表示dsti=(srci>T)?0:M。
CV_THRESH_TRUNC,表示dsti=(srci>T)?M:srci。
CV_THRESH_TOZERO_INV,表示dsti=(srci>T)?0:srci。
CV_THRESH_TOZERO,表示dsti=(srci>T)?srci:0。
可能这样还是不能直观的看出我们实际使用中到底选择哪一种类型,不要着急:
最上面的一个图是将要被阈值处理值和阈值图,下面5个就是前面的阈值处理的类型。
2. cvAdaptiveThreshold
函数原型如下:
void cvAdaptiveThreshold( const void *srcIm, void *dstIm, double maxValue, int method, int type, int blockSize, double delta );
这个函数同上面那个函数不同的是,上面那个函数需要给出阈值,而这个函数的阈值是不要指定的,它是通过一定计算得来的,称之为自适应阈值处理。
前两个参数同cvThreshold的前两个参数一样,你甚至可以看到OpenCV中绝大多数函数的前两个参数都是这样的,第一个为源,第二个为目标。
第三个参数含义也和cvThreshold中的一样。
第四个参数有两种取值:ADAPTIVE_THRESH_MEAN_C和ADAPTIVE_THRESH_GAUSSIAN_C,分别表示对区域内像素采用均值处理和高斯加权处理。
第五个参数也和cvThreshold中的一样。
第六个参数表示区域大小。
最后一个参数是一个定值。
自适应阈值它是计算区域内的一个值减去一个定值作为阈值,所以说它的阈值是动态计算的。
- OpenCV学习之阈值化
- OpenCV学习之阈值化
- opencv 学习之 阈值化<1> 单一阈值
- opencv 学习之 阈值化<2> 自适应阈值
- opencv学习之图像阈值化
- Opencv学习之阈值化处理
- 学习OpenCV---阈值化
- OpenCV学习笔记-阈值化
- OpenCV学习笔记-阈值化
- 【opencv学习之十三】opencv阈值分割threshold函数
- OpenCV学习笔记-自适应阈值化
- OpenCV学习笔记-自适应阈值化
- Opencv学习笔记-----图像阈值化处理
- 【OpenCV学习笔记】十六、图像阈值化
- OpenCV学习笔记-自适应阈值化
- Opencv学习——图像阈值化
- OpenCV学习笔记(二)之最大熵阈值分割
- opencv学习(二十八)之基本图像阈值操作threshold
- 被虐
- let me die
- JBOSS数据源的理解
- ARM平台上蓝牙协议栈Bluez的移植使用和配置
- MyEclipse 10.0,9.0,8.0 下添加jadClipse反编译插件
- OpenCV学习之阈值化
- 我的Google Nexus S 升级到4.0.4啦^_^
- 【Android】数据的四种存储方式
- 据说vc6mfc到2008的dll
- Android 添加系统服务
- UIUC同学Jia-Bin Huang收集的计算机视觉代码合集(ZZ)
- ngx_http分析
- zzuli 1129&& hdu 2047 阿牛的EOF牛肉串
- SVN搭建