人脸识别(二)

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();

        }
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值