下面是使用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