@dotconnor/grommet
Version:
focus on the essential experience
26 lines (24 loc) • 1.27 kB
JavaScript
var POST_DECIMAL_DIGITS = 10;
export var baseUnit = 24;
export var polarToCartesian = function polarToCartesian(centerX, centerY, radius, angleInDegrees) {
var angleInRadians = (angleInDegrees - 90) * Math.PI / 180.0;
return {
x: centerX + radius * Math.cos(angleInRadians),
y: centerY + radius * Math.sin(angleInRadians)
};
};
export var arcCommands = function arcCommands(centerX, centerY, radius, startAngle, endAngle) {
// handle that we can't draw a complete circle
var normalizedEndAngle = endAngle;
if (endAngle - startAngle >= 360) {
normalizedEndAngle = startAngle + 359.99;
}
var start = polarToCartesian(centerX, centerY, radius, normalizedEndAngle);
var end = polarToCartesian(centerX, centerY, radius, startAngle);
var arcSweep = normalizedEndAngle - startAngle <= 180 ? '0' : '1';
var d = ['M', start.x.toFixed(POST_DECIMAL_DIGITS), start.y.toFixed(POST_DECIMAL_DIGITS), 'A', radius.toFixed(POST_DECIMAL_DIGITS), radius.toFixed(POST_DECIMAL_DIGITS), 0, arcSweep, 0, end.x.toFixed(POST_DECIMAL_DIGITS), end.y.toFixed(POST_DECIMAL_DIGITS)].join(' ');
return d;
};
export var translateEndAngle = function translateEndAngle(startAngle, anglePer, value) {
return Math.min(360, Math.max(0, startAngle + anglePer * value));
};