dygraphs
Version:
dygraphs is a fast, flexible open source JavaScript charting library.
128 lines (121 loc) • 15.8 kB
JavaScript
/**
* @license
* Copyright 2011 Dan Vanderkam (danvdk@gmail.com)
* MIT-licenced: https://opensource.org/licenses/MIT
*/
/**
* @fileoverview
* Including this file will add several additional shapes to Dygraph.Circles
* which can be passed to drawPointCallback.
* See tests/custom-circles.html for usage.
*/
/* loader wrapper to allow browser use and ES6 imports */
(function _extras_shapes_closure() {
'use strict';
var Dygraph;
if (window.Dygraph) {
Dygraph = window.Dygraph;
} else if (typeof module !== 'undefined') {
Dygraph = require('../dygraph');
if (typeof Dygraph.NAME === 'undefined' && typeof Dygraph["default"] !== 'undefined') Dygraph = Dygraph["default"];
}
/* end of loader wrapper header */
/**
* @param {!CanvasRenderingContext2D} ctx the canvas context
* @param {number} sides the number of sides in the shape.
* @param {number} radius the radius of the image.
* @param {number} cx center x coordate
* @param {number} cy center y coordinate
* @param {number=} rotationRadians the shift of the initial angle, in radians.
* @param {number=} delta the angle shift for each line. If missing, creates a
* regular polygon.
*/
var regularShape = function regularShape(ctx, sides, radius, cx, cy, rotationRadians, delta) {
rotationRadians = rotationRadians || 0;
delta = delta || Math.PI * 2 / sides;
ctx.beginPath();
var initialAngle = rotationRadians;
var angle = initialAngle;
var computeCoordinates = function computeCoordinates() {
var x = cx + Math.sin(angle) * radius;
var y = cy + -Math.cos(angle) * radius;
return [x, y];
};
var initialCoordinates = computeCoordinates();
var x = initialCoordinates[0];
var y = initialCoordinates[1];
ctx.moveTo(x, y);
for (var idx = 0; idx < sides; idx++) {
angle = idx == sides - 1 ? initialAngle : angle + delta;
var coords = computeCoordinates();
ctx.lineTo(coords[0], coords[1]);
}
ctx.fill();
ctx.stroke();
};
/**
* TODO(danvk): be more specific on the return type.
* @param {number} sides
* @param {number=} rotationRadians
* @param {number=} delta
* @return {Function}
* @private
*/
var shapeFunction = function shapeFunction(sides, rotationRadians, delta) {
return function shapedFunction(g, name, ctx, cx, cy, color, radius) {
ctx.strokeStyle = color;
ctx.fillStyle = "white";
regularShape(ctx, sides, radius, cx, cy, rotationRadians, delta);
};
};
var customCircles = {
TRIANGLE: shapeFunction(3),
SQUARE: shapeFunction(4, Math.PI / 4),
DIAMOND: shapeFunction(4),
PENTAGON: shapeFunction(5),
HEXAGON: shapeFunction(6),
CIRCLE: function CIRCLE(g, name, ctx, cx, cy, color, radius) {
ctx.beginPath();
ctx.strokeStyle = color;
ctx.fillStyle = "white";
ctx.arc(cx, cy, radius, 0, 2 * Math.PI, false);
ctx.fill();
ctx.stroke();
},
STAR: shapeFunction(5, 0, 4 * Math.PI / 5),
PLUS: function PLUS(g, name, ctx, cx, cy, color, radius) {
ctx.strokeStyle = color;
ctx.beginPath();
ctx.moveTo(cx + radius, cy);
ctx.lineTo(cx - radius, cy);
ctx.closePath();
ctx.stroke();
ctx.beginPath();
ctx.moveTo(cx, cy + radius);
ctx.lineTo(cx, cy - radius);
ctx.closePath();
ctx.stroke();
},
EX: function EX(g, name, ctx, cx, cy, color, radius) {
ctx.strokeStyle = color;
ctx.beginPath();
ctx.moveTo(cx + radius, cy + radius);
ctx.lineTo(cx - radius, cy - radius);
ctx.closePath();
ctx.stroke();
ctx.beginPath();
ctx.moveTo(cx + radius, cy - radius);
ctx.lineTo(cx - radius, cy + radius);
ctx.closePath();
ctx.stroke();
}
};
for (var k in customCircles) {
if (!customCircles.hasOwnProperty(k)) continue;
Dygraph.Circles[k] = customCircles[k];
}
/* closure and loader wrapper */
Dygraph._require.add('dygraphs/src/extras/shapes.js', /* exports */{});
})();
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"names":["_extras_shapes_closure","Dygraph","window","module","require","NAME","regularShape","ctx","sides","radius","cx","cy","rotationRadians","delta","Math","PI","beginPath","initialAngle","angle","computeCoordinates","x","sin","y","cos","initialCoordinates","moveTo","idx","coords","lineTo","fill","stroke","shapeFunction","shapedFunction","g","name","color","strokeStyle","fillStyle","customCircles","TRIANGLE","SQUARE","DIAMOND","PENTAGON","HEXAGON","CIRCLE","arc","STAR","PLUS","closePath","EX","k","hasOwnProperty","Circles","_require","add"],"sources":["../../src/extras/shapes.js"],"sourcesContent":["/**\n * @license\n * Copyright 2011 Dan Vanderkam (danvdk@gmail.com)\n * MIT-licenced: https://opensource.org/licenses/MIT\n */\n\n/**\n * @fileoverview\n * Including this file will add several additional shapes to Dygraph.Circles\n * which can be passed to drawPointCallback.\n * See tests/custom-circles.html for usage.\n */\n\n/* loader wrapper to allow browser use and ES6 imports */\n(function _extras_shapes_closure() {\n'use strict';\nvar Dygraph;\nif (window.Dygraph) {\n  Dygraph = window.Dygraph;\n} else if (typeof(module) !== 'undefined') {\n  Dygraph = require('../dygraph');\n  if (typeof(Dygraph.NAME) === 'undefined' && typeof(Dygraph.default) !== 'undefined')\n    Dygraph = Dygraph.default;\n}\n/* end of loader wrapper header */\n\n/**\n * @param {!CanvasRenderingContext2D} ctx the canvas context\n * @param {number} sides the number of sides in the shape.\n * @param {number} radius the radius of the image.\n * @param {number} cx center x coordate\n * @param {number} cy center y coordinate\n * @param {number=} rotationRadians the shift of the initial angle, in radians.\n * @param {number=} delta the angle shift for each line. If missing, creates a\n *     regular polygon.\n */\nvar regularShape = function regularShape(\n    ctx, sides, radius, cx, cy, rotationRadians, delta) {\n  rotationRadians = rotationRadians || 0;\n  delta = delta || Math.PI * 2 / sides;\n\n  ctx.beginPath();\n  var initialAngle = rotationRadians;\n  var angle = initialAngle;\n\n  var computeCoordinates = function computeCoordinates() {\n    var x = cx + (Math.sin(angle) * radius);\n    var y = cy + (-Math.cos(angle) * radius);\n    return [x, y];\n  };\n\n  var initialCoordinates = computeCoordinates();\n  var x = initialCoordinates[0];\n  var y = initialCoordinates[1];\n  ctx.moveTo(x, y);\n\n  for (var idx = 0; idx < sides; idx++) {\n    angle = (idx == sides - 1) ? initialAngle : (angle + delta);\n    var coords = computeCoordinates();\n    ctx.lineTo(coords[0], coords[1]);\n  }\n  ctx.fill();\n  ctx.stroke();\n};\n\n/**\n * TODO(danvk): be more specific on the return type.\n * @param {number} sides\n * @param {number=} rotationRadians\n * @param {number=} delta\n * @return {Function}\n * @private\n */\nvar shapeFunction = function shapeFunction(sides, rotationRadians, delta) {\n  return function shapedFunction(g, name, ctx, cx, cy, color, radius) {\n    ctx.strokeStyle = color;\n    ctx.fillStyle = \"white\";\n    regularShape(ctx, sides, radius, cx, cy, rotationRadians, delta);\n  };\n};\n\nvar customCircles = {\n  TRIANGLE : shapeFunction(3),\n  SQUARE : shapeFunction(4, Math.PI / 4),\n  DIAMOND : shapeFunction(4),\n  PENTAGON : shapeFunction(5),\n  HEXAGON : shapeFunction(6),\n  CIRCLE : function CIRCLE(g, name, ctx, cx, cy, color, radius) {\n    ctx.beginPath();\n    ctx.strokeStyle = color;\n    ctx.fillStyle = \"white\";\n    ctx.arc(cx, cy, radius, 0, 2 * Math.PI, false);\n    ctx.fill();\n    ctx.stroke();\n  },\n  STAR : shapeFunction(5, 0, 4 * Math.PI / 5),\n  PLUS : function PLUS(g, name, ctx, cx, cy, color, radius) {\n    ctx.strokeStyle = color;\n\n    ctx.beginPath();\n    ctx.moveTo(cx + radius, cy);\n    ctx.lineTo(cx - radius, cy);\n    ctx.closePath();\n    ctx.stroke();\n\n    ctx.beginPath();\n    ctx.moveTo(cx, cy + radius);\n    ctx.lineTo(cx, cy - radius);\n    ctx.closePath();\n    ctx.stroke();\n  },\n  EX : function EX(g, name, ctx, cx, cy, color, radius) {\n    ctx.strokeStyle = color;\n\n    ctx.beginPath();\n    ctx.moveTo(cx + radius, cy + radius);\n    ctx.lineTo(cx - radius, cy - radius);\n    ctx.closePath();\n    ctx.stroke();\n\n    ctx.beginPath();\n    ctx.moveTo(cx + radius, cy - radius);\n    ctx.lineTo(cx - radius, cy + radius);\n    ctx.closePath();\n    ctx.stroke();\n  }\n};\n\nfor (var k in customCircles) {\n  if (!customCircles.hasOwnProperty(k)) continue;\n  Dygraph.Circles[k] = customCircles[k];\n}\n\n/* closure and loader wrapper */\nDygraph._require.add('dygraphs/src/extras/shapes.js', /* exports */ {});\n})();\n"],"mappings":"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"}
;