如何更改MediaPipe中Pose的最大姿势数量?
下面这段官方示例代码运行得很好。不过,这段代码只能在一张图片或视频中找到一个姿势。
https://github.com/google/mediapipe/blob/master/docs/solutions/pose.mdimport cv2
import mediapipe as mp
import numpy as np
mp_drawing = mp.solutions.drawing_utils
mp_drawing_styles = mp.solutions.drawing_styles
mp_pose = mp.solutions.pose
# For webcam input:
cap = cv2.VideoCapture(0)
with mp_pose.Pose( # <-- Does not have "max_poses" parameter
min_detection_confidence=0.5,
min_tracking_confidence=0.5) as pose:
while cap.isOpened():
success, image = cap.read()
if not success:
print("Ignoring empty camera frame.")
# If loading a video, use 'break' instead of 'continue'.
continue
# To improve performance, optionally mark the image as not writeable to
# pass by reference.
image.flags.writeable = False
image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
results = pose.process(image)
# Draw the pose annotation on the image.
image.flags.writeable = True
image = cv2.cvtColor(image, cv2.COLOR_RGB2BGR)
mp_drawing.draw_landmarks(
image,
results.pose_landmarks,
mp_pose.POSE_CONNECTIONS,
landmark_drawing_spec=mp_drawing_styles.get_default_pose_landmarks_style())
# Flip the image horizontally for a selfie-view display.
cv2.imshow('MediaPipe Pose', cv2.flip(image, 1))
if cv2.waitKey(5) & 0xFF == 27:
break
cap.release()
根据另一份文档,它指导我们使用PoseLandmarkerOptions()
,这个选项可以让我们通过num_poses
来进行更改,但上面的mp.solutions.pose.Pose()
代码没有这个选项。我希望能在最小修改的情况下重用这段代码。
谢谢!
1 个回答
0
MediaPipe Pose 目前的设计是每次只能检测一张图片中的一个姿势。如果你想检测多个姿势,可能需要想一些变通的方法,比如把输入的图片分成多个部分,然后对每个部分进行姿势检测。不过,按照最新的更新,通过这个接口并没有提供一个 max_poses 的选项。这意味着你只能用 MediaPipe 提供的简单方法一次检测一个姿势。记得关注未来的更新,看看有没有变化!