author | rougeronj |
Fri, 17 Apr 2015 11:48:03 +0200 | |
changeset 161 | 0b01cbd8ed9e |
parent 153 | 60bd2b36b9dc |
child 166 | fa9e24e46968 |
permissions | -rw-r--r-- |
108 | 1 |
!function(e){if("object"==typeof exports&&"undefined"!=typeof module)module.exports=e();else if("function"==typeof define&&define.amd)define([],e);else{var n;"undefined"!=typeof window?n=window:"undefined"!=typeof global?n=global:"undefined"!=typeof self&&(n=self),n.annotviz=e()}}(function(){var define,module,exports;return (function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require=="function"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error("Cannot find module '"+o+"'");throw f.code="MODULE_NOT_FOUND",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require=="function"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})({1:[function(require,module,exports){ |
2 |
/** |
|
3 |
* scripts/main.js |
|
4 |
* |
|
5 |
* This is the starting point for your application. |
|
6 |
* Take a look at http://browserify.org/ for more info |
|
7 |
*/ |
|
8 |
||
9 |
'use strict'; |
|
10 |
||
11 |
var doubleroll = require('./doubleroll'); |
|
12 |
var annotsroll = require('./annotsroll'); |
|
13 |
var annotstimeline = require('./annotstimeline'); |
|
14 |
var annotsvizview = require('./annotsvizview'); |
|
15 |
var stageview = require('./stageview'); |
|
16 |
var wswrapper = require('./wswrapper'); |
|
17 |
var logger = require('./logger'); |
|
119 | 18 |
var utils = require('./utils'); |
108 | 19 |
|
20 |
var _ = require('lodash'); |
|
21 |
||
22 |
module.exports = _({}) |
|
23 |
.extend(doubleroll) |
|
24 |
.extend(annotsroll) |
|
25 |
.extend(annotstimeline) |
|
26 |
.extend(annotsvizview) |
|
27 |
.extend(stageview) |
|
28 |
.extend(wswrapper) |
|
29 |
.extend(logger) |
|
119 | 30 |
.extend(utils) |
108 | 31 |
.value(); |
119 | 32 |
|
33 |
},{"./annotsroll":2,"./annotstimeline":3,"./annotsvizview":4,"./doubleroll":5,"./logger":6,"./stageview":8,"./utils":9,"./wswrapper":10,"lodash":"lodash"}],2:[function(require,module,exports){ |
|
108 | 34 |
/** |
35 |
* js/annotsRoll.js |
|
36 |
* |
|
37 |
* annotsRoll basic component |
|
38 |
* |
|
39 |
*/ |
|
40 |
||
41 |
'use strict'; |
|
42 |
||
43 |
var PIXI = require('pixi'); |
|
44 |
var _ = require('lodash'); |
|
45 |
||
46 |
var DEFAULT_ANNOT_COLOR = '#bababa'; |
|
47 |
||
48 |
var defaultAnnotStyles = { |
|
49 |
'label': { font: '16pt Arial Bold', fill: '#65A954', wordWrap: true}, |
|
50 |
'text' : { font: '12pt Arial Regular', fill: '#444444', wordWrap: true}, |
|
51 |
'user' : { font: '14pt Arial regular', fill: '#666666' }, |
|
52 |
}; |
|
53 |
||
54 |
var defaultOptions = { |
|
55 |
externalRefresh: false, |
|
56 |
defaultColor: DEFAULT_ANNOT_COLOR, |
|
119 | 57 |
annotStyles: defaultAnnotStyles, |
58 |
ignoreAnnots:false |
|
108 | 59 |
}; |
60 |
||
61 |
function AnnotsRoll(options) { |
|
62 |
||
63 |
//parentContainer, xInit, yInit, width, height, widthRoll, pixelsPerSecond, annotColors |
|
64 |
var _this = this; |
|
65 |
var opts = _(options).defaults(defaultOptions).value(); |
|
66 |
||
67 |
||
68 |
this.container = new PIXI.DisplayObjectContainer(); |
|
69 |
this.container.x = opts.xInit; |
|
70 |
this.container.y = opts.yInit; |
|
71 |
this.container.width = opts.width; |
|
72 |
||
73 |
this.height = opts.height; |
|
74 |
this.width = opts.width; |
|
75 |
this.widthRoll = opts.widthRoll; |
|
76 |
this.pixelsPerSecond = opts.pixelsPerSecond; |
|
77 |
this.annotColors = opts.annotColors; |
|
119 | 78 |
this.startTs = opts.startTs || Date.now(); |
79 |
this.ignoreAnnots = opts.ignoreAnnots; |
|
108 | 80 |
|
81 |
var yInit = opts.yInit; |
|
82 |
var annotStyles = _(opts.annotStyles).defaults(defaultAnnotStyles).value(); |
|
130 | 83 |
var marginX = 15; |
108 | 84 |
for(var style in annotStyles) { |
85 |
if (annotStyles[style].wordWrap === true){ |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
86 |
annotStyles[style].wordWrapWidth = this.widthRoll - marginX; |
108 | 87 |
} |
88 |
} |
|
89 |
var started = false; |
|
90 |
var ws = opts.ws; |
|
91 |
var externalRefresh = opts.externalRefresh; |
|
92 |
var stageView = opts.stageView; |
|
119 | 93 |
var waitInterval; |
94 |
var wait = 0; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
95 |
|
108 | 96 |
stageView.registerComponent(this); |
97 |
||
98 |
var isHidden = function(child) { |
|
99 |
// TODO: the origin point is an approximation. Should refine this |
|
100 |
var globalPos = child.toGlobal(new PIXI.Point(0,0)); |
|
101 |
return ((globalPos.x + child.width) < 0) || ((globalPos.y + child.height) < 0) ; |
|
102 |
}; |
|
103 |
||
104 |
this.addAnnots = function(data) { |
|
105 |
||
106 |
//var title = data.content.category.label; |
|
107 |
//var user = data.content.user; |
|
108 |
//Test cat and color |
|
109 |
//var colorAnnot = 0x65A954; |
|
110 |
var category = data.content.category.label, |
|
111 |
text = data.content.text, |
|
112 |
user = data.content.user, |
|
113 |
ts = Date.parse(data.ts), |
|
130 | 114 |
color = data.content.color || this.getColor(ts, data.content.category.code); |
108 | 115 |
|
116 |
this.addAnnot(category, text, user, color, ts); |
|
117 |
}; |
|
118 |
||
119 |
this.getColor = function(ts, code) { |
|
120 |
var colorsDef; |
|
121 |
_(this.annotColors).eachRight(function(cdef) { |
|
122 |
if(cdef.ts < ts) { |
|
123 |
colorsDef = cdef.colors; |
|
124 |
return false; |
|
125 |
} |
|
126 |
}); |
|
127 |
var resColor; |
|
128 |
if(colorsDef) { |
|
129 |
resColor = colorsDef[code]; |
|
130 |
} |
|
131 |
if(!resColor) { |
|
130 | 132 |
resColor = colorsDef.defaultColor || DEFAULT_ANNOT_COLOR; |
108 | 133 |
} |
134 |
return resColor; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
135 |
}; |
108 | 136 |
|
130 | 137 |
this.addAnnot = function(category, text, user, color, ts){ |
108 | 138 |
|
139 |
var x = 0; |
|
140 |
var y = (ts-this.startTs) * this.pixelsPerSecond / 1000 + yInit; |
|
141 |
||
142 |
var colorHex = parseInt(color.replace(/^#/, ''), 16); |
|
143 |
||
119 | 144 |
if (wait === 0){ |
145 |
var graphics = new PIXI.Graphics() |
|
146 |
.beginFill(colorHex) |
|
147 |
.drawRect(x, y, 10, 3) |
|
148 |
.endFill(); |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
149 |
|
119 | 150 |
this.container.addChild(graphics); |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
151 |
|
119 | 152 |
var textHeight = 0; |
153 |
var catLabel = new PIXI.Text( |
|
154 |
category, |
|
155 |
_(annotStyles.label).extend({fill: color}).value() |
|
156 |
); |
|
130 | 157 |
catLabel.x = x + marginX; |
119 | 158 |
catLabel.y = y - 23; |
159 |
this.container.addChild(catLabel); |
|
160 |
textHeight += (catLabel.height - 23 + 2); |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
161 |
|
119 | 162 |
if(text) { |
163 |
var catText = new PIXI.Text(text, annotStyles.text); |
|
130 | 164 |
catText.x = x + marginX; |
119 | 165 |
catText.y = y + textHeight; |
166 |
this.container.addChild(catText); |
|
167 |
textHeight += (catText.height + 2); |
|
168 |
} |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
169 |
|
119 | 170 |
var catUser = new PIXI.Text(user, annotStyles.user); |
130 | 171 |
catUser.x = x + marginX; |
119 | 172 |
catUser.y = y + textHeight; |
173 |
this.container.addChild(catUser); |
|
174 |
textHeight += (catUser.height + 8); |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
175 |
|
119 | 176 |
if (this.ignoreAnnots === true){ |
177 |
wait = textHeight / this.pixelsPerSecond; |
|
178 |
waitInterval = setInterval(function() {_this.refreshWait();}, 1000); |
|
179 |
} |
|
108 | 180 |
} |
181 |
||
182 |
this.addAnnotLine(colorHex, y); |
|
183 |
}; |
|
184 |
||
185 |
this.addAnnotLine = function(color, y) { |
|
186 |
var x = this.widthRoll; |
|
187 |
||
188 |
||
189 |
var graphics = new PIXI.Graphics() |
|
190 |
.beginFill(color) |
|
191 |
.drawRect(x, y, this.width - x, 3) |
|
192 |
.endFill(); |
|
193 |
||
194 |
this.container.addChild(graphics); |
|
195 |
}; |
|
196 |
||
197 |
this.moveTo = function(diffTime){ |
|
198 |
this.container.y = Math.floor(diffTime*this.pixelsPerSecond); |
|
199 |
}; |
|
200 |
||
201 |
this.move = this.refresh = function() { |
|
202 |
var diff = (this.startTs - Date.now())/1000; |
|
203 |
this.moveTo(diff); |
|
204 |
}; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
205 |
|
119 | 206 |
this.refreshWait = function(){ |
207 |
wait -= 1; |
|
208 |
if (wait < 0){ |
|
209 |
wait = 0; |
|
210 |
clearInterval(waitInterval); |
|
211 |
} |
|
212 |
}; |
|
108 | 213 |
|
214 |
this.removePassedObjets = function(){ |
|
215 |
var childrenToRemove = []; |
|
216 |
_(_this.container.children).forEach(function(child) { |
|
217 |
return typeof(child) === 'undefined' || |
|
218 |
(isHidden(child) && childrenToRemove.push(child)); |
|
219 |
}); |
|
220 |
childrenToRemove.forEach(function(child) { |
|
221 |
_this.container.removeChild(child); |
|
222 |
}); |
|
223 |
}; |
|
224 |
||
225 |
this.init = function() { |
|
226 |
||
227 |
ws.message(function(data) { |
|
228 |
_this.addAnnots(data); |
|
229 |
}); |
|
230 |
||
231 |
}; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
232 |
|
108 | 233 |
|
234 |
this.start = function() { |
|
235 |
if(!started) { |
|
236 |
this.startTs = Date.now(); |
|
237 |
started = true; |
|
238 |
} |
|
239 |
this.cleanInterval = setInterval(function () { _this.removePassedObjets(); }, 1000 * this.height / this.pixelsPerSecond ); |
|
240 |
if(!externalRefresh) { |
|
241 |
this.refreshInterval = setInterval(function() {_this.move();}, 1000/this.framerate); |
|
242 |
} |
|
243 |
}; |
|
244 |
||
245 |
this.stop = function() { |
|
246 |
clearInterval(this.cleanInterval); |
|
247 |
if(!externalRefresh) { |
|
248 |
clearInterval(this.refreshInterval); |
|
249 |
} |
|
250 |
}; |
|
251 |
||
252 |
} |
|
253 |
||
254 |
module.exports = { |
|
255 |
AnnotsRoll: AnnotsRoll, |
|
256 |
}; |
|
257 |
||
258 |
},{"lodash":"lodash","pixi":"pixi"}],3:[function(require,module,exports){ |
|
259 |
/** |
|
260 |
* js/annotstimeline |
|
261 |
* |
|
262 |
* annotstimeline basic component |
|
263 |
* |
|
264 |
*/ |
|
265 |
||
266 |
'use strict'; |
|
267 |
||
268 |
var PIXI = require('pixi'); |
|
269 |
var Utils = require('./utils.js'); |
|
270 |
var _ = require('lodash'); |
|
271 |
||
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
272 |
var defaultOptions = { |
108 | 273 |
logger: undefined, |
274 |
intervalWidth: 10, |
|
275 |
intervalHeight: 5, |
|
276 |
maxCellHeight: 200, |
|
130 | 277 |
radius: 300, |
278 |
serverUrl: 'http://127.0.0.1:8080', |
|
279 |
channel: 'ANNOT', |
|
280 |
maxPages: 1000, |
|
281 |
showClockGraphics: true, |
|
282 |
archive: false |
|
108 | 283 |
}; |
284 |
||
285 |
||
286 |
function AnnotsTimeLine(options){ |
|
287 |
var _this = this; |
|
288 |
var opts = _(options).defaults(defaultOptions).value(); |
|
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
289 |
|
108 | 290 |
this.container = new PIXI.DisplayObjectContainer(); |
291 |
this.container.x = opts.xInit; |
|
292 |
this.container.y = opts.yInit; |
|
293 |
this.container.width = opts.width; |
|
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
294 |
this.container.height = opts.height; |
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
295 |
|
108 | 296 |
this.timeBegin = opts.timeBegin; |
297 |
this.timeEnd = opts.timeEnd; |
|
298 |
this.duration = (this.timeEnd - this.timeBegin)/1000; |
|
299 |
this.width = opts.width; |
|
300 |
this.height = opts.height; |
|
301 |
this.intervalHeight = opts.intervalHeight; |
|
302 |
this.intervalWidth = opts.intervalWidth; |
|
303 |
this.maxCellHeight = opts.maxCellHeight; |
|
304 |
this.annotCategories = opts.annotCategories; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
305 |
this.startTs = options.startTs || Date.now(); |
130 | 306 |
this.showClockGraphics = opts.showClockGraphics; |
307 |
this.archive = opts.archive; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
308 |
|
108 | 309 |
this.circleX = opts.circleX || (this.width/2); |
310 |
this.circleY = opts.circleY || (this.height/2); |
|
311 |
this.radius = opts.radius; |
|
130 | 312 |
var perimeter = 2*Math.PI* this.radius; |
313 |
this.intervalDuration = (this.intervalWidth * this.duration / perimeter); |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
314 |
|
130 | 315 |
var channel = opts.channel; |
316 |
var eventCode = opts.eventCode; |
|
317 |
var serverUrl = opts.serverUrl; |
|
318 |
var maxPages = opts.maxPages; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
319 |
|
130 | 320 |
var totalIndex = Math.floor( perimeter/this.intervalWidth); |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
321 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
322 |
this.cells = []; |
130 | 323 |
for (var i=0; i<(perimeter/this.intervalWidth) ; i++){ |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
324 |
this.cells[i] = []; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
325 |
this.cells[i].i = i; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
326 |
this.cells[i].totalAnnots = 0; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
327 |
this.cells[i].categories = {}; |
108 | 328 |
} |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
329 |
|
108 | 330 |
var ws = opts.ws; |
331 |
var stageView = opts.stageView; |
|
332 |
||
333 |
//draw the base - circle and line to locate the scene |
|
334 |
var graphics = new PIXI.Graphics(); |
|
335 |
graphics.lineStyle(2, 0x646464) |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
336 |
.drawCircle(this.circleX, this.circleY, this.radius - 3) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
337 |
.endFill(); |
108 | 338 |
this.container.addChild(graphics); |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
339 |
|
130 | 340 |
stageView.registerComponent(this); |
341 |
||
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
342 |
var loadArchives = function() { |
130 | 343 |
//start timeBegin end startTime |
344 |
//query -> need channel + eventCode |
|
345 |
//iterate over data fill cells |
|
346 |
var startTs = _this.timeBegin; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
347 |
var endTs = Math.min(_this.timeEnd,_this.startTs); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
348 |
|
130 | 349 |
var url = serverUrl + '/p/api/v1/annotation'; |
350 |
var filters = [ |
|
351 |
{ name: 'ts', op: '>', val: new Date(startTs).toISOString()}, //start |
|
352 |
{ name: 'ts', op: '<=', val: new Date(endTs).toISOString()}, //end |
|
353 |
{ name: 'channel', op: '==', val: channel}, //channel |
|
354 |
{ name: 'event_code', op: '==', val: eventCode} //eventcode |
|
355 |
]; |
|
356 |
||
357 |
url = url + '?q=' + JSON.stringify({filters:filters}); |
|
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
358 |
|
130 | 359 |
var totalPage = 1; |
360 |
var currentPage = 1; |
|
361 |
||
362 |
var processResFunction = function(res) { |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
363 |
//console.log("RES archive", res); |
130 | 364 |
if(res) { |
365 |
var data = res.target.json; |
|
366 |
/*jshint -W069 */ |
|
367 |
totalPage = Math.min(maxPages,parseInt(data['total_pages'])); |
|
368 |
data.objects.forEach(function(annotation) { |
|
369 |
_this.addAnnot(annotation); |
|
370 |
}); |
|
371 |
} |
|
372 |
if(currentPage <= totalPage) { |
|
373 |
var jsonLoader = new PIXI.JsonLoader(url+'&page='+currentPage, true); |
|
374 |
jsonLoader.on('loaded', processResFunction); |
|
375 |
jsonLoader.load(); |
|
376 |
currentPage++; |
|
377 |
} |
|
378 |
}; |
|
379 |
processResFunction(); |
|
380 |
||
381 |
}; |
|
108 | 382 |
|
383 |
//Add Annotation to the TimeLine |
|
384 |
this.addAnnot = function(data){ |
|
130 | 385 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
386 |
var ts = Date.parse(data.ts); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
387 |
var colorsDef; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
388 |
_(this.annotCategories).eachRight(function(cdef) { |
130 | 389 |
if(cdef.ts < ts) { |
390 |
colorsDef = cdef; |
|
391 |
return false; |
|
392 |
} |
|
393 |
}); |
|
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
394 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
395 |
if(!colorsDef) { |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
396 |
return; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
397 |
} |
130 | 398 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
399 |
if (this.timeEnd > ts){ |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
400 |
var i = Math.floor((ts - this.timeBegin)/(1000*this.intervalDuration)); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
401 |
|
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
402 |
if (typeof(this.cells[i].graphics) === 'undefined'){ |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
403 |
this.initCell(this.cells[i], colorsDef); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
404 |
} |
130 | 405 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
406 |
var annotCode; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
407 |
if (typeof(colorsDef.colors[data.content.category.code]) !== 'undefined'){ |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
408 |
annotCode = data.content.category.code; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
409 |
} else { |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
410 |
annotCode = 'default'; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
411 |
} |
130 | 412 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
413 |
this.cells[i].categories[annotCode].count += 1; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
414 |
this.cells[i].totalAnnots +=1; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
415 |
this.redrawCell(this.cells[i], colorsDef); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
416 |
} |
108 | 417 |
}; |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
418 |
|
130 | 419 |
this.initClockGraphics = function() { |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
420 |
var tBeg = new PIXI.Text(Utils.formatTime(this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' }); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
421 |
tBeg.x = this.circleX + 15; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
422 |
tBeg.y = this.circleY - this.radius - this.maxCellHeight - 10; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
423 |
this.container.addChild(tBeg); |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
424 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
425 |
var tEnd = new PIXI.Text(Utils.formatTime(this.timeEnd), { font: '12pt Gothic Standard', fill: '#646464' }); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
426 |
tEnd.x = this.circleX - 15 - tEnd.width; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
427 |
tEnd.y = this.circleY - this.radius - this.maxCellHeight - 10; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
428 |
this.container.addChild(tEnd); |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
429 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
430 |
var t15 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)/4) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' }); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
431 |
t15.x = this.circleX + this.radius + this.maxCellHeight + 10 ; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
432 |
t15.y = this.circleY - t15.height; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
433 |
t15.rotation = Math.PI /2; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
434 |
this.container.addChild(t15); |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
435 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
436 |
var t30 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)/2) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' }); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
437 |
t30.x = this.circleX - t30.width/2; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
438 |
t30.y = this.circleY + this.radius + this.maxCellHeight - 2; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
439 |
this.container.addChild(t30); |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
440 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
441 |
var t45 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)*3/4) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' }); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
442 |
t45.x = this.circleX - this.radius - this.maxCellHeight - 10 ; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
443 |
t45.y = this.circleY + t15.height; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
444 |
t45.rotation = -Math.PI/2; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
445 |
this.container.addChild(t45); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
446 |
|
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
447 |
var lineV = new PIXI.Graphics(); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
448 |
lineV.lineStyle(1, 0x646464) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
449 |
.moveTo(this.circleX, this.circleY - (this.radius/3)/2) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
450 |
.lineTo(this.circleX, this.circleY - this.radius - this.maxCellHeight - 10) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
451 |
.endFill(); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
452 |
this.container.addChild(lineV); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
453 |
}; |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
454 |
|
108 | 455 |
//Draw the cellule |
130 | 456 |
this.redrawCell = function(cell, colorsDef){ |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
457 |
var y = 0; |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
458 |
|
130 | 459 |
//Check if total height is higher than Max Cell Height |
460 |
var heightStep; |
|
461 |
if ((cell.totalAnnots*this.intervalHeight) > this.maxCellHeight){ |
|
462 |
heightStep = this.maxCellHeight/cell.totalAnnots; |
|
463 |
} else { |
|
464 |
heightStep = this.intervalHeight; |
|
465 |
} |
|
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
466 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
467 |
//Draw the rect depending on the height step calculated |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
468 |
for (var i=0; i< colorsDef.order.length; i++){ |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
469 |
var currentCode = colorsDef.order[i]; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
470 |
cell.graphics.beginFill(cell.categories[currentCode].color.replace('#', '0x')) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
471 |
.drawRect(0, y, this.intervalWidth-1, -cell.categories[currentCode].count * heightStep) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
472 |
.endFill(); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
473 |
y -= cell.categories[currentCode].count*heightStep; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
474 |
} |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
475 |
}; |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
476 |
|
130 | 477 |
this.initCell = function(cell, colorsDef){ |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
478 |
cell.graphics = new PIXI.Graphics(); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
479 |
cell.graphics.position.x = this.circleX + this.radius * Math.sin(cell.i*(360/totalIndex)*(Math.PI/180)); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
480 |
cell.graphics.position.y = this.circleY - this.radius * Math.cos(cell.i*(360/totalIndex)*(Math.PI/180)); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
481 |
cell.graphics.rotation = (cell.i)*(360/totalIndex)*(Math.PI/180) + (360/(totalIndex*2))*(Math.PI/180); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
482 |
this.container.addChild(cell.graphics); |
130 | 483 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
484 |
for (var category in colorsDef.colors){ |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
485 |
cell.categories[category] = { |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
486 |
'count': 0, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
487 |
'color': colorsDef.colors[category] |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
488 |
}; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
489 |
} |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
490 |
if (typeof(cell.categories['default']) === 'undefined'){ |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
491 |
cell.categories['default'] = { |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
492 |
'count': 0, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
493 |
'color': colorsDef.defaultColor |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
494 |
}; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
495 |
} |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
496 |
}; |
130 | 497 |
|
108 | 498 |
this.init = function() { |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
499 |
if (!this.archive){ |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
500 |
ws.message(function(data) { |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
501 |
_this.addAnnot(data); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
502 |
}); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
503 |
} |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
504 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
505 |
if (this.showClockGraphics){this.initClockGraphics();} |
108 | 506 |
}; |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
507 |
|
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
508 |
|
108 | 509 |
this.start = function() { |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
510 |
this.startTs = Date.now(); |
130 | 511 |
loadArchives(); |
108 | 512 |
}; |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
513 |
|
108 | 514 |
this.refresh = function() { |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
515 |
|
108 | 516 |
}; |
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
517 |
|
108 | 518 |
this.stop = function(){ |
519 |
}; |
|
109
8546e2181a73
correct color codes sent by client
ymh <ymh.work@gmail.com>
parents:
108
diff
changeset
|
520 |
|
108 | 521 |
return this; |
522 |
} |
|
523 |
||
524 |
module.exports = { |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
525 |
AnnotsTimeLine: AnnotsTimeLine |
108 | 526 |
}; |
527 |
||
528 |
},{"./utils.js":9,"lodash":"lodash","pixi":"pixi"}],4:[function(require,module,exports){ |
|
529 |
/** |
|
530 |
* js/annotsvizview.js |
|
531 |
* |
|
532 |
* This is the starting point for your application. |
|
533 |
* Take a look at http://browserify.org/ for more info |
|
148 | 534 |
* |
108 | 535 |
*/ |
148 | 536 |
/*jshint unused: false */ |
108 | 537 |
|
538 |
'use strict'; |
|
539 |
||
540 |
var PIXI = require('pixi'); |
|
541 |
var _ = require('lodash'); |
|
542 |
var DoubleRoll = require('./doubleroll.js'); |
|
543 |
var AnnotsTimeLine = require('./annotstimeline.js'); |
|
544 |
var AnnotsRoll = require('./annotsroll.js'); |
|
130 | 545 |
var Utils = require('./utils.js'); |
108 | 546 |
|
547 |
var defaultOptions = { |
|
548 |
xInit: 0, |
|
549 |
yInit: 0, |
|
550 |
width: 1024, |
|
130 | 551 |
height: 768 |
108 | 552 |
}; |
553 |
||
554 |
function AnnotsVizView(options){ |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
555 |
var _this = this; |
108 | 556 |
var opts = _(options).defaults(defaultOptions).value(); |
557 |
||
558 |
this.container = new PIXI.DisplayObjectContainer(); |
|
559 |
this.container.x = opts.xInit; |
|
560 |
this.container.y = opts.yInit; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
561 |
this.width = opts.width; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
562 |
this.height= opts.height; |
119 | 563 |
this.timeBegin = opts.timeBegin; |
564 |
this.timeEnd = opts.timeEnd; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
565 |
|
130 | 566 |
this.annotCategories = []; |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
567 |
this.annotCategoriesDay2 = []; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
568 |
this.annotCategoriesDay1 = []; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
569 |
|
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
570 |
var wsPianoroll = opts.wsPianoroll; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
571 |
var wsAnnot = opts.wsAnnot; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
572 |
var stageView = opts.stageView; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
573 |
var channel = opts.channel; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
574 |
var serverUrl = opts.serverUrl; |
148 | 575 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
576 |
var eventCode = opts.eventCode; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
577 |
var eventCodeSessionDay2 = opts.eventCodeSessionDay2; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
578 |
var eventCodeSessionDay1 = opts.eventCodeSessionDay1; |
148 | 579 |
var logger = opts.logger; |
108 | 580 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
581 |
Utils.getAnnotCategories(opts.urlCategories + eventCode, this.annotCategories); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
582 |
Utils.getAnnotCategories(opts.urlCategories + eventCodeSessionDay2, this.annotCategoriesDay2); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
583 |
Utils.getAnnotCategories(opts.urlCategories + eventCodeSessionDay1, this.annotCategoriesDay1); |
108 | 584 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
585 |
stageView.registerComponent(this); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
586 |
|
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
587 |
var currentDay = new AnnotsTimeLine.AnnotsTimeLine({ |
108 | 588 |
stageView : stageView, |
589 |
logger: logger, |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
590 |
ws: wsAnnot, |
108 | 591 |
xInit: 0, |
592 |
yInit: 0, |
|
593 |
width: 1024 - 200 - 200, |
|
594 |
height: 768-200, |
|
119 | 595 |
timeBegin: this.timeBegin, |
596 |
timeEnd: this.timeEnd, |
|
108 | 597 |
intervalWidth: 6, |
598 |
intervalHeight: 10, |
|
599 |
maxCellHeight: 70, |
|
600 |
radius: 200, |
|
130 | 601 |
eventCode: eventCode, |
602 |
channel: channel, |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
603 |
serverUrl: serverUrl, |
108 | 604 |
annotCategories: this.annotCategories |
605 |
}); |
|
148 | 606 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
607 |
//Archive day 2 |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
608 |
var timeLineDay2 = new AnnotsTimeLine.AnnotsTimeLine({ |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
609 |
stageView : stageView, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
610 |
xInit: 0, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
611 |
yInit: 0, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
612 |
width: 1024 - 200 - 200, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
613 |
height: 768-200, |
161 | 614 |
timeBegin: Date.parse('2015-04-16T14:00:00+02:00'), |
615 |
timeEnd: Date.parse('2015-04-16T21:00:00+02:00'), |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
616 |
circleX: currentDay.circleX, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
617 |
circleY: currentDay.circleY, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
618 |
intervalWidth: (currentDay.radius*2/3)* currentDay.intervalWidth / currentDay.radius, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
619 |
intervalHeight: (currentDay.intervalHeight * (currentDay.radius - currentDay.radius*2/3))/ currentDay.maxCellHeight, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
620 |
maxCellHeight: (currentDay.radius - currentDay.radius*2/3)/2, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
621 |
radius: currentDay.radius*2/3, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
622 |
annotCategories: this.annotCategoriesDay2, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
623 |
eventCode: eventCodeSessionDay2, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
624 |
channel: channel, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
625 |
serverUrl: serverUrl, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
626 |
showClockGraphics:false, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
627 |
archive: true |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
628 |
}); |
148 | 629 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
630 |
//Archive day 1 |
130 | 631 |
var timeLineDay1 = new AnnotsTimeLine.AnnotsTimeLine({ |
632 |
stageView : stageView, |
|
633 |
xInit: 0, |
|
634 |
yInit: 0, |
|
635 |
width: 1024 - 200 - 200, |
|
636 |
height: 768-200, |
|
161 | 637 |
timeBegin: Date.parse('2015-04-16T14:00:00+02:00'), |
638 |
timeEnd: Date.parse('2015-04-16T21:00:00+02:00'), |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
639 |
circleX: currentDay.circleX, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
640 |
circleY: currentDay.circleY, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
641 |
intervalWidth: (currentDay.radius*2/3)* currentDay.intervalWidth / currentDay.radius, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
642 |
intervalHeight: (currentDay.intervalHeight * (currentDay.radius - currentDay.radius/3))/ currentDay.maxCellHeight, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
643 |
maxCellHeight: (currentDay.radius*2/3 - currentDay.radius/3)/4, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
644 |
radius: currentDay.radius/3, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
645 |
annotCategories: this.annotCategoriesDay1, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
646 |
eventCode: eventCodeSessionDay1, |
130 | 647 |
channel: channel, |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
648 |
serverUrl: serverUrl, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
649 |
showClockGraphics:false, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
650 |
archive: true, |
130 | 651 |
}); |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
652 |
|
148 | 653 |
var currentTimeText = new PIXI.Text('-- : -- : --', { font: '18pt Gothic Standard', fill: '#646464' }); |
130 | 654 |
currentTimeText.x = timeLineDay2.circleX - currentTimeText.width/2; |
655 |
currentTimeText.y = timeLineDay2.circleY - currentTimeText.height/2; |
|
656 |
this.container.addChild(currentTimeText); |
|
108 | 657 |
|
148 | 658 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
659 |
var doubleRollH = new DoubleRoll.DoubleRoll({ |
108 | 660 |
stageView : stageView, |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
661 |
logger: logger, |
108 | 662 |
ws: wsPianoroll, |
663 |
yInit: (this.height - 200), |
|
664 |
sceneHeight: 200, |
|
665 |
pianorolls : [ |
|
666 |
{ |
|
667 |
height: 200, |
|
668 |
timeWidth: 10, |
|
669 |
lineInterval: 5000, |
|
670 |
noteHeight: 10 |
|
671 |
}, |
|
672 |
] |
|
673 |
}); |
|
674 |
||
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
675 |
var doubleRollV = new DoubleRoll.DoubleRoll({ |
108 | 676 |
stageView : stageView, |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
677 |
logger: logger, |
108 | 678 |
ws: wsPianoroll, |
679 |
orientation: 'vertical', |
|
680 |
sceneHeight: 768-200, |
|
681 |
pianorolls : [ |
|
682 |
{ |
|
683 |
height: 200, |
|
684 |
timeWidth: 60, |
|
685 |
lineInterval: 5000, |
|
686 |
noteHeight: 5, |
|
687 |
}, |
|
688 |
] |
|
689 |
}); |
|
690 |
||
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
691 |
var annotsRoll = new AnnotsRoll.AnnotsRoll({ |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
692 |
stageView : stageView, |
108 | 693 |
logger: logger, |
694 |
ws: wsAnnot, |
|
695 |
parentContainer: doubleRollV.stage, |
|
696 |
xInit: 1024 - 200 - 200, |
|
697 |
yInit: 768-200, |
|
698 |
width: 200 + 200, |
|
699 |
height: 768-200, |
|
700 |
widthRoll: 200, |
|
701 |
framerate: doubleRollV.framerate, |
|
702 |
pixelsPerSecond: Math.floor(1024 / 60), |
|
703 |
annotColors: this.annotCategories |
|
704 |
}); |
|
705 |
||
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
706 |
var limiters = new PIXI.Graphics() |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
707 |
.lineStyle(1, 0x646464) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
708 |
.moveTo(annotsRoll.container.x, annotsRoll.container.y) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
709 |
.lineTo(annotsRoll.container.x, annotsRoll.container.y - annotsRoll.height) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
710 |
.moveTo(annotsRoll.container.x + annotsRoll.widthRoll, annotsRoll.container.y) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
711 |
.lineTo(annotsRoll.container.x + annotsRoll.widthRoll, annotsRoll.container.y - annotsRoll.height) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
712 |
.moveTo(0, this.height - 200) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
713 |
.lineTo(this.width, this.height - 200) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
714 |
.drawRect(0, 0, this.width -1, this.height -1) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
715 |
.beginFill(0xECECEC) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
716 |
.drawRect(1024 - 200, 0, 200, 768-200) |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
717 |
.endFill(); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
718 |
this.container.addChild(limiters); |
108 | 719 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
720 |
this.init = function(){ |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
721 |
}; |
108 | 722 |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
723 |
this.updateTime = function(){ |
130 | 724 |
currentTimeText.setText(Utils.formatTime(Date.now())); |
725 |
}; |
|
108 | 726 |
|
130 | 727 |
var refreshTimeInterval; |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
728 |
|
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
729 |
this.start = function() { |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
730 |
refreshTimeInterval = setInterval(function() {_this.updateTime();}, 1000); |
108 | 731 |
}; |
732 |
||
733 |
this.refresh = function() { |
|
734 |
}; |
|
735 |
||
736 |
this.stop = function(){ |
|
737 |
}; |
|
738 |
||
739 |
return this; |
|
740 |
||
741 |
} |
|
742 |
||
743 |
module.exports = { |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
744 |
AnnotsVizView: AnnotsVizView |
108 | 745 |
}; |
746 |
||
130 | 747 |
},{"./annotsroll.js":2,"./annotstimeline.js":3,"./doubleroll.js":5,"./utils.js":9,"lodash":"lodash","pixi":"pixi"}],5:[function(require,module,exports){ |
108 | 748 |
/** |
749 |
* scripts/doubleroll.js |
|
750 |
* |
|
751 |
* This is the starting point for your application. |
|
752 |
* Take a look at http://browserify.org/ for more info |
|
753 |
*/ |
|
754 |
||
755 |
'use strict'; |
|
756 |
||
757 |
||
758 |
var PIXI = require('pixi'); |
|
759 |
var _ = require('lodash'); |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
760 |
var PianoRoll = require('./pianoroll'); |
150
c8fe9606d967
add temporary timeCode on doubleroll and copy change to server
rougeronj
parents:
149
diff
changeset
|
761 |
var Utils = require('./utils.js'); |
108 | 762 |
|
763 |
var defaultConfig = { |
|
764 |
orientation: 'horizontal', |
|
765 |
logger: undefined, |
|
766 |
sceneWidth: 1024, |
|
153
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
767 |
showTimer: false, |
108 | 768 |
pianorolls : [ |
769 |
{ |
|
148 | 770 |
height: 384, |
108 | 771 |
timeWidth: 10, |
772 |
lineInterval: 5000, |
|
148 | 773 |
noteHeight: undefined, |
774 |
range: { |
|
775 |
bottom: 40, |
|
776 |
top: 90, |
|
777 |
}, |
|
778 |
dynamicRange: true, |
|
108 | 779 |
}, |
780 |
{ |
|
148 | 781 |
height: 384, |
108 | 782 |
timeWidth: 60, |
783 |
lineInterval: 5000, |
|
148 | 784 |
noteHeight: undefined, |
785 |
range:{ |
|
786 |
bottom: 0, |
|
787 |
top: 128, |
|
788 |
}, |
|
789 |
dynamicRange: false, |
|
108 | 790 |
}, |
791 |
], |
|
792 |
framerate: 25, |
|
793 |
offsetMusic: false, |
|
794 |
sceneBgColor: 0xFFFFFF, |
|
795 |
lineColor: 0x444444, |
|
796 |
lineFillColor: 0xFFFF00, |
|
797 |
noteColors: [0xB90000, 0x4BDD71, 0xAF931E, 0x1C28BA, 0x536991], |
|
798 |
noteHeight: undefined, |
|
799 |
zeroShift: 0.9, |
|
800 |
timeWidth: 60, |
|
801 |
lineInterval: 5000, |
|
802 |
// wsUri: undefined, |
|
803 |
// eventCode: undefined |
|
804 |
||
805 |
}; |
|
806 |
||
807 |
function DoubleRoll(options) { |
|
808 |
||
809 |
var _this = this; |
|
810 |
var opts = _(options).defaults(defaultConfig).value(); |
|
811 |
||
812 |
var orientation = opts.orientation; |
|
813 |
var isHorizontal = (orientation !== 'vertical'); |
|
814 |
||
815 |
this.logger = opts.logger; |
|
816 |
this.lineColor = opts.lineColor; |
|
817 |
this.lineFillColor = opts.lineFillColor; |
|
818 |
this.framerate = opts.framerate; |
|
819 |
this.offsetMusic = opts.offsetMusic; |
|
820 |
this.noteColors = opts.noteColors; |
|
153
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
821 |
this.showTimer = opts.showTimer; |
108 | 822 |
|
823 |
var noteHeight = opts.noteHeight; |
|
824 |
var sceneHeight = opts.sceneHeight || _(opts.pianorolls).reduce(function(s,p) { return s + p.height; }, 0); |
|
825 |
var timeWidth = opts.timeWidth; |
|
826 |
var lineInterval = opts.lineInterval; |
|
827 |
var offsetMusic = opts.offsetMusic; |
|
828 |
||
829 |
var sceneWidth = opts.sceneWidth; |
|
830 |
var stageView = opts.stageView; |
|
831 |
||
153
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
832 |
|
108 | 833 |
var zeroShift = opts.zeroShift; |
834 |
||
835 |
var ws = opts.ws; |
|
836 |
||
837 |
var colorsReg = {}; |
|
838 |
||
839 |
this.container = new PIXI.DisplayObjectContainer(); |
|
840 |
this.container.x = Math.floor(sceneWidth*zeroShift); |
|
841 |
this.container.y = 0; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
842 |
|
108 | 843 |
stageView.registerComponent(this); |
844 |
||
845 |
var pianorollList = []; |
|
846 |
||
847 |
var pianorollOptions = { |
|
848 |
parentContainer: this.container, |
|
849 |
orientation: orientation, |
|
850 |
xInit: 0, |
|
851 |
width: sceneWidth, |
|
852 |
noteColors: this.noteColors, |
|
853 |
colorsReg: colorsReg, |
|
854 |
lineColor: this.lineColor, |
|
855 |
lineInterval: lineInterval, |
|
856 |
offsetMusic: offsetMusic, |
|
857 |
}; |
|
858 |
||
859 |
var yInit = opts.yInit || 0; |
|
860 |
var linesDown = true; |
|
861 |
_(opts.pianorolls).forEach(function(prDef, i) { |
|
148 | 862 |
var prNoteHeight = noteHeight || prDef.noteHeight || prDef.height / (prDef.range.top - prDef.range.bottom + 1); |
108 | 863 |
var prTimeWidth = prDef.timeWidth || timeWidth; |
864 |
pianorollList.push(new PianoRoll(_({ |
|
865 |
yInit: yInit, |
|
866 |
height: prDef.height, |
|
867 |
linesDown: linesDown, |
|
868 |
pixelsPerSecond: Math.floor(sceneWidth / prTimeWidth), |
|
869 |
noteHeight: prNoteHeight, |
|
148 | 870 |
lineInterval: prDef.lineInterval, |
871 |
range: prDef.range, |
|
872 |
dynamicRange: prDef.dynamicRange, |
|
108 | 873 |
}).defaults(pianorollOptions).value())); |
874 |
yInit += prDef.height; |
|
875 |
linesDown = !linesDown; |
|
876 |
||
877 |
if(i<(opts.pianorolls.length-1)) { |
|
878 |
var lineGraphics = new PIXI.Graphics() |
|
879 |
.beginFill(_this.lineFillColor) |
|
880 |
.lineStyle(1, _this.lineColor) |
|
881 |
.moveTo(Math.floor(sceneWidth*zeroShift), yInit) |
|
882 |
.lineTo(-sceneWidth - Math.floor(sceneWidth*zeroShift), yInit) |
|
883 |
.endFill(); |
|
884 |
_this.container.addChild(lineGraphics); |
|
885 |
} |
|
886 |
}); |
|
887 |
||
153
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
888 |
if (this.showTimer){ |
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
889 |
var currentTimeText = new PIXI.Text('-- : -- : --', { font: '40pt Arial', fill: '#646464' }); |
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
890 |
currentTimeText.x = -currentTimeText.width - 60; |
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
891 |
currentTimeText.y = sceneHeight - currentTimeText.height - 30; |
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
892 |
this.container.addChild(currentTimeText); |
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
893 |
} |
150
c8fe9606d967
add temporary timeCode on doubleroll and copy change to server
rougeronj
parents:
149
diff
changeset
|
894 |
|
c8fe9606d967
add temporary timeCode on doubleroll and copy change to server
rougeronj
parents:
149
diff
changeset
|
895 |
|
108 | 896 |
if(!isHorizontal) { |
150
c8fe9606d967
add temporary timeCode on doubleroll and copy change to server
rougeronj
parents:
149
diff
changeset
|
897 |
this.container.rotation = Math.PI/2; |
108 | 898 |
this.container.y = sceneHeight; |
899 |
this.container.x = sceneWidth; |
|
900 |
} |
|
901 |
||
902 |
||
903 |
this.init = function() { |
|
904 |
||
905 |
ws.message(function(data) { |
|
906 |
_this.addNotes(data); |
|
907 |
}); |
|
908 |
||
909 |
}; |
|
150
c8fe9606d967
add temporary timeCode on doubleroll and copy change to server
rougeronj
parents:
149
diff
changeset
|
910 |
|
c8fe9606d967
add temporary timeCode on doubleroll and copy change to server
rougeronj
parents:
149
diff
changeset
|
911 |
this.updateTime = function(){ |
c8fe9606d967
add temporary timeCode on doubleroll and copy change to server
rougeronj
parents:
149
diff
changeset
|
912 |
currentTimeText.setText(Utils.formatTime(Date.now())); |
c8fe9606d967
add temporary timeCode on doubleroll and copy change to server
rougeronj
parents:
149
diff
changeset
|
913 |
}; |
108 | 914 |
|
915 |
this.addNotes = function(data) { |
|
916 |
||
917 |
pianorollList.forEach(function(c) { |
|
918 |
c.addNoteRaw(data); |
|
919 |
}); |
|
920 |
}; |
|
921 |
||
922 |
this.refresh = function() { |
|
923 |
pianorollList.forEach(function(c) { |
|
924 |
c.move(); |
|
925 |
}); |
|
926 |
}; |
|
927 |
||
928 |
// Init page and intervals |
|
929 |
var startTs; |
|
150
c8fe9606d967
add temporary timeCode on doubleroll and copy change to server
rougeronj
parents:
149
diff
changeset
|
930 |
var refreshTimeInterval; |
108 | 931 |
|
932 |
this.start = function() { |
|
153
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
933 |
if (this.showTimer){ |
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
934 |
refreshTimeInterval = setInterval(function() {_this.updateTime();}, 1000); |
60bd2b36b9dc
put showTime as an option and add it to static pianoroll template on server
rougeronj
parents:
150
diff
changeset
|
935 |
} |
150
c8fe9606d967
add temporary timeCode on doubleroll and copy change to server
rougeronj
parents:
149
diff
changeset
|
936 |
|
108 | 937 |
startTs = Date.now(); |
938 |
pianorollList.forEach(function(c) { |
|
939 |
c.start(); |
|
940 |
}); |
|
941 |
}; |
|
942 |
||
943 |
this.stop = function() { |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
944 |
|
108 | 945 |
pianorollList.forEach(function(c) { |
946 |
c.stop(); |
|
947 |
}); |
|
948 |
}; |
|
949 |
||
950 |
||
951 |
this.log = function(m) { |
|
952 |
if(this.logger) { |
|
953 |
this.logger.log(m); |
|
954 |
} |
|
955 |
}; |
|
956 |
||
957 |
||
958 |
||
959 |
return this; |
|
960 |
} |
|
961 |
||
962 |
module.exports = { |
|
963 |
DoubleRoll: DoubleRoll |
|
964 |
}; |
|
965 |
||
150
c8fe9606d967
add temporary timeCode on doubleroll and copy change to server
rougeronj
parents:
149
diff
changeset
|
966 |
},{"./pianoroll":7,"./utils.js":9,"lodash":"lodash","pixi":"pixi"}],6:[function(require,module,exports){ |
108 | 967 |
/** |
968 |
* js/wswrapper.js |
|
969 |
* |
|
970 |
* simple logger service |
|
971 |
* |
|
972 |
*/ |
|
973 |
||
974 |
/* global document: false */ |
|
975 |
||
976 |
'use strict'; |
|
977 |
||
978 |
function HtmlLogger(doLog, container) { |
|
979 |
||
980 |
var logContainer = container; |
|
981 |
if(typeof(container) === 'string') { |
|
982 |
logContainer = document.getElementById(container); |
|
983 |
} |
|
984 |
if(!doLog) { |
|
985 |
document.body.removeChild(logContainer); |
|
986 |
logContainer = undefined; |
|
987 |
} |
|
988 |
||
989 |
||
990 |
this.log = function(msg) { |
|
991 |
if(doLog && logContainer) { |
|
992 |
logContainer.innerHTML += msg + '\n'; |
|
993 |
logContainer.scrollTop = logContainer.scrollHeight; |
|
994 |
} |
|
995 |
}; |
|
996 |
} |
|
997 |
||
998 |
function ConsoleLogger(doLog) { |
|
999 |
||
1000 |
this.log = function(msg) { |
|
1001 |
if(doLog) { |
|
1002 |
console.log(msg); |
|
1003 |
} |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1004 |
}; |
108 | 1005 |
|
1006 |
} |
|
1007 |
||
1008 |
module.exports = { |
|
1009 |
HtmlLogger: HtmlLogger, |
|
1010 |
ConsoleLogger: ConsoleLogger |
|
1011 |
}; |
|
1012 |
||
1013 |
},{}],7:[function(require,module,exports){ |
|
1014 |
/** |
|
1015 |
* js/pianoroll.js |
|
1016 |
* |
|
1017 |
* pianoroll basic component |
|
1018 |
* |
|
1019 |
*/ |
|
1020 |
||
1021 |
'use strict'; |
|
1022 |
||
1023 |
||
1024 |
var PIXI = require('pixi'); |
|
1025 |
var randomColor = require('randomColor'); |
|
1026 |
var _ = require('lodash'); |
|
1027 |
||
1028 |
var NTP_EPOCH_DELTA = 2208988800; //c.f. RFC 868 |
|
1029 |
||
1030 |
function PianoRoll(options) { |
|
1031 |
var _this = this; |
|
1032 |
this.container = new PIXI.DisplayObjectContainer(); |
|
1033 |
this.container.x = options.xInit; |
|
1034 |
this.container.y = options.yInit; |
|
1035 |
options.parentContainer.addChild(this.container); |
|
1036 |
||
1037 |
var orientation = options.orientation; |
|
1038 |
var isHorizontal = (orientation !== 'vertical'); |
|
1039 |
||
1040 |
this.linesDown = options.linesDown; |
|
1041 |
this.height = options.height; |
|
1042 |
this.pixelsPerSecond = options.pixelsPerSecond; |
|
1043 |
this.width = options.width; |
|
1044 |
this.noteColors = options.noteColors; |
|
1045 |
this.colorsReg = options.colorsReg || {}; |
|
1046 |
this.lineColor = options.lineColor; |
|
1047 |
this.lineInterval = options.lineInterval; |
|
1048 |
this.offsetMusic = options.offsetMusic || false; |
|
1049 |
this.noteHeight = options.noteHeight; |
|
1050 |
this.noteDict = {}; |
|
1051 |
this.startTs = options.startTs || Date.now(); |
|
148 | 1052 |
this.dynamicRange = options.dynamicRange; |
1053 |
this.initRange = options.range; |
|
1054 |
this.range = options.range; |
|
1055 |
||
108 | 1056 |
|
1057 |
var started = false; |
|
1058 |
||
1059 |
var isHidden = function(child) { |
|
1060 |
// TODO: the origin point is an approximation. Should refine this |
|
1061 |
var globalPos = child.toGlobal(new PIXI.Point(0,0)); |
|
1062 |
return ((globalPos.x + child.width) < 0) || ((globalPos.y + child.height) < 0) ; |
|
1063 |
}; |
|
1064 |
||
1065 |
//TODO: I do not like the "regColor" object. This should not be global, but local |
|
1066 |
this.getColor = function(canal) { |
|
1067 |
var color = this.colorsReg[canal]; |
|
1068 |
if(typeof(color) === 'undefined') { |
|
1069 |
var colorsRegSize = Object.keys(this.colorsReg).length; |
|
1070 |
if(colorsRegSize < this.noteColors.length) { |
|
1071 |
color = this.colorsReg[canal] = this.noteColors[colorsRegSize]; |
|
1072 |
} |
|
1073 |
else { |
|
1074 |
color = this.colorsReg[canal] = parseInt(randomColor({ luminosity: 'light', hue: 'random', format:'hex'}).replace(/^#/, ''), 16); |
|
1075 |
} |
|
1076 |
} |
|
1077 |
return color; |
|
1078 |
}; |
|
1079 |
||
148 | 1080 |
this.getNoteRect = function(note, x, y, color, alpha, width, height) { |
108 | 1081 |
var graphics = new PIXI.Graphics(); |
148 | 1082 |
graphics.note = note; |
108 | 1083 |
graphics.beginFill(color, alpha); |
1084 |
graphics.drawRect(0, 0, width, height); |
|
1085 |
graphics.endFill(); |
|
1086 |
graphics.x = x; |
|
1087 |
graphics.y = y; |
|
1088 |
graphics.width = width; |
|
1089 |
graphics.height = height; |
|
1090 |
return graphics; |
|
1091 |
}; |
|
1092 |
||
1093 |
this.addNoteRaw = function(data) { |
|
1094 |
var note = data.content[3]; |
|
1095 |
var velocity = data.content[4]; |
|
1096 |
var ts = (data.content[0] - NTP_EPOCH_DELTA)*1000; |
|
1097 |
var channel = data.content[2]; |
|
1098 |
var sessionTs = data.content[1]; |
|
1099 |
||
1100 |
this.addNote(note, ts, sessionTs, velocity, channel, 0); |
|
1101 |
}; |
|
1102 |
||
1103 |
this.addNote = function(note, startTime, sessionTs, velocity, channel, duration) { |
|
1104 |
||
1105 |
var ts = startTime; |
|
1106 |
if(this.offsetMusic) { |
|
1107 |
ts = this.startTs + sessionTs; |
|
1108 |
} |
|
1109 |
||
1110 |
var noteDuration = duration; |
|
1111 |
var noteVelocity = velocity; |
|
1112 |
var graphics; |
|
1113 |
if(!duration) { |
|
1114 |
if(typeof this.noteDict[channel]==='undefined'){ |
|
1115 |
this.noteDict[channel] = {}; |
|
1116 |
} |
|
1117 |
if(velocity===0) { |
|
1118 |
if(typeof this.noteDict[channel][note] !== 'undefined') { |
|
1119 |
var noteDef = this.noteDict[channel][note]; |
|
1120 |
delete this.noteDict[channel][note]; |
|
1121 |
noteDuration = sessionTs - noteDef.sessionTs; |
|
1122 |
graphics = noteDef.graphics; |
|
1123 |
noteVelocity = noteDef.velocity; |
|
1124 |
ts = noteDef.ts; |
|
1125 |
} |
|
1126 |
} |
|
1127 |
else { |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1128 |
noteDuration = Math.abs(Date.now() - ts); |
108 | 1129 |
this.noteDict[channel][note] = { ts: ts, velocity: velocity, sessionTs: sessionTs}; |
1130 |
} |
|
1131 |
} |
|
1132 |
||
1133 |
||
1134 |
if(!this.offsetMusic || velocity===0) { |
|
1135 |
||
1136 |
var width = noteDuration * this.pixelsPerSecond / 1000; |
|
1137 |
if(!graphics) { |
|
1138 |
var x = (ts-this.startTs) * this.pixelsPerSecond / 1000; |
|
1139 |
if((x+width) < (Math.abs(this.container.x) - this.width)) { |
|
1140 |
// not visible. do nothing |
|
1141 |
return; |
|
1142 |
} |
|
148 | 1143 |
if (this.dynamicRange && (this.range.bottom > note || note > this.range.top)){ |
1144 |
var newScale = {}; |
|
1145 |
newScale['bottom'] = Math.min(note, this.range.bottom); |
|
1146 |
newScale['top'] = Math.max(note, this.range.top); |
|
1147 |
this.rescaleScene(newScale); |
|
1148 |
} |
|
1149 |
var y = Math.floor(((this.range.top-this.range.bottom)-(note-this.range.bottom)+0.5) * (this.noteHeight) - (this.noteHeight/2)); |
|
108 | 1150 |
var color = this.getColor(channel); |
148 | 1151 |
|
108 | 1152 |
var alpha = (noteVelocity / 128); |
1153 |
||
148 | 1154 |
graphics = this.getNoteRect(note, x, y, color, alpha, width, this.noteHeight); |
108 | 1155 |
this.container.addChild(graphics); |
1156 |
} |
|
1157 |
else { |
|
1158 |
graphics.width = width; |
|
1159 |
} |
|
1160 |
||
1161 |
if(!duration && velocity) { |
|
1162 |
this.noteDict[channel][note].graphics = graphics; |
|
1163 |
} |
|
1164 |
} |
|
1165 |
}; |
|
148 | 1166 |
|
1167 |
//rescale scene in case a note out of range is added or a note out of the range is removed |
|
1168 |
this.rescaleScene = function(newScale){ |
|
1169 |
var _this = this; |
|
1170 |
var childrenToUpdate = []; |
|
1171 |
var top = this.initRange.top; |
|
1172 |
var bottom = this.initRange.bottom; |
|
1173 |
_(_this.container.children).forEach(function(child) { |
|
1174 |
if (typeof(child) !== 'undefined' && child.note && !isHidden(child)){ |
|
1175 |
top = Math.max(child.note, top); |
|
1176 |
bottom = Math.min(child.note, bottom); |
|
1177 |
return childrenToUpdate.push(child); |
|
1178 |
} |
|
1179 |
}); |
|
1180 |
if (newScale){ |
|
1181 |
this.range = newScale; |
|
1182 |
}else{ |
|
1183 |
this.range.top = top; |
|
1184 |
this.range.bottom = bottom; |
|
1185 |
} |
|
1186 |
this.noteHeight = this.height / (this.range.top - this.range.bottom + 1); |
|
1187 |
childrenToUpdate.forEach(function(child) { |
|
1188 |
child.y = Math.floor(((_this.range.top-_this.range.bottom)-(child.note-_this.range.bottom)+0.5) * (_this.noteHeight) - (_this.noteHeight/2)); |
|
1189 |
child.height = _this.noteHeight; |
|
1190 |
}); |
|
1191 |
}; |
|
108 | 1192 |
|
1193 |
this.addLine = function(ts){ |
|
1194 |
||
1195 |
if(typeof(ts) === 'undefined') { |
|
1196 |
ts = new Date(); |
|
1197 |
} |
|
1198 |
var x = -this.container.x; |
|
1199 |
var y = this.linesDown ? this.height - 20 : 0; |
|
1200 |
||
1201 |
var graphics = new PIXI.Graphics() |
|
1202 |
.beginFill(0xFFFF00) |
|
1203 |
.lineStyle(1, this.lineColor) |
|
1204 |
.moveTo(0, 0) |
|
1205 |
.lineTo(0, 20) |
|
1206 |
.endFill(); |
|
1207 |
graphics.x = x; |
|
1208 |
graphics.y = y; |
|
1209 |
this.container.addChild(graphics); |
|
1210 |
// Add text |
|
1211 |
//var totalSec = lineNb * this.lineInterval / 1000; |
|
1212 |
var hours = ts.getHours(); |
|
1213 |
var minutes =ts.getMinutes(); |
|
1214 |
var seconds = ts.getSeconds(); |
|
1215 |
var timeStr = (hours < 10 ? '0' + hours : hours) + ':' + (minutes < 10 ? '0' + minutes : minutes) + ':' + (seconds < 10 ? '0' + seconds : seconds); |
|
1216 |
||
1217 |
var fontObj = { font: '10pt Arial', fill: '#444444' }; |
|
1218 |
var t = new PIXI.Text(timeStr, fontObj); |
|
1219 |
if(isHorizontal) { |
|
1220 |
t.x = x + 2; |
|
1221 |
t.y = this.linesDown ? this.height - 15 : 2; |
|
1222 |
} |
|
1223 |
else { |
|
1224 |
t.rotation = -Math.PI/2; |
|
1225 |
t.x = x ; |
|
1226 |
t.y = this.linesDown ? this.height - 2 : t.width + 2; |
|
1227 |
} |
|
1228 |
this.container.addChild(t); |
|
1229 |
}; |
|
1230 |
||
1231 |
this.moveTo = function(diffTime){ |
|
1232 |
var oldX = this.container.x; |
|
1233 |
this.container.x = Math.floor(diffTime*this.pixelsPerSecond); |
|
1234 |
var deltaX = Math.abs(oldX-this.container.x); |
|
1235 |
_.forOwn(this.noteDict, function(channelDict) { |
|
1236 |
_.forOwn(channelDict, function(noteDef) { |
|
1237 |
if(noteDef.graphics) { |
|
1238 |
noteDef.graphics.width = noteDef.graphics.width + deltaX; |
|
1239 |
} |
|
1240 |
}); |
|
1241 |
}); |
|
1242 |
}; |
|
1243 |
||
1244 |
this.move = function() { |
|
1245 |
var diff = (this.startTs - Date.now())/1000; |
|
1246 |
this.moveTo(diff); |
|
1247 |
}; |
|
1248 |
||
1249 |
this.removePassedObjets = function(){ |
|
1250 |
var childrenToRemove = []; |
|
148 | 1251 |
var rescale = false; |
108 | 1252 |
_(_this.container.children).forEach(function(child) { |
1253 |
return typeof(child) === 'undefined' || |
|
1254 |
(isHidden(child) && childrenToRemove.push(child)); |
|
1255 |
}); |
|
1256 |
childrenToRemove.forEach(function(child) { |
|
148 | 1257 |
if (_this.dynamicRange && (_this.range.bottom === child.note || child.note === _this.range.top)){ |
1258 |
rescale = true; |
|
1259 |
} |
|
108 | 1260 |
_this.container.removeChild(child); |
1261 |
}); |
|
148 | 1262 |
//externalize this test to avoid repeated call to the function rescaleScene in the previous loop |
1263 |
if (rescale){ |
|
1264 |
_this.rescaleScene(); |
|
1265 |
} |
|
108 | 1266 |
}; |
1267 |
||
1268 |
this.start = function() { |
|
1269 |
if(!started) { |
|
1270 |
this.startTs = Date.now(); |
|
1271 |
this.addLine(); |
|
1272 |
started = true; |
|
1273 |
} |
|
1274 |
this.verticalLinesInterval = setInterval(function() { _this.addLine(); }, this.lineInterval); |
|
1275 |
this.cleanInterval = setInterval(function () { _this.removePassedObjets(); }, 1000 * this.width / this.pixelsPerSecond ); |
|
1276 |
}; |
|
1277 |
||
1278 |
this.stop = function() { |
|
1279 |
clearInterval(this.verticalLinesInterval); |
|
1280 |
clearInterval(this.cleanInterval); |
|
1281 |
}; |
|
1282 |
||
1283 |
} |
|
1284 |
||
1285 |
module.exports = PianoRoll; |
|
1286 |
||
1287 |
},{"lodash":"lodash","pixi":"pixi","randomColor":"randomColor"}],8:[function(require,module,exports){ |
|
1288 |
/** |
|
1289 |
* scripts/stageview.js |
|
1290 |
* |
|
1291 |
* This is the starting point for your application. |
|
1292 |
* Take a look at http://browserify.org/ for more info |
|
1293 |
*/ |
|
1294 |
||
1295 |
/* global document: false */ |
|
1296 |
||
1297 |
'use strict'; |
|
1298 |
||
1299 |
||
1300 |
var PIXI = require('pixi'); |
|
1301 |
var _ = require('lodash'); |
|
1302 |
||
1303 |
var defaultConfig = { |
|
1304 |
externalRefresh: false, |
|
1305 |
logger: undefined, |
|
1306 |
sceneWidth: 1024, |
|
1307 |
sceneHeight: 768, |
|
1308 |
framerate: 25, |
|
1309 |
sceneBgColor: 0xFFFFFF, |
|
1310 |
canvasContainer: 'canvasContainer', |
|
1311 |
}; |
|
1312 |
||
1313 |
function StageView(options) { |
|
1314 |
||
1315 |
var _this = this; |
|
1316 |
var opts = _(options).defaults(defaultConfig).value(); |
|
1317 |
||
1318 |
var externalRefresh = opts.externalRefresh; |
|
1319 |
||
1320 |
this.logger = opts.logger; |
|
1321 |
this.framerate = opts.framerate; |
|
1322 |
var sceneBgColor = opts.sceneBgColor; |
|
1323 |
var sceneWidth = opts.sceneWidth; |
|
1324 |
var sceneHeight = opts.sceneHeight; |
|
1325 |
var canvasContainer = opts.canvasContainer; |
|
1326 |
var timeContainer = []; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1327 |
var components = []; |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1328 |
|
108 | 1329 |
//create an new instance of a pixi stage |
1330 |
this.stage = new PIXI.Stage(sceneBgColor); |
|
1331 |
//create a renderer instance. |
|
1332 |
var renderer = PIXI.autoDetectRenderer(sceneWidth, sceneHeight); |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1333 |
|
108 | 1334 |
this.init = function() { |
1335 |
||
1336 |
if(typeof(canvasContainer) === 'string') { |
|
1337 |
canvasContainer = document.getElementById(canvasContainer); |
|
1338 |
} |
|
1339 |
if(typeof(timeContainer) === 'string') { |
|
1340 |
timeContainer = document.getElementById(timeContainer); |
|
1341 |
} |
|
1342 |
||
1343 |
canvasContainer.appendChild(renderer.view); |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1344 |
|
108 | 1345 |
components.forEach(function(c){ |
1346 |
c.init(); |
|
1347 |
}); |
|
1348 |
}; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1349 |
|
108 | 1350 |
this.registerTimeContainer = function(container) { |
1351 |
timeContainer.push(container); |
|
1352 |
}; |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1353 |
|
108 | 1354 |
this.registerComponent = function(component) { |
1355 |
components.push(component); |
|
1356 |
this.stage.addChild(component.container); |
|
1357 |
}; |
|
1358 |
||
1359 |
this.refresh = function() { |
|
1360 |
components.forEach(function(c){ |
|
1361 |
c.refresh(); |
|
1362 |
}); |
|
1363 |
renderer.render(this.stage); |
|
1364 |
}; |
|
1365 |
||
1366 |
// Init page and intervals |
|
1367 |
var refreshInterval; |
|
1368 |
||
1369 |
this.start = function() { |
|
1370 |
||
1371 |
if(!externalRefresh) { |
|
1372 |
refreshInterval = setInterval(function() {_this.refresh();}, 1000/this.framerate); |
|
1373 |
} |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1374 |
|
108 | 1375 |
components.forEach(function(c){ |
1376 |
c.start(); |
|
1377 |
}); |
|
1378 |
}; |
|
1379 |
||
1380 |
this.stop = function() { |
|
1381 |
if(!externalRefresh) { |
|
1382 |
clearInterval(refreshInterval); |
|
1383 |
} |
|
1384 |
||
1385 |
components.forEach(function(c){ |
|
1386 |
c.stop(); |
|
1387 |
}); |
|
1388 |
}; |
|
1389 |
||
1390 |
||
1391 |
this.log = function(m) { |
|
1392 |
if(this.logger) { |
|
1393 |
this.logger.log(m); |
|
1394 |
} |
|
1395 |
}; |
|
1396 |
||
1397 |
||
1398 |
return this; |
|
1399 |
} |
|
1400 |
||
1401 |
module.exports = { |
|
1402 |
StageView: StageView |
|
1403 |
}; |
|
1404 |
||
1405 |
},{"lodash":"lodash","pixi":"pixi"}],9:[function(require,module,exports){ |
|
1406 |
/** |
|
1407 |
* js/utils.js |
|
1408 |
* |
|
1409 |
* basic tools |
|
1410 |
* |
|
1411 |
*/ |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1412 |
/*jshint bitwise: false*/ |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1413 |
/*jshint camelcase: false */ |
108 | 1414 |
|
1415 |
'use strict'; |
|
1416 |
||
130 | 1417 |
var PIXI = require('pixi'); |
1418 |
var _ = require('lodash'); |
|
1419 |
var moment = require('moment'); |
|
1420 |
||
108 | 1421 |
function formatTime (ts) { |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1422 |
return moment(ts).format('HH:mm:ss'); |
108 | 1423 |
} |
1424 |
||
119 | 1425 |
function colorToHex(c) { |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1426 |
var m = /rgba?\(\s*(\d+)\s*,\s*(\d+)\s*,\s*(\d+)/.exec(c); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1427 |
return m ? '#' + (1 << 24 | m[1] << 16 | m[2] << 8 | m[3]).toString(16).substr(1) : c; |
119 | 1428 |
} |
1429 |
||
130 | 1430 |
function getAnnotCategories(urlCategories, annotCategories) { |
119 | 1431 |
|
130 | 1432 |
var jsonLoader = new PIXI.JsonLoader(urlCategories, true); |
1433 |
||
1434 |
jsonLoader.on('loaded', function(res) { |
|
1435 |
var data = res.target.json; |
|
1436 |
||
1437 |
while(annotCategories.length > 0) { |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1438 |
annotCategories.pop(); |
130 | 1439 |
} |
1440 |
||
1441 |
data.sessions.forEach(function(session) { |
|
1442 |
var annotCat = { |
|
1443 |
ts: session.start_ts === null ? new Date(0) : Date.parse(session.start_ts), |
|
1444 |
colors: {} |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1445 |
}; |
130 | 1446 |
var categoriesJson = session.categories_json; |
1447 |
annotCat.order = categoriesJson.order; |
|
1448 |
if (typeof(annotCat.order['default']) === 'undefined'){ |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1449 |
annotCat.order.push('default'); |
130 | 1450 |
} |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1451 |
var catList = _.clone(categoriesJson.categories); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1452 |
while(catList.length > 0) { |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1453 |
var cat = catList.pop(); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1454 |
if(cat.code) { |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1455 |
annotCat.colors[cat.code] = colorToHex(cat.color); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1456 |
} |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1457 |
if(cat.subcategories) { |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1458 |
catList = catList.concat(cat.subcategories); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1459 |
} |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1460 |
} |
130 | 1461 |
categoriesJson.categories.forEach(function(cat) { |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1462 |
if(cat.code) { |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1463 |
annotCat.colors[cat.code] = colorToHex(cat.color); |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1464 |
} |
130 | 1465 |
}); |
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1466 |
annotCat.defaultColor = categoriesJson.defaultColor || '#536991'; |
130 | 1467 |
annotCategories.push(annotCat); |
1468 |
}); |
|
1469 |
}); |
|
1470 |
||
1471 |
jsonLoader.load(); |
|
1472 |
||
1473 |
} |
|
108 | 1474 |
|
1475 |
module.exports = { |
|
142
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1476 |
formatTime: formatTime, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1477 |
getAnnotCategories: getAnnotCategories, |
e424eed32f72
Add correct options to annotviz.html fo 3rd day and gulp dist server
rougeronj
parents:
130
diff
changeset
|
1478 |
colorToHex: colorToHex |
108 | 1479 |
}; |
1480 |
||
130 | 1481 |
},{"lodash":"lodash","moment":"moment","pixi":"pixi"}],10:[function(require,module,exports){ |
108 | 1482 |
/** |
1483 |
* js/wswrapper.js |
|
1484 |
* |
|
1485 |
* simple webservice wrapper to register callbacks on onmessage |
|
1486 |
* |
|
1487 |
*/ |
|
1488 |
||
1489 |
/* global WebSocket: false */ |
|
1490 |
||
1491 |
'use strict'; |
|
1492 |
||
1493 |
function WsWrapper(wsurl, logger) { |
|
1494 |
||
1495 |
var url = wsurl; |
|
1496 |
var sock = new WebSocket(url); |
|
1497 |
var loggerObj = logger; |
|
1498 |
||
1499 |
var log = function(msg) { |
|
1500 |
if(loggerObj) { |
|
1501 |
loggerObj.log(msg); |
|
1502 |
} |
|
1503 |
}; |
|
1504 |
||
1505 |
var handlers = []; |
|
1506 |
||
1507 |
sock.onopen = function() { |
|
1508 |
log('Connected to ' + url); |
|
1509 |
}; |
|
1510 |
||
1511 |
sock.onclose = function(e) { |
|
1512 |
log('Connection closed (wasClean = ' + e.wasClean + ', code = ' + e.code + ', reason = \'' + e.reason + '\')'); |
|
1513 |
sock = null; |
|
1514 |
}; |
|
1515 |
||
1516 |
sock.onmessage = function(e) { |
|
1517 |
log('received ' + e.data); |
|
1518 |
var data = JSON.parse(e.data); |
|
1519 |
handlers.forEach(function(handler) { |
|
1520 |
handler(data); |
|
1521 |
}); |
|
1522 |
}; |
|
1523 |
||
1524 |
this.message = function(handler) { |
|
1525 |
if(handler) { |
|
1526 |
handlers.push(handler); |
|
1527 |
} |
|
1528 |
}; |
|
1529 |
||
1530 |
} |
|
1531 |
||
1532 |
module.exports = { |
|
1533 |
WsWrapper: WsWrapper |
|
1534 |
}; |
|
1535 |
||
1536 |
},{}]},{},[1])(1) |
|
1537 |
}); |
|
161 | 1538 |
//# sourceMappingURL=data:application/json;base64,{"version":3,"sources":["node_modules/browserify/node_modules/browser-pack/_prelude.js","./app/js/main.js","/Users/rougeronj/workspace/mons/client/annotviz/app/js/annotsroll.js","/Users/rougeronj/workspace/mons/client/annotviz/app/js/annotstimeline.js","/Users/rougeronj/workspace/mons/client/annotviz/app/js/annotsvizview.js","/Users/rougeronj/workspace/mons/client/annotviz/app/js/doubleroll.js","/Users/rougeronj/workspace/mons/client/annotviz/app/js/logger.js","/Users/rougeronj/workspace/mons/client/annotviz/app/js/pianoroll.js","/Users/rougeronj/workspace/mons/client/annotviz/app/js/stageview.js","/Users/rougeronj/workspace/mons/client/annotviz/app/js/utils.js","/Users/rougeronj/workspace/mons/client/annotviz/app/js/wswrapper.js"],"names":[],"mappings":"AAAA;ACAA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC9BA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC/NA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC5QA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACzNA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC7CA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AChRA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;ACpHA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AC1EA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA","file":"generated.js","sourceRoot":"","sourcesContent":["(function e(t,n,r){function s(o,u){if(!n[o]){if(!t[o]){var a=typeof require==\"function\"&&require;if(!u&&a)return a(o,!0);if(i)return i(o,!0);var f=new Error(\"Cannot find module '\"+o+\"'\");throw f.code=\"MODULE_NOT_FOUND\",f}var l=n[o]={exports:{}};t[o][0].call(l.exports,function(e){var n=t[o][1][e];return s(n?n:e)},l,l.exports,e,t,n,r)}return n[o].exports}var i=typeof require==\"function\"&&require;for(var o=0;o<r.length;o++)s(r[o]);return s})","/**\n * scripts/main.js\n *\n * This is the starting point for your application.\n * Take a look at http://browserify.org/ for more info\n */\n\n'use strict';\n\nvar doubleroll = require('./doubleroll');\nvar annotsroll = require('./annotsroll');\nvar annotstimeline = require('./annotstimeline');\nvar annotsvizview = require('./annotsvizview');\nvar stageview = require('./stageview');\nvar wswrapper = require('./wswrapper');\nvar logger = require('./logger');\nvar utils = require('./utils');\n\nvar _ = require('lodash');\n\nmodule.exports = _({})\n    .extend(doubleroll)\n    .extend(annotsroll)\n    .extend(annotstimeline)\n    .extend(annotsvizview)\n    .extend(stageview)\n    .extend(wswrapper)\n    .extend(logger)\n    .extend(utils)\n    .value();\n","/**\n* js/annotsRoll.js\n*\n* annotsRoll basic component\n*\n*/\n\n'use strict';\n\nvar PIXI = require('pixi');\nvar _ = require('lodash');\n\nvar DEFAULT_ANNOT_COLOR = '#bababa';\n\nvar defaultAnnotStyles = {\n    'label': { font: '16pt Arial Bold', fill: '#65A954', wordWrap: true},\n    'text' : { font: '12pt Arial Regular', fill: '#444444', wordWrap: true},\n    'user' : { font: '14pt Arial regular', fill: '#666666' },\n};\n\nvar defaultOptions = {\n    externalRefresh: false,\n    defaultColor: DEFAULT_ANNOT_COLOR,\n    annotStyles: defaultAnnotStyles,\n    ignoreAnnots:false\n};\n\nfunction AnnotsRoll(options) {\n\n//parentContainer, xInit, yInit, width, height, widthRoll, pixelsPerSecond, annotColors\n    var _this = this;\n    var opts = _(options).defaults(defaultOptions).value();\n\n\n    this.container = new PIXI.DisplayObjectContainer();\n    this.container.x = opts.xInit;\n    this.container.y = opts.yInit;\n    this.container.width = opts.width;\n\n    this.height = opts.height;\n    this.width = opts.width;\n    this.widthRoll = opts.widthRoll;\n    this.pixelsPerSecond = opts.pixelsPerSecond;\n    this.annotColors = opts.annotColors;\n    this.startTs = opts.startTs || Date.now();\n    this.ignoreAnnots = opts.ignoreAnnots;\n\n    var yInit = opts.yInit;\n    var annotStyles = _(opts.annotStyles).defaults(defaultAnnotStyles).value();\n    var marginX = 15;\n    for(var style in annotStyles) {\n    \tif (annotStyles[style].wordWrap === true){\n    \t\tannotStyles[style].wordWrapWidth = this.widthRoll - marginX;\n    \t}\n    }\n    var started = false;\n    var ws = opts.ws;\n    var externalRefresh = opts.externalRefresh;\n    var stageView = opts.stageView;\n    var waitInterval;\n    var wait = 0;\n\n    stageView.registerComponent(this);\n\n    var isHidden = function(child) {\n        // TODO: the origin point is an approximation. Should refine this\n        var globalPos = child.toGlobal(new PIXI.Point(0,0));\n        return ((globalPos.x + child.width) < 0) || ((globalPos.y + child.height) < 0) ;\n    };\n\n    this.addAnnots = function(data) {\n\n        //var title = data.content.category.label;\n        //var user = data.content.user;\n        //Test cat and color\n        //var colorAnnot = 0x65A954;\n        var category = data.content.category.label,\n            text     = data.content.text,\n            user     = data.content.user,\n            ts       = Date.parse(data.ts),\n            color    = data.content.color || this.getColor(ts, data.content.category.code);\n\n        this.addAnnot(category, text, user, color, ts);\n    };\n\n    this.getColor = function(ts, code) {\n        var colorsDef;\n        _(this.annotColors).eachRight(function(cdef) {\n            if(cdef.ts < ts) {\n                colorsDef = cdef.colors;\n                return false;\n            }\n        });\n        var resColor;\n        if(colorsDef) {\n            resColor = colorsDef[code];\n        }\n        if(!resColor) {\n            resColor = colorsDef.defaultColor || DEFAULT_ANNOT_COLOR;\n        }\n        return resColor;\n    };\n\n    this.addAnnot = function(category, text, user, color, ts){\n\n        var x = 0;\n        var y = (ts-this.startTs) * this.pixelsPerSecond / 1000 + yInit;\n\n        var colorHex = parseInt(color.replace(/^#/, ''), 16);\n\n        if (wait === 0){\n\t        var graphics = new PIXI.Graphics()\n\t            .beginFill(colorHex)\n\t            .drawRect(x, y, 10, 3)\n\t            .endFill();\n\n\t        this.container.addChild(graphics);\n\n\t        var textHeight = 0;\n\t        var catLabel = new PIXI.Text(\n\t            category,\n\t            _(annotStyles.label).extend({fill: color}).value()\n\t        );\n\t        catLabel.x = x + marginX;\n\t        catLabel.y = y - 23;\n\t        this.container.addChild(catLabel);\n\t        textHeight += (catLabel.height - 23 + 2);\n\n\t        if(text) {\n\t            var catText = new PIXI.Text(text, annotStyles.text);\n\t            catText.x = x + marginX;\n\t            catText.y = y + textHeight;\n\t            this.container.addChild(catText);\n\t            textHeight += (catText.height + 2);\n\t        }\n\n\t        var catUser = new PIXI.Text(user, annotStyles.user);\n\t        catUser.x = x + marginX;\n\t        catUser.y = y + textHeight;\n\t        this.container.addChild(catUser);\n\t        textHeight += (catUser.height + 8);\n\n\t        if (this.ignoreAnnots === true){\n\t\t        wait = textHeight / this.pixelsPerSecond;\n\t\t        waitInterval = setInterval(function() {_this.refreshWait();}, 1000);\n\t        }\n        }\n\n        this.addAnnotLine(colorHex, y);\n    };\n\n    this.addAnnotLine = function(color, y) {\n        var x = this.widthRoll;\n\n\n        var graphics = new PIXI.Graphics()\n            .beginFill(color)\n            .drawRect(x, y, this.width - x, 3)\n            .endFill();\n\n        this.container.addChild(graphics);\n    };\n\n    this.moveTo = function(diffTime){\n    \tthis.container.y = Math.floor(diffTime*this.pixelsPerSecond);\n    };\n\n    this.move = this.refresh = function() {\n        var diff = (this.startTs - Date.now())/1000;\n        this.moveTo(diff);\n    };\n\n    this.refreshWait = function(){\n    \twait -= 1;\n    \tif (wait < 0){\n    \t\twait = 0;\n    \t\tclearInterval(waitInterval);\n    \t}\n    };\n\n    this.removePassedObjets = function(){\n        var childrenToRemove = [];\n        _(_this.container.children).forEach(function(child) {\n            return typeof(child) === 'undefined' ||\n                (isHidden(child) && childrenToRemove.push(child));\n        });\n        childrenToRemove.forEach(function(child) {\n            _this.container.removeChild(child);\n        });\n    };\n\n    this.init = function() {\n\n        ws.message(function(data) {\n            _this.addAnnots(data);\n        });\n\n    };\n\n\n    this.start = function() {\n        if(!started) {\n            this.startTs = Date.now();\n            started = true;\n        }\n        this.cleanInterval = setInterval(function () { _this.removePassedObjets(); }, 1000 * this.height / this.pixelsPerSecond );\n        if(!externalRefresh) {\n            this.refreshInterval = setInterval(function() {_this.move();}, 1000/this.framerate);\n        }\n    };\n\n    this.stop = function() {\n        clearInterval(this.cleanInterval);\n        if(!externalRefresh) {\n            clearInterval(this.refreshInterval);\n        }\n    };\n\n}\n\nmodule.exports = {\n    AnnotsRoll: AnnotsRoll,\n};\n","/**\n* js/annotstimeline\n*\n* annotstimeline basic component\n*\n*/\n\n'use strict';\n\nvar PIXI = require('pixi');\nvar Utils = require('./utils.js');\nvar _ = require('lodash');\n\nvar defaultOptions = {\n    logger: undefined,\n    intervalWidth: 10,\n    intervalHeight: 5,\n    maxCellHeight: 200,\n    radius: 300,\n    serverUrl: 'http://127.0.0.1:8080',\n    channel: 'ANNOT',\n    maxPages: 1000,\n    showClockGraphics: true,\n    archive: false\n};\n\n\nfunction AnnotsTimeLine(options){\n    var _this = this;\n    var opts = _(options).defaults(defaultOptions).value();\n\n    this.container = new PIXI.DisplayObjectContainer();\n    this.container.x = opts.xInit;\n    this.container.y = opts.yInit;\n    this.container.width = opts.width;\n    this.container.height = opts.height;\n\n    this.timeBegin = opts.timeBegin;\n    this.timeEnd = opts.timeEnd;\n    this.duration = (this.timeEnd - this.timeBegin)/1000;\n    this.width = opts.width;\n    this.height = opts.height;\n    this.intervalHeight = opts.intervalHeight;\n    this.intervalWidth = opts.intervalWidth;\n    this.maxCellHeight = opts.maxCellHeight;\n    this.annotCategories = opts.annotCategories;\n    this.startTs = options.startTs || Date.now();\n    this.showClockGraphics = opts.showClockGraphics;\n    this.archive = opts.archive;\n\n    this.circleX = opts.circleX || (this.width/2);\n    this.circleY = opts.circleY || (this.height/2);\n    this.radius = opts.radius;\n    var perimeter = 2*Math.PI* this.radius;\n    this.intervalDuration = (this.intervalWidth * this.duration / perimeter);\n\n    var channel = opts.channel;\n    var eventCode = opts.eventCode;\n    var serverUrl = opts.serverUrl;\n    var maxPages = opts.maxPages;\n\n    var totalIndex = Math.floor( perimeter/this.intervalWidth);\n\n    this.cells = [];\n    for (var i=0; i<(perimeter/this.intervalWidth) ; i++){\n        this.cells[i] = [];\n        this.cells[i].i = i;\n        this.cells[i].totalAnnots = 0;\n        this.cells[i].categories = {};\n    }\n\n    var ws = opts.ws;\n    var stageView = opts.stageView;\n\n    //draw the base - circle and line to locate the scene\n    var graphics = new PIXI.Graphics();\n    graphics.lineStyle(2, 0x646464)\n        .drawCircle(this.circleX, this.circleY, this.radius - 3)\n        .endFill();\n    this.container.addChild(graphics);\n\n    stageView.registerComponent(this);\n\n    var loadArchives = function() {\n        //start timeBegin end startTime\n        //query -> need channel + eventCode\n        //iterate over data fill cells\n        var startTs = _this.timeBegin;\n        var endTs = Math.min(_this.timeEnd,_this.startTs);\n\n        var url = serverUrl + '/p/api/v1/annotation';\n        var filters = [\n            { name: 'ts', op: '>', val: new Date(startTs).toISOString()}, //start\n            { name: 'ts', op: '<=', val: new Date(endTs).toISOString()}, //end\n            { name: 'channel', op: '==', val: channel}, //channel\n            { name: 'event_code', op: '==', val: eventCode} //eventcode\n        ];\n\n        url = url + '?q=' + JSON.stringify({filters:filters});\n\n        var totalPage = 1;\n        var currentPage = 1;\n\n        var processResFunction = function(res) {\n            //console.log(\"RES archive\", res);\n            if(res) {\n                var data = res.target.json;\n                /*jshint -W069 */\n                totalPage = Math.min(maxPages,parseInt(data['total_pages']));\n                data.objects.forEach(function(annotation) {\n                    _this.addAnnot(annotation);\n                });\n            }\n            if(currentPage <= totalPage) {\n                var jsonLoader = new PIXI.JsonLoader(url+'&page='+currentPage, true);\n                jsonLoader.on('loaded', processResFunction);\n                jsonLoader.load();\n                currentPage++;\n            }\n        };\n        processResFunction();\n\n    };\n\n    //Add Annotation to the TimeLine\n    this.addAnnot = function(data){\n\n        var ts = Date.parse(data.ts);\n        var colorsDef;\n        _(this.annotCategories).eachRight(function(cdef) {\n            if(cdef.ts < ts) {\n                colorsDef = cdef;\n                return false;\n            }\n        });\n\n        if(!colorsDef) {\n            return;\n        }\n\n        if (this.timeEnd > ts){\n            var i = Math.floor((ts - this.timeBegin)/(1000*this.intervalDuration));\n\n            if (typeof(this.cells[i].graphics) === 'undefined'){\n                this.initCell(this.cells[i], colorsDef);\n            }\n\n            var annotCode;\n            if (typeof(colorsDef.colors[data.content.category.code]) !== 'undefined'){\n                annotCode = data.content.category.code;\n            } else {\n                annotCode = 'default';\n            }\n\n            this.cells[i].categories[annotCode].count += 1;\n            this.cells[i].totalAnnots +=1;\n            this.redrawCell(this.cells[i], colorsDef);\n        }\n    };\n\n    this.initClockGraphics = function() {\n        var tBeg = new PIXI.Text(Utils.formatTime(this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });\n        tBeg.x = this.circleX + 15;\n        tBeg.y = this.circleY - this.radius - this.maxCellHeight - 10;\n        this.container.addChild(tBeg);\n\n        var tEnd = new PIXI.Text(Utils.formatTime(this.timeEnd), { font: '12pt Gothic Standard', fill: '#646464' });\n        tEnd.x = this.circleX - 15 - tEnd.width;\n        tEnd.y = this.circleY - this.radius - this.maxCellHeight - 10;\n        this.container.addChild(tEnd);\n\n        var t15 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)/4) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });\n        t15.x = this.circleX + this.radius + this.maxCellHeight + 10 ;\n        t15.y = this.circleY - t15.height;\n        t15.rotation = Math.PI /2;\n        this.container.addChild(t15);\n\n        var t30 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)/2) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });\n        t30.x = this.circleX - t30.width/2;\n        t30.y = this.circleY + this.radius + this.maxCellHeight - 2;\n        this.container.addChild(t30);\n\n        var t45 = new PIXI.Text(Utils.formatTime(((this.timeEnd - this.timeBegin)*3/4) + this.timeBegin), { font: '12pt Gothic Standard', fill: '#646464' });\n        t45.x = this.circleX - this.radius - this.maxCellHeight - 10 ;\n        t45.y = this.circleY + t15.height;\n        t45.rotation = -Math.PI/2;\n        this.container.addChild(t45);\n\n        var lineV = new PIXI.Graphics();\n        lineV.lineStyle(1, 0x646464)\n            .moveTo(this.circleX, this.circleY - (this.radius/3)/2)\n            .lineTo(this.circleX, this.circleY - this.radius - this.maxCellHeight - 10)\n            .endFill();\n        this.container.addChild(lineV);\n    };\n\n    //Draw the cellule\n    this.redrawCell = function(cell, colorsDef){\n        var y = 0;\n\n        //Check if total height is higher than Max Cell Height\n        var heightStep;\n        if ((cell.totalAnnots*this.intervalHeight) > this.maxCellHeight){\n            heightStep = this.maxCellHeight/cell.totalAnnots;\n        } else {\n            heightStep = this.intervalHeight;\n        }\n\n        //Draw the rect depending on the height step calculated\n        for (var i=0; i< colorsDef.order.length; i++){\n            var currentCode = colorsDef.order[i];\n            cell.graphics.beginFill(cell.categories[currentCode].color.replace('#', '0x'))\n                .drawRect(0, y, this.intervalWidth-1, -cell.categories[currentCode].count * heightStep)\n                .endFill();\n            y -= cell.categories[currentCode].count*heightStep;\n        }\n    };\n\n    this.initCell = function(cell, colorsDef){\n        cell.graphics = new PIXI.Graphics();\n        cell.graphics.position.x = this.circleX + this.radius * Math.sin(cell.i*(360/totalIndex)*(Math.PI/180));\n        cell.graphics.position.y = this.circleY - this.radius * Math.cos(cell.i*(360/totalIndex)*(Math.PI/180));\n        cell.graphics.rotation = (cell.i)*(360/totalIndex)*(Math.PI/180) + (360/(totalIndex*2))*(Math.PI/180);\n        this.container.addChild(cell.graphics);\n\n        for (var category in colorsDef.colors){\n            cell.categories[category] = {\n                'count': 0,\n                'color': colorsDef.colors[category]\n            };\n        }\n        if (typeof(cell.categories['default']) === 'undefined'){\n            cell.categories['default'] = {\n                'count': 0,\n                'color': colorsDef.defaultColor\n            };\n        }\n    };\n\n    this.init = function() {\n        if (!this.archive){\n            ws.message(function(data) {\n                _this.addAnnot(data);\n            });\n        }\n\n        if (this.showClockGraphics){this.initClockGraphics();}\n    };\n\n\n    this.start = function() {\n        this.startTs = Date.now();\n        loadArchives();\n    };\n\n    this.refresh = function() {\n\n    };\n\n    this.stop = function(){\n    };\n\n    return this;\n}\n\nmodule.exports = {\n    AnnotsTimeLine: AnnotsTimeLine\n};\n","/**\n* js/annotsvizview.js\n*\n* This is the starting point for your application.\n* Take a look at http://browserify.org/ for more info\n*\n*/\n/*jshint unused: false */\n\n'use strict';\n\nvar PIXI = require('pixi');\nvar _ = require('lodash');\nvar DoubleRoll = require('./doubleroll.js');\nvar AnnotsTimeLine = require('./annotstimeline.js');\nvar AnnotsRoll = require('./annotsroll.js');\nvar Utils = require('./utils.js');\n\nvar defaultOptions = {\n    xInit: 0,\n    yInit: 0,\n    width: 1024,\n    height: 768\n};\n\nfunction AnnotsVizView(options){\n    var _this = this;\n    var opts = _(options).defaults(defaultOptions).value();\n\n    this.container = new PIXI.DisplayObjectContainer();\n    this.container.x = opts.xInit;\n    this.container.y = opts.yInit;\n    this.width = opts.width;\n    this.height= opts.height;\n    this.timeBegin = opts.timeBegin;\n    this.timeEnd = opts.timeEnd;\n\n    this.annotCategories = [];\n    this.annotCategoriesDay2 = [];\n    this.annotCategoriesDay1 = [];\n\n    var wsPianoroll = opts.wsPianoroll;\n    var wsAnnot = opts.wsAnnot;\n    var stageView = opts.stageView;\n    var channel = opts.channel;\n    var serverUrl = opts.serverUrl;\n\n    var eventCode = opts.eventCode;\n    var eventCodeSessionDay2 = opts.eventCodeSessionDay2;\n\tvar eventCodeSessionDay1 = opts.eventCodeSessionDay1;\n    var logger = opts.logger;\n\n\tUtils.getAnnotCategories(opts.urlCategories + eventCode, this.annotCategories);\n    Utils.getAnnotCategories(opts.urlCategories + eventCodeSessionDay2, this.annotCategoriesDay2);\n    Utils.getAnnotCategories(opts.urlCategories + eventCodeSessionDay1, this.annotCategoriesDay1);\n\n    stageView.registerComponent(this);\n\n    var currentDay = new AnnotsTimeLine.AnnotsTimeLine({\n    \tstageView : stageView,\n        logger: logger,\n        ws: wsAnnot,\n        xInit: 0,\n        yInit: 0,\n        width: 1024 - 200 - 200,\n        height: 768-200,\n        timeBegin: this.timeBegin,\n        timeEnd: this.timeEnd,\n        intervalWidth: 6,\n        intervalHeight: 10,\n        maxCellHeight: 70,\n        radius: 200,\n        eventCode: eventCode,\n        channel: channel,\n        serverUrl: serverUrl,\n        annotCategories: this.annotCategories\n    });\n\n\t//Archive day 2\n    var timeLineDay2 = new AnnotsTimeLine.AnnotsTimeLine({\n    \tstageView : stageView,\n        xInit: 0,\n        yInit: 0,\n        width: 1024 - 200 - 200,\n        height: 768-200,\n        timeBegin: Date.parse('2015-04-16T14:00:00+02:00'),\n        timeEnd: Date.parse('2015-04-16T21:00:00+02:00'),\n        circleX: currentDay.circleX,\n        circleY: currentDay.circleY,\n        intervalWidth: (currentDay.radius*2/3)* currentDay.intervalWidth / currentDay.radius,\n        intervalHeight: (currentDay.intervalHeight * (currentDay.radius - currentDay.radius*2/3))/ currentDay.maxCellHeight,\n        maxCellHeight: (currentDay.radius - currentDay.radius*2/3)/2,\n        radius: currentDay.radius*2/3,\n        annotCategories: this.annotCategoriesDay2,\n        eventCode: eventCodeSessionDay2,\n        channel: channel,\n        serverUrl: serverUrl,\n        showClockGraphics:false,\n        archive: true\n    });\n\n\t//Archive day 1\n    var timeLineDay1 = new AnnotsTimeLine.AnnotsTimeLine({\n    \tstageView : stageView,\n        xInit: 0,\n        yInit: 0,\n        width: 1024 - 200 - 200,\n        height: 768-200,\n        timeBegin: Date.parse('2015-04-16T14:00:00+02:00'),\n        timeEnd: Date.parse('2015-04-16T21:00:00+02:00'),\n        circleX: currentDay.circleX,\n        circleY: currentDay.circleY,\n        intervalWidth: (currentDay.radius*2/3)* currentDay.intervalWidth / currentDay.radius,\n        intervalHeight: (currentDay.intervalHeight * (currentDay.radius - currentDay.radius/3))/ currentDay.maxCellHeight,\n        maxCellHeight: (currentDay.radius*2/3 - currentDay.radius/3)/4,\n        radius: currentDay.radius/3,\n        annotCategories: this.annotCategoriesDay1,\n        eventCode: eventCodeSessionDay1,\n        channel: channel,\n        serverUrl: serverUrl,\n        showClockGraphics:false,\n        archive: true,\n    });\n\n    var currentTimeText = new PIXI.Text('-- : -- : --', { font: '18pt Gothic Standard', fill: '#646464' });\n    currentTimeText.x = timeLineDay2.circleX - currentTimeText.width/2;\n    currentTimeText.y = timeLineDay2.circleY - currentTimeText.height/2;\n    this.container.addChild(currentTimeText);\n\n\n    var doubleRollH = new DoubleRoll.DoubleRoll({\n        stageView : stageView,\n        logger: logger,\n        ws: wsPianoroll,\n        yInit: (this.height - 200),\n        sceneHeight: 200,\n        pianorolls : [\n            {\n                height: 200,\n                timeWidth: 10,\n                lineInterval: 5000,\n                noteHeight: 10\n            },\n        ]\n    });\n\n    var doubleRollV = new DoubleRoll.DoubleRoll({\n        stageView : stageView,\n        logger: logger,\n        ws: wsPianoroll,\n        orientation: 'vertical',\n        sceneHeight: 768-200,\n        pianorolls : [\n            {\n                height: 200,\n                timeWidth: 60,\n                lineInterval: 5000,\n                noteHeight: 5,\n            },\n        ]\n    });\n\n    var annotsRoll = new AnnotsRoll.AnnotsRoll({\n        stageView : stageView,\n        logger: logger,\n        ws: wsAnnot,\n        parentContainer: doubleRollV.stage,\n        xInit: 1024 - 200 - 200,\n        yInit: 768-200,\n        width: 200 + 200,\n        height: 768-200,\n        widthRoll: 200,\n        framerate: doubleRollV.framerate,\n        pixelsPerSecond: Math.floor(1024 / 60),\n        annotColors: this.annotCategories\n    });\n\n    var limiters = new PIXI.Graphics()\n        .lineStyle(1, 0x646464)\n        .moveTo(annotsRoll.container.x, annotsRoll.container.y)\n        .lineTo(annotsRoll.container.x, annotsRoll.container.y - annotsRoll.height)\n        .moveTo(annotsRoll.container.x + annotsRoll.widthRoll, annotsRoll.container.y)\n        .lineTo(annotsRoll.container.x + annotsRoll.widthRoll, annotsRoll.container.y - annotsRoll.height)\n        .moveTo(0, this.height - 200)\n        .lineTo(this.width, this.height - 200)\n        .drawRect(0, 0, this.width -1, this.height -1)\n        .beginFill(0xECECEC)\n        .drawRect(1024 - 200, 0, 200, 768-200)\n        .endFill();\n    this.container.addChild(limiters);\n\n    this.init = function(){\n    };\n\n    this.updateTime = function(){\n        currentTimeText.setText(Utils.formatTime(Date.now()));\n    };\n\n    var refreshTimeInterval;\n\n    this.start = function() {\n        refreshTimeInterval = setInterval(function() {_this.updateTime();}, 1000);\n    };\n\n    this.refresh = function() {\n    };\n\n    this.stop = function(){\n    };\n\n    return this;\n\n}\n\nmodule.exports = {\n    AnnotsVizView: AnnotsVizView\n};\n","/**\n* scripts/doubleroll.js\n*\n* This is the starting point for your application.\n* Take a look at http://browserify.org/ for more info\n*/\n\n'use strict';\n\n\nvar PIXI = require('pixi');\nvar _ = require('lodash');\nvar PianoRoll = require('./pianoroll');\nvar Utils = require('./utils.js');\n\nvar defaultConfig = {\n    orientation: 'horizontal',\n    logger: undefined,\n    sceneWidth: 1024,\n    showTimer: false,\n    pianorolls : [\n      {\n        height: 384,\n        timeWidth: 10,\n        lineInterval: 5000,\n        noteHeight: undefined,\n        range: {\n    \t\tbottom: 40,\n    \t\ttop: 90,\n        },\n        dynamicRange: true,\n      },\n      {\n        height: 384,\n        timeWidth: 60,\n        lineInterval: 5000,\n        noteHeight: undefined,\n        range:{\n    \t\tbottom: 0,\n    \t\ttop: 128,\n        },\n        dynamicRange: false,\n      },\n    ],\n    framerate: 25,\n    offsetMusic: false,\n    sceneBgColor: 0xFFFFFF,\n    lineColor: 0x444444,\n    lineFillColor: 0xFFFF00,\n    noteColors: [0xB90000, 0x4BDD71, 0xAF931E, 0x1C28BA, 0x536991],\n    noteHeight: undefined,\n    zeroShift: 0.9,\n    timeWidth: 60,\n    lineInterval: 5000,\n//    wsUri: undefined,\n//    eventCode: undefined\n\n};\n\nfunction DoubleRoll(options) {\n\n    var _this = this;\n    var opts = _(options).defaults(defaultConfig).value();\n\n    var orientation = opts.orientation;\n    var isHorizontal = (orientation !== 'vertical');\n\n    this.logger = opts.logger;\n    this.lineColor = opts.lineColor;\n    this.lineFillColor = opts.lineFillColor;\n    this.framerate = opts.framerate;\n    this.offsetMusic = opts.offsetMusic;\n    this.noteColors = opts.noteColors;\n    this.showTimer = opts.showTimer;\n\n    var noteHeight = opts.noteHeight;\n    var sceneHeight = opts.sceneHeight || _(opts.pianorolls).reduce(function(s,p) { return s + p.height; }, 0);\n    var timeWidth = opts.timeWidth;\n    var lineInterval = opts.lineInterval;\n    var offsetMusic = opts.offsetMusic;\n\n    var sceneWidth = opts.sceneWidth;\n    var stageView = opts.stageView;\n\n    \n    var zeroShift = opts.zeroShift;\n\n    var ws = opts.ws;\n\n    var colorsReg = {};\n\n    this.container = new PIXI.DisplayObjectContainer();\n    this.container.x = Math.floor(sceneWidth*zeroShift);\n    this.container.y = 0;\n\n    stageView.registerComponent(this);\n\n    var pianorollList = [];\n\n    var pianorollOptions = {\n        parentContainer: this.container,\n        orientation: orientation,\n        xInit: 0,\n        width: sceneWidth,\n        noteColors: this.noteColors,\n        colorsReg: colorsReg,\n        lineColor: this.lineColor,\n        lineInterval: lineInterval,\n        offsetMusic: offsetMusic,\n    };\n\n    var yInit = opts.yInit || 0;\n    var linesDown = true;\n    _(opts.pianorolls).forEach(function(prDef, i) {\n        var prNoteHeight = noteHeight || prDef.noteHeight || prDef.height / (prDef.range.top - prDef.range.bottom + 1);\n        var prTimeWidth = prDef.timeWidth || timeWidth;\n        pianorollList.push(new PianoRoll(_({\n            yInit: yInit,\n            height: prDef.height,\n            linesDown: linesDown,\n            pixelsPerSecond: Math.floor(sceneWidth / prTimeWidth),\n            noteHeight: prNoteHeight,\n            lineInterval: prDef.lineInterval,\n            range: prDef.range,\n            dynamicRange: prDef.dynamicRange,\n        }).defaults(pianorollOptions).value()));\n        yInit += prDef.height;\n        linesDown = !linesDown;\n\n        if(i<(opts.pianorolls.length-1)) {\n            var lineGraphics = new PIXI.Graphics()\n                .beginFill(_this.lineFillColor)\n                .lineStyle(1, _this.lineColor)\n                .moveTo(Math.floor(sceneWidth*zeroShift), yInit)\n                .lineTo(-sceneWidth - Math.floor(sceneWidth*zeroShift), yInit)\n                .endFill();\n            _this.container.addChild(lineGraphics);\n        }\n    });\n\n    if (this.showTimer){\n\t    var currentTimeText = new PIXI.Text('-- : -- : --', { font: '40pt Arial', fill: '#646464' });\n\t    currentTimeText.x = -currentTimeText.width - 60; \n\t    currentTimeText.y = sceneHeight - currentTimeText.height - 30;\n\t    this.container.addChild(currentTimeText);\n\t}\n    \n    \n    if(!isHorizontal) {\n        this.container.rotation = Math.PI/2; \n        this.container.y = sceneHeight;\n        this.container.x = sceneWidth;\n    }\n\n\n    this.init = function() {\n\n    \tws.message(function(data) {\n            _this.addNotes(data);\n        });\n\n    };\n    \n    this.updateTime = function(){\n        currentTimeText.setText(Utils.formatTime(Date.now()));\n    };\n\n    this.addNotes = function(data) {\n\n        pianorollList.forEach(function(c) {\n            c.addNoteRaw(data);\n        });\n    };\n\n    this.refresh = function() {\n        pianorollList.forEach(function(c) {\n            c.move();\n        });\n    };\n\n    // Init page and intervals\n    var startTs;\n    var refreshTimeInterval;\n\n    this.start = function() {\n    \tif (this.showTimer){\n    \t\trefreshTimeInterval = setInterval(function() {_this.updateTime();}, 1000);\n    \t}\n    \t\n        startTs = Date.now();\n        pianorollList.forEach(function(c) {\n            c.start();\n        });\n    };\n\n    this.stop = function() {\n\n        pianorollList.forEach(function(c) {\n            c.stop();\n        });\n    };\n\n\n    this.log = function(m) {\n        if(this.logger) {\n            this.logger.log(m);\n        }\n    };\n\n\n\n    return this;\n}\n\nmodule.exports = {\n    DoubleRoll: DoubleRoll\n};\n","/**\n* js/wswrapper.js\n*\n* simple logger service\n*\n*/\n\n/* global document: false */\n\n'use strict';\n\nfunction HtmlLogger(doLog, container) {\n\n    var logContainer = container;\n    if(typeof(container) === 'string') {\n        logContainer = document.getElementById(container);\n    }\n    if(!doLog) {\n        document.body.removeChild(logContainer);\n        logContainer = undefined;\n    }\n\n\n    this.log = function(msg) {\n        if(doLog && logContainer) {\n            logContainer.innerHTML += msg + '\\n';\n            logContainer.scrollTop = logContainer.scrollHeight;\n        }\n    };\n}\n\nfunction ConsoleLogger(doLog) {\n\n    this.log = function(msg) {\n        if(doLog) {\n            console.log(msg);\n        }\n    };\n\n}\n\nmodule.exports = {\n    HtmlLogger: HtmlLogger,\n    ConsoleLogger: ConsoleLogger\n};\n","/**\n* js/pianoroll.js\n*\n* pianoroll basic component\n*\n*/\n\n'use strict';\n\n\nvar PIXI = require('pixi');\nvar randomColor = require('randomColor');\nvar _ = require('lodash');\n\nvar NTP_EPOCH_DELTA = 2208988800; //c.f. RFC 868\n\nfunction PianoRoll(options) {\n    var _this = this;\n    this.container = new PIXI.DisplayObjectContainer();\n    this.container.x = options.xInit;\n    this.container.y = options.yInit;\n    options.parentContainer.addChild(this.container);\n\n    var orientation = options.orientation;\n    var isHorizontal = (orientation !== 'vertical');\n\n    this.linesDown = options.linesDown;\n    this.height = options.height;\n    this.pixelsPerSecond = options.pixelsPerSecond;\n    this.width = options.width;\n    this.noteColors = options.noteColors;\n    this.colorsReg = options.colorsReg || {};\n    this.lineColor = options.lineColor;\n    this.lineInterval = options.lineInterval;\n    this.offsetMusic = options.offsetMusic || false;\n    this.noteHeight = options.noteHeight;\n    this.noteDict = {};\n    this.startTs = options.startTs || Date.now();\n    this.dynamicRange = options.dynamicRange;\n    this.initRange = options.range;\n    this.range = options.range;\n    \n\n    var started = false;\n\n    var isHidden = function(child) {\n        // TODO: the origin point is an approximation. Should refine this\n        var globalPos = child.toGlobal(new PIXI.Point(0,0));\n        return ((globalPos.x + child.width) < 0) || ((globalPos.y + child.height) < 0) ;\n    };\n\n    //TODO: I do not like the \"regColor\" object. This should not be global, but local\n    this.getColor = function(canal) {\n        var color = this.colorsReg[canal];\n        if(typeof(color) === 'undefined') {\n            var colorsRegSize = Object.keys(this.colorsReg).length;\n            if(colorsRegSize < this.noteColors.length) {\n                color = this.colorsReg[canal] = this.noteColors[colorsRegSize];\n            }\n            else {\n                color = this.colorsReg[canal] = parseInt(randomColor({ luminosity: 'light', hue: 'random', format:'hex'}).replace(/^#/, ''), 16);\n            }\n        }\n        return color;\n    };\n\n    this.getNoteRect = function(note, x, y, color, alpha, width, height) {\n        var graphics = new PIXI.Graphics();\n        graphics.note = note;\n        graphics.beginFill(color, alpha);\n        graphics.drawRect(0, 0, width, height);\n        graphics.endFill();\n        graphics.x = x;\n        graphics.y = y;\n        graphics.width = width;\n        graphics.height = height;\n        return graphics;\n    };\n\n    this.addNoteRaw = function(data) {\n        var note = data.content[3];\n        var velocity = data.content[4];\n        var ts = (data.content[0] - NTP_EPOCH_DELTA)*1000;\n        var channel = data.content[2];\n        var sessionTs = data.content[1];\n\n        this.addNote(note, ts, sessionTs, velocity, channel, 0);\n    };\n\n    this.addNote = function(note, startTime, sessionTs, velocity, channel, duration) {\n\n        var ts = startTime;\n        if(this.offsetMusic) {\n            ts = this.startTs + sessionTs;\n        }\n\n        var noteDuration = duration;\n        var noteVelocity = velocity;\n        var graphics;\n        if(!duration) {\n            if(typeof this.noteDict[channel]==='undefined'){\n                this.noteDict[channel] = {};\n            }\n            if(velocity===0) {\n                if(typeof this.noteDict[channel][note] !== 'undefined') {\n                    var noteDef = this.noteDict[channel][note];\n                    delete this.noteDict[channel][note];\n                    noteDuration = sessionTs - noteDef.sessionTs;\n                    graphics = noteDef.graphics;\n                    noteVelocity = noteDef.velocity;\n                    ts = noteDef.ts;\n                }\n            }\n            else {\n                noteDuration = Math.abs(Date.now() - ts);\n                this.noteDict[channel][note] = { ts: ts, velocity: velocity, sessionTs: sessionTs};\n            }\n        }\n\n\n        if(!this.offsetMusic || velocity===0) {\n\n            var width = noteDuration * this.pixelsPerSecond / 1000;\n            if(!graphics) {\n                var x = (ts-this.startTs) * this.pixelsPerSecond / 1000;\n                if((x+width) <  (Math.abs(this.container.x) - this.width)) {\n                    // not visible. do nothing\n                    return;\n                }\n            \tif (this.dynamicRange && (this.range.bottom > note || note > this.range.top)){\n            \t\tvar newScale = {};\n            \t\tnewScale['bottom'] = Math.min(note, this.range.bottom);\n            \t\tnewScale['top'] = Math.max(note, this.range.top);\n            \t\tthis.rescaleScene(newScale);\n            \t}\n            \tvar y = Math.floor(((this.range.top-this.range.bottom)-(note-this.range.bottom)+0.5) * (this.noteHeight) - (this.noteHeight/2));\n                var color = this.getColor(channel);\n                \n                var alpha = (noteVelocity / 128);\n\n                graphics = this.getNoteRect(note, x, y, color, alpha, width, this.noteHeight);\n                this.container.addChild(graphics);\n            }\n            else {\n                graphics.width = width;\n            }\n\n            if(!duration && velocity) {\n                this.noteDict[channel][note].graphics = graphics;\n            }\n        }\n    };\n    \n    //rescale scene in case a note out of range is added or a note out of the range is removed\n    this.rescaleScene = function(newScale){\n    \tvar _this = this;\n    \tvar childrenToUpdate = [];\n    \tvar top = this.initRange.top;\n    \tvar bottom = this.initRange.bottom;\n    \t_(_this.container.children).forEach(function(child) {\n    \t\tif (typeof(child) !== 'undefined' && child.note && !isHidden(child)){\n    \t\t\ttop = Math.max(child.note, top);\n    \t\t\tbottom = Math.min(child.note, bottom);\n    \t\t\treturn childrenToUpdate.push(child);\n    \t\t}\n        });\n    \tif (newScale){\n    \t\tthis.range = newScale;\n    \t}else{\n    \t\tthis.range.top = top; \n    \t\tthis.range.bottom = bottom; \n    \t}\n    \tthis.noteHeight = this.height / (this.range.top - this.range.bottom + 1);\n    \tchildrenToUpdate.forEach(function(child) {\n\t\t\tchild.y = Math.floor(((_this.range.top-_this.range.bottom)-(child.note-_this.range.bottom)+0.5) * (_this.noteHeight) - (_this.noteHeight/2));\n\t\t\tchild.height = _this.noteHeight;\n        });\n    };\n\n    this.addLine = function(ts){\n\n        if(typeof(ts) === 'undefined') {\n            ts = new Date();\n        }\n        var x = -this.container.x;\n        var y = this.linesDown ? this.height - 20 : 0;\n\n        var graphics = new PIXI.Graphics()\n            .beginFill(0xFFFF00)\n            .lineStyle(1, this.lineColor)\n            .moveTo(0, 0)\n            .lineTo(0, 20)\n            .endFill();\n        graphics.x = x;\n        graphics.y = y;\n        this.container.addChild(graphics);\n        // Add text\n        //var totalSec = lineNb * this.lineInterval / 1000;\n        var hours = ts.getHours();\n        var minutes =ts.getMinutes();\n        var seconds = ts.getSeconds();\n        var timeStr = (hours < 10 ? '0' + hours : hours) + ':' + (minutes < 10 ? '0' + minutes : minutes) + ':' + (seconds  < 10 ? '0' + seconds : seconds);\n\n        var fontObj = { font: '10pt Arial', fill: '#444444' };\n        var t = new PIXI.Text(timeStr, fontObj);\n        if(isHorizontal) {\n            t.x = x + 2;\n            t.y = this.linesDown ? this.height - 15 : 2;\n        }\n        else {\n            t.rotation = -Math.PI/2;\n            t.x = x ;\n            t.y = this.linesDown ? this.height - 2 : t.width + 2;\n        }\n        this.container.addChild(t);\n    };\n\n    this.moveTo = function(diffTime){\n        var oldX = this.container.x;\n        this.container.x = Math.floor(diffTime*this.pixelsPerSecond);\n        var deltaX = Math.abs(oldX-this.container.x);\n        _.forOwn(this.noteDict, function(channelDict) {\n            _.forOwn(channelDict, function(noteDef) {\n                if(noteDef.graphics) {\n                    noteDef.graphics.width = noteDef.graphics.width + deltaX;\n                }\n            });\n        });\n    };\n\n    this.move = function() {\n        var diff = (this.startTs - Date.now())/1000;\n        this.moveTo(diff);\n    };\n\n    this.removePassedObjets = function(){\n        var childrenToRemove = [];\n        var rescale = false;\n        _(_this.container.children).forEach(function(child) {\n            return typeof(child) === 'undefined' ||\n                (isHidden(child) && childrenToRemove.push(child));\n        });\n        childrenToRemove.forEach(function(child) {\n        \tif (_this.dynamicRange && (_this.range.bottom === child.note || child.note === _this.range.top)){\n                rescale = true;\n            }\n            _this.container.removeChild(child);\n        });\n        //externalize this test to avoid repeated call to the function rescaleScene in the previous loop\n        if (rescale){\n            _this.rescaleScene();\n        }\n    };\n\n    this.start = function() {\n        if(!started) {\n            this.startTs = Date.now();\n            this.addLine();\n            started = true;\n        }\n        this.verticalLinesInterval = setInterval(function() { _this.addLine(); }, this.lineInterval);\n        this.cleanInterval = setInterval(function () { _this.removePassedObjets(); }, 1000 * this.width / this.pixelsPerSecond );\n    };\n\n    this.stop = function() {\n        clearInterval(this.verticalLinesInterval);\n        clearInterval(this.cleanInterval);\n    };\n\n}\n\nmodule.exports = PianoRoll;\n","/**\n* scripts/stageview.js\n*\n* This is the starting point for your application.\n* Take a look at http://browserify.org/ for more info\n*/\n\n/* global document: false */\n\n'use strict';\n\n\nvar PIXI = require('pixi');\nvar _ = require('lodash');\n\nvar defaultConfig = {\n    externalRefresh: false,\n    logger: undefined,\n    sceneWidth: 1024,\n    sceneHeight: 768,\n    framerate: 25,\n    sceneBgColor: 0xFFFFFF,\n    canvasContainer: 'canvasContainer',\n};\n\nfunction StageView(options) {\n\n    var _this = this;\n    var opts = _(options).defaults(defaultConfig).value();\n\n    var externalRefresh = opts.externalRefresh;\n\n    this.logger = opts.logger;\n    this.framerate = opts.framerate;\n    var sceneBgColor = opts.sceneBgColor;\n    var sceneWidth = opts.sceneWidth;\n    var sceneHeight = opts.sceneHeight;\n    var canvasContainer = opts.canvasContainer;\n    var timeContainer = [];\n    var components = [];\n\n    //create an new instance of a pixi stage\n    this.stage = new PIXI.Stage(sceneBgColor);\n    //create a renderer instance.\n    var renderer = PIXI.autoDetectRenderer(sceneWidth, sceneHeight);\n\n    this.init = function() {\n\n        if(typeof(canvasContainer) === 'string') {\n            canvasContainer = document.getElementById(canvasContainer);\n        }\n        if(typeof(timeContainer) === 'string') {\n            timeContainer = document.getElementById(timeContainer);\n        }\n\n        canvasContainer.appendChild(renderer.view);\n\n        components.forEach(function(c){\n    \t\tc.init();\n    \t});\n    };\n\n    this.registerTimeContainer = function(container) {\n    \ttimeContainer.push(container);\n    };\n\n    this.registerComponent = function(component) {\n    \tcomponents.push(component);\n    \tthis.stage.addChild(component.container);\n    };\n\n    this.refresh = function() {\n    \tcomponents.forEach(function(c){\n    \t\tc.refresh();\n    \t});\n        renderer.render(this.stage);\n    };\n\n    // Init page and intervals\n    var refreshInterval;\n\n    this.start = function() {\n\n        if(!externalRefresh) {\n            refreshInterval = setInterval(function() {_this.refresh();}, 1000/this.framerate);\n        }\n\n        components.forEach(function(c){\n    \t\tc.start();\n    \t});\n    };\n\n    this.stop = function() {\n        if(!externalRefresh) {\n            clearInterval(refreshInterval);\n        }\n        \n        components.forEach(function(c){\n    \t\tc.stop();\n    \t});\n    };\n\n\n    this.log = function(m) {\n        if(this.logger) {\n            this.logger.log(m);\n        }\n    };\n\n\n    return this;\n}\n\nmodule.exports = {\n    StageView: StageView\n};\n","/**\n* js/utils.js\n*\n* basic tools\n*\n*/\n/*jshint bitwise: false*/\n/*jshint camelcase: false */\n\n'use strict';\n\nvar PIXI = require('pixi');\nvar _ = require('lodash');\nvar moment = require('moment');\n\nfunction formatTime (ts) {\n    return moment(ts).format('HH:mm:ss');\n}\n\nfunction colorToHex(c) {\n    var m = /rgba?\\(\\s*(\\d+)\\s*,\\s*(\\d+)\\s*,\\s*(\\d+)/.exec(c);\n    return m ? '#' + (1 << 24 | m[1] << 16 | m[2] << 8 | m[3]).toString(16).substr(1) : c;\n}\n\nfunction getAnnotCategories(urlCategories, annotCategories) {\n\n    var jsonLoader = new PIXI.JsonLoader(urlCategories, true);\n\n    jsonLoader.on('loaded', function(res) {\n        var data = res.target.json;\n\n        while(annotCategories.length > 0) {\n            annotCategories.pop();\n        }\n\n        data.sessions.forEach(function(session) {\n            var annotCat = {\n                ts: session.start_ts === null ? new Date(0) : Date.parse(session.start_ts),\n                colors: {}\n            };\n            var categoriesJson = session.categories_json;\n            annotCat.order = categoriesJson.order;\n            if (typeof(annotCat.order['default']) === 'undefined'){\n                annotCat.order.push('default');\n            }\n            var catList = _.clone(categoriesJson.categories);\n            while(catList.length > 0) {\n                var cat = catList.pop();\n                if(cat.code) {\n                    annotCat.colors[cat.code] = colorToHex(cat.color);\n                }\n                if(cat.subcategories) {\n                    catList = catList.concat(cat.subcategories);\n                }\n            }\n            categoriesJson.categories.forEach(function(cat) {\n                if(cat.code) {\n                    annotCat.colors[cat.code] = colorToHex(cat.color);\n                }\n            });\n            annotCat.defaultColor = categoriesJson.defaultColor || '#536991';\n            annotCategories.push(annotCat);\n        });\n    });\n\n    jsonLoader.load();\n\n}\n\nmodule.exports = {\n    formatTime: formatTime,\n    getAnnotCategories: getAnnotCategories,\n    colorToHex: colorToHex\n};\n","/**\n* js/wswrapper.js\n*\n* simple webservice wrapper to register callbacks on onmessage\n*\n*/\n\n/* global WebSocket: false */\n\n'use strict';\n\nfunction WsWrapper(wsurl, logger) {\n\n    var url = wsurl;\n    var sock = new WebSocket(url);\n    var loggerObj = logger;\n\n    var log = function(msg) {\n        if(loggerObj) {\n            loggerObj.log(msg);\n        }\n    };\n\n    var handlers = [];\n\n    sock.onopen = function() {\n        log('Connected to ' + url);\n    };\n\n    sock.onclose = function(e) {\n        log('Connection closed (wasClean = ' + e.wasClean + ', code = ' + e.code + ', reason = \\'' + e.reason + '\\')');\n        sock = null;\n    };\n\n    sock.onmessage = function(e) {\n        log('received ' + e.data);\n        var data = JSON.parse(e.data);\n        handlers.forEach(function(handler) {\n            handler(data);\n        });\n    };\n\n    this.message = function(handler) {\n        if(handler) {\n            handlers.push(handler);\n        }\n    };\n\n}\n\nmodule.exports = {\n    WsWrapper: WsWrapper\n};\n"]} |