OpenCV - Panduan Cepat

OpenCV adalah pustaka lintas platform yang dapat digunakan untuk mengembangkan waktu nyata computer vision applications. Ini terutama berfokus pada pemrosesan gambar, pengambilan dan analisis video termasuk fitur seperti deteksi wajah dan deteksi objek.

Mari kita mulai bab ini dengan mendefinisikan istilah "Visi Komputer".

Visi Komputer

Computer Vision dapat didefinisikan sebagai disiplin ilmu yang menjelaskan bagaimana merekonstruksi, menyela, dan memahami pemandangan 3D dari gambar 2D-nya, dalam kaitannya dengan properti struktur yang ada dalam pemandangan tersebut. Ini berkaitan dengan pemodelan dan mereplikasi visi manusia menggunakan perangkat lunak dan perangkat keras komputer.

Computer Vision tumpang tindih secara signifikan dengan bidang berikut -

  • Image Processing - Ini berfokus pada manipulasi gambar.

  • Pattern Recognition - Menjelaskan berbagai teknik untuk mengklasifikasikan pola.

  • Photogrammetry - Ini berkaitan dengan mendapatkan pengukuran yang akurat dari gambar.

Computer Vision Vs Pemrosesan Gambar

Image processingberhubungan dengan transformasi gambar-ke-gambar. Input dan output dari pengolahan citra keduanya adalah citra.

Computer visionadalah konstruksi deskripsi eksplisit dan bermakna tentang objek fisik dari gambarnya. Keluaran computer vision berupa deskripsi atau interpretasi dari struktur dalam scene 3D.

Aplikasi Computer Vision

Di sini kami telah membuat daftar beberapa domain utama di mana Computer Vision banyak digunakan.

Aplikasi Robotika

  • Lokalisasi - Tentukan lokasi robot secara otomatis

  • Navigation

  • Menghindari rintangan

  • Perakitan (pasak dalam lubang, pengelasan, pengecatan)

  • Manipulasi (misalnya manipulator robot PUMA)

  • Human Robot Interaction (HRI) - Robotika cerdas untuk berinteraksi dengan dan melayani orang

Aplikasi Obat

  • Klasifikasi dan deteksi (misalnya lesi atau klasifikasi sel dan deteksi tumor)
  • Segmentasi 2D / 3D
  • Rekonstruksi organ manusia 3D (MRI atau ultrasound)
  • Operasi robotika yang dipandu visi

Aplikasi Otomasi Industri

  • Inspeksi industri (deteksi cacat)
  • Assembly
  • Pembacaan kode batang dan label paket
  • Penyortiran objek
  • Pemahaman dokumen (misalnya OCR)

Aplikasi Keamanan

  • Biometrik (iris, sidik jari, pengenalan wajah)

  • Pengawasan - Mendeteksi aktivitas atau perilaku tertentu yang mencurigakan

Aplikasi Transportasi

  • Kendaraan otonom
  • Keamanan, misalnya, pemantauan kewaspadaan pengemudi

Fitur Perpustakaan OpenCV

Menggunakan pustaka OpenCV, Anda dapat -

  • Membaca dan menulis gambar

  • Rekam dan simpan video

  • Gambar proses (filter, transformasi)

  • Lakukan deteksi fitur

  • Mendeteksi objek tertentu seperti wajah, mata, mobil, dalam video atau gambar.

  • Analisis video, yaitu memperkirakan gerakan di dalamnya, kurangi latar belakang, dan lacak objek di dalamnya.

OpenCV awalnya dikembangkan di C ++. Selain itu, binding Python dan Java juga disediakan. OpenCV berjalan di berbagai Sistem Operasi seperti windows, Linux, OSx, FreeBSD, Net BSD, Open BSD, dll.

Tutorial ini menjelaskan konsep OpenCV dengan contoh-contoh menggunakan pengikatan Java.

Modul Perpustakaan OpenCV

Berikut adalah modul perpustakaan utama dari perpustakaan OpenCV.

Fungsi Inti

Modul ini mencakup struktur data dasar seperti Scalar, Point, Range, dll., Yang digunakan untuk membangun aplikasi OpenCV. Selain itu, ini juga mencakup array multidimensiMat, yang digunakan untuk menyimpan gambar. Di pustaka Java OpenCV, modul ini disertakan sebagai paket dengan namaorg.opencv.core.

Pengolahan citra

Modul ini mencakup berbagai operasi pemrosesan gambar seperti pemfilteran gambar, transformasi gambar geometris, konversi ruang warna, histogram, dll. Di pustaka Java OpenCV, modul ini disertakan sebagai paket dengan nama org.opencv.imgproc.

Video

Modul ini mencakup konsep analisis video seperti estimasi gerak, pengurangan latar belakang, dan pelacakan objek. Di pustaka Java OpenCV, modul ini disertakan sebagai paket dengan namaorg.opencv.video.

Video I / O

Modul ini menjelaskan pengambilan video dan codec video menggunakan pustaka OpenCV. Di pustaka Java OpenCV, modul ini disertakan sebagai paket dengan namaorg.opencv.videoio.

kalib3d

Modul ini mencakup algoritme mengenai algoritme geometri multi-tampilan dasar, kalibrasi kamera tunggal dan stereo, estimasi pose objek, korespondensi stereo, dan elemen rekonstruksi 3D. Di pustaka Java OpenCV, modul ini disertakan sebagai paket dengan namaorg.opencv.calib3d.

fitur2d

Modul ini mencakup konsep deteksi dan deskripsi fitur. Di pustaka Java OpenCV, modul ini disertakan sebagai paket dengan namaorg.opencv.features2d.

Objdetect

Modul ini mencakup deteksi objek dan instance dari kelas yang telah ditentukan sebelumnya seperti wajah, mata, mug, orang, mobil, dll. Di pustaka Java OpenCV, modul ini disertakan sebagai paket dengan nama org.opencv.objdetect.

Highgui

Ini adalah antarmuka yang mudah digunakan dengan kemampuan UI sederhana. Di pustaka Java OpenCV, fitur modul ini termasuk dalam dua paket berbeda yaitu,org.opencv.imgcodecs dan org.opencv.videoio.

Sejarah Singkat OpenCV

OpenCV awalnya merupakan inisiatif penelitian Intel untuk menyarankan aplikasi intensif CPU. Secara resmi diluncurkan pada tahun 1999.

  • Pada tahun 2006, versi utama pertamanya, OpenCV 1.0 dirilis.
  • Pada bulan Oktober 2009, versi utama kedua, OpenCV 2 dirilis.
  • Pada Agustus 2012, OpenCV diambil alih oleh organisasi nonprofit OpenCV.org.

Di bab ini, Anda akan mempelajari cara menginstal OpenCV dan mengatur lingkungannya di sistem Anda.

Menginstal OpenCV

Pertama-tama, Anda perlu mengunduh OpenCV ke sistem Anda. Ikuti langkah-langkah yang diberikan di bawah ini.

Step 1 - Buka beranda OpenCV dengan mengklik link berikut: http://opencv.org/ Saat mengklik, Anda akan melihat beranda seperti yang ditunjukkan di bawah ini.

Step 2 - Sekarang, klik Downloadstautan yang disorot pada tangkapan layar di atas. Saat mengklik, Anda akan diarahkan ke halaman download OpenCV.

Step 3 - Saat mengklik tautan yang disorot pada tangkapan layar di atas, sebuah file bernama opencv-3.1.0.exeakan diunduh. Ekstrak file ini untuk membuat folderopencv di sistem Anda, seperti yang ditunjukkan pada tangkapan layar berikut.

Step 4 - Buka foldernya OpenCVbuildjava. Di sini Anda akan menemukan file jar dari OpenCV bernamaopencv-310.jar. Simpan file ini di folder terpisah untuk digunakan lebih lanjut.

Instalasi Eclipse

Setelah mengunduh file JAR yang diperlukan, Anda harus menyematkan file JAR ini ke lingkungan Eclipse Anda. Anda dapat melakukan ini dengan mengatur Build Path ke file JAR ini dan dengan menggunakanpom.xml.

Menyetel Jalur Bangun

Berikut adalah langkah-langkah untuk menyiapkan OpenCV di Eclipse -

Step 1- Pastikan Anda telah menginstal Eclipse di sistem Anda. Jika tidak, unduh dan instal Eclipse di sistem Anda.

Step 2 - Buka Eclipse, klik File, New, dan Buka proyek baru seperti yang ditunjukkan pada gambar berikut.

Step 3 - Saat memilih proyek, Anda akan mendapatkan New ProjectPenyihir. Di wizard ini, pilih proyek Java dan lanjutkan dengan mengklikNext tombol, seperti yang ditunjukkan pada tangkapan layar berikut.

Step 4 - Saat melanjutkan, Anda akan diarahkan ke New Java Project wizard. Buat proyek baru dan klikNext, seperti yang ditunjukkan pada tangkapan layar berikut.

Step 5- Setelah membuat proyek baru, klik kanan padanya. PilihBuild Path dan klik Configure Build Path… seperti yang ditunjukkan pada tangkapan layar berikut.

Step 6 - Saat mengklik Build Path opsi, Anda akan diarahkan ke Java Build Path wizard. KlikAdd External JARs tombol, seperti yang ditunjukkan pada tangkapan layar berikut.

Step 7 - Pilih jalur tempat Anda menyimpan file opencv-310.jar.

Step 8 - Saat mengklik Open pada gambar di atas, file-file itu akan ditambahkan ke perpustakaan Anda.

Step 9 - Saat mengklik OK, Anda akan berhasil menambahkan file JAR yang diperlukan ke proyek saat ini dan Anda dapat memverifikasi perpustakaan yang ditambahkan ini dengan memperluas Perpustakaan yang Dirujuk.

Mengatur Path untuk Native Libraries

Selain file JAR, Anda perlu mengatur jalur untuk perpustakaan asli (file DLL) OpenCV.

Location of DLL files - Buka folder instalasi OpenCV dan buka sub-folder buildjava. Di sini Anda akan menemukan dua folderx64 (64 bit) dan x86 (32 bit) yang berisi file dll file dari OpenCV.

Buka folder yang sesuai untuk sistem operasi Anda, lalu Anda dapat melihat file dll file, seperti yang ditunjukkan pada tangkapan layar berikut.

Sekarang, atur jalur untuk file ini juga dengan mengikuti langkah-langkah yang diberikan di bawah ini -

Step 1- Sekali lagi, buka jendela JavaBuildPath. Di sini Anda dapat mengamati file JAR yang ditambahkan danJRE System Library.

Step 2 - Saat mengembangkannya, Anda akan mendapatkan perpustakaan sistem dan Native library location, seperti yang disorot di tangkapan layar berikut.

Step 3 - Klik dua kali pada file Native library location. Di sini, Anda dapat melihatNative Library Folder Configuration window seperti gambar dibawah.

Di sini, klik tombolnya External Folder… dan pilih lokasi dll file di sistem Anda.

Untuk mengambil gambar, kami menggunakan perangkat seperti kamera dan pemindai. Perangkat ini merekam nilai numerik gambar (Mis: nilai piksel). OpenCV merupakan library yang memproses gambar digital, oleh karena itu kita perlu menyimpan gambar tersebut untuk diproses.

Itu Matkelas perpustakaan OpenCV digunakan untuk menyimpan nilai-nilai gambar. Ini mewakili larik n-dimensi dan digunakan untuk menyimpan data gambar grayscale atau gambar berwarna, volume voxel, bidang vektor, point cloud, tensor, histogram, dll.

Kelas ini terdiri dari dua bagian data: the header dan a pointer

  • Header - Berisi informasi seperti ukuran, metode yang digunakan untuk menyimpan, dan alamat matriks (ukuran konstan).

  • Pointer - Menyimpan nilai piksel gambar (Terus bervariasi).

Kelas Mat

Pustaka OpenCV Java menyediakan kelas ini dengan nama yang sama (Mat) di dalam paket org.opencv.core.

Konstruktor

Kelas Mat pustaka Java OpenCV memiliki berbagai konstruktor, yang dengannya Anda dapat membuat objek Mat.

S.No Pembangun dan Deskripsi
1

Mat()

Ini adalah konstruktor default tanpa parameter dalam banyak kasus. Kami menggunakan ini untuk konstruktor untuk membuat matriks kosong dan meneruskannya ke metode OpenCV lainnya.

2

Mat(int rows, int cols, int type)

Konstruktor ini menerima tiga parameter tipe bilangan bulat yang mewakili jumlah baris dan kolom dalam larik 2D dan jenis larik (yang akan digunakan untuk menyimpan data).

3

Mat(int rows, int cols, int type, Scalar s)

Termasuk parameter yang sebelumnya, konstruktor ini juga menerima objek dari kelas Scalar sebagai parameter.

4

Mat(Size size, int type)

Konstruktor ini menerima dua parameter, objek yang mewakili ukuran matriks dan bilangan bulat yang mewakili tipe larik yang digunakan untuk menyimpan data.

5

Mat(Size size, int type, Scalar s)

