• 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; 

    基于opencv的人脸检测并保存图片发送:http://www.eyesourcecode.com/thread-41275-1-1.html 
    OpenCV源码:http://www.eyesourcecode.com/forum-OpenCV-1.html

  • 相关阅读:
    java传递String参数
    C++ string与int的互相转换
    java插入排序
    凸包Graham Scan算法实现
    求平面上N点最远两点和最近两点距离
    求最大公约数
    n个数连接得到最小或最大的多位整数(携程)
    Java快排
    背包问题
    二分查找离左边元素最近的(可以等于)
  • 原文地址:https://www.cnblogs.com/eyeandroid/p/4491553.html
Copyright © 2020-2023  润新知