OpenCV杂谈_06
一. 需要做的前期准备
- 环境配置:
Python版本:3.9.0
功能包:opencv-python(4.5.2.52)、mediapipe(0.8.4.2)、time(已镶嵌在内部) - 一个用的顺手的IDE(本人推荐Pycharm)
二. 源码如下
import cv2
import mediapipe as mp
import time
cap = cv2.VideoCapture(0)
mpHands = mp.solutions.hands
hands = mpHands.Hands()
mpDraw = mp.solutions.drawing_utils
pTime = 0
cTime = 0
while True:
success, img = cap.read()
imgRGB = cv2.cvtColor(img, cv2.COLOR_BGR2RGB)
results = hands.process(imgRGB)
if results.multi_hand_landmarks:
for handLms in results.multi_hand_landmarks:
for id, lm in enumerate(handLms.landmark):
h, w, c = img.shape
cx, cy = int(lm.x * w), int(lm.y * h)
print(id, cx, cy)
if id == 4:
cv2.circle(img, (cx, cy), 10, (255, 0, 255), cv2.FILLED)
mpDraw.draw_landmarks(img, handLms, mpHands.HAND_CONNECTIONS)
cTime = time.time()
fps = 1/(cTime - pTime)
pTime = cTime
cv2.putText(img, 'FPS:' + str(int(fps)), (10, 70), cv2.FONT_ITALIC, 1, (0, 0, 255), 3)
cv2.imshow("Image", img)
cv2.waitKey(1)
三. 结果展示
![by demo](https://img-blog.csdnimg.cn/20210519160703340.GIF)
四. 感悟与分享
- 由于是直接调用别人事先写好的关于手的检测功能,以及在选择标记点时也参照了手的标记点示意图,总感觉有些tricky,不过Python不就是为了让你不重复造轮子么。
- 手部的标记点示意图:
![by demo](https://img-blog.csdnimg.cn/20210519161225722.PNG?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80MDI0Nzg3Ng==,size_16,color_FFFFFF,t_70)
- 参考课程及推荐:https://www.youtube.com/watch?v=NZde8Xt78Iw&list=RDCMUCYUjYU5FveRAscQ8V21w81A&index=11(内容为英文,且需要翻墙)
如有问题,敬请指正。欢迎转载,但请注明出处。