OpenCV-사진 속 얼굴 인식

그만큼 VideoCapture 의 클래스 org.opencv.videoio패키지에는 시스템 카메라를 사용하여 비디오를 캡처하는 클래스와 메서드가 포함되어 있습니다. 단계별로 가서 어떻게하는지 배우자.

1 단계 : OpenCV 네이티브 라이브러리로드

OpenCV 라이브러리를 사용하여 Java 코드를 작성하는 동안해야 할 첫 번째 단계는 다음을 사용하여 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

지정된 경로를 열면 다음과 같이 출력 이미지를 관찰 할 수 있습니다.