opencv2 threshod函数例程

#include "stdafx.h"
#include "opencv/cv.h"
#include "opencv/highgui.h"
#include <stdio.h>
#include <iostream>

using namespace std;
using namespace cv;
	
Mat src, srcGray, dst;

char * windowName = "Threshold Demo";     // 窗口标题
char * trackbarType = "Type";			  // 选取阈值方法的滑动条标题
char * trackbarValue = "Value";			  // 选取阈值大小的滑动条标题

int	const maxValue = 255;                 // 最大阈值
int const maxType = 3;                    // 阈值方法的总数

int threadhold = 0;                       // 当前阈值大小
int threadholdType = 3;                   // 当前所用阈值方法

void threadOpreation(int, void* );        // 声明阈值操作函数

int main(int argc, char** argv)
{
	char * filename = "d:\\lena.jpg";
	src = imread(filename,1);
	if (!src.data)
	{
		cout << "read image error !" << endl;
		return -1;
	}

	// 变成灰度图像
	cvtColor(src, srcGray, CV_RGB2GRAY);
	// 创建一个窗口显示图片
	namedWindow(windowName, CV_WINDOW_AUTOSIZE);

	// 创建滑动条
	createTrackbar(trackbarType, windowName, &threadholdType, maxType, threadOpreation);
	createTrackbar(trackbarValue, windowName, &threadhold, maxValue, threadOpreation);

	// 初始化自定义阈值函数
	threadOpreation(0, 0);
	while (true)
	{
		int c = 0;
		c = waitKey(10);
		if (27 == c)
		{
			break;
		}
	}
}

void threadOpreation(int, void* )
{
  /* 
	 0: 二进制阈值
     1: 反二进制阈值
     2: 截断阈值
     3: 0阈值
  */
	threshold(srcGray, dst, threadhold, maxValue,threadholdType);
	imshow(windowName, dst);
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值