Метод под названием threshold () используется для преобразования изображений в градациях серого в двоичное изображение. Ниже приводится синтаксис этого метода.
threshold(Mat src, Mat dst, double thresh, double maxval, int type)
Этот метод принимает следующие параметры —
-
mat — объект Mat, представляющий входное изображение.
-
dst — объект Mat, представляющий выходное изображение.
-
thresh — Целое число, представляющее пороговое значение.
-
maxval — целое число, представляющее максимальное значение для использования с типами порогов THRESH_BINARY и THRESH_BINARY_INV.
-
type — Целочисленный код, представляющий тип преобразования, например, RGB в оттенки серого.
mat — объект Mat, представляющий входное изображение.
dst — объект Mat, представляющий выходное изображение.
thresh — Целое число, представляющее пороговое значение.
maxval — целое число, представляющее максимальное значение для использования с типами порогов THRESH_BINARY и THRESH_BINARY_INV.
type — Целочисленный код, представляющий тип преобразования, например, RGB в оттенки серого.
Вы можете преобразовать изображение в градациях серого в двоичное изображение, передав код Imgproc.THRESH_BINARY вместе со значениями оставшимся параметрам.
пример
Следующая программа демонстрирует, как читать цветное изображение как двоичное изображение и отображать его с помощью окна JavaFX.
import java.awt.image.BufferedImage; import org.opencv.core.Core; import org.opencv.core.Mat; import org.opencv.imgcodecs.Imgcodecs; import org.opencv.imgproc.Imgproc; import javafx.application.Application; import javafx.embed.swing.SwingFXUtils; import javafx.scene.Group; import javafx.scene.Scene; import javafx.scene.image.ImageView; import javafx.scene.image.WritableImage; import javafx.stage.Stage; public class ColorToBinary extends Application { @Override public void start(Stage stage) throws Exception { WritableImage writableImage = loadAndConvert(); // Setting the image view ImageView imageView = new ImageView(writableImage); // Setting the position of the image imageView.setX(10); imageView.setY(10); // setting the fit height and width of the image view imageView.setFitHeight(400); imageView.setFitWidth(600); // Setting the preserve ratio of the image view imageView.setPreserveRatio(true); // Creating a Group object Group root = new Group(imageView); // Creating a scene object Scene scene = new Scene(root, 600, 400); // Setting title to the Stage stage.setTitle("Loading an image"); // Adding scene to the stage stage.setScene(scene); // Displaying the contents of the stage stage.show(); } public WritableImage loadAndConvert() throws Exception { // Loading the OpenCV core library System.loadLibrary( Core.NATIVE_LIBRARY_NAME ); // Instantiating the Imgcodecs class Imgcodecs imageCodecs = new Imgcodecs(); // File input = new File("C:/EXAMPLES/OpenCV/sample.jpg"); String input = "C:/EXAMPLES/OpenCV/sample.jpg"; // Reading the image Mat src = imageCodecs.imread(input); // Creating the destination matrix Mat dst = new Mat(); // Converting to binary image... Imgproc.threshold(src, dst, 200, 500, Imgproc.THRESH_BINARY); // Extracting data from the transformed image (dst) byte[] data1 = new byte[dst.rows() * dst.cols() * (int)(dst.elemSize())]; dst.get(0, 0, data1); // Creating Buffered image using the data BufferedImage bufImage = new BufferedImage(dst.cols(),dst.rows(), BufferedImage.TYPE_BYTE_GRAY); // Setting the data elements to the image bufImage.getRaster().setDataElements(0, 0, dst.cols(), dst.rows(), data1); // Creating a Writable image WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null); System.out.println("Converted to binary"); return writableImage; } public static void main(String args[]) throws Exception { launch(args); } }
Входное изображение
Предположим, что ниже указано входное изображение sample.jpg, указанное в вышеуказанной программе.
Выходное изображение
При выполнении программы вы получите следующий вывод.