我现在的角色只是一个软件开发人员,所以暂时不深究算法问题,我的目的只有一个:以最快的方式完成项目框架搭建,从而进行进度评估。
说明
进行人脸鉴别(不关心是谁的脸)从代码量上来讲可以说非常少,我不再作具体说明,源码的注释已经足够详细,这里我使用的CascadeClassifier,大体分为三步:
- 加载级联分类器,一般以xml格式的文件存在,一般都是以大量的数据进行训练从而得到该文件,这里我们使用opencv提供的haarcascade_frontalface_alt.xml,这个文件在源码包里可以找到。
- 获取原始图像数据,需要cv::Mat数据类型,设置一些参数,然后开始鉴别,只需调用detectMultiScale即可。
- 输出经过识别的图像,一般经过识别的图像我们都会做一些标记,比如画个圆圈,加几个字之类的。
代码
我也做了一个在Linux下的Qt Creator的可执行项目(点我下载)
int main( int argc, const char** argv )
{
test();
return 0;
}
void test()
{
VideoCapture cap(0);//为了方便,使用opencv自带的函数驱动摄像头,之后会移植v4l2过来
if(!cap.isOpened())
{
perror("fail to open camera");
return;
}
Mat image;
bool tryflip = false;
CascadeClassifier cascade, nestedCascade;
cascade.load( "/usr/local/share/OpenCV/haarcascades/haarcascade_frontalface_alt.xml" );//加载主级联分类器
nestedCascade.load("/usr/local/share/OpenCV/haarcascades/haarcascade_eye_tree_eyeglasses.xml");//加载辅助级联分类