X-Git-Url: https://adrianiainlam.tk/git/?a=blobdiff_plain;f=gallery%2Fdrawing.js;h=6443cf4152459484991b400f27ec820336f7bd2f;hb=117b8bee20ce2bf7d36668af054285244d438b5c;hp=9d6c93551572c53c92a5906e3a9e33dcb792a401;hpb=795b16307db2a673ba7aa3452f6f6b0e93baeb3a;p=dygraphs.git diff --git a/gallery/drawing.js b/gallery/drawing.js index 9d6c935..6443cf4 100644 --- a/gallery/drawing.js +++ b/gallery/drawing.js @@ -4,17 +4,25 @@ Gallery.register( name: 'Time Series Drawing Demo', title: 'Time Series Drawing Demo', setup: function(parent) { - parent.innerHTML = - "
" + - "
" + - "
" + - "
" + - "
" + - "
" + - "

Toolbar/cursor icons are CC-licensed from " + - "FatCow.

"; + parent.innerHTML = [ + "
", + "
", + "
", + "
", + "
", + "
", + "

Toolbar/cursor icons are CC-licensed from ", + "FatCow.

"].join("\n"); }, + run: function() { + var zoom = document.getElementById('tool_zoom'); + zoom.onclick = function() { change_tool(zoom) }; + var pencil = document.getElementById('tool_pencil'); + pencil.onclick = function() { change_tool(pencil) }; + var eraser = document.getElementById('tool_eraser'); + eraser.onclick = function() { change_tool(eraser) }; + var start_date = new Date("2002/12/29").getTime(); var end_date = new Date().getTime(); var data = []; @@ -22,153 +30,153 @@ Gallery.register( var millis = d + 2 * 3600 * 1000; data.push( [ new Date(new Date(millis).strftime("%Y/%m/%d")), 50 ]); } - - var isDrawing = false; - var lastDrawRow = null, lastDrawValue = null; - var tool = 'pencil'; - var valueRange = [0, 100]; - - function setPoint(event, g, context) { - var canvasx = Dygraph.pageX(event) - Dygraph.findPosX(g.graphDiv); - var canvasy = Dygraph.pageY(event) - Dygraph.findPosY(g.graphDiv); - var xy = g.toDataCoords(canvasx, canvasy); - var x = xy[0], value = xy[1]; - var rows = g.numRows(); - var closest_row = -1; - var smallest_diff = -1; - // TODO(danvk): binary search - for (var row = 0; row < rows; row++) { - var date = g.getValue(row, 0); // millis - var diff = Math.abs(date - x); - if (smallest_diff < 0 || diff < smallest_diff) { - smallest_diff = diff; - closest_row = row; + + var isDrawing = false; + var lastDrawRow = null, lastDrawValue = null; + var tool = 'pencil'; + var valueRange = [0, 100]; + + function setPoint(event, g, context) { + var canvasx = Dygraph.pageX(event) - Dygraph.findPosX(g.graphDiv); + var canvasy = Dygraph.pageY(event) - Dygraph.findPosY(g.graphDiv); + var xy = g.toDataCoords(canvasx, canvasy); + var x = xy[0], value = xy[1]; + var rows = g.numRows(); + var closest_row = -1; + var smallest_diff = -1; + // TODO(danvk): binary search + for (var row = 0; row < rows; row++) { + var date = g.getValue(row, 0); // millis + var diff = Math.abs(date - x); + if (smallest_diff < 0 || diff < smallest_diff) { + smallest_diff = diff; + closest_row = row; + } } - } - - if (closest_row != -1) { - if (lastDrawRow === null) { + + if (closest_row != -1) { + if (lastDrawRow === null) { + lastDrawRow = closest_row; + lastDrawValue = value; + } + var coeff = (value - lastDrawValue) / (closest_row - lastDrawRow); + if (closest_row == lastDrawRow) coeff = 0.0; + var minRow = Math.min(lastDrawRow, closest_row); + var maxRow = Math.max(lastDrawRow, closest_row); + for (var row = minRow; row <= maxRow; row++) { + if (tool == 'pencil') { + var val = lastDrawValue + coeff * (row - lastDrawRow); + val = Math.max(valueRange[0], Math.min(val, valueRange[1])); + data[row][1] = val; + if (val == null || isNaN(val)) console.log(val); + } else if (tool == 'eraser') { + data[row][1] = null; + } + } lastDrawRow = closest_row; lastDrawValue = value; + g.updateOptions({ file: data }); + g.setSelection(closest_row); // prevents the dot from being finnicky. } - var coeff = (value - lastDrawValue) / (closest_row - lastDrawRow); - if (closest_row == lastDrawRow) coeff = 0.0; - var minRow = Math.min(lastDrawRow, closest_row); - var maxRow = Math.max(lastDrawRow, closest_row); - for (var row = minRow; row <= maxRow; row++) { - if (tool == 'pencil') { - var val = lastDrawValue + coeff * (row - lastDrawRow); - val = Math.max(valueRange[0], Math.min(val, valueRange[1])); - data[row][1] = val; - if (val == null || isNaN(val)) console.log(val); - } else if (tool == 'eraser') { - data[row][1] = null; + } + + function finishDraw() { + isDrawing = false; + lastDrawRow = null; + lastDrawValue = null; + } + + var change_tool = function(tool_div) { + var ids = ['tool_zoom', 'tool_pencil', 'tool_eraser']; + for (var i = 0; i < ids.length; i++) { + var div = document.getElementById(ids[i]); + if (div == tool_div) { + div.style.backgroundPosition = -(i * 32) + 'px -32px'; + } else { + div.style.backgroundPosition = -(i * 32) + 'px 0px'; } } - lastDrawRow = closest_row; - lastDrawValue = value; - g.updateOptions({ file: data }); - g.setSelection(closest_row); // prevents the dot from being finnicky. - } - } - - function finishDraw() { - isDrawing = false; - lastDrawRow = null; - lastDrawValue = null; - } - - window.change_tool = function(tool_div) { - var ids = ['tool_zoom', 'tool_pencil', 'tool_eraser']; - for (var i = 0; i < ids.length; i++) { - var div = document.getElementById(ids[i]); - if (div == tool_div) { - div.style.backgroundPosition = -(i * 32) + 'px -32px'; - } else { - div.style.backgroundPosition = -(i * 32) + 'px 0px'; + tool = tool_div.id.replace('tool_', ''); + + var dg_div = document.getElementById("draw_div"); + if (tool == 'pencil') { + dg_div.style.cursor = 'url(images/cursor-pencil.png) 2 30, auto'; + } else if (tool == 'eraser') { + dg_div.style.cursor = 'url(images/cursor-eraser.png) 10 30, auto'; + } else if (tool == 'zoom') { + dg_div.style.cursor = 'crosshair'; } } - tool = tool_div.id.replace('tool_', ''); - - var dg_div = document.getElementById("draw_div"); - if (tool == 'pencil') { - dg_div.style.cursor = 'url(drawing/cursor-pencil.png) 2 30, auto'; - } else if (tool == 'eraser') { - dg_div.style.cursor = 'url(drawing/cursor-eraser.png) 10 30, auto'; - } else if (tool == 'zoom') { - dg_div.style.cursor = 'crosshair'; - } - } - change_tool(document.getElementById("tool_pencil")); - - g = new Dygraph(document.getElementById("draw_div"), data, - { - valueRange: valueRange, - labels: [ 'Date', 'Value' ], - interactionModel: { - mousedown: function (event, g, context) { - if (tool == 'zoom') { - Dygraph.defaultInteractionModel.mousedown(event, g, context); - } else { - // prevents mouse drags from selecting page text. - if (event.preventDefault) { - event.preventDefault(); // Firefox, Chrome, etc. + change_tool(document.getElementById("tool_pencil")); + + g = new Dygraph(document.getElementById("draw_div"), data, + { + valueRange: valueRange, + labels: [ 'Date', 'Value' ], + interactionModel: { + mousedown: function (event, g, context) { + if (tool == 'zoom') { + Dygraph.defaultInteractionModel.mousedown(event, g, context); } else { - event.returnValue = false; // IE - event.cancelBubble = true; + // prevents mouse drags from selecting page text. + if (event.preventDefault) { + event.preventDefault(); // Firefox, Chrome, etc. + } else { + event.returnValue = false; // IE + event.cancelBubble = true; + } + isDrawing = true; + setPoint(event, g, context); } - isDrawing = true; - setPoint(event, g, context); - } - }, - mousemove: function (event, g, context) { - if (tool == 'zoom') { - Dygraph.defaultInteractionModel.mousemove(event, g, context); - } else { - if (!isDrawing) return; - setPoint(event, g, context); - } - }, - mouseup: function(event, g, context) { - if (tool == 'zoom') { - Dygraph.defaultInteractionModel.mouseup(event, g, context); - } else { - finishDraw(); - } - }, - mouseout: function(event, g, context) { - if (tool == 'zoom') { - Dygraph.defaultInteractionModel.mouseout(event, g, context); + }, + mousemove: function (event, g, context) { + if (tool == 'zoom') { + Dygraph.defaultInteractionModel.mousemove(event, g, context); + } else { + if (!isDrawing) return; + setPoint(event, g, context); + } + }, + mouseup: function(event, g, context) { + if (tool == 'zoom') { + Dygraph.defaultInteractionModel.mouseup(event, g, context); + } else { + finishDraw(); + } + }, + mouseout: function(event, g, context) { + if (tool == 'zoom') { + Dygraph.defaultInteractionModel.mouseout(event, g, context); + } + }, + dblclick: function(event, g, context) { + Dygraph.defaultInteractionModel.dblclick(event, g, context); + }, + mousewheel: function(event, g, context) { + var normal = event.detail ? event.detail * -1 : event.wheelDelta / 40; + var percentage = normal / 50; + var axis = g.xAxisRange(); + var xOffset = g.toDomCoords(axis[0], null)[0]; + var x = event.offsetX - xOffset; + var w = g.toDomCoords(axis[1], null)[0] - xOffset; + var xPct = w == 0 ? 0 : (x / w); + + var delta = axis[1] - axis[0]; + var increment = delta * percentage; + var foo = [increment * xPct, increment * (1 - xPct)]; + var dateWindow = [ axis[0] + foo[0], axis[1] - foo[1] ]; + + g.updateOptions({ + dateWindow: dateWindow + }); + Dygraph.cancelEvent(event); } }, - dblclick: function(event, g, context) { - Dygraph.defaultInteractionModel.dblclick(event, g, context); - }, - mousewheel: function(event, g, context) { - var normal = event.detail ? event.detail * -1 : event.wheelDelta / 40; - var percentage = normal / 50; - var axis = g.xAxisRange(); - var xOffset = g.toDomCoords(axis[0], null)[0]; - var x = event.offsetX - xOffset; - var w = g.toDomCoords(axis[1], null)[0] - xOffset; - var xPct = w == 0 ? 0 : (x / w); - - var delta = axis[1] - axis[0]; - var increment = delta * percentage; - var foo = [increment * xPct, increment * (1 - xPct)]; - var dateWindow = [ axis[0] + foo[0], axis[1] - foo[1] ]; - - g.updateOptions({ - dateWindow: dateWindow - }); - Dygraph.cancelEvent(event); - } - }, - strokeWidth: 1.5, - gridLineColor: 'rgb(196, 196, 196)', - drawYGrid: false, - drawYAxis: false - }); - window.onmouseup = finishDraw; - } + strokeWidth: 1.5, + gridLineColor: 'rgb(196, 196, 196)', + drawYGrid: false, + drawYAxis: false + }); + window.onmouseup = finishDraw; + } }); \ No newline at end of file