人脸识别 Open CV

Open CV是什么?

    OpenCV是一个基于BSD许可(开源)发行的跨平台计算机视觉库,可以运行在Linux、Windows、Android和Mac OS操作系统上。它轻量级而且高效——由一系列 C 函数和少量 C++ 类构成,同时提供了Python、Ruby、MATLAB等语言的接口,实现了图像处理和计算机视觉方面的很多通用算法。

本文主要用来做一个人脸识别的Demo。

环境配置

    准备工作:

    opencv-2.4.10.jar,csdn下载地址:http://download.csdn.net/download/zzl819748566/9938373

   opencv_java2410.dll, csdn下载地址:http://download.csdn.net/download/zzl819748566/9941463

    haarcascade_frontalface_alt.xml(脸部识别文件)

    github地址:https://github.com/Alarm1673/faceDetectorDemo

目录结构

172650_a8WX_2431191.png

    首先创建一个demo项目,在该项目中先创建一个FaceDetector类,为避免文件乱放,把所有相关的配置均放在该项目内,包括xml文件和jar包、被识别的图片12.jpg、需要加载的dll文件需要在idea中引入。

173241_LHbR_2431191.png

代码实现

    

package com.zzl;

/**
 * Class <code>Object</code> is the root of the class hierarchy.
 * Every class has <code>Object</code> as a superclass. All objects,
 * including arrays, implement the methods of this class.
 *
 * @author Administrator
 * @version 1.0
 * @see
 * @since JDK1.7
 * <p>
 * History
 * Created by Administrator on 2017/8/17 0017.
 */
import org.opencv.core.*;
import org.opencv.core.Point;
import org.opencv.highgui.Highgui;
import org.opencv.imgproc.Imgproc;
import org.opencv.objdetect.CascadeClassifier;


public class FaceDetector {

    public static void main(String[] args) throws Exception{
        //人脸识别
        detectFace();

    }

    public static void detectFace(){
        //加载本地的OpenCV库
        System.loadLibrary(Core.NATIVE_LIBRARY_NAME);
        System.out.println("Running FaceDetector");
        //创建实例CascadeClassifier,将已加装的分类器的文件名传进来
        CascadeClassifier faceDetector = new CascadeClassifier("D:\\study\\faceDetetorDemo\\src\\com\\zzl\\haarcascade_frontalface_alt.xml");
        //将图片转转化成Java API能够接受使用Highui类的格式,铺垫在OpenCV C++的n维密集数组类上边
        Mat image = Highgui.imread("D:\\study\\faceDetetorDemo\\src\\com\\zzl\\12.jpg");

        MatOfRect faceDetections = new MatOfRect();
        //调用分类器上的detectMultiScale方法传递给它图象和MatOfRect对象。MatOfRect将有面部检测
        faceDetector.detectMultiScale(image, faceDetections);

        System.out.println(String.format("Detected %s faces", faceDetections.toArray().length));
        //遍历所有的脸部检测并用矩形标记图像
        for (Rect rect : faceDetections.toArray()) {
            Core.rectangle(image, new Point(rect.x, rect.y), new Point(rect.x + rect.width, rect.y + rect.height),
                    new Scalar(0, 255, 0));
            // 把检测到的人脸重新定义大小后保存成文件
            Mat sub = image.submat(rect);
            Mat mat = new Mat();
            Size size = new Size(100, 100);
            Imgproc.resize(sub, mat, size);
            Highgui.imwrite("D:\\study\\faceDetetorDemo\\src\\com\\zzl\\face.jpg", mat);
        }

        //输出图片
        String filename = "D:\\study\\faceDetetorDemo\\src\\com\\zzl\\output.jpg";
        System.out.println(String.format("Writing %s", filename));
        Highgui.imwrite(filename, image);

    }

}

效果

原图:  12.jpg                                                      识别图:output.jpg                                        

173600_KiRK_2431191.png173633_5sKv_2431191.png

截取头像图:face.jpg

173758_xWTa_2431191.png

    自此,人脸识别出来了,duang~duang~duang~

转载于:https://my.oschina.net/alarm1673/blog/1517367

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值