如何使用 C++ 在 OpenCV 中檢測最大的人臉?
我們將學習僅檢測最大的人臉。此主題與上一個主題相同。唯一不同的是我們使用了一個額外的“矩形”結構和一個“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;
}輸出

廣告
資料結構
網路
RDBMS
作業系統
Java
iOS
HTML
CSS
Android
Python
C 程式設計
C++
C#
MongoDB
MySQL
Javascript
PHP