-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathMain.py
71 lines (58 loc) · 2.01 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
import cv2
from cvzone.HandTrackingModule import HandDetector
import cvzone
import numpy as np
cap = cv2.VideoCapture(2)
cap.set(3, 1280)
cap.set(4, 720)
detector = HandDetector(detectionCon=0.8)
colorR = (255, 0, 255)
cx, cy, w, h = 100, 100, 200, 200
class DragRect():
def __init__(self, posCenter, size=[200, 200]):
self.posCenter = posCenter
self.size = size
def update(self, cursor):
cx, cy = self.posCenter
w, h = self.size
# If the index finger tip is in the rectangle region
if cx - w // 2 < cursor[0] < cx + w // 2 and \
cy - h // 2 < cursor[1] < cy + h // 2:
self.posCenter = cursor
rectList = []
for x in range(5):
rectList.append(DragRect([x * 250 + 150, 150]))
while True:
success, img = cap.read()
img = cv2.flip(img, 1)
img = detector.findHands(img)
lmList, _ = detector.findPosition(img)
if lmList:
l, _, _ = detector.findDistance(8, 12, img, draw=False)
print(l)
if l < 30:
cursor = lmList[8] # index finger tip landmark
# call the update here
for rect in rectList:
rect.update(cursor)
## Draw solid
# for rect in rectList:
# cx, cy = rect.posCenter
# w, h = rect.size
# cv2.rectangle(img, (cx - w // 2, cy - h // 2),
# (cx + w // 2, cy + h // 2), colorR, cv2.FILLED)
# cvzone.cornerRect(img, (cx - w // 2, cy - h // 2, w, h), 20, rt=0)
## Draw Transperency
imgNew = np.zeros_like(img, np.uint8)
for rect in rectList:
cx, cy = rect.posCenter
w, h = rect.size
cv2.rectangle(imgNew, (cx - w // 2, cy - h // 2),
(cx + w // 2, cy + h // 2), colorR, cv2.FILLED)
cvzone.cornerRect(imgNew, (cx - w // 2, cy - h // 2, w, h), 20, rt=0)
out = img.copy()
alpha = 0.5
mask = imgNew.astype(bool)
out[mask] = cv2.addWeighted(img, alpha, imgNew, 1 - alpha, 0)[mask]
cv2.imshow("Image", out)
cv2.waitKey(1)