-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy patheyetribe.js
103 lines (100 loc) · 3.32 KB
/
eyetribe.js
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
103
(function() {
var net = require('net');
var socket = null;
var latest = {};
var listening = false;
var port = 6555;
var socket_errors = 0;
var eyetribe = {
setup: function() {
},
stop_listening: function() {
listening = false;
if(socket) {
socket.destroy();
}
socket = null;
},
listen: function() {
if(socket) { return; }
latest = {
gaze_ts: 0,
status: 'not_initialized'
};
socket = new net.Socket();
socket.heartbeatCounter = 0;
socket.on('data', function(raw_data) {
var data = null;
try {
data = JSON.parse(raw_data);
} catch(e) { }
if(!data) { return; }
if(data.values && data.values.frame) {
var trackState = data.values.frame.state;
if(!socket.readyNotified) {
socket.readyNotified = true;
console.log("eyetribe state changed to \"tracker_ready\"");
} else if(socket.lastTrackState != trackState) {
socket.lastTrackState = trackState;
var state = "not_tracking";
if(trackState < 8) {
state = "fully_tracking";
if(trackState < 7) {
state = "partial_tracking";
}
}
console.log("eyetribe state changed to \"" + state + "\"");
latest.gaze_state = state;
latest.status = state;
}
// console.log(data.values.frame.state + " " + data.values.frame.avg.x + "," + data.values.frame.avg.y);
if(data.values.frame.state < 8) {
latest.gaze_x = data.values.frame.avg.x;
latest.gaze_y = data.values.frame.avg.y;
latest.gaze_ts = (new Date()).getTime();
// console.log("found " + latest.gaze_x + ", " + latest.gaze_y);
}
} else {
//console.log(data);
}
socket.heartbeatCounter++;
if(data.request == "get" && data.values && data.values.push === false) {
console.log("eyetribe connected. state: " + JSON.stringify(data.values));
latest.screen_width = data.values.screenresw;
latest.screen_height = data.values.screenresh;
socket.write(JSON.stringify({category: "tracker", request: "set", values: {"push": true}}));
} else if(socket.heartbeatCounter > 5 && listening) {
socket.heartbeatCounter = 0;
socket.write(JSON.stringify({category: "heartbeat"}));
}
});
socket.on('close', function() {
console.log("socket closed");
eyetribe.stop_listening();
});
socket.on('error', function() {
console.log("socket error");
socket_errors++;
eyetribe.stop_listening();
});
socket.connect(port, function() {
listening = true;
console.log('socket connected! sending initial message');
var json = {
"category": "tracker",
"request" : "get",
"values": [ "push", "iscalibrated", "screenresw", "screenresh" ]
};
socket.write(JSON.stringify(json));
});
},
ping: function() {
// if not already listening, go ahead and start listening
if(!listening && socket_errors < 10) {
eyetribe.listen();
}
return latest;
}
};
module.exports = eyetribe;
})();