-
-
Notifications
You must be signed in to change notification settings - Fork 13
/
Copy patheye_blink.py
102 lines (92 loc) · 3.32 KB
/
eye_blink.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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
# This code is made by MRayan Asim
# Packages needed:
# pip install opencv-python
# pip install numpy
import cv2
# Initializing the face and eye cascade classifiers from xml files
face_cascade = cv2.CascadeClassifier("haarcascade_frontalface_default.xml")
eye_cascade = cv2.CascadeClassifier(
"haarcascade_eye_tree_eyeglasses.xml"
) # also download the other .xml files with it (in the same folder)
# Variable to store execution state
first_read = True
# Starting the video capture
cap = cv2.VideoCapture(0)
while True:
ret, img = cap.read()
# Converting the recorded image to grayscale
gray = cv2.cvtColor(img, cv2.COLOR_BGR2GRAY)
# Applying filter to remove impurities
gray = cv2.bilateralFilter(gray, 5, 1, 1)
# Detecting the face for the region of the image to be fed to the eye classifier
faces = face_cascade.detectMultiScale(gray, 1.3, 5, minSize=(200, 200))
if len(faces) > 0:
for x, y, w, h in faces:
img = cv2.rectangle(img, (x, y), (x + w, y + h), (0, 255, 0), 2)
# roi_face is the face which is input to the eye classifier
roi_face = gray[y : y + h, x : x + w]
roi_face_clr = img[y : y + h, x : x + w]
eyes = eye_cascade.detectMultiScale(roi_face, 1.3, 5, minSize=(50, 50))
# Examining the length of the eyes object for eyes
if len(eyes) >= 2:
# Check if the program is running for detection
if first_read:
cv2.putText(
img,
"Eye detected, press 's' to begin",
(70, 70),
cv2.FONT_HERSHEY_PLAIN,
3,
(0, 255, 0),
2,
)
else:
cv2.putText(
img,
"Eyes open!",
(70, 70),
cv2.FONT_HERSHEY_PLAIN,
2,
(255, 255, 255),
2,
)
first_read = (
True # Reset first_read to True after detecting the blink
)
else:
if first_read:
# To ensure if the eyes are present before starting
cv2.putText(
img,
"No eyes detected",
(70, 70),
cv2.FONT_HERSHEY_PLAIN,
3,
(0, 0, 255),
2,
)
else:
# This will print on the console and restart the algorithm
print("Blink detected--------------")
cv2.waitKey(3000)
first_read = True
else:
cv2.putText(
img,
"No face detected",
(100, 100),
cv2.FONT_HERSHEY_PLAIN,
3,
(0, 255, 0),
2,
)
# Controlling the algorithm with keys
cv2.imshow("img", img)
a = cv2.waitKey(1)
if a == ord("q"):
break
elif a == ord("s") and first_read:
# This will start the detection
first_read = False
cap.release()
cv2.destroyAllWindows()