Java DIP - Konversi Ruang Warna OpenCV

Untuk mengubah ruang warna dari satu gambar ke gambar lainnya menggunakan OpenCV, kita membaca gambar menjadi BufferedImage dan mengubahnya menjadi MatObyek. Sintaksnya diberikan di bawah ini -

File input = new File("digital_image_processing.jpg");
BufferedImage image = ImageIO.read(input);
//convert Buffered Image to Mat.

OpenCv memungkinkan banyak jenis konversi warna, yang semuanya dapat ditemukan di kelas Imgproc. Beberapa jenis dijelaskan secara singkat -

Sr.No. Jenis Konversi Warna
1 COLOR_RGB2BGR
2 COLOR_RGB2BGRA
3 COLOR_RGB2GRAY
4 COLOR_RGB2HLS
5 COLOR_RGB2HSV
6 COLOR_RGB2Luv
7 COLOR_RGB2YUV
8 COLOR_RGB2Lab

Dari salah satu jenis konversi warna, teruskan yang sesuai ke dalam metode cvtColor() dalam Imgprockelas. Sintaksnya diberikan di bawah ini -

Imgproc.cvtColor(source mat, destination mat1, Color_Conversion_Code);

Metode cvtColor() mengambil tiga parameter yaitu matriks citra sumber, matriks citra tujuan dan tipe konversi warna.

Selain metode cvtColor (), ada metode lain yang disediakan oleh kelas Imgproc. Mereka dijelaskan secara singkat -

Sr.No. Metode & Deskripsi
1

cvtColor(Mat src, Mat dst, int code, int dstCn)

Ini mengubah gambar dari satu ruang warna ke ruang warna lainnya.

2

dilate(Mat src, Mat dst, Mat kernel)

Ini melebarkan gambar dengan menggunakan elemen penataan tertentu.

3

equalizeHist(Mat src, Mat dst)

Ini menyamakan histogram dari gambar grayscale.

4

filter2D(Mat src, Mat dst, int ddepth, Mat kernel, Point anchor, double delta)

Ini menggabungkan gambar dengan kernel.

5

GaussianBlur(Mat src, Mat dst, Size ksize, double sigmaX)

Ini mengaburkan gambar menggunakan filter Gaussian.

6

integral(Mat src, Mat sum)

Ini menghitung integral dari suatu gambar.

Contoh

Contoh berikut menunjukkan penggunaan kelas Imgproc untuk mengonversi gambar dari satu ruang warna ke ruang warna lainnya.

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

import java.io.File;
import javax.imageio.ImageIO;

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

public class Main {
   public static void main( String[] args ) {
   
      try {
         System.loadLibrary( Core.NATIVE_LIBRARY_NAME );
         File input = new File("digital_image_processing.jpg");
         BufferedImage image = ImageIO.read(input);	
         byte[] data = ((DataBufferByte) image.getRaster().getDataBuffer()).getData();
         Mat mat = new Mat(image.getHeight(),image.getWidth(), CvType.CV_8UC3);
         mat.put(0, 0, data);

         Mat mat1 = new Mat(image.getHeight(), image.getWidth(), CvType.CV_8UC3);
         Imgproc.cvtColor(mat, mat1, Imgproc.COLOR_RGB2HSV);

         byte[] data1 = new byte[mat1.rows()*mat1.cols()*(int)(mat1.elemSize())];
         mat1.get(0, 0, data1);
         BufferedImage image1 = new BufferedImage(mat1.cols(), mat1.rows(), 5);
         image1.getRaster().setDataElements(0, 0, mat1.cols(), mat1.rows(), data1);

         File ouptut = new File("hsv.jpg");
         ImageIO.write(image1, "jpg", ouptut);
         
      } catch (Exception e) {
         System.out.println("Error: " + e.getMessage());
      }
   }
}

Keluaran

Ketika Anda menjalankan contoh yang diberikan, itu mengubah nama gambar digital_image_processing.jpg ke gambar ruang warna HSV yang setara dan menulisnya di hard disk dengan nama hsv.jpg.

Gambar Asli (RGB)

Gambar yang Dikonversi (HSV)