OpenCV - एक तस्वीर में चेहरा पहचान

VideoCapture की कक्षा org.opencv.videoioपैकेज में सिस्टम कैमरा का उपयोग करके वीडियो कैप्चर करने के लिए कक्षाएं और विधियाँ हैं। आइए कदम से कदम मिलाते हैं और इसे करना सीखें।

चरण 1: OpenCV देशी लाइब्रेरी लोड करें

OpenCV लाइब्रेरी का उपयोग करके जावा कोड लिखते समय, आपको जो पहला कदम उठाने की ज़रूरत है, वह है OpenCV के मूल पुस्तकालय को लोड करके loadLibrary()। OpenCV देशी लाइब्रेरी को लोड करें जैसा कि नीचे दिखाया गया है।

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

चरण 2: CascadeClassifier वर्ग को त्वरित करें

CascadeClassifier पैकेज की कक्षा org.opencv.objdetectका उपयोग क्लासिफायर फाइल को लोड करने के लिए किया जाता है। इस कक्षा को उत्तीर्ण करके त्वरित करेंxml फ़ाइल lbpcascade_frontalface.xml जैसा की नीचे दिखाया गया।

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

चरण 3: चेहरों का पता लगाएं

आप विधि का उपयोग करके छवि में चेहरे का पता लगा सकते हैं detectMultiScale() नामित वर्ग का CascadeClassifier। यह विधि कक्षा की एक वस्तु को स्वीकार करती हैMat इनपुट छवि और कक्षा का एक ऑब्जेक्ट पकड़ना MatOfRect पहचाने गए चेहरों को संग्रहीत करने के लिए।

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

उदाहरण

निम्नलिखित कार्यक्रम दर्शाता है कि एक छवि में चेहरे का पता कैसे लगाया जाए।

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

मान लें कि निम्नलिखित इनपुट छवि है facedetection_input.jpg उपरोक्त कार्यक्रम में निर्दिष्ट।

उत्पादन

कार्यक्रम को निष्पादित करने पर, आपको निम्नलिखित आउटपुट मिलेगा -

Detected 3 faces 
Image Processed

यदि आप निर्दिष्ट पथ खोलते हैं, तो आप आउटपुट इमेज को निम्नानुसार देख सकते हैं -