-
Notifications
You must be signed in to change notification settings - Fork 12
/
process_eye.py
56 lines (45 loc) · 1.77 KB
/
process_eye.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
# -*- coding: utf-8 -*-
"""
Created on Tue Aug 15 16:59:44 2017
@author: Diego L.Guarin -- diego_guarin at meei.harvard.edu
"""
import cv2
from eye_window import ProcessEye
def get_iris_manual(Image, shape, position):
#function of obtain the iris manually, it ask the user to select 4 points
#around the iris
#get the eye from the image
if position == 'left':
#Left Eye
x_left = shape[42,0]
w_left = (shape[45,0]-x_left)
y_left = min(shape[43,1],shape[44,1])
h_left = (max(shape[46,1],shape[47,1])-y_left)
Eye = Image.copy()
Eye = Eye[(y_left-5):(y_left+h_left+5),(x_left-5):(x_left+w_left+5)]
elif position == 'right':
x_right = shape[36,0]
w_right = (shape[39,0]-x_right)
y_right = min(shape[37,1],shape[38,1])
h_right = (max(shape[41,1],shape[40,1])-y_right)
Eye = Image.copy()
Eye = Eye[(y_right-5):(y_right+h_right+5),(x_right-5):(x_right+w_right+5)]
#transform brg(opencv color scheme) to rbg (normal color scheme)
temp_image=Eye.copy()
temp_image = cv2.cvtColor(temp_image,cv2.COLOR_BGR2RGB)
#open the window to get the pupil
EyeWindow = ProcessEye(temp_image)
EyeWindow.exec_()
#return to full image coordinates
circle = EyeWindow._circle
if circle is not None: #verify that the is something to return
if position == 'left':
circle[0] = circle[0]+x_left-5
circle[1] = circle[1]+y_left-5
elif position == 'right':
circle[0] = circle[0]+x_right-5
circle[1] = circle[1]+y_right-5
#return circle information to main window
return circle
else: #if the user didn't include the 4 points then return 'None'
return None