OpenCV - Erosi

Erosi adalah proses yang mirip dengan dilatasi. Tetapi nilai piksel yang dihitung di sini adalah pelebaran minimum daripada maksimum. Gambar diganti di bawah titik jangkar dengan nilai piksel minimum.

Dengan prosedur ini, area area gelap bertambah besar dan area terang berkurang. Misalnya, ukuran objek dalam bayangan gelap atau bayangan hitam bertambah, sementara itu berkurang dalam bayangan putih atau bayangan cerah.

Contoh

Anda dapat melakukan operasi ini pada gambar menggunakan erode() metode dari imgprockelas. Berikut adalah sintaks dari metode ini -

erode(src, dst, kernel)

Metode ini menerima parameter berikut -

  • src - A Mat objek yang mewakili sumber (gambar masukan) untuk operasi ini.

  • dst - A Mat objek yang mewakili tujuan (gambar keluaran) untuk operasi ini.

  • kernel - A Mat objek yang mewakili kernel.

Anda dapat menyiapkan matriks kernel menggunakan getStructuringElement()metode. Metode ini menerima integer yang mewakilimorph_rect tipe dan objek tipe Size.

Imgproc.getStructuringElement(int shape, Size ksize);

Program berikut menunjukkan cara melakukan operasi erosi pada gambar tertentu.

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

public class ErodeTest {
   public static void main( String[] args ) {
      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Reading the Image from the file and storing it in to a Matrix object
      String file ="C:/EXAMPLES/OpenCV/sample.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();

      // Preparing the kernel matrix object
      Mat kernel = Imgproc.getStructuringElement(Imgproc.MORPH_RECT, 
         new  Size((2*2) + 1, (2*2)+1));

      // Applying erode on the Image
      Imgproc.erode(src, dst, kernel);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap10/Erosion.jpg", dst);

      System.out.println("Image processed");
   }
}

Asumsikan bahwa berikut ini adalah gambar input sample.jpg ditentukan dalam program di atas.

Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut -

Image Loaded

Jika Anda membuka jalur yang ditentukan, Anda dapat mengamati gambar keluaran sebagai berikut -