-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathCamController.js
121 lines (103 loc) · 4.15 KB
/
CamController.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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
function CamController(camElem, camNameElem, camRefElem, camPauseIconElem, camWaitTimerElem, rotateDelay) {
this.imgElement = camElem;
this.nameElem = camNameElem;
this.refElem = camRefElem;
this.pauseElem = camPauseIconElem;
this.waitTimerElem = camWaitTimerElem;
this.rotateDelay = rotateDelay;
this.shouldRotate = false;
this.cams = {
'carpark': {title: 'Car park', url: 'http://gateway.hackspace:8082'},
'main1': {title: 'Main room 1', url: 'http://gateway.hackspace:8083'}, // by soldering station
'door': {title: 'Internal door', url: 'http://gateway.hackspace:8084'},
'main2': {title: 'Main room 2', url: 'http://wifihifi.hackspace:8081'}, // on gateway cabinet
'outside': {title: 'Outside door', url: 'http://wifihifi.hackspace:8082'},
'3dprinter': {title: '3D printer', url: 'http://3dprinter.hackspace:8081'}
};
this.rotateCams = ['carpark', 'outside', '3dprinter'];
this.currentCam = 0;
this.nextCam();
};
CamController.prototype.nextCam = function() {
this.currentCam = (this.currentCam+1) % this.rotateCams.length;
this.switchTo(this.rotateCams[this.currentCam], function (err) {
if (err) {
this.rotateTimeout = window.setTimeout(this.nextCam.bind(this), 1000);
} else if (this.shouldRotate) {
this.rotateTimeout = window.setTimeout(this.nextCam.bind(this), this.rotateDelay);
this.resetWaitTimer(this.rotateDelay);
}
this.updateStatus();
}.bind(this));
}
CamController.prototype.startRotation = function() {
if (this.rotateTimeout) {
window.clearTimeout(this.rotateTimeout);
}
console.log('Starting camera rotation');
this.shouldRotate = true;
this.nextCam();
}
CamController.prototype.stopRotation = function() {
console.log('Stopping camera rotation');
window.clearTimeout(this.rotateTimeout);
this.rotateTimeout = null;
this.shouldRotate = false;
this.updateStatus();
}
CamController.prototype.switchTo = function(cameraName, cb /* err */) {
if (!this.cams.hasOwnProperty(cameraName)) {
console.log('Nonexistent camera ' + cameraName);
}
console.log('Switching to cam ' + this.cams[cameraName].title);
window.clearTimeout(this.rotateTimeout);
this.rotateTimeout = null;
var img = new Image();
img.addEventListener('load', function() {
console.log('Loaded cam ' + this.cams[cameraName].title);
this.imgElement.replaceChild(img, this.imgElement.querySelector('img'));
this.nameElem.innerHTML = this.cams[cameraName].title;
this.refElem.innerHTML = cameraName;
cb && cb(null);
}.bind(this));
img.addEventListener('error', function() {
console.log('Camera failed to load: ' + img.src);
cb && cb('Camera failed to load: ' + img.src);
}.bind(this));
img.src = this.cams[cameraName].url;
}
CamController.prototype.fixOnCam = function(camName) {
this.stopRotation();
this.switchTo(camName, function (err) {
this.updateStatus();
}.bind(this));
}
CamController.prototype.lingerOnCam = function(camName) {
this.stopRotation();
this.switchTo(camName, function (err) {
if (err) {
return this.startRotation();
}
this.rotateTimeout = window.setTimeout(this.startRotation.bind(this), 30000);
this.resetWaitTimer(30000);
this.updateStatus();
}.bind(this));
}
CamController.prototype.updateStatus = function() {
if (this.rotateTimeout) {
this.pauseElem.classList.add('hide');
this.waitTimerElem.classList.remove('hide');
} else {
this.pauseElem.classList.remove('hide');
this.waitTimerElem.classList.add('hide');
}
}
CamController.prototype.resetWaitTimer = function(durationMs) {
// Reset the CSS animation back to the start
var pie = this.waitTimerElem.querySelector('.pie');
pie.classList.remove('animate');
pie.style.animationDuration = durationMs/1000 + 's';
window.setTimeout(function () {
pie.classList.add('animate');
}, 10); // arbitrary amount of time to allow the browser to render the element without the animation applied
}