threshold函数

来源:互联网 发布:淘宝里的运费险怎么退 编辑:程序博客网 时间:2024/06/07 11:56

threshold函数

函数的作用:

对图像中的像素进行阈值处理,进行分割,常用于二值化处理

函数调用形式:

C++: double threshold(InputArray src, OutputArray dst, double thresh, double maxval, int type)

src 原始数组 (单通道 , 8-bit of 32-bit 浮点数). 

dst 输出数组,必须与 src 的类型一致,或者为 8-bit. 

threshold 阈值

 max_value 使用 CV_THRESH_BINARY 和 CV_THRESH_BINARY_INV 的最大值. threshold_type 阈值类型 

函数 cvThreshold 对单通道数组应用固定阈值操作。该函数的典型应用是对灰度图像进行阈值操作得到二值图像。(cvCmpS 也可以达到此目的) 或者是去掉噪声,例如过滤很小或很大象素值的图像点。本函数支持的对图像取阈值的方法由 threshold_type 确定:

threshold_type=CV_THRESH_BINARY:dst(x,y) = max_value, if src(x,y)>threshold           0, otherwisethreshold_type=CV_THRESH_BINARY_INV:dst(x,y) = 0, if src(x,y)>threshold           max_value, otherwisethreshold_type=CV_THRESH_TRUNC:dst(x,y) = threshold, if src(x,y)>threshold           src(x,y), otherwisethreshold_type=CV_THRESH_TOZERO:dst(x,y) = src(x,y), if (x,y)>threshold           0, otherwisethreshold_type=CV_THRESH_TOZERO_INV:dst(x,y) = 0, if src(x,y)>threshold           src(x,y), otherwise

代码示范

#include "opencv2/imgproc/imgproc.hpp"#include "opencv2/highgui/highgui.hpp"#include <stdlib.h>#include <stdio.h>using namespace cv;/// 全局变量定义及赋值int threshold_value = 0;int threshold_type = 3;;int const max_value = 255;int const max_type = 4;int const max_BINARY_value = 255;Mat src, src_gray, dst;char* window_name = "Threshold Demo";char* trackbar_type = "Type: \n 0: Binary \n 1: Binary Inverted \n 2: Truncate \n 3: To Zero \n 4: To Zero Inverted";char* trackbar_value = "Value";/// 自定义函数声明void Threshold_Demo( int, void* );/** * @主函数 */int main( int argc, char** argv ){  /// 读取一副图片,不改变图片本身的颜色类型(该读取方式为DOS运行模式)  src = imread( argv[1], 1 );  /// 将图片转换成灰度图片  cvtColor( src, src_gray, CV_RGB2GRAY );  /// 创建一个窗口显示图片  namedWindow( window_name, CV_WINDOW_AUTOSIZE );  /// 创建滑动条来控制阈值  createTrackbar( trackbar_type,                  window_name, &threshold_type,                  max_type, Threshold_Demo );  createTrackbar( trackbar_value,                  window_name, &threshold_value,                  max_value, Threshold_Demo );  /// 初始化自定义的阈值函数  Threshold_Demo( 0, 0 );  /// 等待用户按键。如果是ESC健则退出等待过程。  while(true)  {    int c;    c = waitKey( 20 );    if( (char)c == 27 )      { break; }   }}/** * @自定义的阈值函数 */void Threshold_Demo( int, void* ){  /* 0: 二进制阈值     1: 反二进制阈值     2: 截断阈值     3: 0阈值     4: 反0阈值   */  threshold( src_gray, dst, threshold_value, max_BINARY_value,threshold_type );  imshow( window_name, dst );}

0 0
原创粉丝点击