forked from opengazer/OpenGazer
-
Notifications
You must be signed in to change notification settings - Fork 0
/
EyeExtractor.cpp
56 lines (45 loc) · 1.67 KB
/
EyeExtractor.cpp
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
#include "utils.h"
#include "EyeExtractor.h"
const int EyeExtractor::eyedx = 32;
const int EyeExtractor::eyedy = 16;
const CvSize EyeExtractor::eyesize = cvSize(eyedx*2, eyedy*2);
void EyeExtractor::processEye(void) {
cvConvertScale(eyegrey.get(), eyefloat2.get());
// todo: equalize it somehow first!
cvSmooth(eyefloat2.get(), eyefloat.get(), CV_GAUSSIAN, 3);
cvEqualizeHist(eyegrey.get(), eyegrey.get());
}
EyeExtractor::EyeExtractor(const PointTracker &tracker):
tracker(tracker),
eyefloat2(cvCreateImage( eyesize, IPL_DEPTH_32F, 1 )),
eyegrey(cvCreateImage( eyesize, 8, 1 )),
eyefloat(cvCreateImage( eyesize, IPL_DEPTH_32F, 1 )),
eyeimage(cvCreateImage( eyesize, 8, 3 ))
{
}
void EyeExtractor::extractEye(const IplImage *origimage)
throw (TrackingException)
{
if (!tracker.status[tracker.eyepoint1])
throw TrackingException();
double x0 = tracker.currentpoints[tracker.eyepoint1].x;
double y0 = tracker.currentpoints[tracker.eyepoint1].y;
double x1 = tracker.currentpoints[tracker.eyepoint2].x;
double y1 = tracker.currentpoints[tracker.eyepoint2].y;
double factor = 0.17;
double xfactor = 0.05;
double yfactor = 0.20 * (x0 < x1 ? -1 : 1);
double L = factor / eyedx;
double LL = x0 < x1? L : -L;
float matrix[6] =
{LL*(x1-x0), LL*(y0-y1),
x0 + factor * ((1-xfactor)*(x1-x0) + yfactor * (y0-y1)),
LL*(y1-y0), LL*(x1-x0),
y0 + factor * ((1-xfactor)*(y1-y0) + yfactor * (x1-x0))};
CvMat M = cvMat( 2, 3, CV_32F, matrix );
cvGetQuadrangleSubPix( origimage, eyeimage.get(), &M);
cvCvtColor(eyeimage.get(), eyegrey.get(), CV_RGB2GRAY);
processEye();
}
EyeExtractor::~EyeExtractor(void) {
}