一、概述
因为OpenCv对UI兼容不是很好,C#可以很好地写UI,有2个框架可供选择:1、EmguCv;2、OpenCvSharp。OpenCvSharp是一个日本人开发的开源项目,里面封装的类和方法和OpenCv非常相似,且底层协议用的是BSD,对商业友好,OpenCvSharp的下载量已经超过了EmguCv,之前用了EmguCv,现在改用OpenCvSharp来做OpenCv的程序开发。人脸识别系统大致可分为四部分:
第一、人脸检测;
第二、数据准备及人脸识别器的训练;
第三、人脸识别并显示结果;
第四、添加人脸数据
二、人脸检测
加载haarcascade_frontalface_alt.xml(一个已经训练好的用于检测人脸的级联分类器文件,在OpenCv库下的Source文件夹下有很多这样额级联分类器资源),DetectMultiScale方法用于检测人脸,返回人脸矩形框,关键代码如下:
CascadeClassifier cascade = new CascadeClassifier(@"..\..\FaceCascade\haarcascade_frontalface_alt.xml");
Rect[] faces = cascade.DetectMultiScale(
image: grayImage,
scaleFactor: 1.1,
minNeighbors: 2,
flags: HaarDetectionType.DoRoughSearch | HaarDetectionType.ScaleImage,
minSize: new OpenCvSharp.Size(30, 30)
);
三、数据准备及人脸识别器的训练
需要准备好经过灰度化和直方图均衡化的人脸图像以及它对应的ID(每张人脸只有一个ID,一个ID可以对应多张人脸),为每个人建立一个文件夹,文件夹下存储多张该人脸图片(本系统设定只存3张)。创建一个识别器,OpenCV提供了三种人脸识别器:FisherFaceRecognizer,LBPHFaceRecognizer,EigenFaceRecognizer,可任选一种识别器创建。将人脸数据和ID导入到人脸识别器进行训练