周报15

java版动作识别

package 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.objdetect.CascadeClassifier;
import org.opencv.imgcodecs.Imgcodecs;
import org.opencv.imgproc.Imgproc;
public class Test {
//引入训练好的人脸识别XML文件
static String PAHT = "E:\\opencv\\opencv\\build\\etc\\haarcascades\\haarcascade_frontalface_alt.xml";
static String IMAGE_PATH = "E:\\opencv\\1.jpg";
static String productPath = "E:\\opencv";

public static void main(String[] args) {

System.loadLibrary(Core.NATIVE_LIBRARY_NAME);
String Path = Test.class.getResource("haarcascade_frontalface_alt.xml").getPath();
System.out.println(Path);
CascadeClassifier faceDetector = new CascadeClassifier(PAHT);
Mat image = Imgcodecs.imread(IMAGE_PATH);
System.out.println(image);
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 = productPath+"\\ouput.jpg";
System.out.println(String.format("Writing %s", filename));
boolean flag = Imgcodecs.imwrite(filename, image);
System.out.println(flag);
}


}

posted @ 2022-06-12 17:33  我的未来姓栗山  阅读(33)  评论(0编辑  收藏  举报