Termasuk parameter yang sebelumnya, konstruktor ini juga menerima objek dari kelas Scalar sebagai parameter.

6

Mat(long addr)

7

Mat(Mat m, Range rowRange)

Konstruktor ini menerima objek matriks lain dan objek kelas Rentang yang mewakili rentang baris yang akan diambil untuk membuat matriks baru.

8

Mat(Mat m, Range rowRange, Range colRange)

Termasuk parameter dari yang sebelumnya, konstruktor ini juga menerima objek dari kelas. Rentang mewakili rentang kolom.

9

Mat(Mat m, Rect roi)

Konstruktor ini menerima dua objek, satu mewakili matriks lain dan yang lainnya mewakili Region Of Interest.

Note -

  • Jenis array. Gunakan CV_8UC1, ..., CV_64FC4 untuk membuat 1-4 matriks saluran, atau CV_8UC (n), ..., CV_64FC (n) untuk membuat matriks multi-saluran (hingga saluran CV_CN_MAX).

  • Jenis matriks diwakili oleh berbagai bidang kelas CvType yang termasuk dalam paket org.opencv.core.

Metode dan Deskripsi

Berikut adalah beberapa metode yang disediakan oleh kelas Mat.

S.No Metode dan Deskripsi
1

Mat col(int x)

Metode ini menerima parameter integer yang mewakili indeks kolom dan mengambil dan mengembalikan kolom itu.

2

Mat row(int y)

Metode ini menerima parameter integer yang mewakili indeks suatu baris dan mengambil serta mengembalikan baris tersebut.

3

int cols()

Metode ini mengembalikan jumlah kolom dalam matriks.

4

int rows()

Metode ini mengembalikan jumlah baris dalam matriks.

5

Mat setTo(Mat value)

Metode ini menerima objek dari Mat ketik dan setel elemen array ke nilai yang ditentukan.

6

Mat setTo(Scalar s)

Metode ini menerima objek dari Scalar ketik dan setel elemen array ke nilai yang ditentukan.

Membuat dan Menampilkan Matriks

Pada bagian ini, kita akan membahas contoh OpenCV pertama kita. Kita akan melihat bagaimana membuat dan menampilkan matriks OpenCV sederhana.

Diberikan di bawah ini adalah langkah-langkah yang harus diikuti untuk membuat dan menampilkan matriks di OpenCV.

Langkah 1: Muat pustaka asli OpenCV

Saat menulis kode Java menggunakan pustaka OpenCV, langkah pertama yang perlu Anda lakukan adalah memuat pustaka asli OpenCV menggunakan loadLibrary(). Muat pustaka asli OpenCV seperti yang ditunjukkan di bawah ini.

//Loading the core library 
System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

Langkah 2: Buat instance kelas Mat

Buat instance kelas Mat menggunakan salah satu fungsi yang disebutkan di bab ini sebelumnya.

//Creating a matrix 
Mat matrix = new Mat(5, 5, CvType.CV_8UC1, new Scalar(0));

Langkah 3: Isi matriks menggunakan metode

Anda dapat mengambil baris / kolom tertentu dari sebuah matriks dengan meneruskan nilai indeks ke metode row()/col().

Dan, Anda dapat menyetel nilai ke nilai ini menggunakan salah satu varian dari setTo() metode.

//Retrieving the row with index 0 
Mat row0 = matrix.row(0); 
     
//setting values of all elements in the row with index 0 
row0.setTo(new Scalar(1)); 
     
//Retrieving the row with index 3 
Mat col3 = matrix.col(3);  
     
//setting values of all elements in the row with index 3 
col3.setTo(new Scalar(3));

Example

Anda dapat menggunakan kode program berikut untuk membuat dan menampilkan matriks sederhana di Java menggunakan pustaka OpenCV.

import org.opencv.core.Core; 
import org.opencv.core.Mat;  
import org.opencv.core.CvType;  
import org.opencv.core.Scalar;   

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

      //Creating a matrix 
      Mat matrix = new Mat(5, 5, CvType.CV_8UC1, new Scalar(0));  

      //Retrieving the row with index 0 
      Mat row0 = matrix.row(0);

      //setting values of all elements in the row with index 0 
      row0.setTo(new Scalar(1)); 

      //Retrieving the row with index 3 
      Mat col3 = matrix.col(3);  

      //setting values of all elements in the row with index 3 
      col3.setTo(new Scalar(3)); 

      //Printing the matrix 
      System.out.println("OpenCV Mat data:\n" + matrix.dump()); 
   } 
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

OpenCV Mat data: 
[  1,   1,   1,   3,   1; 
   0,   0,   0,   3,   0; 
   0,   0,   0,   3,   0; 
   0,   0,   0,   3,   0; 
   0,   0,   0,   3,   0]

Memuat Gambar menggunakan JavaSE API

Itu BufferedImage kelas dari java.awt.image.BufferedImage paket digunakan untuk menyimpan gambar dan file ImageIO kelas paket import javax.imageio menyediakan metode untuk membaca dan menulis Gambar.

Example

Anda dapat menggunakan kode program berikut untuk memuat dan menyimpan gambar menggunakan pustaka JavaSE.

import java.awt.image.BufferedImage; 
import java.io.File; 
import java.io.IOException; 
import javax.imageio.ImageIO;
  
public class LoadingImage_JSE_library {
   public static void main( String[] args ) throws IOException {
      //Input File 
      File input = new File("C:/EXAMPLES/OpenCV/sample.jpg");
          
      //Reading the image 
      BufferedImage image = ImageIO.read(input);
      
      //Saving the image with a different name
      File ouptut = new File("C:/OpenCV/sample.jpg");
      ImageIO.write(image, "jpg", ouptut);
         
      System.out.println("image Saved");
   } 
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

image Saved

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

Itu Imgcodecs kelas paket org.opencv.imgcodecsmenyediakan metode untuk membaca dan menulis gambar. Dengan OpenCV, Anda dapat membaca gambar dan menyimpannya dalam matriks (melakukan transformasi pada matriks jika diperlukan). Nanti, Anda dapat menulis matriks yang telah diproses ke sebuah file.

Itu read() metode dari Imgcodecskelas digunakan untuk membaca gambar menggunakan OpenCV. Berikut adalah sintaks dari metode ini.

imread(filename)

Ini menerima argumen (filename), variabel tipe String yang merepresentasikan jalur file yang akan dibaca.

Diberikan di bawah ini adalah langkah-langkah yang harus diikuti untuk membaca gambar di Java menggunakan pustaka OpenCV.

Langkah 1: Muat pustaka asli OpenCV

Muat pustaka asli OpenCV menggunakan load() metode, seperti yang ditunjukkan di bawah ini.

//Loading the core library 
System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

Langkah 2: Buat instance kelas Imgcodecs

Instantiate Imgcodecs kelas.

//Instantiating the Imgcodecs class 
Imgcodecs imageCodecs = new Imgcodecs();

Langkah 3: Membaca gambar

Baca gambar menggunakan metode ini imread(). Metode ini menerima argumen string yang mewakili jalur gambar dan mengembalikan gambar dibaca sebagaiMat obyek.

//Reading the Image from the file  
Mat matrix = imageCodecs.imread(Path of the image);

Contoh

Kode program berikut menunjukkan bagaimana Anda bisa read an image menggunakan perpustakaan OpenCV.

import org.opencv.core.Core; 
import org.opencv.core.Mat;  
import org.opencv.imgcodecs.Imgcodecs;
 
public class ReadingImages {
   public static void main(String args[]) { 
      //Loading the OpenCV core library  
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME ); 
     
      //Instantiating the Imagecodecs class 
      Imgcodecs imageCodecs = new Imgcodecs(); 
     
      //Reading the Image from the file  
      String file ="C:/EXAMPLES/OpenCV/sample.jpg"; 
      Mat matrix = imageCodecs.imread(file); 
     
      System.out.println("Image Loaded");     
   } 
}

Saat menjalankan program di atas, OpenCV memuat gambar yang ditentukan dan menampilkan output berikut -

Image Loaded

Itu write() metode dari Imgcodecskelas digunakan untuk menulis gambar menggunakan OpenCV. Untuk menulis gambar, ulangi tiga langkah pertama dari contoh sebelumnya.

Untuk menulis gambar, Anda perlu menjalankan imwrite() metode dari Imgcodecs kelas.

Berikut adalah sintaks dari metode ini.

imwrite(filename, mat)

Metode ini menerima parameter berikut -

  • filename - A String variabel yang mewakili jalur tempat menyimpan file.

  • mat - A Mat objek yang mewakili gambar yang akan ditulis.

Contoh

Program berikut adalah contoh untuk write an image menggunakan program Java menggunakan pustaka OpenCV.

import org.opencv.core.Core; 
import org.opencv.core.Mat; 
import org.opencv.imgcodecs.Imgcodecs;
 
public class WritingImages {  
   public static void main(String args[]) { 
      //Loading the OpenCV core library  
      System.loadLibrary(Core.NATIVE_LIBRARY_NAME); 
      
      //Instantiating the imagecodecs class 
      Imgcodecs imageCodecs = new Imgcodecs(); 

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

      System.out.println("Image Loaded ..........");
      String file2 = "C:/EXAMPLES/OpenCV/sample_resaved.jpg"; 

      //Writing the image 
      imageCodecs.imwrite(file2, matrix); 
      System.out.println("Image Saved ............"); 
   } 
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Image Loaded .......... 
Image Saved ...........

Jika Anda membuka jalur yang ditentukan, Anda dapat mengamati gambar yang disimpan seperti yang ditunjukkan di bawah ini -

Pada bab sebelumnya, kita telah membahas cara membaca dan menyimpan gambar menggunakan pustaka Java OpenCV. Selain itu, kami juga dapat menampilkan gambar yang dimuat di jendela terpisah menggunakan pustaka GUI seperti AWT / Swings dan JavaFX.

Mengonversi Mat ke Gambar Buffered

Untuk membaca gambar kami menggunakan metode imread(). Metode ini mengembalikan gambar yang dibaca dalam bentukMatrix. Tapi, untuk menggunakan gambar ini dengan perpustakaan GUI (AWT / Swings dan JavaFX), itu harus dikonversi sebagai objek kelasBufferedImage dari paket java.awt.image.BufferedImage.

Berikut adalah langkah-langkah untuk mengubah file Mat objek OpenCV ke BufferedImage obyek.

Langkah 1: Enkode Mat ke MatOfByte

Pertama-tama, Anda perlu mengubah matriks menjadi matriks byte. Anda dapat melakukannya dengan menggunakan metode iniimencode() dari kelas Imgcodecs. Berikut adalah sintaks dari metode ini.

imencode(ext, image, matOfByte);

Metode ini menerima parameter berikut -

  • Ext - Parameter String yang menentukan format gambar (.jpg, .png, dll.)

  • image - Objek Mat pada gambar

