java - opencv人脸识别,获取图像周围坐标 "bounding box"

标签 java opencv coordinates

今天我正在尝试使用java中的opencv项目,我正在关注this代码。我修改它以与 opencv 3.0.0 一起使用。基本上我试图从文件夹中获取一堆图像并裁剪面部识别找到面部的图片。所以问题是我似乎无法获得图像周围的“边界框”的坐标( bounding box )。我想将图像裁剪到框中,有谁知道我在说什么或该怎么做?

感谢任何帮助! :) 我是一名(非常)初学者程序员。谢谢!

import java.io.File;
import java.io.IOException;
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.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;
import org.opencv.objdetect.CascadeClassifier;

public class hello {
    public static void main(String[] args) throws IOException {
    System.loadLibrary(Core.NATIVE_LIBRARY_NAME);
    System.out.println("\nRunning FaceDetector");

    CascadeClassifier faceDetector = new CascadeClassifier("C:/Users/Family/workspace/detect face/haarcascade_frontalface_alt.xml");

    File folder = new File("C:\\Users\\Family\\Downloads\\Photos");
    File[] listOfFiles = folder.listFiles();

    for (int j = 0; j < listOfFiles.length; j++) {
        System.out.println(listOfFiles[j]);
    }

    for (int i = 0; i < listOfFiles.length-1; i++){
        String picname = listOfFiles[i].toString();

        System.out.println("reading: " + listOfFiles[i]);

        Mat image = Imgcodecs.imread(picname);

        MatOfRect faceDetections = new MatOfRect();
        faceDetector.detectMultiScale(image, faceDetections);

        System.out.println(String.format("Detected %s faces", faceDetections.toArray().length));


        for (Rect rect : faceDetections.toArray()) {
            Imgproc.rectangle(image, new Point(rect.x, rect.y), new Point(rect.x + rect.width, rect.y + rect.height), new Scalar (0, 255, 0));
        }


        String filename = "monkey.png";
        System.out.println(String.format("Writing %s", filename));
        Imgcodecs.imwrite(filename, image);

    }
}

}

最佳答案

试试这个方法..

rect.getX(); //for getting x cordinates
rect.getY(); //for getting y cordinates
rect.getWidth(); //for getting width
rect.getHeight(); //for getting height

这张图片会对你有所帮助。

enter image description here

关于java - opencv人脸识别,获取图像周围坐标 "bounding box",我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31932588/

相关文章:

opencv flann 模块 : knn-search for hierarchical kmeans tree giving weird result

python - 如何将路径的 (X,Y) 坐标列表拆分为单独的 X 和 Y 坐标列表?

python - imdecode 返回 None Python opencv2

opencv - OpenCV SURF比较描述符

java - 需要一个对象的坐标

r - 使用 R 查找最近的 X,Y 坐标

java - 运行 "hbase shell"在 OSX 中给出错误

java - 访问 ="permitAll"和过滤器 ="none"之间的区别?

java - JDBC 类路径问题

Java - 大字符串需要用不同的字段长度分割