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

指定したパスを開くと、次のように出力画像を確認できます。