  • matOfByte - Objek kosong dari kelas MatOfByte

Encode gambar menggunakan metode ini seperti yang ditunjukkan di bawah ini.

//Reading the image 
Mat image = Imgcodecs.imread(file);

//instantiating an empty MatOfByte class 
MatOfByte matOfByte = new MatOfByte();

//Converting the Mat object to MatOfByte 
Imgcodecs.imencode(".jpg", image, matOfByte);

Langkah 2: Ubah objek MatOfByte menjadi array byte

Ubah file MatOfByte objek ke dalam array byte menggunakan metode toArray().

byte[] byteArray = matOfByte.toArray();

Langkah 3: Mempersiapkan objek InputStream

Siapkan objek InputStream dengan meneruskan larik byte yang dibuat pada langkah sebelumnya ke konstruktor file ByteArrayInputStream kelas.

//Preparing the InputStream object 
InputStream in = new ByteArrayInputStream(byteArray);

Langkah 4: Mempersiapkan objek InputStream

Teruskan objek Input Stream yang dibuat di langkah sebelumnya ke read() metode dari ImageIOkelas. Ini akan mengembalikan objek BufferedImage.

//Preparing the BufferedImage 
BufferedImage bufImage = ImageIO.read(in);

Menampilkan Gambar menggunakan AWT / Swings

Untuk menampilkan gambar menggunakan bingkai AWT / Swings, pertama-tama, baca gambar menggunakan imread() metode dan mengubahnya menjadi BufferedImage mengikuti langkah-langkah yang disebutkan di atas.

Kemudian, buat instance JFrame kelas dan tambahkan gambar buffer yang dibuat ke ContentPane dari JFrame, seperti yang ditunjukkan di bawah ini -

//Instantiate JFrame 
JFrame frame = new JFrame();
 
//Set Content to the JFrame 
frame.getContentPane().add(new JLabel(new ImageIcon(bufImage))); 
frame.pack(); 
frame.setVisible(true);

Example

Kode program berikut menunjukkan bagaimana Anda bisa read gambar dan display melalui jendela ayun menggunakan perpustakaan OpenCV.

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;

import javax.imageio.ImageIO;
import javax.swing.ImageIcon;
import javax.swing.JFrame;
import javax.swing.JLabel;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.imgcodecs.Imgcodecs;

public class DisplayingImagesUsingSwings {
   public static void main(String args[]) throws Exception { 
      //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 image = Imgcodecs.imread(file); 
    
      //Encoding the image 
      MatOfByte matOfByte = new MatOfByte();       
      Imgcodecs.imencode(".jpg", image, matOfByte); 

      //Storing the encoded Mat in a byte array 
      byte[] byteArray = matOfByte.toArray(); 

      //Preparing the Buffered Image 
      InputStream in = new ByteArrayInputStream(byteArray); 
      BufferedImage bufImage = ImageIO.read(in); 

      //Instantiate JFrame 
      JFrame frame = new JFrame(); 

      //Set Content to the JFrame 
      frame.getContentPane().add(new JLabel(new ImageIcon(bufImage))); 
      frame.pack(); 
      frame.setVisible(true);
      
      System.out.println("Image Loaded");     
   } 
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Image Loaded

Selain itu, Anda dapat melihat jendela yang menampilkan gambar yang dimuat, sebagai berikut -

Menampilkan Gambar menggunakan JavaFX

Untuk menampilkan gambar menggunakan JavaFX, pertama-tama, baca gambar menggunakan imread() metode dan mengubahnya menjadi BufferedImage. Kemudian, ubah BufferedImage menjadi WritableImage, seperti yang ditunjukkan di bawah ini.

WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

Lewati ini WritableImage keberatan dengan konstruktor ImageView kelas.

ImageView imageView = new ImageView(writableImage);

Example

Kode program berikut menunjukkan caranya read gambar dan display melalui jendela JavaFX menggunakan pustaka OpenCV.

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;

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 javax.imageio.ImageIO;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfByte;
import org.opencv.imgcodecs.Imgcodecs;

public class DisplayingImagesJavaFX extends Application {
   @Override 
   public void start(Stage stage) throws IOException {   
      WritableImage writableImage = loadImage(); 
  
      //Setting the image view 
      ImageView imageView = new ImageView(writableImage); 
        
      //Setting the position of the image 
      imageView.setX(50); 
      imageView.setY(25); 
        
      //setting the fit height and width of the image view 
      imageView.setFitHeight(400); 
      imageView.setFitWidth(500);
      
      //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 loadImage() throws IOException {
      //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 image = Imgcodecs.imread(file);
      
      //Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", image, matOfByte);

      //Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();
      
      //Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray); 
      BufferedImage bufImage = ImageIO.read(in);

      System.out.println("Image Loaded");
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage; 
   }
   public static void main(String args[]) {
      launch(args); 
   } 
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Image Loaded

Selain itu, Anda dapat melihat jendela yang menampilkan gambar yang dimuat, sebagai berikut -

OpenCV mendukung berbagai jenis gambar seperti berwarna, biner, grayscale, dll. Menggunakan imread() metode dan bidang standar dari Imgcodecs kelas, Anda dapat membaca gambar yang diberikan sebagai tipe lain.

Parameter bendera metode imread () (IMREAD_XXX)

Di bab-bab sebelumnya, kita telah melihat sintaks imread() metode dari Imgcodecskelas. Ini menerima argumen string yang mewakili lokasi gambar yang akan dibaca.

imread(filename)

Itu imread() metode memiliki sintaks lain.

imread(filename, int flags)

Sintaks ini menerima dua parameter -

  • filename - Ini menerima argumen (filename), variabel tipe String yang merepresentasikan jalur file yang akan dibaca.

  • flags- Nilai integer yang mewakili nilai flag yang telah ditentukan sebelumnya. Untuk setiap nilai, ini membaca gambar yang diberikan sebagai jenis tertentu (warna skala abu-abu, dll.)

Berikut adalah tabel yang mencantumkan berbagai bidang yang disediakan di Imgproc kelas sebagai nilai untuk parameter ini.

S.No Bidang dan Deskripsi
1

IMREAD_COLOR

Jika bendera disetel ke nilai ini, gambar yang dimuat akan dikonversi menjadi gambar berwarna BGR (Biru Hijau Merah) 3 saluran.

2

IMREAD_GRAYSCALE

Jika bendera disetel ke nilai ini, gambar yang dimuat akan dikonversi menjadi gambar skala abu-abu saluran tunggal.

3

IMREAD_LOAD_GDAL

Jika bendera disetel ke nilai ini, Anda dapat memuat gambar menggunakan gdal sopir.

4

IMREAD_ANYCOLOR

Jika bendera disetel ke nilai ini, gambar dibaca dalam format warna apa pun yang memungkinkan.

5

IMREAD_REDUCED_COLOR_2

IMREAD_REDUCED_COLOR_4

IMREAD_REDUCED_COLOR_8

Jika bendera disetel ke nilai ini, gambar dibaca sebagai BGR tiga saluran, dan ukuran gambar dikurangi menjadi ½, ¼ th atau ⅛ th dari ukuran asli gambar sehubungan dengan bidang yang digunakan.

6

IMREAD_REDUCED_GRAYSCALE_2

IMREAD_REDUCED_GRAYSCALE_4

IMREAD_REDUCED_GRAYSCALE_8

Jika bendera disetel ke nilai ini, gambar dibaca sebagai gambar skala abu-abu saluran tunggal, dan ukuran gambar dikurangi menjadi ½, ¼ th atau ⅛ th dari ukuran asli gambar sehubungan dengan bidang yang digunakan .

7

IMREAD_UNCHANGED

Jika bendera disetel ke nilai ini, gambar yang dimuat dikembalikan apa adanya.

Program berikut menunjukkan cara membaca gambar berwarna sebagai skala abu-abu dan menampilkannya menggunakan jendela JavaFX. Di sini, kami telah membaca gambar dengan mengoper benderaIMREAD_GRAYSCALE bersama dengan String yang menahan jalur gambar berwarna.

import java.awt.image.BufferedImage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;

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 ReadingAsGrayscale 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("Reading image as grayscale");
      
      // 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 imagecodecs class
      Imgcodecs imageCodecs = new Imgcodecs();

      String input = "C:/EXAMPLES/OpenCV/sample.jpg";

      // Reading the image
      Mat src = imageCodecs.imread(input, Imgcodecs.IMREAD_GRAYSCALE);
       
      byte[] data1 = new byte[src.rows() * src.cols() * (int)(src.elemSize())];
      src.get(0, 0, data1);
      
      // Creating the buffered image
      BufferedImage bufImage = new BufferedImage(src.cols(),src.rows(), 
         BufferedImage.TYPE_BYTE_GRAY);
      
      // Setting the data elements to the image
      bufImage.getRaster().setDataElements(0, 0, src.cols(), src.rows(), data1);
              
      // Creating a WritableImage
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      System.out.println("Image Read");
      return writableImage;
   } 
   public static void main(String args[]) throws Exception { 
      launch(args); 
   } 
}

Gambar Masukan

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

Gambar Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut.

Program berikut menunjukkan cara membaca gambar berwarna sebagai gambar jenis BGR dan menampilkannya menggunakan jendela JavaFX. Di sini, kami telah membaca gambar dengan mengoper benderaIMREAD_COLOR ke metode imread() bersama dengan String yang menahan jalur gambar berwarna.

import java.awt.image.BufferedImage;

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.imgcodecs.Imgcodecs;

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 ReadingAsColored 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("Reading as colored 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 );
       
      String input = "C:/EXAMPLES/OpenCV/sample.jpg";
       
      Mat dst = new Mat();

      // Reading the image
      Mat src = Imgcodecs.imread(input, Imgcodecs.IMREAD_COLOR);

      byte[] data1 = new byte[src.rows() * src.cols() * (int)(src.elemSize())]; 
      src.get(0, 0, data1);
      
      // Creating the buffered image
      BufferedImage bufImage = new BufferedImage(src.cols(),src.rows(), 
         BufferedImage.TYPE_3BYTE_BGR);

      // Setting the data elements to the image 
      bufImage.getRaster().setDataElements(0, 0, src.cols(), src.rows(), data1);

      // Creating a WritableImage
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

      System.out.println("Image read");
      return writableImage;
   } 
   public static void main(String args[]) throws Exception {
      launch(args);
   } 
}

Gambar Masukan

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

Gambar Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut.

Pada bab sebelumnya, kita membahas bagaimana membaca citra input sebagai tipe yang berbeda (biner, grayscale, BGR, dll.). Pada bab ini, kita akan belajar bagaimana mengubah satu jenis gambar ke gambar lainnya.

Kelas bernama Imgproc dari paket org.opencv.imgproc menyediakan metode untuk mengubah gambar dari satu warna ke warna lainnya.

Mengonversi Gambar Berwarna ke Skala Abu-abu

Sebuah metode bernama cvtColor()digunakan untuk mengubah gambar berwarna menjadi skala abu-abu. Berikut adalah sintaks dari metode ini.

cvtColor(Mat src, Mat dst, int code)

Metode ini menerima parameter berikut -

  • src - Matriks yang mewakili sumber.

  • dst - Matriks yang mewakili tujuan.

  • code - Kode integer yang mewakili jenis konversi, misalnya RGB ke Grayscale.

Anda dapat mengubah gambar berwarna menjadi skala abu-abu dengan meneruskan kode Imgproc.COLOR_RGB2GRAY bersama dengan matriks sumber dan tujuan sebagai parameter untuk cvtColor() metode.

Contoh

Program berikut menunjukkan cara membaca gambar berwarna sebagai gambar grayscale dan menampilkannya menggunakan jendela JavaFX.

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 ColorToGrayscale 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("Colored to grayscale 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 );

      String input = "C:/EXAMPLES/OpenCV/sample.jpg";

      //Reading the image
      Mat src = Imgcodecs.imread(input);

      //Creating the empty destination matrix
      Mat dst = new Mat();

      //Converting the image to gray sacle and saving it in the dst matrix
      Imgproc.cvtColor(src, dst, Imgproc.COLOR_RGB2GRAY);
      
      //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 WritableImage
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      System.out.println("Converted to Grayscale");
      return writableImage;
   }
   public static void main(String args[]) throws Exception {
      launch(args);
   }
}

Gambar Masukan

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

Gambar Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut.

Sebuah metode yang disebut threshold()digunakan untuk mengubah gambar grayscale menjadi gambar biner. Berikut adalah sintaks dari metode ini.

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

Metode ini menerima parameter berikut -

  • mat - A Mat objek yang mewakili gambar masukan.

  • dst - A Mat objek yang mewakili gambar keluaran.

  • thresh - Bilangan bulat yang mewakili nilai ambang batas.

  • maxval - Bilangan bulat yang mewakili nilai maksimum untuk digunakan dengan tipe thresholding THRESH_BINARY dan THRESH_BINARY_INV.

  • type - Kode integer yang mewakili jenis konversi, misalnya RGB ke Grayscale.

Anda dapat mengubah gambar grayscale ke gambar biner dengan melewatkan kode Imgproc.THRESH_BINARY bersama dengan nilai parameter yang tersisa.

Contoh

Program berikut menunjukkan cara membaca gambar berwarna sebagai gambar biner dan menampilkannya menggunakan jendela JavaFX.

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

Gambar Masukan

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

Gambar Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut.

Anda dapat menggunakan metode yang sama yang disebutkan di bab sebelumnya untuk mengonversi citra grayscale menjadi citra biner. Lewati saja jalur untuk citra grayscale sebagai masukan untuk program ini.

Contoh

