1在图片上把人脸用矩形框,选出来
2需要对图片进行【灰度】处理
3需要样本文件,进行检索,haarcascade_eye.xml(眼睛)、haarcascade_frontalface_alt.xml(人脸)文件地址【百度网盘】
链接:https://pan.baidu.com/s/1FWsl6oeYgV0UCEcUOQHsJw
提取码:fs3c
4对每一帧图片进行扫描,和样本进行对比
static void Main(string[] args)
{
// 展示原图
// 把filePath改成你需要的图片路径
string filePath = "F:\\1.png";
Mat image_gray = new Mat();
Mat image = Cv2.ImRead(filePath);
//Cv2.ImShow("原图", image);
Cv2.CvtColor(image, image_gray, ColorConversionCodes.BGR2GRAY);
Cv2.EqualizeHist(image_gray, image_gray);
CascadeClassifier eye_Classifier = new CascadeClassifier(); //载入分类器
CascadeClassifier face_cascade = new CascadeClassifier(); //载入分类器
加载分类训练器,OpenCv官方文档提供的xml文档,可以直接调用
xml文档路径 opencv\sources\data\haarcascades
if (!eye_Classifier.Load("F:\\haarcascade_eye.xml")) //需要将xml文档放在自己指定的路径下
{
Console.WriteLine("眼部文件不存在!");
}
if (!face_cascade.Load("F:\\haarcascade_frontalface_alt.xml"))
{
Console.WriteLine("脸部文件不存在!");
}
//
Scalar color = new Scalar(0, 0, 255);
Rect[] eyeRect = eye_Classifier.DetectMultiScale(
image: image_gray,
scaleFactor: 1.1,
minNeighbors: 2,
flags: HaarDetectionType.DoRoughSearch | HaarDetectionType.ScaleImage,
minSize: new OpenCvSharp.Size(30, 30)
);
for (int eyeIdx = 0; eyeIdx < eyeRect.Length; eyeIdx++)
{
//用矩形画出检测到的位置
Cv2.Rectangle(image, eyeRect[eyeIdx], color);
}
//---------------------------------------------------------------//
//
Rect[] faceRect = face_cascade.DetectMultiScale(
image: image_gray,
scaleFactor: 1.1,
minNeighbors: 2,
flags: HaarDetectionType.DoRoughSearch | HaarDetectionType.ScaleImage,
minSize: new OpenCvSharp.Size(30, 30)
);
//
for (int i = 0; i < faceRect.Length; i++)
{
//用矩形画出检测到的位置
Cv2.Rectangle(image, faceRect[i], color);
}
//显示当前帧
Cv2.ImShow("人脸识别图", image);
Cv2.WaitKey();
}