OpenCV - Dilatasi

Erosi dan dilasi adalah dua jenis operasi morfologi. Sesuai dengan namanya, operasi morfologi adalah sekumpulan operasi yang memproses gambar menurut bentuknya.

Berdasarkan gambar input yang diberikan, "elemen struktural" dikembangkan. Ini dapat dilakukan di salah satu dari dua prosedur tersebut. Ini ditujukan untuk menghilangkan noise dan mengatasi ketidaksempurnaan, untuk membuat gambar menjadi jelas.

Pelebaran

Prosedur ini mengikuti konvolusi dengan beberapa kernel dengan bentuk tertentu seperti persegi atau lingkaran. Kernel ini memiliki titik jangkar, yang menunjukkan pusatnya.

Kernel ini tumpang tindih di atas gambar untuk menghitung nilai piksel maksimum. Setelah dihitung, gambar diganti dengan jangkar di tengah. Dengan prosedur ini, area area terang bertambah besar dan karenanya ukuran gambar bertambah.

Misalnya, ukuran objek dengan bayangan putih atau bayangan cerah bertambah, sedangkan ukuran benda dengan bayangan hitam atau bayangan gelap berkurang.

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

dilate(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.

Contoh

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 mendemonstrasikan bagaimana melakukan operasi dilasi pada citra 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 DilateTest {
   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 dilate on the Image
      Imgproc.dilate(src, dst, kernel);

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

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

Memasukkan

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

Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut -

Image Processed

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