1 | ;
|
2 | /*
|
3 | * I need to do the following:
|
4 | * diff angles between vectors
|
5 | * find perpendicular vector to a point on a path
|
6 | * find tangent to a point on a path
|
7 | * transform (translate, rotate) for nodes and edges
|
8 | * es modules so I can pull out just what I need
|
9 | *
|
10 | * Specs to compare:
|
11 | * tests
|
12 | * typescript
|
13 | * maintained (open issues unresolved for a long time?)
|
14 | * node and browser
|
15 | */
|
16 | Object.defineProperty(exports, "__esModule", { value: true });
|
17 | exports.transform = exports.sameSide = exports.multiplyMatrixByVector = exports.getTransformationMatrix = exports.translate = exports.scale = exports.rotate = exports.multiplyMatrices = exports.invertMatrix = exports.getStartSideByOrientation = exports.getAngleFromPointToPoint = exports.getAngleAtPoint = exports.reverseAngle = exports.getAngleOfEmanationFromPoint = exports.getMinimumAngleBetweenVectors = exports.flipSide = exports.flipOrientation = exports.crossProduct = exports.addAngles = exports.SmartPath = exports.SmartVector = exports.SmartPoint = exports.START_SEGMENT_DETAILS_MAPS = exports.EMANATION_ANGLE_TO_START_SIDE_MAPPINGS = exports.START_SIDE_TO_EMANATION_ANGLE_MAPPINGS = exports.START_SIDE_TO_ORIENTATION_MAP = void 0;
|
18 | var lodash_1 = require("lodash");
|
19 | var fp_1 = require("lodash/fp");
|
20 | var Angle_1 = require("./spinoffs/Angle");
|
21 | var points_1 = require("points");
|
22 | // TODO why doesn't the following work?
|
23 | // Also, why doesn't ../node_modules/kaavio/lib/drawers/edges/ exist?
|
24 | //import * as edgeDrawers from "kaavio/src/drawers/edges/index";
|
25 | //import * as edgeDrawers from "../node_modules/kaavio/src/drawers/edges/index";
|
26 | //import * as edgeDrawers from "kaavio/src/drawers/edges/index";
|
27 | //import * as edgeDrawers from "kaavio/lib/drawers/edges/index";
|
28 | var edgeDrawers = require("./edge/edgeDrawers");
|
29 | // We are using the standard SVG coordinate system where:
|
30 | // the origin is the upper-left-most point
|
31 | // positive x is to the right
|
32 | // positive y is down
|
33 | // uses left hand rule, so positive angle is clockwise,
|
34 | // starting with 0 pointing to the right
|
35 | // The orientation is a unit vector that indicates the orientation of an
|
36 | // at a point. When it is attached to a rectangle, we almost always want it to
|
37 | // point away from the side to which it is attached.
|
38 | exports.START_SIDE_TO_ORIENTATION_MAP = {
|
39 | right: [1, 0],
|
40 | bottom: [0, 1],
|
41 | left: [-1, 0],
|
42 | top: [0, -1]
|
43 | };
|
44 | exports.START_SIDE_TO_EMANATION_ANGLE_MAPPINGS = fp_1.fromPairs(fp_1.toPairs(exports.START_SIDE_TO_ORIENTATION_MAP).map(function (_a) {
|
45 | var startSide = _a[0], orientation = _a[1];
|
46 | return [startSide, Angle_1.fromSlope([0, 0], orientation)];
|
47 | }));
|
48 | exports.EMANATION_ANGLE_TO_START_SIDE_MAPPINGS = fp_1.toPairs(exports.START_SIDE_TO_EMANATION_ANGLE_MAPPINGS).reduce(function (acc, _a) {
|
49 | var side = _a[0], angle = _a[1];
|
50 | acc.set(angle, side);
|
51 | return acc;
|
52 | }, new Map());
|
53 | exports.START_SEGMENT_DETAILS_MAPS = fp_1.toPairs(exports.START_SIDE_TO_ORIENTATION_MAP).map(function (_a) {
|
54 | var startSide = _a[0], orientation = _a[1];
|
55 | var orientationX = orientation[0], orientationY = orientation[1];
|
56 | return {
|
57 | sideAttachedTo: startSide,
|
58 | orientation: orientation,
|
59 | angle: Angle_1.normalize(Math.atan2(orientationY, orientationX))
|
60 | };
|
61 | });
|
62 | var SmartPoint = /** @class */ (function () {
|
63 | //orientationVector?: SmartVector;
|
64 | function SmartPoint(point) {
|
65 | var _this = this;
|
66 | this.angle = function () {
|
67 | return Angle_1.fromSlope([0, 0], _this.orientation);
|
68 | };
|
69 | this.fromArray = function (_a) {
|
70 | var x = _a[0], y = _a[1];
|
71 | _this.x = x;
|
72 | _this.y = y;
|
73 | };
|
74 | this.toArray = function () {
|
75 | return [_this.x, _this.y];
|
76 | };
|
77 | lodash_1.assign(this, point);
|
78 | /*
|
79 | if (!isUndefined(this.orientation)) {
|
80 | this.orientationVector = new SmartVector(
|
81 | { x: 0, y: 0 },
|
82 | { x: this.orientation[0], y: this.orientation[1] }
|
83 | );
|
84 | }
|
85 | //*/
|
86 | }
|
87 | return SmartPoint;
|
88 | }());
|
89 | exports.SmartPoint = SmartPoint;
|
90 | var SmartVector = /** @class */ (function () {
|
91 | function SmartVector(p0, p1) {
|
92 | var _this = this;
|
93 | this.angleDistance = function (vector2) {
|
94 | return Angle_1.distance(_this.angle, vector2.angle);
|
95 | };
|
96 | this.p0 = new SmartPoint(p0);
|
97 | this.p1 = new SmartPoint(p1);
|
98 | this.angle = Angle_1.fromSlope(this.p0.toArray(), this.p1.toArray());
|
99 | }
|
100 | return SmartVector;
|
101 | }());
|
102 | exports.SmartVector = SmartVector;
|
103 | var SmartPath = /** @class */ (function () {
|
104 | function SmartPath(points, edge) {
|
105 | var _this = this;
|
106 | this.position = function (scalar, accuracy) {
|
107 | var _a = points_1.position(_this.path.points, scalar, accuracy), x = _a.x, y = _a.y, degreesFromNorth = _a.angle;
|
108 | /* the points library returns the angle from north, in degrees, increasing CW, so
|
109 | * this has an angle of 0 deg.:
|
110 | *
|
111 | * ^
|
112 | * |
|
113 | * |
|
114 | * |
|
115 | *
|
116 | * and this has an angle of 90 deg.:
|
117 | *
|
118 | * ------->
|
119 | */
|
120 | return {
|
121 | x: x,
|
122 | y: y,
|
123 | // convert to radians and use angle orientation of SVG coordinate system
|
124 | angle: Angle_1.normalize(Angle_1.degreesToRadians(degreesFromNorth + 270))
|
125 | };
|
126 | };
|
127 | var smartPoints = points.map(function (point) { return new SmartPoint(point); });
|
128 | this.points = smartPoints;
|
129 | this.sum = new SmartVector(smartPoints[0], fp_1.last(smartPoints));
|
130 | if (!fp_1.isUndefined(edge)) {
|
131 | var points_2 = edge.points, markerStart = edge.markerStart, markerEnd = edge.markerEnd;
|
132 | this.path = new edgeDrawers[edge.drawAs](smartPoints, markerStart, markerEnd);
|
133 | }
|
134 | }
|
135 | return SmartPath;
|
136 | }());
|
137 | exports.SmartPath = SmartPath;
|
138 | // TODO explore using the packages points and angles (and maybe vectory) together
|
139 | var smartPath1 = new SmartPath([
|
140 | { x: 50, y: 30, moveTo: true },
|
141 | { x: 50, y: 70, curve: { type: "arc", rx: 20, ry: 20, sweepFlag: 1 } },
|
142 | { x: 150, y: 100, curve: { type: "arc", rx: 20, ry: 20, sweepFlag: 1 } }
|
143 | ]);
|
144 | var smartPath2 = new SmartPath([
|
145 | { x: 100, y: 50, moveTo: true },
|
146 | { x: 50, y: 70, curve: { type: "arc", rx: 20, ry: 20, sweepFlag: 1 } }
|
147 | //{ x: 200, y: 100 }
|
148 | ]);
|
149 | /* OLD CODE BELOW */
|
150 | function addAngles(angle1, angle2) {
|
151 | var sum = angle1 + angle2;
|
152 | var singleRevolutionSum = sum % (2 * Math.PI);
|
153 | return Math.sign(singleRevolutionSum) === -1
|
154 | ? 2 * Math.PI + singleRevolutionSum
|
155 | : singleRevolutionSum;
|
156 | }
|
157 | exports.addAngles = addAngles;
|
158 | // see https://gist.github.com/ahwolf/4349166 and
|
159 | // http://www.blackpawn.com/texts/pointinpoly/default.html
|
160 | function crossProduct(u, v) {
|
161 | return u[0] * v[1] - v[0] * u[1];
|
162 | }
|
163 | exports.crossProduct = crossProduct;
|
164 | function flipOrientation(orientation) {
|
165 | return orientation.map(function (orientationScalar) { return -1 * orientationScalar; });
|
166 | }
|
167 | exports.flipOrientation = flipOrientation;
|
168 | function flipSide(side) {
|
169 | return exports.EMANATION_ANGLE_TO_START_SIDE_MAPPINGS.get(reverseAngle(exports.START_SIDE_TO_EMANATION_ANGLE_MAPPINGS[side]));
|
170 | }
|
171 | exports.flipSide = flipSide;
|
172 | function getMinimumAngleBetweenVectors(vectorDirectionAngle1, vectorDirectionAngle2) {
|
173 | var vectors = [vectorDirectionAngle1, vectorDirectionAngle2];
|
174 | var minVector = Math.min.apply(undefined, vectors);
|
175 | var maxVector = Math.max.apply(undefined, vectors);
|
176 | if (minVector < 0 || maxVector >= 2 * Math.PI) {
|
177 | throw new Error("getMinimumAngleBetweenVectors(" + vectorDirectionAngle1 + ", " + vectorDirectionAngle2 + ")\n\t\t\t\t\t\t\t\t\t\tinputs must be in interval [0, 2 * Math.PI).");
|
178 | }
|
179 | return (Math.max(vectorDirectionAngle1, vectorDirectionAngle2) -
|
180 | Math.min(vectorDirectionAngle1, vectorDirectionAngle2));
|
181 | /*
|
182 | const diff = addAngles(vectorDirectionAngle1, -1 * vectorDirectionAngle2);
|
183 | return diff <= Math.PI ? diff : diff % Math.PI;
|
184 | //*/
|
185 | //return diff > Math.PI ? diff - Math.PI : diff;
|
186 | }
|
187 | exports.getMinimumAngleBetweenVectors = getMinimumAngleBetweenVectors;
|
188 | function getAngleOfEmanationFromPoint(point) {
|
189 | var _a = point.orientation, orientationX = _a[0], orientationY = _a[1];
|
190 | return Math.atan2(orientationY, orientationX);
|
191 | }
|
192 | exports.getAngleOfEmanationFromPoint = getAngleOfEmanationFromPoint;
|
193 | function reverseAngle(angle) {
|
194 | return addAngles(angle, Math.PI);
|
195 | }
|
196 | exports.reverseAngle = reverseAngle;
|
197 | function getAngleAtPoint(edge, positionX) {
|
198 | var id = edge.id, points = edge.points, markerStart = edge.markerStart, markerEnd = edge.markerEnd;
|
199 | var referencedPath = new edgeDrawers[edge.drawAs.toLowerCase()](points, markerStart, markerEnd);
|
200 | var tangentLength = 0.02;
|
201 | var firstPointOfTangent = referencedPath.getPointAtPosition(Math.max(0, positionX - tangentLength / 2));
|
202 | var lastPointOfTangent = referencedPath.getPointAtPosition(Math.min(1, positionX + tangentLength / 2));
|
203 | return getAngleFromPointToPoint(firstPointOfTangent, lastPointOfTangent);
|
204 | }
|
205 | exports.getAngleAtPoint = getAngleAtPoint;
|
206 | function getAngleFromPointToPoint(_a, _b) {
|
207 | var x0 = _a.x, y0 = _a.y;
|
208 | var x1 = _b.x, y1 = _b.y;
|
209 | return Math.atan2(y1 - y0, x1 - x0);
|
210 | }
|
211 | exports.getAngleFromPointToPoint = getAngleFromPointToPoint;
|
212 | function getStartSideByOrientation(_a) {
|
213 | var orientationX = _a[0], orientationY = _a[1];
|
214 | if (Math.abs(orientationX) > Math.abs(orientationY)) {
|
215 | if (orientationX > 0) {
|
216 | return "right"; //East
|
217 | }
|
218 | else {
|
219 | return "left"; //West
|
220 | }
|
221 | }
|
222 | else {
|
223 | if (orientationY > 0) {
|
224 | return "bottom"; //South
|
225 | }
|
226 | else {
|
227 | return "top"; //North
|
228 | }
|
229 | }
|
230 | }
|
231 | exports.getStartSideByOrientation = getStartSideByOrientation;
|
232 | // see http://blog.acipo.com/matrix-inversion-in-javascript/
|
233 | /**
|
234 | * Calculate the inverse matrix.
|
235 | * @returns {Matrix}
|
236 | */
|
237 | function invertMatrix(M) {
|
238 | // I use Guassian Elimination to calculate the inverse:
|
239 | // (1) 'augment' the matrix (left) by the identity (on the right)
|
240 | // (2) Turn the matrix on the left into the identity by elemetry row ops
|
241 | // (3) The matrix on the right is the inverse (was the identity matrix)
|
242 | // There are 3 elemtary row ops: (I combine b and c in my code)
|
243 | // (a) Swap 2 rows
|
244 | // (b) Multiply a row by a scalar
|
245 | // (c) Add 2 rows
|
246 | //if the matrix isn't square: exit (error)
|
247 | if (M.length !== M[0].length) {
|
248 | return;
|
249 | }
|
250 | //create the identity matrix (I), and a copy (C) of the original
|
251 | var i = 0, ii = 0, j = 0, dim = M.length, e = 0, t = 0;
|
252 | var I = [], C = [];
|
253 | for (i = 0; i < dim; i += 1) {
|
254 | // Create the row
|
255 | I[I.length] = [];
|
256 | C[C.length] = [];
|
257 | for (j = 0; j < dim; j += 1) {
|
258 | //if we're on the diagonal, put a 1 (for identity)
|
259 | if (i === j) {
|
260 | I[i][j] = 1;
|
261 | }
|
262 | else {
|
263 | I[i][j] = 0;
|
264 | }
|
265 | // Also, make the copy of the original
|
266 | C[i][j] = M[i][j];
|
267 | }
|
268 | }
|
269 | // Perform elementary row operations
|
270 | for (i = 0; i < dim; i += 1) {
|
271 | // get the element e on the diagonal
|
272 | e = C[i][i];
|
273 | // if we have a 0 on the diagonal (we'll need to swap with a lower row)
|
274 | if (e === 0) {
|
275 | //look through every row below the i'th row
|
276 | for (ii = i + 1; ii < dim; ii += 1) {
|
277 | //if the ii'th row has a non-0 in the i'th col
|
278 | if (C[ii][i] !== 0) {
|
279 | //it would make the diagonal have a non-0 so swap it
|
280 | for (j = 0; j < dim; j++) {
|
281 | e = C[i][j]; //temp store i'th row
|
282 | C[i][j] = C[ii][j]; //replace i'th row by ii'th
|
283 | C[ii][j] = e; //repace ii'th by temp
|
284 | e = I[i][j]; //temp store i'th row
|
285 | I[i][j] = I[ii][j]; //replace i'th row by ii'th
|
286 | I[ii][j] = e; //repace ii'th by temp
|
287 | }
|
288 | //don't bother checking other rows since we've swapped
|
289 | break;
|
290 | }
|
291 | }
|
292 | //get the new diagonal
|
293 | e = C[i][i];
|
294 | //if it's still 0, not invertable (error)
|
295 | if (e === 0) {
|
296 | return;
|
297 | }
|
298 | }
|
299 | // Scale this row down by e (so we have a 1 on the diagonal)
|
300 | for (j = 0; j < dim; j++) {
|
301 | C[i][j] = C[i][j] / e; //apply to original matrix
|
302 | I[i][j] = I[i][j] / e; //apply to identity
|
303 | }
|
304 | // Subtract this row (scaled appropriately for each row) from ALL of
|
305 | // the other rows so that there will be 0's in this column in the
|
306 | // rows above and below this one
|
307 | for (ii = 0; ii < dim; ii++) {
|
308 | // Only apply to other rows (we want a 1 on the diagonal)
|
309 | if (ii === i) {
|
310 | continue;
|
311 | }
|
312 | // We want to change this element to 0
|
313 | e = C[ii][i];
|
314 | // Subtract (the row above(or below) scaled by e) from (the
|
315 | // current row) but start at the i'th column and assume all the
|
316 | // stuff left of diagonal is 0 (which it should be if we made this
|
317 | // algorithm correctly)
|
318 | for (j = 0; j < dim; j++) {
|
319 | C[ii][j] -= e * C[i][j]; //apply to original matrix
|
320 | I[ii][j] -= e * I[i][j]; //apply to identity
|
321 | }
|
322 | }
|
323 | }
|
324 | //we've done all operations, C should be the identity
|
325 | //matrix I should be the inverse:
|
326 | return I;
|
327 | }
|
328 | exports.invertMatrix = invertMatrix;
|
329 | // from http://tech.pro/tutorial/1527/matrix-multiplication-in-functional-javascript
|
330 | function multiplyMatrices(m1, m2) {
|
331 | var result = [];
|
332 | for (var i = 0; i < m1.length; i++) {
|
333 | result[i] = [];
|
334 | for (var j = 0; j < m2[0].length; j++) {
|
335 | var sum = 0;
|
336 | for (var k = 0; k < m1[0].length; k++) {
|
337 | sum += m1[i][k] * m2[k][j];
|
338 | }
|
339 | result[i][j] = sum;
|
340 | }
|
341 | }
|
342 | return result;
|
343 | }
|
344 | exports.multiplyMatrices = multiplyMatrices;
|
345 | /**
|
346 | * rotate
|
347 | *
|
348 | * @param theta (float): rotation angle in radians, measured clockwise
|
349 | * @return transformation matrix for rotation
|
350 | *
|
351 | * Note that for Canvas and SVG, the y axis points down:
|
352 | *
|
353 | * *---------> x
|
354 | * |
|
355 | * |
|
356 | * |
|
357 | * v
|
358 | *
|
359 | * y
|
360 | *
|
361 | * The transformation matrix returned takes this into account and is intentionally
|
362 | * different from the transformation matrix that would be returned if the y-axis
|
363 | * pointed up, as is common in many math classes.
|
364 | */
|
365 | function rotate(theta) {
|
366 | if (!fp_1.isFinite(theta)) {
|
367 | throw new Error("Invalid input: rotate(" + theta + "). Requires a finite number.");
|
368 | }
|
369 | return [
|
370 | [Math.cos(theta), -1 * Math.sin(theta), 0],
|
371 | [Math.sin(theta), Math.cos(theta), 0],
|
372 | [0, 0, 1]
|
373 | ];
|
374 | }
|
375 | exports.rotate = rotate;
|
376 | function scale(_a) {
|
377 | var xScale = _a[0], yScale = _a[1];
|
378 | if (!fp_1.isFinite(xScale) || !fp_1.isFinite(yScale)) {
|
379 | throw new Error("Invalid input: rotate([" + xScale + ", " + yScale + "]). Requires array of two finite numbers.");
|
380 | }
|
381 | return [[xScale, 0, 0], [0, yScale, 0], [0, 0, 1]];
|
382 | }
|
383 | exports.scale = scale;
|
384 | function translate(_a) {
|
385 | var xTranslation = _a[0], yTranslation = _a[1];
|
386 | if (!fp_1.isFinite(xTranslation) || !fp_1.isFinite(yTranslation)) {
|
387 | throw new Error("Invalid input: translate([" + xTranslation + ", " + yTranslation + "]). Requires array of two finite numbers.");
|
388 | }
|
389 | return [[1, 0, xTranslation], [0, 1, yTranslation], [0, 0, 1]];
|
390 | }
|
391 | exports.translate = translate;
|
392 | var transformations = {
|
393 | rotate: rotate,
|
394 | scale: scale,
|
395 | translate: translate
|
396 | };
|
397 | function getTransformationMatrix(transformationSequence) {
|
398 | // Start with identity matrix
|
399 | var concatenatedTransformationMatrix = [[1, 0, 0], [0, 1, 0], [0, 0, 1]];
|
400 | transformationSequence.forEach(function (transformation) {
|
401 | var thisTransformationMatrix = transformations[transformation.key](transformation.value);
|
402 | concatenatedTransformationMatrix = multiplyMatrices(concatenatedTransformationMatrix, thisTransformationMatrix);
|
403 | });
|
404 | return concatenatedTransformationMatrix;
|
405 | }
|
406 | exports.getTransformationMatrix = getTransformationMatrix;
|
407 | function multiplyMatrixByVector(transformationMatrix, vector) {
|
408 | var x = vector[0][0] * transformationMatrix[0][0] +
|
409 | vector[1][0] * transformationMatrix[0][1] +
|
410 | vector[2][0] * transformationMatrix[0][2], y = vector[0][0] * transformationMatrix[1][0] +
|
411 | vector[1][0] * transformationMatrix[1][1] +
|
412 | vector[2][0] * transformationMatrix[1][2], z = vector[0][0] * transformationMatrix[2][0] +
|
413 | vector[1][0] * transformationMatrix[2][1] +
|
414 | vector[2][0] * transformationMatrix[2][2];
|
415 | return [[x], [y], [z]];
|
416 | }
|
417 | exports.multiplyMatrixByVector = multiplyMatrixByVector;
|
418 | /**
|
419 | * sameSide
|
420 | *
|
421 | * Calculate whether the current edge's second point, a, (end of first segment)
|
422 | * and its final point, b, are both on the same side of the referenced edge.
|
423 | *
|
424 | * current edge: pipes/hyphens
|
425 | * referenced edge: dots
|
426 | *
|
427 | * Example of True
|
428 | *
|
429 | * p1
|
430 | * .
|
431 | * .
|
432 | * *------------a
|
433 | * . |
|
434 | * . |
|
435 | * . |
|
436 | * . |
|
437 | * . |
|
438 | * . |
|
439 | * . |
|
440 | * . |
|
441 | * . |
|
442 | * . |
|
443 | * . *-----b
|
444 | * .
|
445 | * .
|
446 | * p2
|
447 | *
|
448 | *
|
449 | * Example of False
|
450 | *
|
451 | * p1
|
452 | * .
|
453 | * *------------a
|
454 | * . |
|
455 | * . |
|
456 | * . |
|
457 | * . |
|
458 | * . |
|
459 | * .|
|
460 | * |.
|
461 | * | .
|
462 | * | .
|
463 | * | .
|
464 | * *-----b .
|
465 | * .
|
466 | * p2
|
467 | *
|
468 | *
|
469 | * @param {Object} p1 - first point of the referenced edge
|
470 | * @param {Object} p2 - last point of the referenced edge
|
471 | * @param {Object} a - last point of the first segment of the current edge (the point following the start point)
|
472 | * @param {Object} b - point where the current edge ends
|
473 | * @return {Boolean) - whether the last point of the first segment of the current edge is on the same side as the last point of the current edge
|
474 | */
|
475 | function sameSide(p1, p2, a, b) {
|
476 | var bMinusA = [b.x - a.x, b.y - a.y];
|
477 | var p1MinusA = [p1.x - a.x, p1.y - a.y];
|
478 | var p2MinusA = [p2.x - a.x, p2.y - a.y];
|
479 | var crossProduct1 = crossProduct(bMinusA, p1MinusA);
|
480 | var crossProduct2 = crossProduct(bMinusA, p2MinusA);
|
481 | return Math.sign(crossProduct1) === Math.sign(crossProduct2);
|
482 | }
|
483 | exports.sameSide = sameSide;
|
484 | function transform(_a) {
|
485 | var element = _a.element, transformOrigin = _a.transformOrigin, transformationSequence = _a.transformationSequence;
|
486 | var x = element.x, y = element.y, width = element.width, height = element.height;
|
487 | (transformOrigin = transformOrigin || "50% 50%"),
|
488 | (transformationSequence = transformationSequence || []);
|
489 | var transformOriginKeywordMappings = {
|
490 | left: "0%",
|
491 | center: "50%",
|
492 | right: "100%",
|
493 | top: "0%",
|
494 | bottom: "100%"
|
495 | };
|
496 | var transformOriginKeywordMappingsKeys = Object.keys(transformOriginKeywordMappings);
|
497 | var transformOriginPoint = transformOrigin
|
498 | .split(" ")
|
499 | .map(function (value, i) {
|
500 | var numericOrPctValue;
|
501 | var numericValue;
|
502 | if (transformOriginKeywordMappingsKeys.indexOf(value) > -1) {
|
503 | numericOrPctValue = transformOriginKeywordMappings[value];
|
504 | }
|
505 | else {
|
506 | numericOrPctValue = value;
|
507 | }
|
508 | if (numericOrPctValue.indexOf("%") > -1) {
|
509 | var decimalPercent = parseFloat(numericOrPctValue) / 100;
|
510 | if (i === 0) {
|
511 | numericValue = decimalPercent * width;
|
512 | }
|
513 | else {
|
514 | numericValue = decimalPercent * height;
|
515 | }
|
516 | }
|
517 | else if (value.indexOf("em") > -1) {
|
518 | // TODO refactor. this is hacky.
|
519 | numericValue = parseFloat(numericOrPctValue) * 12;
|
520 | }
|
521 | else {
|
522 | numericValue = parseFloat(numericOrPctValue);
|
523 | }
|
524 | if (i === 0) {
|
525 | numericValue += x;
|
526 | }
|
527 | else {
|
528 | numericValue += y;
|
529 | }
|
530 | return numericValue;
|
531 | });
|
532 | // shift origin from top left corner of element bounding box to point specified by transformOrigin (default: center of bounding box)
|
533 | transformationSequence.unshift({
|
534 | key: "translate",
|
535 | value: [transformOriginPoint[0], transformOriginPoint[1]]
|
536 | });
|
537 | // shift origin back to top left corner of element bounding box
|
538 | transformationSequence.push({
|
539 | key: "translate",
|
540 | value: [-1 * transformOriginPoint[0], -1 * transformOriginPoint[1]]
|
541 | });
|
542 | var transformationMatrix = getTransformationMatrix(transformationSequence);
|
543 | var topLeftPoint = [[x], [y], [1]];
|
544 | var bottomRightPoint = [[x + width], [y + height], [1]];
|
545 | var topLeftPointTransformed = multiplyMatrixByVector(transformationMatrix, topLeftPoint);
|
546 | var bottomRightPointTransformed = multiplyMatrixByVector(transformationMatrix, bottomRightPoint);
|
547 | element.x = topLeftPointTransformed[0][0];
|
548 | element.y = topLeftPointTransformed[1][0];
|
549 | element.width = bottomRightPointTransformed[0][0] - element.x;
|
550 | element.height = bottomRightPointTransformed[1][0] - element.y;
|
551 | return element;
|
552 | }
|
553 | exports.transform = transform;
|
554 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"geom-utils.js","sourceRoot":"","sources":["../src/geom-utils.ts"],"names":[],"mappings":"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"} |
\ | No newline at end of file |