OpenCV - 简单阈值

阈值处理是一种图像分割方法,通常用于创建二值图像。阈值处理有两种类型,即简单阈值处理和自适应阈值处理。

简单阈值处理

在简单阈值处理操作中,值大于指定阈值的像素将被分配一个标准值。

您可以使用 Imgproc 类 的方法 threshold() 对图像执行简单阈值处理,以下是此方法的语法。

threshold(src, dst, thresh, maxval, type)

此方法接受以下参数 −

  • src −类 Mat 的对象,表示源(输入)图像。

  • dst − 类 Mat 的对象,表示目标(输出)图像。

  • thresh − 表示阈值的双精度型变量。

  • maxval − 表示像素值大于阈值时要给出的值的双精度型变量。

  • type − 表示要使用的阈值类型的整数型变量。

示例

以下程序演示了如何在 OpenCV 中对图像执行简单的阈值操作。

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class Thresh {
   public static void main(String args[]) {
        // 加载 OpenCV 核心库
        System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
        
        // 从文件中读取图像并将其存储到 Matrix 对象中
        String file ="E:/OpenCV/chap14/thresh_input.jpg";
        Mat src = Imgcodecs.imread(file);
        
        // 创建一个空矩阵来存储结果
        Mat dst = new Mat();
        Imgproc.threshold(src, dst, 50, 255, Imgproc.THRESH_BINARY);
        
        // 写入图像
        Imgcodecs.imwrite("E:/OpenCV/chap14/thresh_trunc.jpg", dst);
        
        System.out.println("Image Processed");
   }
}

假设以下是上述程序中指定的输入图像 thresh_input.jpg

Thresh Input

输出

执行程序时,您将获得以下输出 −

Image Processed

如果打开指定路径,您可以观察到输出图像如下 −

Thresh Output

其他类型的简单阈值处理

除了上例中演示的 THRESH_BINARY 操作外,OpenCV 还提供各种其他类型的阈值操作。所有这些类型均由 Imgproc 类的预定义静态字段(固定值)表示。

您可以通过将其各自的预定义值传递给 threshold() 方法的名为 type 的参数来选择所需的阈值操作类型。

Imgproc.threshold(src, dst, 50, 255, Imgproc.THRESH_BINARY);

以下是代表各种类型的阈值操作及其各自输出的值。

操作和描述 输出
THRESH_BINARY THRESH_BINARY
THRESH_BINARY_INV THRESH_BINARY_INV
THRESH_TRUNC THRESH_TRUNC
THRESH_TOZERO THRESH_TOZERO
THRESH_TOZERO_INV THRESH_TOZERO_INV