X-Git-Url: https://git.sesse.net/?a=blobdiff_plain;f=score.js;h=85ab488b39d9a17f05ee9a81bcb86c787f85c3f7;hb=a863d093841773e0e17cc4965c073b443e195071;hp=21a2cde5b71ad71034dd1fd4d944995497795b39;hpb=f229762296dd4504ced5af1025b2413b52b2c1e6;p=ultimatescore diff --git a/score.js b/score.js index 21a2cde..85ab488 100644 --- a/score.js +++ b/score.js @@ -4,7 +4,8 @@ let clock_running = false; let clock_visible = false; let comment_visible = false; let lowerthird_visible = false; -let clock_left = 30 * 60; +let clock_elapsed = 0; +let clock_limit = 30 * 60; let scoreA = 0; let scoreB = 0; let clock_origin; @@ -44,14 +45,14 @@ function startclock() function stopclock() { if (!clock_running) return; - clock_left = time_left(); + clock_elapsed = time_elapsed(); clock_origin = Date.now(); clock_running = false; } function setclock(amount) { - clock_left = amount; + clock_elapsed = amount; clock_origin = Date.now(); update_clock(); } @@ -62,6 +63,12 @@ function setclockfromstate() setclock(amount); } +function setclocklimitfromstate() +{ + let amount = parseInt(state['clock_limit_min']) * 60 + parseInt(state['clock_limit_sec']); + clock_limit = amount; +} + function showclock() { if (clock_visible) return; @@ -151,18 +158,23 @@ function hidelowerthird() lowerthird_visible = false; } -function time_left() +function time_elapsed() { let elapsed = (Date.now() - clock_origin) * 1e-3; - if (elapsed > clock_left) return 0; - return Math.ceil(clock_left - elapsed); + if (clock_elapsed + elapsed >= clock_limit) { + clock_elapsed = clock_limit; + clock_origin = Date.now(); + clock_running = false; + return clock_limit; + } + return Math.floor(clock_elapsed + elapsed); } function update_clock() { - let left = time_left(); - let min = Math.floor(left / 60); - let sec = left % 60; + let elapsed = time_elapsed(); + let min = Math.floor(elapsed / 60); + let sec = elapsed % 60; if (sec < 10) sec = "0" + sec; document.getElementById('clock').innerHTML = min + ":" + sec; @@ -229,3 +241,40 @@ update_score(); //play(); //startclock(); + +let websocket = null; + +function open_ws() +{ + console.log("Connecting..."); + try { + if (websocket) + websocket.close(); + websocket = new WebSocket("ws://127.0.0.1:5250/"); + websocket.onopen = function(evt) { + console.log("Connected to client."); + }; + websocket.onclose = function(evt) { + console.log("Disconnected from client."); + setTimeout(open_ws, 100); + }; + websocket.onmessage = function(evt) { + let msg = evt.data; + let m = msg.match(/^update (.*)/); + if (m !== null) { + update(m[1]); + } + m = msg.match(/^eval (.*)/); + if (m !== null) { + eval(m[1]); + } + }; + websocket.onerror = function(evt) { + console.log('Error: ' + evt.data); + }; + } catch (exception) { + console.log('Error: ' + exception); + setTimeout(open_ws, 100); + } +}; +open_ws();