OpenCV讀入圖像檢測人臉

下面是使用OpenCV通過在硬盤中讀入圖像來對其進行Haar人臉檢測的代碼。

//包含頭文件 
#include <opencv2/core/core.hpp>
#include "cv.h" 
#include "highgui.h"

int main()
{
    const char* cascade_name = "C:\\opencv249\\sources\\data\\haarcascades\\haarcascade_frontalface_alt2.xml";//分類器路徑,按實際填寫

    static CvMemStorage* storage = 0;
    static CvHaarClassifierCascade* cascade = 0;

    cascade = (CvHaarClassifierCascade*)cvLoad(cascade_name, 0, 0, 0);
    storage = cvCreateMemStorage(0);

    IplImage *image = cvLoadImage("E:\\1.jpg");//讀入圖像,按實際輸入

    CvSeq* faces = cvHaarDetectObjects(image, cascade, storage, 1.1, 2, CV_HAAR_DO_CANNY_PRUNING, cvSize(30, 30));//Haar人臉檢測

    int num_of_face = faces->total;//得到檢測所得的人臉個數

    CvScalar color[1] = { 255, 0, 0 };//設置矩形框顏色

    for (int i = 1; i < num_of_face + 1; i++)
    {
        CvRect* r = (CvRect*)cvGetSeqElem(faces, i); //獲取每個人臉的信息,返回類型是矩形。i爲人臉編號,0,1,2。。。可以用循環讀取。
        cvRectangle(image, cvPoint(r->x, r->y), cvPoint(r->x + r->width, r->y + r->height), color[0], 3);//畫矩形框
    }

    cvNamedWindow("Test", CV_WINDOW_AUTOSIZE);//創建窗口,第二個參數CV_WINDOW_AUTOSIZE代表保存圖像原來大小  
    cvShowImage("Test", image);//顯示圖片

    cvWaitKey(0);//等待操作    

    cvReleaseImage(&image);//釋放圖片    
    cvDestroyWindow("Test");//銷燬窗口   

    return 0;
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章