UNPKG

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