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
目录结构
首先创建一个demo项目,在该项目中先创建一个FaceDetector类,为避免文件乱放,把所有相关的配置均放在该项目内,包括xml文件和jar包、被识别的图片12.jpg、需要加载的dll文件需要在idea中引入。
代码实现
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
截取头像图:face.jpg
自此,人脸识别出来了,duang~duang~duang~