发布于 2021-11-16 05:28:24
使用fbx模型的搅拌机中的索引似乎与mediapipe face网格解决方案中提供的索引相同。这些指标与mediapipe canonical face model uv visualization中的指标相同。This answer提供了通过索引获取地标的示例。
需要启用Developer Extras。在编辑模式下,该选项显示在Viewport Overlays > Developer > Indices下,如下所示,以便在搅拌器中获取索引。获取索引的替代选项可以是found here。
我已经展示了一个左眼地标索引的例子,因为它们出现在规范的脸部网格uv可视化中。
索引可视化


代码
基于的代码,https://google.github.io/mediapipe/solutions/face_mesh.html。
import cv2
import mediapipe as mp
mp_drawing = mp.solutions.drawing_utils
mp_drawing_styles = mp.solutions.drawing_styles
mp_face_mesh = mp.solutions.face_mesh
# For static images:
import glob
IMAGE_FILES = glob.glob('img.jpg')
drawing_spec = mp_drawing.DrawingSpec(thickness=1, circle_radius=1)
with mp_face_mesh.FaceMesh(
static_image_mode=True,
max_num_faces=1,
refine_landmarks=True,
min_detection_confidence=0.5) as face_mesh:
for idx, file in enumerate(IMAGE_FILES):
image = cv2.imread(file)
# Convert the BGR image to RGB before processing.
results = face_mesh.process(cv2.cvtColor(image, cv2.COLOR_BGR2RGB))
# Print and draw face mesh landmarks on the image.
if not results.multi_face_landmarks:
continue
annotated_image = image.copy()
landmarks_list = [
33, 7, 163, 144, 145, 153, 154, 155,
133, 173, 157, 158, 159, 160, 161, 246
]
for face_landmarks in results.multi_face_landmarks:
#print('face_landmarks:', face_landmarks)
print(len(face_landmarks.landmark))
# print(face_landmarks.landmark[7])
for idx in landmarks_list:
loc_x = int(face_landmarks.landmark[idx].x * image.shape[1])
loc_y = int(face_landmarks.landmark[idx].y * image.shape[0])
print(loc_x, loc_y)
cv2.circle(annotated_image,(loc_x, loc_y), 2, (255,255,255), 2)
cv2_imshow(annotated_image)输出

演示笔记本
https://stackoverflow.com/questions/69167499
复制相似问题