VS2017&OPENCV4.0
#include <opencv2/opencv.hpp>
#include <iostream>
#include <math.h>
#include <opencv2\imgproc\types_c.h>
using namespace cv;
Mat src, gray_src, dst;
int threshold_value = 127;
int threshold_max = 255;
int type_value = 2;
int type_max = 4;
const char* output_title = "binary image";
void threshold_demo(int, void*);
int main(int argc, char** argv)
{
src = imread("D:\\test.jpg");
if (!src.data) {
printf("could not load image...\n");
return -1;
}
namedWindow("input image", WINDOW_AUTOSIZE);
namedWindow(output_title, WINDOW_AUTOSIZE);
imshow("input image", src);
createTrackbar("Threshold Value:", output_title, &threshold_value, threshold_max, threshold_demo);//创建阈值
createTrackbar("Type Value:", output_title, &type_value, type_max, threshold_demo);//类型值
threshold_demo(0, 0);
waitKey(0);
return 0;
}
void threshold_demo(int, void*) {
cvtColor(src, gray_src, CV_BGR2GRAY);
threshold(gray_src, dst, 0, 255, THRESH_TRIANGLE | type_value);//THRESH_TRIANGLE | type_value自动算阈值
imshow(output_title, dst);
}