/**
* 固定阈值操作,
* 该函数的典型应用是对灰度图像进行阈值操作得到二值图像。 或者是去掉噪声,例如过滤很小或很大象素值的图像点。
* 对图像取阈值的方法由 threshold_type 确定:
* THRESH_BINARY 大于阈值的部分被置为255,小于部分被置为0
* THRESH_BINARY_INV 大于阈值部分被置为0,小于部分被置为255
* THRESH_TRUNC 大于阈值部分被置为threshold,小于部分保持原样
* THRESH_TOZERO 小于阈值部分被置为0,大于部分保持不变
* THRESH_TOZERO_INV 大于阈值部分被置为0,小于部分保持不变
* threshold(
* Mat src, --输入图像
* Mat dst, --输出图像
* double threshold, --当前阈值
* double max_value, --最大阈值,一般为255
* int threshold_type --阈值类型
* )
*/
@Test
public void testThreshold() {
Mat src = GeneralUtils.converMat("D:\\test\\0001.jpg");
//转成灰度图
Mat gray = new Mat();
Imgproc.cvtColor(src, gray, Imgproc.COLOR_BGR2GRAY);
Mat dst = new Mat();
//大于阈值的部分被置为255,小于部分被置为0
Imgproc.threshold(gray, dst, 127, 255, Imgproc.THRESH_BINARY);
GeneralUtils.saveByteImg(dst, "D:\\test\\THRESH_BINARY.jpg");
//大于阈值部分被置为0,小于部分被置为255
Imgproc.threshold(gray, dst, 127, 255, Imgproc.THRESH_BINARY_INV);
GeneralUtils.saveByteImg(dst, "D:\\test\\THRESH_BINARY_INV.jpg");
//大于阈值部分被置为threshold,小于部分保持原样
Imgproc.threshold(gray, dst, 127, 255, Imgproc.THRESH_TRUNC);
GeneralUtils.saveByteImg(dst, "D:\\test\\THRESH_TRUNC.jpg");
//小于阈值部分被置为0,大于部分保持不变
Imgproc.threshold(gray, dst, 127, 255, Imgproc.THRESH_TOZERO);
GeneralUtils.saveByteImg(dst, "D:\\test\\THRESH_TOZERO.jpg");
// 大于阈值部分被置为0,小于部分保持不变
Imgproc.threshold(gray, dst, 127, 255, Imgproc.THRESH_TOZERO_INV);
GeneralUtils.saveByteImg(dst, "D:\\test\\THRESH_TOZERO_INV.jpg");
//自动阈值寻找与二值化
double t = Imgproc.threshold(gray, dst, 0, 255, Imgproc.THRESH_BINARY | Imgproc.THRESH_OTSU);
System.out.println(t);
}
/*
* 自适应阈值adaptiveThreshold,图像二值化处理,用于图像信息与特征的提取,对于对比大的图像有较好效果,
* 相对于opencv中固定阈值化操作(threshold()),自适应阈值中图像中每一个像素点的阈值是不同的,该阈值由其领域中图像像素带点加权平均决定
* adaptiveThreshold(
* Mat src, --输入图像
* Mat dst, --输出图像
* double maxValue, --最大阈值255
* int adaptiveMethod, --超过阈值的部分取值是多少(对于cv.THRESH_BINARY而言)
* int thresholdType, --这是阈值类型,只有两个取值,分别为 THRESH_BINARY 和THRESH_BINARY_INV
* int blockSize, --像素的邻域块大小选择,这是局部邻域大小,3、5、7等
* double C --这个参数实际上是一个偏移值调整量,用均值和高斯计算阈值后,再减或加这个值就是最终阈值。
* );
*/
@Test
public void testAdaptiveThreshold() {
Mat src = GeneralUtils.converMat("D:\\test\\0001.jpg");
Mat gray = new Mat();
Mat binary = new Mat();
//转成灰度图像
Imgproc.cvtColor(src, gray, Imgproc.COLOR_BGR2GRAY);
//自适应阈值
Imgproc.adaptiveThreshold(gray, binary, 255, Imgproc.ADAPTIVE_THRESH_GAUSSIAN_C, Imgproc.THRESH_BINARY, 7, 10);
GeneralUtils.saveByteImg(binary, "D:\\test\\adaptiveThreshold.jpg");
}