Computer >> Máy Tính >  >> Lập trình >> Java

Xử lý ảnh / xói mòn ảnh OpenCV Ví dụ Java.


Xói mòn và giãn nở là hai hoạt động hình thái cơ bản. Như tên gọi, hoạt động hình thái học là tập hợp các hoạt động xử lý hình ảnh theo hình dạng của chúng.

Trong quá trình xói mòn, các pixel bổ sung bị xóa khỏi ranh giới hình ảnh, tổng số pixel bị xóa trong quá trình xói mòn phụ thuộc vào kích thước của phần tử cấu trúc được sử dụng.

Bạn có thể thực hiện thao tác xói mòn trên hình ảnh bằng cách sử dụng xói mòn () phương thức của lớp Imgproc, phương thức này ba đối tượng mat đại diện cho nguồn, đích và hạt nhân.

Ví dụ

import java.awt.Image;
import java.awt.image.BufferedImage;
import java.io.IOException;
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;
import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Size;
import org.opencv.highgui.HighGui;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;
public class ImageErosion extends Application {
   public void start(Stage stage) throws IOException {
      //Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
      //Reading image data
      String file ="D:\\Images\\lamma2.jpg";
      Mat src = Imgcodecs.imread(file);
      //Creating destination matrix
      Mat dst = new Mat(src.rows(), src.cols(), src.type());
      //Preparing the kernel matrix object
      Mat kernel = Imgproc.getStructuringElement(Imgproc.MORPH_RECT, new Size((2*2) + 1, (2*2)+1));
      //Applying erosion on the Image
      Imgproc.erode(src, dst, kernel);
      //Converting matrix to JavaFX writable image
      Image img = HighGui.toBufferedImage(dst);
      WritableImage writableImage= SwingFXUtils.toFXImage((BufferedImage) img, null);
      //Setting the image view
      ImageView imageView = new ImageView(writableImage);
      imageView.setX(10);
      imageView.setY(10);
      imageView.setFitWidth(575);
      imageView.setPreserveRatio(true);
      //Setting the Scene object
      Group root = new Group(imageView);
      Scene scene = new Scene(root, 595, 400);
      stage.setTitle("Erosion Example");
      stage.setScene(scene);
      stage.show();
   }
   public static void main(String args[]) {
      launch(args);
   }
}

Hình ảnh đầu vào

Xử lý ảnh / xói mòn ảnh OpenCV Ví dụ Java.

Đầu ra

Khi thực thi, chương trình trên tạo ra kết quả sau -

Xử lý ảnh / xói mòn ảnh OpenCV Ví dụ Java.