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

Ví dụ về dịch hình ảnh Java bằng OpenCV.


warpAffine ( ) phương thức của lớp Imgproc áp dụng một phép biến đổi affine cho hình ảnh được chỉ định. Phương thức này chấp nhận -

  • Ba đối tượng Mat đại diện cho nguồn, đích và ma trận chuyển đổi.

  • Một giá trị số nguyên đại diện cho kích thước của hình ảnh đầu ra.

Để dịch một hình ảnh Tạo một ma trận dịch và chuyển nó dưới dạng ma trận chuyển đổi cho phương pháp này cùng với các tham số khác.

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.MatOfPoint2f;
import org.opencv.core.Point;
import org.opencv.core.Size;
import org.opencv.highgui.HighGui;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;
public class TranslatingAnImage 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\\elephant.jpg";
      Mat src = Imgcodecs.imread(file);
      //Creating destination matrix
      Mat dst = new Mat(src.rows(), src.cols(), src.type());
      Point p1 = new Point( 0,0 );
      Point p2 = new Point( src.cols() - 1, 0 );
      Point p3 = new Point( 0, src.rows() - 1 );
      Point p4 = new Point( src.cols()*0.0, src.rows()*0.33 );
      Point p5 = new Point( src.cols()*0.85, src.rows()*0.25 );
      Point p6 = new Point( src.cols()*0.15, src.rows()*0.7 );
      MatOfPoint2f ma1 = new MatOfPoint2f(p1,p2,p3);
      MatOfPoint2f ma2 = new MatOfPoint2f(p4,p5,p6);
      //Creating the transformation matrix
      Mat tranformMatrix = Imgproc.getAffineTransform(ma1,ma2);
      //Creating object of the class Size
      Size size = new Size(src.cols(), src.cols());
      //Applying Wrap Affine
      Imgproc.warpAffine(src, dst, tranformMatrix, size);
      //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("Image Translation example");
      stage.setScene(scene);
      stage.show();
   }
   public static void main(String args[]) {
      launch(args);
   }
}

Hình ảnh đầu vào

Ví dụ về dịch hình ảnh Java bằng OpenCV.

Đầu ra

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

Ví dụ về dịch hình ảnh Java bằng OpenCV.