]> average.org Git - pulsecounter.git/commitdiff
resizeable canvas
authorEugene Crosser <crosser@average.org>
Wed, 23 Dec 2015 08:33:52 +0000 (11:33 +0300)
committerEugene Crosser <crosser@average.org>
Wed, 23 Dec 2015 08:33:52 +0000 (11:33 +0300)
web/index.html

index 18b60e6762fbbfa577800f19b4c8b60cb3c46cf3..e08a07a9f0211d995eb08d711d39c4e21367c280 100644 (file)
     ctx.strokeStyle = color;
     ctx.stroke();
   }
+  function redraw() {
+    if (cold_d.length && hot_d.length) {
+      drawplot(cold_d, "blue");
+      drawplot(hot_d, "red");
+      xaxis();
+      yaxis();
+    } else {
+      /* load animation here */ ;
+    }
+  }
 
   function gotdata(data) {
     document.getElementById("cold").innerHTML =
       (data.current.cold / 100).toFixed(2);
     document.getElementById("hot").innerHTML =
       (data.current.hot / 100).toFixed(2);
-    canvas = document.getElementById("plot");
-
-    ctx = canvas.getContext("2d");
-    ww = canvas.width;
-    wh = canvas.height;
-
     tmin = data.range.lo;
     tmax = data.range.hi;
     tfact = (ww - xzero) / (tmax - tmin);
     cold_d = differentiate(data.cold);
     hot_d = differentiate(data.hot);
     hfact = (wh - yzero) / hmax;
-
     //document.getElementById("debug").innerHTML = cold_d + "<br>" + hot_d;
-
-    drawplot(cold_d, "blue");
-    drawplot(hot_d, "red");
-    xaxis();
-    yaxis();
+    redraw();
   }
 
   function sendquery(lo, hi) {
     xmlhttp.send();
   }
 
+  function resize() {
+    ww = window.innerWidth;
+    if (ww > window.innerHeight) ww = window.innerHeight;
+    wh = ww / 2;
+    canvas.width = ww;
+    canvas.height = wh;
+    canvas.style.width = ww + "px";
+    canvas.style.height = wh + "px";
+    redraw();
+  }
+
   function initialize() {
     dbg = document.getElementById("debug");
+    canvas = document.getElementById("plot");
+    ctx = canvas.getContext("2d");
     xmlhttp = new XMLHttpRequest();
+    resize();
     sendquery();
   }
 
   /* Set up */
   if(window.attachEvent) {
     window.attachEvent('onload', initialize);
+    window.attachEvent('onresize', resize);
   } else {
     window.onload = initialize;
+    window.onresize = resize;
   }
 </script>
 <style>