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 -