Eclipse+Java+OpenCV246人脸检测
来源:互联网 发布:网络疯传婚礼新娘吃 编辑:程序博客网 时间:2024/05/16 23:49
1.环境搭建:见上一篇博客
整个项目的结构图:
package com.njupt.zhb.test;import org.opencv.core.Core;import org.opencv.core.Mat;import org.opencv.core.MatOfRect;import org.opencv.core.Point;import org.opencv.core.Rect;import org.opencv.core.Scalar;import org.opencv.highgui.Highgui;import org.opencv.objdetect.CascadeClassifier;//// Detects faces in an image, draws boxes around them, and writes the results// to "faceDetection.png".//public class DetectFaceDemo { public void run() { System.out.println("\nRunning DetectFaceDemo"); System.out.println(getClass().getResource("lbpcascade_frontalface.xml").getPath()); // Create a face detector from the cascade file in the resources // directory. //CascadeClassifier faceDetector = new CascadeClassifier(getClass().getResource("lbpcascade_frontalface.xml").getPath()); //Mat image = Highgui.imread(getClass().getResource("lena.png").getPath()); //注意:源程序的路径会多打印一个‘/’,因此总是出现如下错误/* * Detected 0 faces Writing faceDetection.png libpng warning: Image * width is zero in IHDR libpng warning: Image height is zero in IHDR * libpng error: Invalid IHDR data */ //因此,我们将第一个字符去掉 String xmlfilePath=getClass().getResource("lbpcascade_frontalface.xml").getPath().substring(1); CascadeClassifier faceDetector = new CascadeClassifier(xmlfilePath); Mat image = Highgui.imread(getClass().getResource("we.jpg").getPath().substring(1)); // Detect faces in the image. // MatOfRect is a special container class for Rect. MatOfRect faceDetections = new MatOfRect(); faceDetector.detectMultiScale(image, faceDetections); System.out.println(String.format("Detected %s faces", faceDetections.toArray().length)); // Draw a bounding box around each face. 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)); } // Save the visualized detection. String filename = "faceDetection.png"; System.out.println(String.format("Writing %s", filename)); Highgui.imwrite(filename, image); }}
3.编写测试类:
package com.njupt.zhb.test;public class TestMain { public static void main(String[] args) { System.out.println("Hello, OpenCV"); // Load the native library. System.loadLibrary("opencv_java246"); new DetectFaceDemo().run(); }}//运行结果://Hello, OpenCV////Running DetectFaceDemo///E:/eclipse_Jee/workspace/JavaOpenCV246/bin/com/njupt/zhb/test/lbpcascade_frontalface.xml//Detected 8 faces//Writing faceDetection.png
运行结果:
源码下载:http://download.csdn.net/detail/nuptboyzhb/5961985
未经允许,不得用于商业目的
- Eclipse+Java+OpenCV246人脸检测
- OpenCV246人脸检测
- Eclipse+Java+OpenCV246环境搭建和代码测试
- Eclipse+Java+OpenCV246环境搭建和代码测试
- VS2012配置OPENCV246
- VS2012+Opencv246 配置
- Java使用OpenCV人脸检测
- 人脸检测----(java+opencv)
- Java+opencv3.2.0之人脸检测
- eclipse检测不到手机
- eclipse检测不到手机
- JAVA应用JNI调用OpenCV实现人脸检测(1)
- JAVA应用JNI调用OpenCV实现人脸检测(1)
- JAVA应用JNI调用OpenCV实现人脸检测
- java与opencv结合,进行人脸检测
- 人脸检测的harr检测函数
- 人脸检测or五官检测
- OpenCV:人脸检测和行人检测
- 从无序数组中获取最小的M个元素(小顶堆实现)
- Charting Basics制作图表的基本知识
- SRM 588 D2 L3:GameInDarknessDiv2,DFS
- 堆排序算法(C#实现)
- 外包与非外包 浅谈
- Eclipse+Java+OpenCV246人脸检测
- 插入排序算法--直接插入算法,折半排序算法,希尔排序算法(C#实现)
- HDU-1256
- 2013/08/16 C# WPF 学习笔记
- java
- Warm up(hdu4612双连通分量+缩点+树的直径)
- zoj 3165 (最小割,最大点权独立集)
- Android 同步锁的使用
- 博客典藏