-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.py
86 lines (74 loc) · 3.12 KB
/
main.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
import cv2 as cv
import mediapipe as mp
import time
class handDetector():
def __init__(self,mode = False,maxHands = 2, detectionCon = 0.5,trackCon = 0.5):
self.mode = mode
self.maxHands = maxHands
self.detectionCon = detectionCon
self.trackCon = trackCon
self.mpHands = mp.solutions.hands
self.hands = self.mpHands.Hands(static_image_mode= self.mode,
max_num_hands=self.maxHands,
min_detection_confidence=self.detectionCon,
min_tracking_confidence= self.trackCon)
self.mpDraw = mp.solutions.drawing_utils
def findHands(self,img,draw = True):
imgRGB = cv.cvtColor(img,cv.COLOR_BGR2RGB)
self.results = self.hands.process(imgRGB)
if self.results.multi_hand_landmarks:
for handLM in self.results.multi_hand_landmarks:
if draw:
self.mpDraw.draw_landmarks(img,handLM,self.mpHands.HAND_CONNECTIONS)
return img
def findPosition(self,img, handNo =0):
lmList = []
if self.results.multi_hand_landmarks:
myHand =self.results.multi_hand_landmarks[handNo]
for id, lm in enumerate(myHand.landmark):
h, w, c = img.shape
cx, cy = int(lm.x * w), int(lm.y * h)
lmList.append([id,cx,cy])
return lmList
def distance(self,point1,point2):
return (point1[1] - point2[1])*(point1[1] - point2[1]) + (point1[2] - point2[2])*(point1[2] - point2[2])
def getFingers(self,img,handNo = 0):
fingers = [1,1,1,1,1]
lmList = self.findPosition(img,handNo= handNo)
try:
if abs(lmList[3][1]-lmList[0][1]) < (lmList[2][1]-lmList[0][1]) or self.distance(lmList[0], lmList[2]) > self.distance(lmList[4], lmList[0]):
fingers[0] = 0
if self.distance(lmList[0], lmList[6]) > self.distance(lmList[8], lmList[0]):
fingers[1] = 0
if self.distance(lmList[0], lmList[10]) > self.distance(lmList[0], lmList[12]):
fingers[2] = 0
if self.distance(lmList[0], lmList[14]) > self.distance(lmList[0], lmList[16]):
fingers[3] = 0
if self.distance(lmList[0], lmList[18]) > self.distance(lmList[0], lmList[20]):
fingers[4] = 0
except:
raise Exception("NO Hand Found")
return fingers
def main():
pTime = 0
cap = cv.VideoCapture(0)
detector = handDetector()
while True:
success, img = cap.read()
img = detector.findHands(img)
try:
fingers = detector.getFingers(img)
print(fingers)
except Exception as ex:
print(f'An Exception Occurred: {ex}')
cTime = time.time()
fps = 1 / (cTime - pTime)
pTime = cTime
cv.putText(img, str(int(fps)), (10, 70), cv.FONT_HERSHEY_PLAIN, 3, (255, 0, 255), 3)
cv.imshow('image', img)
k = cv.waitKey(1)
if k == 27:
cv.destroyAllWindows()
break
if __name__ == "__main__":
main()