Program berikut menunjukkan cara membaca gambar grayscale sebagai gambar biner dan menampilkannya menggunakan jendela JavaFX.

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 GrayScaleToBinary 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("Grayscale to binary 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 imagecodecs class
      Imgcodecs imageCodecs = new Imgcodecs();

      String input = "E:/OpenCV/chap7/grayscale.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_BINARY);

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

Gambar Masukan

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

Gambar Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut.

Anda dapat menggambar berbagai bentuk seperti Circle, Rectangle, Line, Ellipse, Polylines, Convex, Polylines, Polylines pada gambar menggunakan metode masing-masing org.opencv.imgproc paket.

Anda dapat menggambar lingkaran pada gambar menggunakan metode ini circle() dari imgprockelas. Berikut adalah sintaks dari metode ini -

circle(img, center, radius, color, thickness)

Metode ini menerima parameter berikut -

  • mat - A Mat objek yang mewakili gambar di mana lingkaran akan digambar.

  • point - A Point objek yang mewakili pusat lingkaran.

  • radius - Variabel tipe integer mewakili jari-jari lingkaran.

  • scalar - A Scalarobjek yang mewakili warna lingkaran. (BGR)

  • thickness - An integermewakili ketebalan lingkaran; secara default, nilai ketebalan adalah 1.

Contoh

Program berikut mendemonstrasikan cara menggambar lingkaran pada gambar dan menampilkannya menggunakan jendela JavaFX.

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

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.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingCircle extends Application {
   Mat matrix = null;
   
   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      DrawingCircle obj = new DrawingCircle();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      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("Drawing Circle on the image");
      
      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }      
   public WritableImage LoadImage() throws Exception {
      // 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 ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      //Drawing a Circle Imgproc.circle ( matrix, //Matrix obj of the image new Point(230, 160), //Center of the circle 100, //Radius new Scalar(0, 0, 255), //Scalar object for color 10 //Thickness of the circle );
      
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);
      this.matrix = matrix;
      
      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Anda dapat menggambar garis pada gambar menggunakan metode ini line() dari imgprockelas. Berikut adalah sintaks dari metode ini.

line(img, pt1, pt2, color, thickness)

Metode ini menerima parameter berikut -

  • mat - A Mat objek yang mewakili gambar di mana garis akan ditarik.

  • pt1 and pt2 - Dua Point benda-benda yang mewakili titik-titik di mana garis akan ditarik.

  • scalar - A Scalarobjek yang mewakili warna lingkaran. (BGR)

  • thickness- Bilangan bulat yang mewakili ketebalan garis; secara default, nilai ketebalan adalah 1.

Contoh

Program berikut menunjukkan cara menggambar garis pada gambar dan menampilkannya menggunakan jendela JavaFX.

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

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.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingLine extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
   
      // Capturing the snapshot from the camera
      DrawingLine obj = new DrawingLine();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      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("Drawing a line on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // 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 ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      // Drawing a line Imgproc.line ( matrix, //Matrix obj of the image new Point(10, 200), //p1 new Point(300, 200), //p2 new Scalar(0, 0, 255), //Scalar object for color 5 //Thickness of the line );
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);

      this.matrix = matrix;

      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Anda dapat menggambar persegi panjang pada gambar menggunakan metode ini rectangle() dari imgprockelas. Berikut adalah sintaks dari metode ini -

rectangle(img, pt1, pt2, color, thickness)

Metode ini menerima parameter berikut -

  • mat - A Mat objek yang mewakili gambar persegi panjang yang akan digambar.

  • pt1 and pt2 - Dua Point objek yang mewakili simpul dari persegi panjang yang akan digambar.

  • scalar - A Scalarobjek yang mewakili warna persegi panjang. (BGR)

  • thickness- Bilangan bulat yang mewakili ketebalan persegi panjang; secara default, nilai ketebalan adalah 1.

Contoh

Contoh berikut menunjukkan cara menggambar persegi panjang pada gambar dan menampilkannya menggunakan jendela JavaFX.

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

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.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingRectangle extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      DrawingRectangle obj = new DrawingRectangle();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      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("Drawing Rectangle on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // 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 ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      // Drawing a Rectangle Imgproc.rectangle ( matrix, //Matrix obj of the image new Point(130, 50), //p1 new Point(300, 280), //p2 new Scalar(0, 0, 255), //Scalar object for color 5 //Thickness of the line );
      
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);

      this.matrix = matrix;

      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Anda dapat menggambar elips pada gambar menggunakan metode ini rectangle() dari imgprockelas. Berikut adalah sintaks dari metode ini -

ellipse(img, box, color, thickness)

Metode ini menerima parameter berikut -

  • mat - A Mat objek yang mewakili gambar di mana Persegi akan digambar.

  • box - Objek RotatedRect (Elips digambar tertulis dalam persegi panjang ini.)

  • scalar - A Scalarobjek yang mewakili warna Persegi Panjang. (BGR)

  • thickness- Bilangan bulat yang mewakili ketebalan Persegi Panjang; secara default, nilai ketebalan adalah 1.

Konstruktor file RotatedRect kelas menerima objek dari kelas Point, objek dari kelas Ukuran, dan variabel tipe ganda, seperti yang ditunjukkan di bawah ini.

RotatedRect(Point c, Size s, double a)

Contoh

Program berikut menunjukkan cara menggambar elips pada gambar dan menampilkannya menggunakan jendela JavaFX.

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

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.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.RotatedRect;
import org.opencv.core.Scalar;
import org.opencv.core.Size;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingEllipse extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      DrawingEllipse obj = new DrawingEllipse();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      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("Drawing Ellipse on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // 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 ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      // Drawing an Ellipse Imgproc.ellipse ( matrix, //Matrix obj of the image new RotatedRect ( // RotatedRect(Point c, Size s, double a) new Point(200, 150), new Size(260, 180), 180 ), new Scalar(0, 0, 255), //Scalar object for color 10 //Thickness of the line );
      
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);

      this.matrix = matrix;
      
      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Anda dapat menggambar Polylines pada gambar menggunakan metode ini polylines() dari imgprockelas. Berikut adalah sintaks dari metode ini.

polylines(img, pts, isClosed, color, thickness)

Metode ini menerima parameter berikut -

  • mat - A Mat objek yang mewakili gambar di mana Polylines akan digambar.

  • pts - A List objek yang menahan objek bertipe MatOfPoint.

  • isClosed - Parameter tipe boolean yang menentukan cuaca ketika polyline ditutup.

  • scalar - A Scalarobjek yang mewakili warna Polylines. (BGR)

  • thickness- Bilangan bulat yang mewakili ketebalan Polylines; secara default, nilai ketebalan adalah 1.

Konstruktor file MatOfPoint kelas menerima objek dari kelas Point.

MatOfPoint(Point... a)

Contoh

Program berikut menunjukkan cara menggambar polyline pada gambar dan menampilkannya menggunakan jendela JavaFX.

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;

import java.util.ArrayList;
import java.util.List;
import javax.imageio.ImageIO;

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.MatOfByte;
import org.opencv.core.MatOfPoint;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingPolyLines extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      DrawingPolyLines obj = new DrawingPolyLines();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      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("Drawing Polylines on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }      
   public WritableImage LoadImage() throws Exception {
      // 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 ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      List<MatOfPoint> list = new ArrayList();
      list.add(
         new MatOfPoint (
            new Point(75, 100), new Point(350, 100),
            new Point(75, 150), new Point(350, 150),
            new Point(75, 200), new Point(350, 200),
            new Point(75, 250), new Point(350, 250)
         )
      );
      // Drawing polylines Imgproc.polylines ( matrix, // Matrix obj of the image list, // java.util.List<MatOfPoint> pts false, // isClosed new Scalar(0, 0, 255), // Scalar object for color 2 // Thickness of the line );
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);

      this.matrix = matrix;

      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Anda dapat menggambar polyline cembung pada gambar menggunakan metode ini fillconvexPoly() dari imgprockelas. Berikut adalah sintaks dari metode ini.

fillConvexPoly(Mat img, MatOfPoint points, Scalar color)

Metode ini menerima parameter berikut -

  • mat - A Mat objek yang mewakili gambar di mana Polylines cembung akan digambar.

  • points - A MatOfPoint objek yang merepresentasikan titik-titik di mana polylines cembung akan digambar.

  • scalar - A Scalarobjek yang mewakili warna Polylines cembung. (BGR)

Konstruktor file MatOfPoint kelas menerima objek dari kelas Point.

MatOfPoint(Point... a)

Contoh

Program berikut mendemonstrasikan cara menggambar polyline cembung pada gambar dan menampilkannya menggunakan jendela JavaFX.

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

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.MatOfByte;
import org.opencv.core.MatOfPoint;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class FillConvexPoly extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      FillConvexPoly obj = new FillConvexPoly();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      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("Drawing convex Polylines (fill) on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // 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 ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      MatOfPoint matOfPoint = new MatOfPoint (
         new Point(75, 100), new Point(350, 100),
         new Point(75, 150), new Point(350, 150),
         new Point(75, 200), new Point(350, 200),
         new Point(75, 250), new Point(350, 250)
      ); 
      // Drawing polylines Imgproc.fillConvexPoly ( matrix, // Matrix obj of the image matOfPoint, // java.util.List<MatOfPoint> pts new Scalar(0, 0, 255) // Scalar object for color );
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);
      this.matrix = matrix;
            
      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage;
   } 
   public static void main(String args[]) {
      launch(args);
   }
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Anda dapat menggambar garis panah pada gambar menggunakan metode ini arrowedLine() dari imgprockelas. Berikut adalah sintaks dari metode ini -

arrowedLine(Mat img, Point pt1, Point pt2, Scalar color)

Metode ini menerima parameter berikut -

  • mat - A Mat objek yang mewakili gambar di mana garis panah akan digambar.

  • pt1 and pt2 - Dua Point objek yang mewakili titik-titik di mana garis panah akan ditarik.

  • scalar - A Scalarobjek yang mewakili warna garis panah. (BGR)

Contoh

Program berikut menunjukkan cara menggambar garis panah pada gambar dan menampilkannya menggunakan jendela JavaFX.

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

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.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class DrawingArrowedLine extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      DrawingArrowedLine obj = new DrawingArrowedLine();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      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("Drawing a line on the image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // 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/Aish.jpg";
      Mat matrix = Imgcodecs.imread(file);

      //Drawing a line Imgproc.arrowedLine( matrix, // Matrix obj of the image new Point(10, 200), // p1 new Point(590, 200), // p2 new Scalar(0, 100, 255) // Scalar object for color );

      // arrowedLine(Mat img, Point pt1, Point pt2, Scalar color)
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);
      this.matrix = matrix;

      // Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);

      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Anda dapat menambahkan teks ke gambar menggunakan metode ini arrowedLine() dari imgprockelas. Berikut adalah sintaks dari metode ini.

putText(img, text, org, fontFace, fontScale, Scalar color, int thickness)

Metode ini menerima parameter berikut -

  • mat - A Mat objek yang mewakili gambar yang akan ditambahkan teks.

  • text - A string variabel yang mewakili teks yang akan ditambahkan.

  • org - A Point objek yang mewakili string teks sudut kiri bawah pada gambar.

  • fontFace - Variabel tipe integer yang mewakili tipe font.

  • fontScale - Variabel bertipe double yang mewakili faktor skala yang dikalikan dengan ukuran dasar font tertentu.

  • scalar - A Scalarobjek yang mewakili warna teks yang akan ditambahkan. (BGR)

  • thickness - Integer yang mewakili ketebalan garis secara default, nilai ketebalan adalah 1.

Contoh

Program berikut mendemonstrasikan cara menambahkan teks ke gambar dan menampilkannya menggunakan jendela JavaFX.

import java.awt.image.BufferedImage;

import java.io.ByteArrayInputStream;
import java.io.InputStream;
import javax.imageio.ImageIO;

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.MatOfByte;
import org.opencv.core.Point;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class AddingTextToImage extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws Exception {
      // Capturing the snapshot from the camera
      AddingTextToImage obj = new AddingTextToImage();
      WritableImage writableImage = obj.LoadImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // setting the fit height and width of the image view
      imageView.setFitHeight(600);
      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("Adding text to an image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage LoadImage() throws Exception {
      // 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 ="E:/OpenCV/chap8/input.jpg";
      Mat matrix = Imgcodecs.imread(file);

      // Adding Text Imgproc.putText ( matrix, // Matrix obj of the image "Ravivarma's Painting", // Text to be added new Point(10, 50), // point Core.FONT_HERSHEY_SIMPLEX , // front face 1, // front scale new Scalar(0, 0, 0), // Scalar object for color 4 // Thickness );
      
      // Encoding the image
      MatOfByte matOfByte = new MatOfByte();
      Imgcodecs.imencode(".jpg", matrix, matOfByte);

      // Storing the encoded Mat in a byte array
      byte[] byteArray = matOfByte.toArray();

      // Displaying the image
      InputStream in = new ByteArrayInputStream(byteArray);
      BufferedImage bufImage = ImageIO.read(in);
      this.matrix = matrix;

      //Creating the Writable Image
      WritableImage writableImage = SwingFXUtils.toFXImage(bufImage, null);
      return writableImage;
   }
   public static void main(String args[]) {
      launch(args);
   }
}

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Blurring (smoothing) adalah operasi pemrosesan gambar yang umum digunakan untuk mengurangi noise gambar. Proses ini menghapus konten frekuensi tinggi, seperti tepian, dari gambar dan membuatnya mulus.

Secara umum, pengaburan dicapai dengan konvolusi (setiap elemen gambar ditambahkan ke tetangga lokalnya, diberi bobot oleh kernel) gambar melalui kernel filter akses rendah.

Buram (Rata-rata)

Selama operasi ini, gambar dibelitkan dengan filter kotak (dinormalisasi). Dalam proses ini, elemen pusat gambar diganti dengan rata-rata semua piksel di area kernel.

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

blur(src, dst, ksize, anchor, borderType)

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.

  • ksize - A Size objek yang mewakili ukuran kernel.

  • anchor - Variabel jenis integer yang mewakili titik jangkar.

  • borderType - Variabel tipe integer yang mewakili tipe border yang akan digunakan untuk output.

Contoh

Program berikut memperagakan cara melakukan operasi rata-rata (buram) pada gambar.

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

public class BlurTest {
   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();

      // Creating the Size and Point objects
      Size size = new Size(45, 45);
      Point point = new Point(20, 30);

      // Applying Blur effect on the Image
      Imgproc.blur(src, dst, size, point, Core.BORDER_DEFAULT);

