mirror of
https://github.com/penpot/penpot-exporter-figma-plugin.git
synced 2025-01-04 22:01:08 -05:00
23e97fb3d7
* linear gradient * radial gradients * fixes * fixes
43 lines
1.3 KiB
TypeScript
43 lines
1.3 KiB
TypeScript
import { applyMatrixToPoint } from '@plugin/utils/applyMatrixToPoint';
|
|
import { matrixInvert } from '@plugin/utils/matrixInvert';
|
|
|
|
export const calculateRadialGradient = (t: Transform): { start: number[]; end: number[] } => {
|
|
const transform = t.length === 2 ? [...t, [0, 0, 1]] : [...t];
|
|
const mxInv = matrixInvert(transform);
|
|
|
|
if (!mxInv) {
|
|
return {
|
|
start: [0, 0],
|
|
end: [0, 0]
|
|
};
|
|
}
|
|
|
|
const centerPoint = applyMatrixToPoint(mxInv, [0.5, 0.5]);
|
|
const rxPoint = applyMatrixToPoint(mxInv, [1, 0.5]);
|
|
const ryPoint = applyMatrixToPoint(mxInv, [0.5, 1]);
|
|
|
|
const rx = Math.sqrt(
|
|
Math.pow(rxPoint[0] - centerPoint[0], 2) + Math.pow(rxPoint[1] - centerPoint[1], 2)
|
|
);
|
|
const ry = Math.sqrt(
|
|
Math.pow(ryPoint[0] - centerPoint[0], 2) + Math.pow(ryPoint[1] - centerPoint[1], 2)
|
|
);
|
|
const angle =
|
|
Math.atan((rxPoint[1] - centerPoint[1]) / (rxPoint[0] - centerPoint[0])) * (180 / Math.PI);
|
|
|
|
return {
|
|
start: centerPoint,
|
|
end: calculateRadialGradientEndPoint(angle, centerPoint, [rx, ry])
|
|
};
|
|
};
|
|
|
|
const calculateRadialGradientEndPoint = (
|
|
rotation: number,
|
|
center: number[],
|
|
radius: number[]
|
|
): [number, number] => {
|
|
const angle = rotation * (Math.PI / 180);
|
|
const x = center[0] + radius[0] * Math.cos(angle);
|
|
const y = center[1] + radius[1] * Math.sin(angle);
|
|
return [x, y];
|
|
};
|