关键点说明

mediapipe手势识别可以识别出手部的21个关键点
hand_landmarks.png

获取关键点坐标

模型给出的结果是归一化的坐标比例,要获取在图像中的坐标需要乘以图像的宽高

  1. x = hand_landmarks.landmark[mp_hands.HandLandmark.INDEX_FINGER_TIP].x * image_width
  2. y = hand_landmarks.landmark[mp_hands.HandLandmark.INDEX_FINGER_TIP].y * image_height

示例代码

  1. import cv2
  2. import mediapipe as mp
  3. import numpy as np
  4. Key_Esc = 27
  5. mp_drawing = mp.solutions.drawing_utils
  6. mp_drawing_styles = mp.solutions.drawing_styles
  7. mp_hands = mp.solutions.hands
  8. # For webcam input:
  9. cap = cv2.VideoCapture(0)
  10. with mp_hands.Hands(
  11. # model_complexity=0,
  12. min_detection_confidence=0.5,
  13. min_tracking_confidence=0.5) as hands:
  14. while cap.isOpened():
  15. success, image = cap.read()
  16. if not success:
  17. print("Ignoring empty camera frame.")
  18. # If loading a video, use 'break' instead of 'continue'.
  19. continue
  20. # To improve performance, optionally mark the image as not writeable to
  21. # pass by reference.
  22. image.flags.writeable = False
  23. image = cv2.cvtColor(image, cv2.COLOR_BGR2RGB)
  24. results = hands.process(image)
  25. print('Handedness:', results.multi_handedness)
  26. # print(results.multi_hand_landmarks)
  27. # Draw the hand annotations on the image.
  28. image.flags.writeable = True
  29. image = cv2.cvtColor(image, cv2.COLOR_RGB2BGR)
  30. if results.multi_hand_landmarks:
  31. for hand_landmarks in results.multi_hand_landmarks:
  32. mp_drawing.draw_landmarks(
  33. image,
  34. hand_landmarks,
  35. mp_hands.HAND_CONNECTIONS,
  36. mp_drawing_styles.get_default_hand_landmarks_style(),
  37. mp_drawing_styles.get_default_hand_connections_style())
  38. # Flip the image horizontally for a selfie-view display.
  39. cv2.imshow('MediaPipe Hands', np.rot90(
  40. cv2.resize(cv2.flip(image, 1), (320, 240))))
  41. if cv2.waitKey(5) == Key_Esc:
  42. break
  43. cap.release()