使用 flandmark (Javacv) 显示每个关键点的协调

Show coordinated for each keypoints using flandmark (Javacv)

我目前正在使用 JavaCV 从 flandmark 使用这个示例。参考:https://github.com/bytedeco/javacv-examples/blob/master/flandmark-demo/src/main/java/flandmark/Example1.java。我设法 运行 代码,但有没有一种方法可以显示面部(眼睛、嘴巴、鼻子)每个关键点的坐标? flandmark 库可以检测到大约 7/8 个关键点。谢谢

您在函数 detectFaceInImage 中找到了地标。在同一功能的底部,您会看到如何在脸上绘制检测到的地标:

flandmark_detect(input, bbox, model, landmarks);

// display landmarks
cvRectangle(orig, cvPoint(bbox[0], bbox[1]), cvPoint(bbox[2], bbox[3]), CV_RGB(255, 0, 0));
cvRectangle(orig,
cvPoint((int) model.bb().get(0), (int) model.bb().get(1)),
cvPoint((int) model.bb().get(2), (int) model.bb().get(3)), CV_RGB(0, 0, 255));
cvCircle(orig,
cvPoint((int) landmarks[0], (int) landmarks[1]), 3, CV_RGB(0, 0, 255), CV_FILLED, 8, 0);
for (int i = 2; i < 2 * model.data().options().M(); i += 2) {
    cvCircle(orig, cvPoint((int) (landmarks[i]), (int) (landmarks[i + 1])), 3, CV_RGB(255, 0, 0), CV_FILLED, 8, 0);
}

bbox是一个int[]包含人脸边界框的坐标为:

int[0] -> top left x
int[1] -> top left y
int[2] -> bottom right x
int[3] -> bottom right y

landmarks是一个double[],包含依次为地标点的坐标:

index: 0   1   2   3   ...
coord: s0x s0y s1x s1y ...

参考来自 flandmark homepage

的图像

地标总数存储在model.data().options().M()中。现在你已经具备了打印地标坐标的所有基础知识:

for (int i = 0; i < 2 * model.data().options().M(); i += 2) {
    System.out.println("S" + (i/2) + ": (" + (int)(landmarks[i]) + ", " + (int)(landmarks[i+1]) + ")");
}