forked from FAR-Lab/Interactive-Lab-Hub
-
Notifications
You must be signed in to change notification settings - Fork 0
/
hand_pose.py
88 lines (73 loc) · 2.98 KB
/
hand_pose.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
import cv2
import time
import numpy as np
import HandTrackingModule as htm
import math
from ctypes import cast, POINTER
import alsaaudio
m = alsaaudio.Mixer()
################################
wCam, hCam = 640, 480
################################
cap = cv2.VideoCapture(0)
cap.set(3, wCam)
cap.set(4, hCam)
pTime = 0
detector = htm.handDetector(detectionCon=0.7)
minVol = 0
maxVol = 100
vol = 0
volBar = 400
volPer = 0
while True:
success, img = cap.read()
img = detector.findHands(img)
lmList = detector.findPosition(img, draw=False)
if len(lmList) != 0:
thumbX, thumbY = lmList[4][1], lmList[4][2] #thumb
pointerX, pointerY = lmList[8][1], lmList[8][2] #pointer
middleX, middleY = lmList[12][1], lmList[12][2]
ringX, ringY = lmList[16][1], lmList[16][2]
pinkyX, pinkyY = lmList[20][1], lmList[20][2]
cx, cy = (thumbX + pointerX) // 2, (thumbY + pointerY) // 2
cv2.circle(img, (thumbX, thumbY), 15, (255, 0, 255), cv2.FILLED)
cv2.circle(img, (pointerX, pointerY), 15, (255, 0, 255), cv2.FILLED)
cv2.circle(img, (middleX, middleY), 15, (255, 0, 255), cv2.FILLED)
cv2.circle(img, (ringX, ringY), 15, (255, 0, 255), cv2.FILLED)
cv2.circle(img, (pinkyX, pinkyY), 15, (255, 0, 255), cv2.FILLED)
cv2.line(img, (thumbX, thumbY), (pointerX, pointerY), (255, 0, 255), 3)
cv2.circle(img, (cx, cy), 15, (255, 0, 255), cv2.FILLED)
len_calc = lambda x1,y1,x2,y2: math.hypot(x2 - x1, y2 - y1)
length = len_calc(thumbX,thumbY,pointerX,pointerY)
length1 = len_calc(pointerX,pointerY,middleX,middleY)
length2 = len_calc(middleX, middleY, ringX, ringY)
length3 = len_calc(ringX, ringY, pinkyX, pinkyY)
length4 = len_calc(thumbX,thumbY, ringX, ringY)
print(length1,length2,length3)
condition = length>100 and length1>100 and length2<100 and length3>100 and length4<100
if condition:
m.setvolume(0)
volPer = 0
volBar = 400
print("CONDITION")
cv2.putText(img, 'quiet coyote!', (40, 70), cv2.FONT_HERSHEY_COMPLEX,
1, (255, 255, 255), 3)
else:
vol = np.interp(length, [50, 300], [minVol, maxVol])
volBar = np.interp(length, [50, 300], [400, 150])
volPer = np.interp(length, [50, 300], [0, 100])
m.setvolume(int(vol))
print(int(length), vol)
if length < 50:
cv2.circle(img, (cx, cy), 15, (0, 255, 0), cv2.FILLED)
cv2.rectangle(img, (50, 150), (85, 400), (255, 0, 0), 3)
cv2.rectangle(img, (50, int(volBar)), (85, 400), (255, 0, 0), cv2.FILLED)
cv2.putText(img, f'{int(volPer)} %', (40, 450), cv2.FONT_HERSHEY_COMPLEX,
1, (255, 0, 0), 3)
cTime = time.time()
fps = 1 / (cTime - pTime)
pTime = cTime
cv2.putText(img, f'FPS: {int(fps)}', (40, 50), cv2.FONT_HERSHEY_COMPLEX,
1, (255, 0, 0), 3)
cv2.imshow("Img", img)
cv2.waitKey(1)