Computer >> 컴퓨터 >  >> 프로그램 작성 >> C++

C++를 사용하여 OpenCV에서 가장 큰 얼굴을 감지하는 방법은 무엇입니까?

<시간/>

가장 큰 얼굴만 감지하는 방법을 배웁니다. 이 주제는 이전 주제와 동일합니다. 유일한 차이점은 추가 'Rect' 구조와 'for 루프'를 사용하여 가장 큰 얼굴을 감지한다는 것입니다.

이 함수의 실제 형식 -

Mat faceROI = image_with_humanface(maxRect)

maxRect는 이미지에서 가장 큰 얼굴의 면적과 위치 정보를 가지고 있다. 위의 라인은 이미지에서 가장 큰 얼굴이 위치한 동일한 위치에서 maxRect에 저장된 동일한 영역을 자르고 'faceROI' 행렬에 저장하는 것입니다.

다음 프로그램은 정지 사진에서 가장 큰 얼굴을 감지합니다 -

예시

#include<iostream>
#include<opencv2/highgui/highgui.hpp>
#include<opencv2/imgproc/imgproc.hpp>
//This header includes definition of 'rectangle()' function//
#include<opencv2/objdetect/objdetect.hpp>
//This header includes the definition of Cascade Classifier//
#include<string>
using namespace std;
using namespace cv;
int main(int argc, char** argv) {
   Mat image_with_humanface;//Declaring a matrix to load image with human faces//
   image_with_humanface = imread("person.jpg");//loading an image that contains human face in it//
   namedWindow("Face Detection");//Declaring an window to show the result//  
   string trained_classifier_location = "C:/opencv/sources/data/haarcascades/haarcascade_frontalface_alt.xml";//Defining the location our XML Trained Classifier in a string//
   CascadeClassifier faceDetector;//Declaring an object named 'face detector' of CascadeClassifier class//
   faceDetector.load(trained_classifier_location);//loading the XML trained classifier in the object//
   vector<Rect>faces;//Declaring a rectangular vector named faces//
   faceDetector.detectMultiScale(image_with_humanface, faces, 1.1, 4, CASCADE_FIND_BIGGEST_OBJECT);//Detecting the faces in 'image_with_humanfaces' matrix//
   Rect maxRect;//Declaring a rectangle. By default the size is zero pixel//
   for (int i = 0; i < faces.size(); i++){ //Initiating for loop to detect the largest face//
      if (faces[i].area() > maxRect.area()){ //Calculating the area of face and comparing it with area of maxRect//
         maxRect = faces[i];//storing the largest rectangle in MaxRect according to size of largest face//
      }
   }
   for (size_t i = 0; i < faces.size(); i++){ //Loop to draw rectangle around the faces//
      Mat faceROI = image_with_humanface(maxRect);//Storing the face in a matrix having size equal to maxRect//
      int x = maxRect.x;//Getting the initial row value of face rectangle's starting point//
      int y = maxRect.y;//Getting the initial column value of face rectangle's starting point//
      int h = y + maxRect.height;//Calculating the height of the rectangle//
      int w = x + maxRect.width;//Calculating the width of the rectangle//
      rectangle(image_with_humanface, Point(x, y), Point(w, h), Scalar(255, 0, 255), 3, 6, 0);//Drawing a rectangle using around the largest//
   }
   imshow("Face Detection",image_with_humanface);//Showing the largest face face//  
   waitKey(0);//To wait for keystroke to terminate the program
   return 0;
}

출력

C++를 사용하여 OpenCV에서 가장 큰 얼굴을 감지하는 방법은 무엇입니까?