      // blur(Mat src, Mat dst, Size ksize, Point anchor, int borderType)
      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap9/blur.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 Processed

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

Dalam operasi Gaussian Blur, gambar berbelit-belit dengan filter Gaussian, bukan filter kotak. Filter Gaussian adalah filter low-pass yang menghilangkan komponen frekuensi tinggi yang berkurang.

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

GaussianBlur(src, dst, ksize, sigmaX)

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.

  • ksize - A Size objek yang mewakili ukuran kernel.

  • sigmaX - Variabel tipe double yang mewakili deviasi standar kernel Gaussian dalam arah X.

Contoh

Program berikut mendemonstrasikan cara melakukan operasi Gaussian blur pada gambar.

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 GaussianTest {
   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();
    
      // Applying GaussianBlur on the Image
      Imgproc.GaussianBlur(src, dst, new Size(45, 45), 0);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap9/Gaussian.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 Processed

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

Operasi Median blur serupa dengan metode rata-rata lainnya. Di sini, elemen pusat gambar diganti dengan median semua piksel di area kernel. Operasi ini memproses tepi sambil menghilangkan noise.

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

medianBlur(src, dst, ksize)

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.

  • ksize - A Size objek yang mewakili ukuran kernel.

Contoh

Program berikut menunjukkan cara melakukan operasi keburaman median pada gambar.

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

public class MedianBlurTest {
   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();

      // Applying MedianBlur on the Image
      Imgproc.medianBlur(src, dst, 15);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap9/median.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 Processed

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

Pemfilteran gambar memungkinkan Anda menerapkan berbagai efek pada gambar. Dalam bab ini dan tiga bab berikutnya, kita akan membahas berbagai operasi filter seperti Filter Bilateral, Filter Kotak, Filter Kotak SQR dan Filter2D.

Filter Bilateral

Operasi Filter Bilateral menerapkan gambar bilateral ke filter. Anda dapat melakukan operasi ini pada gambar menggunakanmedianBlur() metode dari imgprockelas. Berikut adalah sintaks dari metode ini.

bilateralFilter(src, dst, d, sigmaColor, sigmaSpace, borderType)

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.

  • d - Variabel dengan tipe integer yang mewakili diameter lingkungan piksel.

  • sigmaColor - Variabel dengan tipe integer yang mewakili sigma filter dalam ruang warna.

  • sigmaSpace - Variabel dengan tipe integer yang merepresentasikan sigma filter dalam ruang koordinat.

  • borderType - Objek integer yang mewakili jenis perbatasan yang digunakan.

Contoh

Program berikut menunjukkan cara melakukan operasi Filter Bilateral pada gambar.

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

public class BilateralFilter {
   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 ="E:/OpenCV/chap11/filter_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

      // Applying Bilateral filter on the Image
      Imgproc.bilateralFilter(src, dst, 15, 80, 80, Core.BORDER_DEFAULT);

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

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

Asumsikan bahwa berikut ini adalah gambar input filter_input.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 -

Operasi Filter Kotak mirip dengan operasi blur rata-rata; itu menerapkan gambar bilateral ke filter. Di sini, Anda dapat memilih apakah kotak akan dinormalisasi atau tidak.

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

boxFilter(src, dst, ddepth, ksize, anchor, normalize, borderType)

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.

  • ddepth - Variabel tipe integer yang mewakili kedalaman gambar keluaran.

  • ksize - A Size objek yang mewakili ukuran kernel yang diburamkan.

  • anchor - Variabel jenis integer yang mewakili titik jangkar.

  • Normalize - Variabel tipe boolean yang menentukan cuaca kernel harus dinormalisasi.

  • borderType - Objek integer yang mewakili jenis perbatasan yang digunakan.

Contoh

Program berikut menunjukkan bagaimana melakukan operasi Filter Kotak pada gambar.

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

public class BoxFilterTest {
   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 = "E:/OpenCV/chap11/filter_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

      // Creating the objects for Size and Point
      Size size = new Size(45, 45);
      Point point = Point(-1, -1);

      // Applying Box Filter effect on the Image
      Imgproc.boxFilter(src, dst, 50, size, point, true, Core.BORDER_DEFAULT);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap11/boxfilterjpg", dst);

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

Asumsikan bahwa berikut ini adalah gambar input filter_input.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 -

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

sqrBoxFilter(src, dst, ddepth, ksize)

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.

  • ddepth - Variabel tipe integer yang mewakili kedalaman gambar keluaran.

  • ksize - A Size objek yang mewakili ukuran kernel yang diburamkan.

Contoh

Program berikut mendemonstrasikan bagaimana melakukan operasi filter Sqrbox pada gambar yang diberikan.

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 SqrBoxFilterTest {
   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 ="E:/OpenCV/chap11/filter_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

      // Applying Box Filter effect on the Image
      Imgproc.sqrBoxFilter(src, dst, -1, new Size(1, 1));
     
      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap11/sqrboxfilter.jpg", dst);

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

Asumsikan bahwa berikut ini adalah gambar input filter_input.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 -

Operasi Filter2D menggabungkan gambar dengan kernel. Anda dapat melakukan operasi ini pada gambar menggunakanFilter2D() metode dari imgprockelas. Berikut adalah sintaks dari metode ini -

filter2D(src, dst, ddepth, 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.

  • ddepth - Variabel tipe integer yang mewakili kedalaman gambar keluaran.

  • kernel - A Mat objek yang mewakili kernel konvolusi.

Contoh

Program berikut menunjukkan cara melakukan operasi Filter2D pada gambar.

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

public class Filter2D {
   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 ="E:/OpenCV/chap11/filter_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

      // Creating kernel matrix
      Mat kernel = Mat.ones(2,2, CvType.CV_32F);
      
      for(int i = 0; i<kernel.rows(); i++) {
         for(int j = 0; j<kernel.cols(); j++) {
            double[] m = kernel.get(i, j);

            for(int k = 1; k<m.length; k++) {
               m[k] = m[k]/(2 * 2);
            }
            kernel.put(i,j, m);
         }
      }
      Imgproc.filter2D(src, dst, -1, kernel);
      Imgcodecs.imwrite("E:/OpenCV/chap11/filter2d.jpg", dst);
      System.out.println("Image Processed");
   }
}

Asumsikan bahwa berikut ini adalah gambar input filter_input.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 -

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 -

Erosi adalah proses yang sangat 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 mendemonstrasikan bagaimana 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 -

Pada bab-bab sebelumnya, kami membahas proses erosion dan dilation. Selain keduanya, OpenCV memiliki lebih banyak transformasi morfologis. ItumorphologyEx() dari metode kelas Imgproc digunakan untuk melakukan operasi ini pada gambar tertentu.

Berikut adalah sintaks dari metode ini -

morphologyEx(src, dst, op, kernel)

Metode ini menerima parameter berikut -

  • src - Objek kelas Mat mewakili gambar sumber (masukan).

  • dst - objek kelas Mat mewakili gambar tujuan (keluaran).

  • op - Bilangan bulat yang merepresentasikan jenis operasi Morfologi.

  • kernel - Matriks kernel.

Contoh

Program berikut menunjukkan bagaimana menerapkan operasi morfologi "top-hat" pada gambar menggunakan pustaka OpenCV.

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

public class MorphologyExTest {
   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 ="E:/OpenCV/chap12/morph_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

      // Creating kernel matrix
      Mat kernel = Mat.ones(5,5, CvType.CV_32F);

      // Applying Blur effect on the Image 
      Imgproc.morphologyEx(src, dst, Imgproc.MORPH_TOPHAT, kernel);

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

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

Asumsikan bahwa berikut ini adalah gambar input morph_input.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 -

Lebih Banyak Operasi

Selain operasi morfologi TOPHAT, ditunjukkan di sebelumnya example, OpenCV melayani berbagai jenis morfologi lainnya. Semua jenis ini diwakili oleh bidang statis yang telah ditentukan sebelumnya (nilai tetap) dariImgproc kelas.

Anda dapat memilih jenis morfologi yang Anda butuhkan dengan meneruskan nilai masing-masing yang telah ditentukan sebelumnya ke parameter op dari morphologyEx() metode.

// Applying Blur effect on the Image
Imgproc.morphologyEx(src, dst, Imgproc.MORPH_TOPHAT, kernel);

Berikut ini adalah nilai-nilai yang mewakili jenis operasi morfologi dan keluarannya masing-masing.

Operasi dan Deskripsi Keluaran
MORPH_BLACKHAT
MORPH_CLOSE
MORPH_CROSS
MORPH_DILATE
MORPH_ELLIPSE
MORPH_ERODE
MORPH_GRADIENT
MORPH_OPEN
MORPH_RECT
MORPH_TOPHAT

Piramida adalah operasi pada gambar di mana,

  • Gambar masukan awalnya dihaluskan menggunakan filter penghalusan tertentu (misal: Gaussian, Laplacian) dan kemudian gambar yang dihaluskan disubsampel.

  • Proses ini diulangi beberapa kali.

Selama operasi piramida, kehalusan gambar ditingkatkan dan resolusi (ukuran) dikurangi.

Pyramid Up

Di Pyramid Up, gambar awalnya diambil sampelnya lalu diburamkan. Anda dapat melakukan operasi Pyramid Up pada gambar menggunakanpyrUP() metode dari imgprockelas. Berikut adalah sintaks dari metode ini -

pyrUp(src, dst, dstsize, borderType)

Metode ini menerima parameter berikut -

  • src - Objek kelas Mat mewakili gambar sumber (masukan).

  • mat - Objek kelas Mat mewakili gambar tujuan (keluaran).

  • size - Objek kelas Size mewakili ukuran untuk memperbesar atau memperkecil gambar.

  • borderType - Variabel tipe integer yang merepresentasikan tipe border yang akan digunakan.

Contoh

Program berikut menunjukkan cara melakukan operasi Pyramid Up pada gambar.

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 PyramidUp {
   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 ="E:/OpenCV/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

      // Applying pyrUp on the Image
      Imgproc.pyrUp(src, dst, new Size(src.cols()*2,  src.rows()*2), Core.BORDER_DEFAULT);

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

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

Asumsikan bahwa berikut ini adalah gambar input pyramid_input.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 -

Piramida Bawah

Di Pyramid Down, gambar awalnya diburamkan lalu disampling ke bawah. Anda dapat melakukan operasi Pyramid Down pada gambar menggunakanpyrDown() metode dari imgprockelas. Berikut adalah sintaks dari metode ini -

pyrDown(src, dst, dstsize, borderType)

Metode ini menerima parameter berikut -

  • src - Objek kelas Mat mewakili gambar sumber (masukan).

  • mat - Objek kelas Mat mewakili gambar tujuan (keluaran).

  • size - Objek kelas Size mewakili ukuran untuk memperbesar atau memperkecil gambar.

  • borderType - Variabel tipe integer yang merepresentasikan tipe border yang akan digunakan.

Contoh

Program berikut mendemonstrasikan bagaimana melakukan operasi Pyramid Down pada gambar.

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 PyramidDown {
   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 ="E:/OpenCV/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

      // Applying pyrDown on the Image
      Imgproc.pyrDown(src, dst, new Size(src.cols()/2,  src.rows()/2),
         Core.BORDER_DEFAULT);

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

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

Asumsikan bahwa berikut ini adalah gambar input pyramid_input.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 -

Mean Shift Filtering

Dalam operasi piramida Pergeseran Rata-rata, langkah awal segmentasi pergeseran rata-rata suatu citra dilakukan.

Anda dapat melakukan operasi Pemfilteran Pergeseran Rata-rata piramida pada gambar menggunakan pyrDown() metode dari imgprockelas. Berikut adalah sintaks dari metode ini.

pyrMeanShiftFiltering(src, dst, sp, sr)

Metode ini menerima parameter berikut -

  • src - Objek kelas Mat mewakili gambar sumber (masukan).

  • mat - Objek kelas Mat mewakili gambar tujuan (keluaran).

  • sp - Variabel tipe double yang mewakili radius jendela spasial.

  • sr - Variabel tipe double yang mewakili radius jendela warna.

Contoh

Program berikut mendemonstrasikan bagaimana melakukan operasi Mean Shift Filtering pada gambar tertentu.

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

public class PyramidMeanShift {
   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 ="E:/OpenCV/chap13/pyramid_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

      // Applying meanShifting on the Image
      Imgproc.pyrMeanShiftFiltering(src, dst, 200, 300);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap13/meanShift_output.jpg", dst);
      
      System.out.println("Image Processed");
   } 
}

Asumsikan bahwa berikut ini adalah gambar input pyramid_input.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 -

Thresholding merupakan salah satu metode segmentasi citra, secara umum digunakan untuk membuat citra biner. Thresholding ada dua jenis yaitu thresholding sederhana dan thresholding adaptif.

Thresholding Sederhana

Dalam operasi thresholding sederhana, piksel yang nilainya lebih besar dari nilai ambang batas yang ditentukan, ditetapkan dengan nilai standar.

Anda dapat melakukan operasi ambang sederhana pada gambar menggunakan metode ini threshold() dari Imgproc class, Berikut adalah sintaks dari metode ini.

threshold(src, dst, thresh, maxval, type)

Metode ini menerima parameter berikut -

  • src - Objek kelas Mat mewakili gambar sumber (masukan).

  • dst - Objek kelas Mat mewakili gambar tujuan (keluaran).

  • thresh - Variabel tipe ganda yang mewakili nilai ambang batas.

  • maxval - Variabel tipe ganda yang mewakili nilai yang akan diberikan jika nilai piksel lebih dari nilai ambang batas.

  • type - Variabel tipe integer yang mewakili tipe ambang batas yang akan digunakan.

Contoh

Program berikut mendemonstrasikan bagaimana melakukan operasi thresholding sederhana pada image di OpenCV.

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

public class Thresh {
   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 ="E:/OpenCV/chap14/thresh_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Creating an empty matrix to store the result
      Mat dst = new Mat();
      Imgproc.threshold(src, dst, 50, 255, Imgproc.THRESH_BINARY);

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

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

Asumsikan bahwa berikut ini adalah gambar input thresh_input.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 -

Jenis thresholding sederhana lainnya

Selain itu THRESH_BINARYOperasi yang ditunjukkan dalam contoh sebelumnya, OpenCV melayani berbagai jenis operasi ambang batas lainnya. Semua jenis ini diwakili oleh bidang statis yang telah ditentukan sebelumnya (nilai tetap) dariImgproc kelas.

Anda dapat memilih jenis operasi ambang yang Anda perlukan, dengan meneruskan masing-masing nilai yang telah ditentukan sebelumnya ke parameter bernama type dari threshold() metode.

Imgproc.threshold(src, dst, 50, 255, Imgproc.THRESH_BINARY);

Berikut ini adalah nilai-nilai yang mewakili berbagai jenis operasi ambang batas dan keluarannya masing-masing.

Operasi dan Deskripsi Keluaran
THRESH_BINARY
THRESH_BINARY_INV
THRESH_TRUNC
THRESH_TOZERO
THRESH_TOZERO_INV

Di simple thresholding, nilai ambang adalah global, yaitu sama untuk semua piksel pada gambar. Adaptive thresholding adalah metode penghitungan nilai ambang batas untuk wilayah yang lebih kecil sehingga akan terdapat nilai ambang batas yang berbeda untuk wilayah yang berbeda.

Di OpenCV, Anda dapat melakukan operasi Ambang batas adaptif pada gambar menggunakan metode ini adaptiveThreshold() dari Imgprockelas. Berikut adalah sintaks dari metode ini.

adaptiveThreshold(src, dst, maxValue, adaptiveMethod, thresholdType, blockSize, C)

Metode ini menerima parameter berikut -

  • src - Objek kelas Mat mewakili gambar sumber (masukan).

  • dst - Objek kelas Mat mewakili gambar tujuan (keluaran).

  • maxValue - Variabel tipe ganda yang mewakili nilai yang akan diberikan jika nilai piksel lebih dari nilai ambang batas.

  • adaptiveMethod- Variabel integer jenis yang mewakili metode adaptif yang akan digunakan. Ini akan menjadi salah satu dari dua nilai berikut

    • ADAPTIVE_THRESH_MEAN_C - nilai ambang batas adalah rata-rata kawasan lingkungan.

    • ADAPTIVE_THRESH_GAUSSIAN_C - nilai ambang adalah jumlah tertimbang dari nilai lingkungan di mana bobot adalah jendela Gaussian.

  • thresholdType - Variabel tipe integer yang mewakili tipe ambang batas yang akan digunakan.

  • blockSize - Variabel berjenis integer yang mewakili ukuran lingkungan piksel yang digunakan untuk menghitung nilai ambang batas.

  • C - Variabel tipe ganda yang mewakili konstanta yang digunakan di kedua metode (dikurangi dari mean atau mean tertimbang).

  • Contoh

    Program berikut menunjukkan bagaimana melakukan operasi ambang batas Adaptif pada gambar di OpenCV. Di sini kami memilih ambang jenis adaptifbinary dan ADAPTIVE_THRESH_MEAN_C untuk metode ambang batas.

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    import org.opencv.imgcodecs.Imgcodecs;
    import org.opencv.imgproc.Imgproc;
    
    public class AdaptiveThresh {
       public static void main(String args[]) throws Exception {
          // 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 ="E:/OpenCV/chap14/thresh_input.jpg";
          
          // Reading the image
          Mat src = Imgcodecs.imread(file,0);
    
          // Creating an empty matrix to store the result
          Mat dst = new Mat();
    
          Imgproc.adaptiveThreshold(src, dst, 125, Imgproc.ADAPTIVE_THRESH_MEAN_C,
             Imgproc.THRESH_BINARY, 11, 12);
    
          // Writing the image
          Imgcodecs.imwrite("E:/OpenCV/chap14/Adaptivemean_thresh_binary.jpg", dst);
    
          System.out.println("Image Processed");
       } 
    }

    Asumsikan bahwa berikut ini adalah gambar input thresh_input.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 -

    Jenis Lain dari Adaptive Thresholding

    Selain itu ADAPTIVE_THRESH_MEAN_C sebagai metode adaptif dan THRESH_BINARY sebagai jenis ambang seperti yang ditunjukkan pada contoh sebelumnya, kita dapat memilih lebih banyak kombinasi dari kedua nilai ini.

    Imgproc.adaptiveThreshold(src, dst, 125, Imgproc.ADAPTIVE_THRESH_MEAN_C, Imgproc.THRESH_BINARY, 11, 12);

    Berikut adalah nilai yang mewakili berbagai kombinasi nilai untuk parameter adaptiveMethod dan thresholdType dan keluarannya masing-masing.

    adaptiveMethod / thresholdType ADAPTIVE_THRESH_MEAN_C ADAPTIVE_THRESH_GAUSSIAN_C:
    THRESH_BINARY
    THRESH_BINARY_INV

    Bab ini mengajarkan Anda cara katak berbatasan dengan gambar.

    Metode copyMakeBorder ()

    Anda dapat menambahkan berbagai batas ke gambar menggunakan metode ini copyMakeBorder() dari kelas bernama Core, yang termasuk dalam paket org.opencv.core. berikut adalah sintaks dari metode ini.

    copyMakeBorder(src, dst, top, bottom, left, right, borderType)

    Metode ini menerima parameter berikut -

    • src - Objek kelas Mat mewakili gambar sumber (masukan).

    • dst - Objek kelas Mat mewakili gambar tujuan (keluaran).

    • top - Variabel bilangan bulat, jenis bilangan bulat yang mewakili panjang batas di bagian atas gambar.

    • bottom - Variabel bilangan bulat, jenis bilangan bulat yang mewakili panjang batas di bagian bawah gambar.

    • left - Variabel integer jenis integer yang mewakili panjang perbatasan di sebelah kiri gambar.

    • right - Variabel integer jenis integer mewakili panjang perbatasan di sebelah kanan gambar.

    • borderType - Variabel tipe integer yang mewakili tipe border yang akan digunakan.

    Contoh

    Program berikut adalah contoh yang mendemonstrasikan, bagaimana menambahkan perbatasan ke gambar tertentu.

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    import org.opencv.imgcodecs.Imgcodecs;
    
    public class AddingBorder {
       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 ="E:/OpenCV/chap15/input.jpg";
          Mat src = Imgcodecs.imread(file);
    
          // Creating an empty matrix to store the result
          Mat dst = new Mat();
       
          Core.copyMakeBorder(src, dst, 20, 20, 20, 20, Core.BORDER_CONSTANT);
          Imgcodecs.imwrite("E:/OpenCV/chap15/border_constant.jpg", dst);
    
          System.out.println("Image Processed");
       }
    }

    Asumsikan bahwa berikut ini adalah gambar input thresh_input.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 -

    Jenis Perbatasan Lainnya

    Selain tipe perbatasan, BORDER_CONSTANTditunjukkan pada contoh sebelumnya, OpenCV melayani berbagai jenis perbatasan. Semua jenis ini diwakili oleh bidang statis yang telah ditentukan (nilai tetap) dari kelas Inti.

    Anda dapat memilih jenis operasi ambang yang Anda perlukan, dengan meneruskan masing-masing nilai yang telah ditentukan sebelumnya ke parameter bernama borderType dari copyMakeBorder() metode.

    Core.copyMakeBorder(src, dst, 20, 20, 20, 20, Core.BORDER_CONSTANT);

    Berikut ini adalah nilai-nilai yang mewakili berbagai jenis operasi perbatasan dan keluarannya masing-masing.

    Operasi dan Deskripsi Keluaran
    BORDER_CONSTANT
    BORDER_ISOLATED
    BORDER_DEFAULT
    BORDER_REFLECT
    BORDER_REFLECT_101
    BORDER_REFLECT101
    BORDER_REPLICATE
    BORDER_WRAP

    Menggunakan sobel operation, Anda dapat mendeteksi tepi gambar dalam arah horizontal dan vertikal. Anda dapat menerapkan operasi sobel pada gambar menggunakan metode inisobel(). Berikut adalah sintaks dari metode ini -

    Sobel(src, dst, ddepth, dx, dy)

    Metode ini menerima parameter berikut -

    • src - Objek kelas Mat mewakili gambar sumber (masukan).

    • dst - Objek kelas Mat mewakili gambar tujuan (keluaran).

    • ddepth - Variabel integer yang mewakili kedalaman gambar (-1)

    • dx- Variabel integer yang mewakili turunan x. (0 atau 1)

    • dy- Variabel integer mewakili turunan y. (0 atau 1)

    Contoh

    Program berikut menunjukkan cara melakukan operasi Sobel pada gambar tertentu.

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    
    import org.opencv.imgcodecs.Imgcodecs;
    import org.opencv.imgproc.Imgproc;
    
    public class SobelTest {
       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 ="E:/OpenCV/chap16/sobel_input.jpg";
          Mat src = Imgcodecs.imread(file);
    
          // Creating an empty matrix to store the result
          Mat dst = new Mat();
    
          // Applying sobel on the Image
          Imgproc.Sobel(src, dst, -1, 1, 1);
    
          // Writing the image
          Imgcodecs.imwrite("E:/OpenCV/chap16/sobel_output.jpg", dst);
    
          System.out.println("Image processed");
       }
    }

    Asumsikan bahwa berikut ini adalah gambar input sobel_input.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 -

    sobel Varian

    Saat meneruskan nilai yang berbeda ke parameter terakhir (dx dan dy) (antara 0 dan 1), Anda akan mendapatkan keluaran yang berbeda -

    // Applying sobel on the Image
    Imgproc.Sobel(src, dst, -1, 1, 1);

    Tabel berikut mencantumkan berbagai nilai untuk variabel dx dan dy metode Sobel() dan keluarannya masing-masing.

    Turunan X Turunan Y Keluaran
    0 1
    1 0
    1 1

    Scharr juga digunakan untuk mendeteksi turunan kedua dari suatu gambar dalam arah horizontal dan vertikal. Anda dapat melakukan operasi scharr pada gambar menggunakan metode inischarr(). Berikut adalah sintaks dari metode ini -

    Scharr(src, dst, ddepth, dx, dy)

    Metode ini menerima parameter berikut -

    • src - Objek kelas Mat mewakili gambar sumber (masukan).

    • dst - Objek kelas Mat mewakili gambar tujuan (keluaran).

    • ddepth - Variabel integer yang mewakili kedalaman gambar (-1)

    • dx- Variabel integer yang mewakili turunan x. (0 atau 1)

    • dy- Variabel integer mewakili turunan y. (0 atau 1)

    Contoh

    Program berikut menunjukkan bagaimana menerapkan scharr ke gambar tertentu.

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    
    import org.opencv.imgcodecs.Imgcodecs;
    import org.opencv.imgproc.Imgproc;
    
    public class ScharrTest {
    
       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 ="E:/OpenCV/chap16/sobel_input.jpg";
          Mat src = Imgcodecs.imread(file);
    
          // Creating an empty matrix to store the result
          Mat dst = new Mat();
    
          // Applying Box Filter effect on the Image
          Imgproc.Scharr(src, dst, Imgproc.CV_SCHARR, 0, 1);
    
          // Writing the image
          Imgcodecs.imwrite("E:/OpenCV/chap16/scharr_output.jpg", dst);
    
          System.out.println("Image processed");
       }
    }

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

    Keluaran

    Saat menjalankannya, Anda akan mendapatkan output berikut -

    Image Processed

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

    Derivatif scharr lainnya

    Saat meneruskan nilai yang berbeda ke parameter terakhir (dx dan dy) (antara 0 dan 1) Anda akan mendapatkan keluaran yang berbeda -

    // Applying scharr on the Image
    Imgproc.Scharr(src, dst, -1, 1, 1);

    Berikut adalah tabel yang mencantumkan berbagai nilai untuk variabel dx dan dy metode scharr() dan keluarannya masing-masing.

    Turunan X Turunan Y Keluaran
    0 1
    1 0

    Operator Laplacian juga merupakan operator turunan yang digunakan untuk mencari tepi pada gambar. Ini adalah topeng turunan orde dua. Dalam topeng ini kami memiliki dua klasifikasi lebih lanjut, satu Operator Laplacian Positif dan lainnya adalah Operator Laplacian Negatif.

    Tidak seperti operator lain, Laplacian tidak mengambil tepi ke arah tertentu tetapi mengambil tepi dalam klasifikasi berikut.

    • Tepi Dalam
    • Tepi Luar

    Anda bisa tampil Laplacian Transform operasi pada gambar menggunakan Laplacian() metode dari imgproc kelas, berikut adalah sintaks dari metode ini.

    Laplacian(src, dst, ddepth)

    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.

    • ddepth - Variabel tipe integer yang merepresentasikan kedalaman gambar tujuan.

    Contoh

    Program berikut mendemonstrasikan bagaimana melakukan operasi transformasi Laplace pada gambar yang diberikan.

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    import org.opencv.imgcodecs.Imgcodecs;
    import org.opencv.imgproc.Imgproc;
    
    public class LaplacianTest {
       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 ="E:/OpenCV/chap18/laplacian_input.jpg";
          Mat src = Imgcodecs.imread(file);
    
          // Creating an empty matrix to store the result
          Mat dst = new Mat();
    
          // Applying GaussianBlur on the Image
          Imgproc.Laplacian(src, dst, 10);
    
          // Writing the image
          Imgcodecs.imwrite("E:/OpenCV/chap18/laplacian.jpg", dst);
    
          System.out.println("Image Processed");
       }
    }

    Asumsikan bahwa berikut ini adalah gambar input laplacian_input.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 -

    Itu distance transformOperator umumnya mengambil gambar biner sebagai input. Dalam operasi ini, intensitas tingkat abu-abu dari titik-titik di dalam wilayah latar depan diubah ke jarak masing-masing jarak dari nilai terdekat 0 (batas).

    Anda dapat menerapkan transformasi jarak di OpenCV menggunakan metode ini distanceTransform(). Berikut adalah sintaks dari metode ini.

    distanceTransform(src, dst, distanceType, maskSize)

    Metode ini menerima parameter berikut -

    • src - Objek kelas Mat mewakili gambar sumber (masukan).

    • dst - Objek kelas Mat mewakili gambar tujuan (keluaran).

    • distanceType - Variabel tipe integer yang mewakili tipe transformasi jarak yang akan diterapkan.

    • maskSize - Variabel tipe integer yang mewakili ukuran topeng yang akan digunakan.

    Contoh

    Program berikut mendemonstrasikan bagaimana melakukan operasi transformasi jarak pada citra tertentu.

    import org.opencv.core.Core;
    import org.opencv.core.Mat;
    import org.opencv.imgcodecs.Imgcodecs;
    import org.opencv.imgproc.Imgproc;
    
    public class DistanceTransform {
       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 ="E:/OpenCV/chap19/input.jpg";
          Mat src = Imgcodecs.imread(file,0);
    
          // Creating an empty matrix to store the results
          Mat dst = new Mat();
          Mat binary = new Mat();
    
          // Converting the grayscale image to binary image
          Imgproc.threshold(src, binary, 100, 255, Imgproc.THRESH_BINARY);
    
          // Applying distance transform
          Imgproc.distanceTransform(mat, dst, Imgproc.DIST_C, 3);
    
          // Writing the image
          Imgcodecs.imwrite("E:/OpenCV/chap19/distnceTransform.jpg", dst);
    
          System.out.println("Image Processed");
       }
    }

Asumsikan bahwa berikut ini adalah gambar input input.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 -

Jenis Operasi Transformasi Jarak

Selain jenis operasi jarak DIST_Cditunjukkan dalam contoh sebelumnya, OpenCV melayani berbagai jenis operasi transformasi jarak lainnya. Semua jenis ini diwakili oleh bidang statis yang telah ditentukan (nilai tetap) dari kelas Imgproc.

Anda dapat memilih jenis operasi transformasi jarak yang Anda butuhkan, dengan meneruskan nilai masing-masing yang telah ditentukan ke parameter bernama distanceType dari distanceTransform() metode.

// Applying distance transform 
Imgproc.distanceTransform(mat, dst, Imgproc.DIST_C, 3);

Berikut ini adalah nilai-nilai yang mewakili berbagai jenis distanceTransform operasi dan outputnya masing-masing.

Operasi dan Deskripsi Keluaran
DIST_C
DIST_L1
DIST_L2
DIST_LABEL_PIXEL
DIST_MASK_3

Dalam bab ini, kita akan mempelajari cara menggunakan OpenCV untuk menangkap bingkai menggunakan kamera sistem. ItuVideoCapture kelas dari org.opencv.videoiopaket berisi kelas dan metode untuk merekam video menggunakan kamera. Mari selangkah demi selangkah dan pelajari cara menangkap bingkai -

Langkah 1: Muat pustaka asli OpenCV

Saat menulis kode Java menggunakan pustaka OpenCV, langkah pertama yang perlu Anda lakukan adalah memuat pustaka asli OpenCV menggunakan loadLibrary(). Muat pustaka asli OpenCV seperti yang ditunjukkan di bawah ini.

// Loading the core library 
System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

Langkah 2: Buat instance kelas perekaman video

Instantiate kelas Mat menggunakan salah satu fungsi yang disebutkan dalam tutorial ini sebelumnya.

// Instantiating the VideoCapture class (camera:: 0) 
VideoCapture capture = new VideoCapture(0);

Langkah 3: Baca bingkainya

Anda dapat membaca bingkai dari kamera menggunakan read() metode dari VideoCapturekelas. Metode ini menerima objek kelasMat untuk menyimpan bingkai baca.

// Reading the next video frame from the camera 
Mat matrix = new Mat(); 
capture.read(matrix);

Contoh

Program berikut mendemonstrasikan cara menangkap bingkai menggunakan kamera dan menampilkannya menggunakan jendela JavaFX. Ini juga menyimpan bingkai yang diambil.

import java.awt.image.BufferedImage;
import java.awt.image.DataBufferByte;
import java.awt.image.WritableRaster;

import java.io.FileNotFoundException;
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.imgcodecs.Imgcodecs;
import org.opencv.videoio.VideoCapture;

public class CameraSnapshotJavaFX extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws FileNotFoundException, IOException {
      // Capturing the snapshot from the camera
      CameraSnapshotJavaFX obj = new CameraSnapshotJavaFX();
      WritableImage writableImage = obj.capureSnapShot();

      // Saving the image
      obj.saveImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // 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("Capturing an image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage capureSnapShot() {
      WritableImage WritableImage = null;

      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Instantiating the VideoCapture class (camera:: 0)
      VideoCapture capture = new VideoCapture(0);

      // Reading the next video frame from the camera
      Mat matrix = new Mat();
      capture.read(matrix);

      // If camera is opened
      if( capture.isOpened()) {
         // If there is next video frame
         if (capture.read(matrix)) {
            // Creating BuffredImage from the matrix
            BufferedImage image = new BufferedImage(matrix.width(), 
               matrix.height(), BufferedImage.TYPE_3BYTE_BGR);
            
            WritableRaster raster = image.getRaster();
            DataBufferByte dataBuffer = (DataBufferByte) raster.getDataBuffer();
            byte[] data = dataBuffer.getData();
            matrix.get(0, 0, data);
            this.matrix = matrix;
            
            // Creating the Writable Image
            WritableImage = SwingFXUtils.toFXImage(image, null);
         }
      }
      return WritableImage;
   }
   public void saveImage() {
      // Saving the Image
      String file = "E:/OpenCV/chap22/sanpshot.jpg";

      // Instantiating the imgcodecs class
      Imgcodecs imageCodecs = new Imgcodecs();

      // Saving it again 
      imageCodecs.imwrite(file, matrix);
   }
   public static void main(String args[]) {
      launch(args);
   }
}

Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut.

Jika Anda membuka jalur yang ditentukan, Anda dapat mengamati bingkai yang sama yang disimpan sebagai file jpg.

Itu VideoCapture kelas dari org.opencv.videoiopaket berisi kelas dan metode untuk merekam video menggunakan kamera sistem. Mari selangkah demi selangkah dan pelajari cara melakukannya.

Langkah 1: Muat pustaka asli OpenCV

Saat menulis kode Java menggunakan pustaka OpenCV, langkah pertama yang perlu Anda lakukan adalah memuat pustaka asli OpenCV menggunakan loadLibrary(). Muat pustaka asli OpenCV seperti yang ditunjukkan di bawah ini.

// Loading the core library 
System.loadLibrary(Core.NATIVE_LIBRARY_NAME);

Langkah 2: Buat instance kelas CascadeClassifier

Itu CascadeClassifier kelas paket org.opencv.objdetectdigunakan untuk memuat file pengklasifikasi. Instantiate kelas ini dengan meneruskanxml mengajukan lbpcascade_frontalface.xml seperti gambar dibawah.

// Instantiating the CascadeClassifier 
String xmlFile = "E:/OpenCV/facedetect/lbpcascade_frontalface.xml"; 
CascadeClassifier classifier = new CascadeClassifier(xmlFile);

Langkah 3: Deteksi wajah

Anda dapat mendeteksi wajah dalam gambar menggunakan metode detectMultiScale() dari kelas bernama CascadeClassifier. Metode ini menerima objek kelasMat memegang gambar masukan dan objek kelas MatOfRect untuk menyimpan wajah yang terdeteksi.

// Detecting the face in the snap 
MatOfRect faceDetections = new MatOfRect(); 
classifier.detectMultiScale(src, faceDetections);

Contoh

Program berikut menunjukkan cara mendeteksi wajah dalam gambar.

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.MatOfRect;
import org.opencv.core.Point;
import org.opencv.core.Rect;
import org.opencv.core.Scalar;

import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;
import org.opencv.objdetect.CascadeClassifier;
  
public class FaceDetectionImage {
   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 ="E:/OpenCV/chap23/facedetection_input.jpg";
      Mat src = Imgcodecs.imread(file);

      // Instantiating the CascadeClassifier
      String xmlFile = "E:/OpenCV/facedetect/lbpcascade_frontalface.xml";
      CascadeClassifier classifier = new CascadeClassifier(xmlFile);

      // Detecting the face in the snap
      MatOfRect faceDetections = new MatOfRect();
      classifier.detectMultiScale(src, faceDetections);
      System.out.println(String.format("Detected %s faces", 
         faceDetections.toArray().length));

      // Drawing boxes for (Rect rect : faceDetections.toArray()) { Imgproc.rectangle( src, // where to draw the box new Point(rect.x, rect.y), // bottom left new Point(rect.x + rect.width, rect.y + rect.height), // top right new Scalar(0, 0, 255), 3 // RGB colour );
      }

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap23/facedetect_output1.jpg", src);

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

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

Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut -

Detected 3 faces 
Image Processed

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

Program berikut menunjukkan cara mendeteksi wajah menggunakan kamera sistem dan menampilkannya menggunakan jendela JavaFX.

Contoh

import java.awt.image.BufferedImage;
import java.awt.image.DataBufferByte;
import java.awt.image.WritableRaster;

import java.io.FileNotFoundException;
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.MatOfRect;
import org.opencv.core.Point;
import org.opencv.core.Rect;
import org.opencv.core.Scalar;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;
import org.opencv.objdetect.CascadeClassifier;
import org.opencv.videoio.VideoCapture;

public class faceDetectionJavaFXX extends Application {
   Mat matrix = null;

   @Override
   public void start(Stage stage) throws FileNotFoundException, IOException {
      // Capturing the snapshot from the camera
      faceDetectionJavaFXX obj = new faceDetectionJavaFXX();
      WritableImage writableImage = obj.capureFrame();

      // Saving the image
      obj.saveImage();

      // Setting the image view
      ImageView imageView = new ImageView(writableImage);

      // 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("Capturing an image");

      // Adding scene to the stage
      stage.setScene(scene);

      // Displaying the contents of the stage
      stage.show();
   }
   public WritableImage capureFrame() {
      WritableImage writableImage = null;

      // Loading the OpenCV core library
      System.loadLibrary( Core.NATIVE_LIBRARY_NAME );

      // Instantiating the VideoCapture class (camera:: 0)
      VideoCapture capture = new VideoCapture(0);

      // Reading the next video frame from the camera
      Mat matrix = new Mat();
      capture.read(matrix);

      // If camera is opened
      if(!capture.isOpened()) {
         System.out.println("camera not detected");
      } else
         System.out.println("Camera detected ");
           
      // If there is next video frame
      if (capture.read(matrix)) {
         /////// Detecting the face in the snap /////
         String file = "E:/OpenCV/facedetect/lbpcascade_frontalface.xml";
         CascadeClassifier classifier = new CascadeClassifier(file);

         MatOfRect faceDetections = new MatOfRect();
         classifier.detectMultiScale(matrix, faceDetections);
         System.out.println(String.format("Detected %s faces",
            faceDetections.toArray().length));

         // Drawing boxes for (Rect rect : faceDetections.toArray()) { Imgproc.rectangle( matrix, //where to draw the box new Point(rect.x, rect.y), //bottom left new Point(rect.x + rect.width, rect.y + rect.height), //top right new Scalar(0, 0, 255) //RGB colour );
         }
         // Creating BuffredImage from the matrix
         BufferedImage image = new BufferedImage(matrix.width(), matrix.height(),
            BufferedImage.TYPE_3BYTE_BGR);
         
         WritableRaster raster = image.getRaster();
         DataBufferByte dataBuffer = (DataBufferByte) raster.getDataBuffer();
         byte[] data = dataBuffer.getData();
         matrix.get(0, 0, data);

         this.matrix = matrix;
           
         // Creating the Writable Image
         writableImage = SwingFXUtils.toFXImage(image, null);
      }
      return writableImage;
   }
   public void saveImage() {
      // Saving the Image
      String file = "E:/OpenCV/chap23/facedetected.jpg";

      // Instantiating the imagecodecs class
      Imgcodecs imageCodecs = new Imgcodecs();

      // Saving it again
      imageCodecs.imwrite(file, matrix);
   }
   public static void main(String args[]) {
      launch(args);
   }
}

Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut.

Jika Anda membuka jalur yang ditentukan, Anda dapat melihat snapshot yang sama disimpan sebagai file jpg gambar.

Anda bisa tampil affine translation pada gambar menggunakan warpAffine()metode kelas imgproc. Berikut adalah sintaks dari metode ini -

Imgproc.warpAffine(src, dst, tranformMatrix, size);

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.

  • tranformMatrix - A Mat objek yang mewakili matriks transformasi.

  • size - Variabel tipe integer yang mewakili ukuran gambar keluaran.

Contoh

Program berikut menunjukkan bagaimana menerapkan operasi affine pada gambar yang diberikan.

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.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class AffineTranslation {
   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 ="E:/OpenCV/chap24/transform_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

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

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

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

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

Keluaran

Saat menjalankannya, Anda akan mendapatkan output berikut -

Image Processed

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

Kamu bisa perform rotation operasi pada gambar menggunakan warpAffine() metode dari imgprockelas. Berikut adalah sintaks dari metode ini -

Imgproc.warpAffine(src, dst, rotationMatrix, size);

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.

  • rotationMatrix - A Mat objek yang mewakili matriks rotasi.

  • size - Variabel tipe integer yang mewakili ukuran gambar keluaran.

Contoh

Program berikut mendemonstrasikan cara memutar gambar.

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Point;
import org.opencv.core.Size;

import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class Rotation {
   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 ="E:/OpenCV/chap24/transform_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

      // Creating a Point object
      Point point = new Point(300, 200)

      // Creating the transformation matrix M
      Mat rotationMatrix = Imgproc.getRotationMatrix2D(point, 30, 1);

      // Creating the object of the class Size
      Size size = new Size(src.cols(), src.cols());

      // Rotating the given image
      Imgproc.warpAffine(src, dst, rotationMatrix, size);

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

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

Asumsikan bahwa berikut ini adalah gambar input transform_input.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 -

Anda bisa tampil scaling pada gambar menggunakan resize() metode dari imgprockelas. Berikut adalah sintaks dari metode ini.

resize(Mat src, Mat dst, Size dsize, double fx, double fy, int interpolation)

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.

  • dsize - A Size objek yang mewakili ukuran gambar keluaran.

  • fx - Variabel tipe ganda yang mewakili faktor skala di sepanjang sumbu horizontal.

  • fy - Variabel tipe ganda yang mewakili faktor skala di sepanjang sumbu vertikal.

  • Interpolation - Variabel integer yang mewakili metode interpolasi.

Contoh

Program berikut menunjukkan bagaimana cara mendaftar scale transformation ke gambar.

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 Scaling {
   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 ="E:/OpenCV/chap24/transform_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

      // Creating the Size object
      Size size = new Size(src.rows()*2, src.rows()*2);

      // Scaling the Image
      Imgproc.resize(src, dst, size, 0, 0, Imgproc.INTER_AREA);

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

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

Asumsikan bahwa berikut ini adalah gambar input transform_input.jpg ditentukan dalam program di atas (size - Width: 300px dan height: 300px).

Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut -

Image Processed

Jika Anda membuka jalur yang ditentukan, Anda dapat mengamati gambar keluaran sebagai berikut (size - Width: 600px dan height: 600px) -

Di OpenCV, Anda dapat menerapkan peta warna yang berbeda ke gambar menggunakan metode ini applyColorMap() dari kelas Imgproc. Berikut adalah sintaks dari metode ini -

applyColorMap(Mat src, Mat dst, int colormap)

Ini menerima tiga parameter -

  • src - Objek kelas Mat mewakili gambar sumber (masukan).

  • dst - Objek kelas Mat mewakili gambar tujuan (keluaran).

  • colormap - Variabel tipe integer yang mewakili tipe peta warna yang akan diterapkan.

Contoh

Program berikut menunjukkan bagaimana cara mendaftar color map ke gambar.

import org.opencv.core.Core;
import org.opencv.core.Mat;

import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class ColorMapTest {
   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 ="E:/OpenCV/chap25/color_input.jpg";
      Mat src = Imgcodecs.imread(file);

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

      // Applying color map to an image
      Imgproc.applyColorMap(src, dst, Imgproc.COLORMAP_HOT);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap25/colormap_hot.jpg", dst);
      System.out.println("Image processed");
   }
}

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

Keluaran

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Image Processed

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

Lebih Banyak Operasi

Sebagai tambahannya COLORMAP_HOTditunjukkan pada contoh sebelumnya, OpenCV melayani berbagai jenis peta warna lainnya. Semua jenis ini diwakili oleh bidang statis yang telah ditentukan (nilai tetap) dari kelas Imgproc.

Anda dapat memilih jenis peta warna yang Anda butuhkan, dengan meneruskan nilai masing-masing yang telah ditentukan sebelumnya ke parameter bernama colormap dari applyColorMap() metode.

Imgproc.applyColorMap(src, dst, Imgproc.COLORMAP_HOT);

Berikut ini adalah nilai-nilai yang mewakili berbagai jenis peta warna dan keluarannya masing-masing.

Operasi dan Deskripsi Keluaran
COLORMAP_AUTUMN
COLORMAP_BONE
COLORMAP_COOL
COLORMAP_HOT
COLORMAP_HSV
COLORMAP_JET
COLORMAP_OCEAN
COLORMAP_PARULA
COLORMAP_PINK
COLORMAP_RAINBOW
COLORMAP_SPRING
COLORMAP_SUMMER
COLORMAP_WINTER

Deteksi Tepi Canny digunakan untuk mendeteksi tepi pada gambar. Ini menerima gambar skala abu-abu sebagai masukan dan menggunakan algoritma multistage.

Anda dapat melakukan operasi ini pada gambar menggunakan Canny() metode dari imgproc kelas, berikut adalah sintaks dari metode ini.

Canny(image, edges, threshold1, threshold2)

Metode ini menerima parameter berikut -

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

  • edges - A Mat objek yang mewakili tujuan (tepi) untuk operasi ini.

  • threshold1 - Variabel tipe ganda yang mewakili ambang pertama untuk prosedur histeresis.

  • threshold2 - Variabel tipe ganda yang mewakili ambang kedua untuk prosedur histeresis.

Contoh

Program berikut adalah contoh yang mendemonstrasikan, bagaimana melakukan operasi Canny Edge Detection pada gambar tertentu.

import org.opencv.core.Core;
import org.opencv.core.Mat;

import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class CannyEdgeDetection {
   public static void main(String args[]) throws Exception {
      // 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 = "E:/OpenCV/chap17/canny_input.jpg";

      // Reading the image
      Mat src = Imgcodecs.imread(file);

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

      // Converting the image from color to Gray
      Imgproc.cvtColor(src, gray, Imgproc.COLOR_BGR2GRAY);
      Mat edges = new Mat();

      // Detecting the edges
      Imgproc.Canny(gray, edges, 60, 60*3);

      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap17/canny_output.jpg", edges);
      System.out.println("Image Loaded");
   } 
}

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

Keluaran

Saat menjalankan program di atas, Anda akan mendapatkan output berikut -

Image Processed

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

Anda dapat mendeteksi bentuk gambar tertentu dengan menerapkan Hough Transform technique menggunakan metode ini HoughLines() dari Imgprockelas. Berikut adalah sintaks dari metode ini.

HoughLines(image, lines, rho, theta, threshold)

Metode ini menerima parameter berikut -

  • image - Objek kelas Mat mewakili gambar sumber (masukan).

  • lines - Objek kelas Mat yang menyimpan vektor yang menyimpan parameter (r, Φ) dari garis.

  • rho - Variabel tipe double yang mewakili resolusi parameter r dalam piksel.

  • theta - Variabel bertipe double yang merepresentasikan resolusi parameter rad dalam radian.

  • threshold - Variabel jenis bilangan bulat yang mewakili jumlah minimum persimpangan untuk "mendeteksi" garis.

Contoh

Program berikut menunjukkan cara mendeteksi garis Hough pada gambar tertentu.

import org.opencv.core.Core;
import org.opencv.core.Mat;
import org.opencv.core.Point;
import org.opencv.core.Scalar;

import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;

public class HoughlinesTest {
   public static void main(String args[]) throws Exception {
      // 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 = "E:/OpenCV/chap21/hough_input.jpg";

      // Reading the image
      Mat src = Imgcodecs.imread(file,0);

      // Detecting edges of it
      Mat canny = new Mat();
      Imgproc.Canny(src, canny, 50, 200, 3, false);

      // Changing the color of the canny
      Mat cannyColor = new Mat();
      Imgproc.cvtColor(canny, cannyColor, Imgproc.COLOR_GRAY2BGR);

      // Detecting the hough lines from (canny)
      Mat lines = new Mat();
      Imgproc.HoughLines(canny, lines, 1, Math.PI/180, 100);

      System.out.println(lines.rows());
      System.out.println(lines.cols());

      // Drawing lines on the image
      double[] data;
      double rho, theta;
      Point pt1 = new Point();
      Point pt2 = new Point();
      double a, b;
      double x0, y0;
      
      for (int i = 0; i < lines.cols(); i++) {
         data = lines.get(0, i);
         rho = data[0];
         theta = data[1];
         
         a = Math.cos(theta);
         b = Math.sin(theta);
         x0 = a*rho;
         y0 = b*rho;
         
         pt1.x = Math.round(x0 + 1000*(-b));
         pt1.y = Math.round(y0 + 1000*(a));
         pt2.x = Math.round(x0 - 1000*(-b));
         pt2.y = Math.round(y0 - 1000 *(a));
         Imgproc.line(cannyColor, pt1, pt2, new Scalar(0, 0, 255), 6);
      }
      // Writing the image
      Imgcodecs.imwrite("E:/OpenCV/chap21/hough_output.jpg", cannyColor);
          
      System.out.println("Image Processed");
   }
}

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

Keluaran

Saat menjalankan program, Anda akan mendapatkan output berikut -

143 
1 
Image Processed

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

Itu histogramgambar menunjukkan frekuensi nilai intensitas piksel. Dalam histogram gambar, sumbu X menunjukkan intensitas tingkat abu-abu dan sumbu Y menunjukkan frekuensi intensitas ini.

Histogram equalizationmeningkatkan kontras gambar, untuk meregangkan kisaran yang lebih dalam. Anda dapat menyamakan histogram dari gambar yang diberikan menggunakan metode iniequalizeHist() dari Imgprockelas. Berikut adalah sintaks dari metode ini.

equalizeHist(src, dst)

Metode ini menerima parameter berikut -

  • src - Objek kelas Mat mewakili gambar sumber (masukan).

  • dst - Objek kelas Matmewakili keluaran. (Gambar diperoleh setelah menyamakan histogram)

Contoh

Program berikut menunjukkan cara menyamakan histogram dari gambar yang diberikan.

import java.util.ArrayList;
import java.util.List;

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 HistoTest {
   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 ="E:/OpenCV/chap20/histo_input.jpg";

      // Load the image
      Mat img = Imgcodecs.imread(file);

      // Creating an empty matrix
      Mat equ = new Mat();
      img.copyTo(equ);

      // Applying blur
      Imgproc.blur(equ, equ, new Size(3, 3));

      // Applying color
      Imgproc.cvtColor(equ, equ, Imgproc.COLOR_BGR2YCrCb);
      List<Mat> channels = new ArrayList<Mat>();

      // Splitting the channels
      Core.split(equ, channels);

      // Equalizing the histogram of the image
      Imgproc.equalizeHist(channels.get(0), channels.get(0));
      Core.merge(channels, equ);
      Imgproc.cvtColor(equ, equ, Imgproc.COLOR_YCrCb2BGR);

      Mat gray = new Mat();
      Imgproc.cvtColor(equ, gray, Imgproc.COLOR_BGR2GRAY);
      Mat grayOrig = new Mat();
      Imgproc.cvtColor(img, grayOrig, Imgproc.COLOR_BGR2GRAY);

      Imgcodecs.imwrite("E:/OpenCV/chap20/histo_output.jpg", equ);
      System.out.println("Image Processed");
   }
}

Asumsikan bahwa berikut ini adalah gambar input histo_input.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 -