OpenCV - Deteksi Wajah dalam Gambar

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 -