OpenCV - Farbiges Bild zu Binär

Eine Methode namens threshold()wird verwendet, um Graustufenbilder in Binärbilder umzuwandeln. Es folgt die Syntax dieser Methode.

threshold(Mat src, Mat dst, double thresh, double maxval, int type)

Diese Methode akzeptiert die folgenden Parameter:

  • mat - A. Mat Objekt, das das Eingabebild darstellt.

  • dst - A. Mat Objekt, das das Ausgabebild darstellt.

  • thresh - Eine Ganzzahl, die den Schwellenwert darstellt.

  • maxval - Eine Ganzzahl, die den Maximalwert darstellt, der mit den Schwellenwerttypen THRESH_BINARY und THRESH_BINARY_INV verwendet werden soll.

  • type - Ein ganzzahliger Code, der den Typ der Konvertierung darstellt, z. B. RGB in Graustufen.

Sie können ein Graustufenbild in ein Binärbild konvertieren, indem Sie den Code übergeben Imgproc.THRESH_BINARY zusammen mit den Werten zu den übrigen Parametern.

Beispiel

Das folgende Programm zeigt, wie Sie ein farbiges Bild als Binärbild lesen und im JavaFX-Fenster anzeigen.

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);
   }
}

Bild eingeben

Angenommen, das Folgende ist das Eingabebild sample.jpg im obigen Programm angegeben.

Ausgabebild

Beim Ausführen des Programms erhalten Sie die folgende Ausgabe.