@dotconnor/grommet
Version:
focus on the essential experience
40 lines (31 loc) • 1.55 kB
JavaScript
exports.__esModule = true;
exports.translateEndAngle = exports.arcCommands = exports.polarToCartesian = exports.baseUnit = void 0;
var POST_DECIMAL_DIGITS = 10;
var baseUnit = 24;
exports.baseUnit = baseUnit;
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)
};
};
exports.polarToCartesian = polarToCartesian;
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;
};
exports.arcCommands = arcCommands;
var translateEndAngle = function translateEndAngle(startAngle, anglePer, value) {
return Math.min(360, Math.max(0, startAngle + anglePer * value));
};
exports.translateEndAngle = translateEndAngle;
;