UNPKG

react-planner-viewer

Version:

react-planner-viewer is a React Component for view plans builded with react-planner in 2D mode

304 lines (241 loc) 35.2 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); var _slicedToArray = function () { function sliceIterator(arr, i) { var _arr = []; var _n = true; var _d = false; var _e = undefined; try { for (var _i = arr[Symbol.iterator](), _s; !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"]) _i["return"](); } finally { if (_d) throw _e; } } return _arr; } return function (arr, i) { if (Array.isArray(arr)) { return arr; } else if (Symbol.iterator in Object(arr)) { return sliceIterator(arr, i); } else { throw new TypeError("Invalid attempt to destructure non-iterable instance"); } }; }(); /** @description Determines the distance between two points * @param {number} x0 Vertex 0 x * @param {number} y0 Vertex 0 y * @param {number} x1 Vertex 1 x * @param {number} y1 Vertex 1 y * @return {number} */ exports.compareVertices = compareVertices; exports.minVertex = minVertex; exports.maxVertex = maxVertex; exports.orderVertices = orderVertices; exports.pointsDistance = pointsDistance; exports.verticesDistance = verticesDistance; exports.horizontalLine = horizontalLine; exports.verticalLine = verticalLine; exports.linePassingThroughTwoPoints = linePassingThroughTwoPoints; exports.distancePointFromLine = distancePointFromLine; exports.closestPointFromLine = closestPointFromLine; exports.intersectionFromTwoLines = intersectionFromTwoLines; exports.intersectionFromTwoLineSegment = intersectionFromTwoLineSegment; exports.distancePointFromLineSegment = distancePointFromLineSegment; exports.isPointOnLineSegment = isPointOnLineSegment; exports.closestPointFromLineSegment = closestPointFromLineSegment; exports.pointPositionOnLineSegment = pointPositionOnLineSegment; exports.mapRange = mapRange; exports.angleBetweenTwoPointsAndOrigin = angleBetweenTwoPointsAndOrigin; exports.angleBetweenTwoPoints = angleBetweenTwoPoints; exports.samePoints = samePoints; exports.extendLine = extendLine; exports.roundVertex = roundVertex; var _math = require("./math.js"); var _constants = require("../constants"); function compareVertices(v0, v1) { return v0.x === v1.x ? v0.y - v1.y : v0.x - v1.x; } function minVertex(v0, v1) { return compareVertices(v0, v1) > 0 ? v1 : v0; } function maxVertex(v0, v1) { return compareVertices(v0, v1) > 0 ? v0 : v1; } function orderVertices(vertices) { return vertices.sort(compareVertices); } function pointsDistance(x0, y0, x1, y1) { var diff_x = x0 - x1; var diff_y = y0 - y1; return Math.sqrt(diff_x * diff_x + diff_y * diff_y); } function verticesDistance(v1, v2) { var x0 = v1.x, y0 = v1.y; var x1 = v2.x, y1 = v2.y; return pointsDistance(x0, y0, x1, y1); } function horizontalLine(y) { return { a: 0, b: 1, c: -y }; } function verticalLine(x) { return { a: 1, b: 0, c: -x }; } function linePassingThroughTwoPoints(x1, y1, x2, y2) { // (x2 - x1)(y - y1) = (y2 - y1)(x - x1) // (y1 - y2)x + (x2 - x1)y + (y2x1 - x2y1) = 0 if (x1 === x2 && y1 == y2) throw new Error("Geometry error"); if (x1 === x2) return verticalLine(x); if (y1 === y2) return horizontalLine(y1); return { a: y1 - y2, b: x2 - x1, c: y2 * x1 - x2 * y1 }; } function distancePointFromLine(a, b, c, x, y) { //https://en.wikipedia.org/wiki/Distance_from_a_point_to_a_line return (0, _math.fAbs)(a * x + b * y + c) / Math.sqrt(a * a + b * b); } function closestPointFromLine(a, b, c, x, y) { //https://en.wikipedia.org/wiki/Distance_from_a_point_to_a_line var denom = a * a + b * b; return { x: (b * (b * x - a * y) - a * c) / denom, y: (a * -b * x + a * y - b * c) / denom }; } function intersectionFromTwoLines(a, b, c, j, k, l) { var det = b * j - a * k; if (det === 0) return undefined; //no intersection var y = (a * l - c * j) / det; var x = (c * k - b * l) / det; return { x: x, y: y }; } function intersectionFromTwoLineSegment(p1, p2, p3, p4) { //https://github.com/psalaets/line-intersect/blob/master/lib/check-intersection.js var x1 = p1.x, y1 = p1.y; var x2 = p2.x, y2 = p2.y; var x3 = p3.x, y3 = p3.y; var x4 = p4.x, y4 = p4.y; var denom = (y4 - y3) * (x2 - x1) - (x4 - x3) * (y2 - y1); var numA = (x4 - x3) * (y1 - y3) - (y4 - y3) * (x1 - x3); var numB = (x2 - x1) * (y1 - y3) - (y2 - y1) * (x1 - x3); if ((0, _math.fAbs)(denom) <= _constants.EPSILON) { if ((0, _math.fAbs)(numA) <= _constants.EPSILON && (0, _math.fAbs)(numB) <= _constants.EPSILON) { var comparator = function comparator(pa, pb) { return pa.x === pb.x ? pa.y - pb.y : pa.x - pb.x; }; var line0 = [p1, p2].sort(comparator); var line1 = [p3.toJS(), p4.toJS()].sort(comparator); var _sort = [line0, line1].sort(function (lineA, lineB) { return comparator(lineA[0], lineB[0]); }), _sort2 = _slicedToArray(_sort, 2), lineSX = _sort2[0], lineDX = _sort2[1]; if (lineSX[1].x === lineDX[0].x) { return { type: lineDX[0].y <= lineSX[1].y ? "colinear" : "none" }; } else { return { type: lineDX[0].x <= lineSX[1].x ? "colinear" : "none" }; } } return { type: "parallel" }; } var uA = numA / denom; var uB = numB / denom; if (uA >= 0 - _constants.EPSILON && uA <= 1 + _constants.EPSILON && uB >= 0 - _constants.EPSILON && uB <= 1 + _constants.EPSILON) { var point = { x: x1 + uA * (x2 - x1), y: y1 + uA * (y2 - y1) }; return { type: "intersecting", point: point }; } return { type: "none" }; } function distancePointFromLineSegment(x1, y1, x2, y2, xp, yp) { //http://stackoverflow.com/a/6853926/1398836 var A = xp - x1; var B = yp - y1; var C = x2 - x1; var D = y2 - y1; var dot = A * C + B * D; var len_sq = C * C + D * D; var param = -1; if (len_sq != 0) //in case of 0 length line param = dot / len_sq; var xx = void 0, yy = void 0; if (param < 0) { xx = x1; yy = y1; } else if (param > 1) { xx = x2; yy = y2; } else { xx = x1 + param * C; yy = y1 + param * D; } var dx = xp - xx; var dy = yp - yy; return Math.sqrt(dx * dx + dy * dy); } /** * * @param x1 {number} x for first vertex of the segment * @param y1 {number} y for first vertex of the segment * @param x2 {number} x for second vertex of the segment * @param y2 {number} y for second vertex of the segment * @param xp {number} x for point we want to verify * @param yp {number} y for point we want to verify * @param maxDistance {number} the epsilon value used for comparisons * @returns {boolean} true if the point lies on the line segment false otherwise */ function isPointOnLineSegment(x1, y1, x2, y2, xp, yp) { var maxDistance = arguments.length > 6 && arguments[6] !== undefined ? arguments[6] : _constants.EPSILON; return distancePointFromLineSegment(x1, y1, x2, y2, xp, yp) <= maxDistance; } function closestPointFromLineSegment(x1, y1, x2, y2, xp, yp) { if (x1 === x2) return { x: x1, y: yp }; if (y1 === y2) return { x: xp, y: y1 }; var m = (y2 - y1) / (x2 - x1); var q = y1 - m * x1; var mi = -1 / m; var qi = yp - mi * xp; var x = (qi - q) / (m - mi); var y = m * x + q; return { x: x, y: y }; } function pointPositionOnLineSegment(x1, y1, x2, y2, xp, yp) { var length = pointsDistance(x1, y1, x2, y2); var distance = pointsDistance(x1, y1, xp, yp); var offset = distance / length; if (x1 > x2) offset = mapRange(offset, 0, 1, 1, 0); return offset; } function mapRange(value, low1, high1, low2, high2) { return low2 + (high2 - low2) * (value - low1) / (high1 - low1); } function angleBetweenTwoPointsAndOrigin(x1, y1, x2, y2) { return -Math.atan2(y1 - y2, x2 - x1) * 180 / Math.PI; } function angleBetweenTwoPoints(x1, y1, x2, y2) { return Math.atan2(y2 - y1, x2 - x1); } function samePoints(_ref, _ref2) { var x1 = _ref.x, y1 = _ref.y; var x2 = _ref2.x, y2 = _ref2.y; return (0, _math.fAbs)(x1 - x2) <= _constants.EPSILON && (0, _math.fAbs)(y1 - y2) <= _constants.EPSILON; } /** @description Extend line based on coordinates and new line length * @param {number} x1 Vertex 1 x * @param {number} y1 Vertex 1 y * @param {number} x2 Vertex 2 x * @param {number} y2 Vertex 2 y * @param {number} newDistance New line length * @return {object} */ function extendLine(x1, y1, x2, y2, newDistance) { var precision = arguments.length > 5 && arguments[5] !== undefined ? arguments[5] : 6; var rad = Math.atan2(y2 - y1, x2 - x1); return { x: (0, _math.toFixedFloat)(x1 + Math.cos(rad) * newDistance, precision), y: (0, _math.toFixedFloat)(y1 + Math.sin(rad) * newDistance, precision) }; } function roundVertex(vertex) { var precision = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 6; vertex.set('x', (0, _math.toFixedFloat)(vertex.get('x'), precision)); vertex.set('y', (0, _math.toFixedFloat)(vertex.get('y'), precision)); return vertex; } //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/utils/geometry.js"],"names":["compareVertices","minVertex","maxVertex","orderVertices","pointsDistance","verticesDistance","horizontalLine","verticalLine","linePassingThroughTwoPoints","distancePointFromLine","closestPointFromLine","intersectionFromTwoLines","intersectionFromTwoLineSegment","distancePointFromLineSegment","isPointOnLineSegment","closestPointFromLineSegment","pointPositionOnLineSegment","mapRange","angleBetweenTwoPointsAndOrigin","angleBetweenTwoPoints","samePoints","extendLine","roundVertex","v0","v1","x","y","vertices","sort","x0","y0","x1","y1","diff_x","diff_y","Math","sqrt","v2","a","b","c","x2","y2","Error","denom","j","k","l","det","undefined","p1","p2","p3","p4","x3","y3","x4","y4","numA","numB","comparator","pa","pb","line0","line1","toJS","lineA","lineB","lineSX","lineDX","type","uA","uB","point","xp","yp","A","B","C","D","dot","len_sq","param","xx","yy","dx","dy","maxDistance","m","q","mi","qi","length","distance","offset","value","low1","high1","low2","high2","atan2","PI","newDistance","precision","rad","cos","sin","vertex","set","get"],"mappings":"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","file":"geometry.js","sourcesContent":["/** @description Determines the distance between two points\n *  @param {number} x0 Vertex 0 x\n *  @param {number} y0 Vertex 0 y\n *  @param {number} x1 Vertex 1 x\n *  @param {number} y1 Vertex 1 y\n *  @return {number}\n */\nimport {toFixedFloat, fAbs} from './math.js';\nimport {EPSILON} from \"../constants\";\n\nexport function compareVertices(v0, v1) {\n  return v0.x === v1.x ? v0.y - v1.y : v0.x - v1.x\n}\n\nexport function minVertex(v0, v1) {\n  return compareVertices(v0, v1) > 0 ? v1 : v0;\n}\n\nexport function maxVertex(v0, v1) {\n  return compareVertices(v0, v1) > 0 ? v0 : v1;\n}\n\nexport function orderVertices(vertices) {\n  return vertices.sort(compareVertices);\n}\n\nexport function pointsDistance(x0, y0, x1, y1) {\n  let diff_x = x0 - x1;\n  let diff_y = y0 - y1;\n\n  return Math.sqrt((diff_x * diff_x) + (diff_y * diff_y));\n}\n\nexport function verticesDistance(v1, v2) {\n\n  let {x: x0, y: y0} = v1;\n  let {x: x1, y: y1} = v2;\n\n  return pointsDistance(x0, y0, x1, y1);\n}\n\nexport function horizontalLine(y) {\n  return {a: 0, b: 1, c: -y}\n}\n\nexport function verticalLine(x) {\n  return {a: 1, b: 0, c: -x}\n}\n\nexport function linePassingThroughTwoPoints(x1, y1, x2, y2) {\n  // (x2 - x1)(y - y1) = (y2 - y1)(x - x1)\n  // (y1 - y2)x + (x2 - x1)y + (y2x1 - x2y1) = 0\n\n  if (x1 === x2 && y1 == y2) throw new Error(\"Geometry error\");\n  if (x1 === x2) return verticalLine(x);\n  if (y1 === y2) return horizontalLine(y1);\n\n  return {\n    a: y1 - y2,\n    b: x2 - x1,\n    c: y2 * x1 - x2 * y1\n  };\n}\n\nexport function distancePointFromLine(a, b, c, x, y) {\n  //https://en.wikipedia.org/wiki/Distance_from_a_point_to_a_line\n  return fAbs(a * x + b * y + c) / Math.sqrt(a * a + b * b);\n}\n\nexport function closestPointFromLine(a, b, c, x, y) {\n  //https://en.wikipedia.org/wiki/Distance_from_a_point_to_a_line\n  let denom = a * a + b * b;\n  return {\n    x: (b * (b * x - a * y) - a * c) / denom,\n    y: ((a * -b * x + a * y) - b * c) / denom,\n  }\n}\n\nexport function intersectionFromTwoLines(a, b, c, j, k, l) {\n  let det = (b * j - a * k);\n\n  if (det === 0) return undefined; //no intersection\n\n  let y = (a * l - c * j) / det;\n  let x = (c * k - b * l) / det;\n  return {x, y};\n}\n\nexport function intersectionFromTwoLineSegment(p1, p2, p3, p4) {\n  //https://github.com/psalaets/line-intersect/blob/master/lib/check-intersection.js\n\n  let {x: x1, y: y1} = p1;\n  let {x: x2, y: y2} = p2;\n  let {x: x3, y: y3} = p3;\n  let {x: x4, y: y4} = p4;\n\n  let denom = ((y4 - y3) * (x2 - x1)) - ((x4 - x3) * (y2 - y1));\n  let numA = ((x4 - x3) * (y1 - y3)) - ((y4 - y3) * (x1 - x3));\n  let numB = ((x2 - x1) * (y1 - y3)) - ((y2 - y1) * (x1 - x3));\n\n  if (fAbs(denom) <= EPSILON) {\n    if (fAbs(numA) <= EPSILON && fAbs(numB) <= EPSILON) {\n\n      let comparator = (pa, pb) => pa.x === pb.x ? pa.y - pb.y : pa.x - pb.x;\n      let line0 = [p1, p2].sort(comparator);\n      let line1 = [p3.toJS(), p4.toJS()].sort(comparator);\n\n      let [lineSX, lineDX] = [line0, line1].sort((lineA, lineB) => comparator(lineA[0], lineB[0]));\n\n      if (lineSX[1].x === lineDX[0].x) {\n        return {type: (lineDX[0].y <= lineSX[1].y) ? \"colinear\" : \"none\"};\n      } else {\n        return {type: (lineDX[0].x <= lineSX[1].x) ? \"colinear\" : \"none\"};\n      }\n    }\n    return {type: \"parallel\"};\n  }\n\n  var uA = numA / denom;\n  var uB = numB / denom;\n\n  if (uA >= (0 - EPSILON) && uA <= (1 + EPSILON) && uB >= (0 - EPSILON) && uB <= (1 + EPSILON)) {\n    let point = {\n      x: x1 + (uA * (x2 - x1)),\n      y: y1 + (uA * (y2 - y1))\n    };\n    return {type: \"intersecting\", point};\n  }\n\n  return {type: \"none\"};\n}\n\nexport function distancePointFromLineSegment(x1, y1, x2, y2, xp, yp) {\n  //http://stackoverflow.com/a/6853926/1398836\n\n  let A = xp - x1;\n  let B = yp - y1;\n  let C = x2 - x1;\n  let D = y2 - y1;\n\n  let dot = A * C + B * D;\n  let len_sq = C * C + D * D;\n  let param = -1;\n  if (len_sq != 0) //in case of 0 length line\n    param = dot / len_sq;\n\n  let xx, yy;\n\n  if (param < 0) {\n    xx = x1;\n    yy = y1;\n  }\n  else if (param > 1) {\n    xx = x2;\n    yy = y2;\n  }\n  else {\n    xx = x1 + param * C;\n    yy = y1 + param * D;\n  }\n\n  let dx = xp - xx;\n  let dy = yp - yy;\n  return Math.sqrt(dx * dx + dy * dy);\n}\n\n/**\n *\n * @param x1 {number} x for first vertex of the segment\n * @param y1 {number} y for first vertex of the segment\n * @param x2 {number} x for second vertex of the segment\n * @param y2 {number} y for second vertex of the segment\n * @param xp {number} x for point we want to verify\n * @param yp {number} y for point we want to verify\n * @param maxDistance {number} the epsilon value used for comparisons\n * @returns {boolean} true if the point lies on the line segment false otherwise\n */\nexport function isPointOnLineSegment(x1, y1, x2, y2, xp, yp, maxDistance = EPSILON) {\n  return distancePointFromLineSegment(x1, y1, x2, y2, xp, yp) <= maxDistance;\n}\n\nexport function closestPointFromLineSegment(x1, y1, x2, y2, xp, yp) {\n  if (x1 === x2) return {x: x1, y: yp};\n  if (y1 === y2) return {x: xp, y: y1};\n\n  let m = (y2 - y1) / (x2 - x1);\n  let q = y1 - m * x1;\n\n  let mi = -1 / m;\n  let qi = yp - mi * xp;\n\n  let x = (qi - q) / (m - mi);\n  let y = (m * x + q);\n\n  return {x, y};\n}\n\nexport function pointPositionOnLineSegment(x1, y1, x2, y2, xp, yp) {\n  let length = pointsDistance(x1, y1, x2, y2);\n  let distance = pointsDistance(x1, y1, xp, yp);\n\n  let offset = distance / length;\n  if (x1 > x2) offset = mapRange(offset, 0, 1, 1, 0);\n\n  return offset;\n}\n\nexport function mapRange(value, low1, high1, low2, high2) {\n  return low2 + (high2 - low2) * (value - low1) / (high1 - low1);\n}\n\nexport function angleBetweenTwoPointsAndOrigin(x1, y1, x2, y2) {\n  return -(Math.atan2(y1 - y2, x2 - x1)) * 180 / Math.PI;\n}\n\nexport function angleBetweenTwoPoints(x1, y1, x2, y2) {\n  return Math.atan2(y2 - y1, x2 - x1);\n}\n\nexport function samePoints({x: x1, y: y1}, {x: x2, y: y2}) {\n  return fAbs(x1 - x2) <= EPSILON && fAbs(y1 - y2) <= EPSILON;\n}\n\n/** @description Extend line based on coordinates and new line length\n *  @param {number} x1 Vertex 1 x\n *  @param {number} y1 Vertex 1 y\n *  @param {number} x2 Vertex 2 x\n *  @param {number} y2 Vertex 2 y\n *  @param {number} newDistance New line length\n *  @return {object}\n */\nexport function extendLine(x1, y1, x2, y2, newDistance, precision = 6) {\n  let rad = Math.atan2(y2 - y1, x2 - x1);\n\n  return {\n    x: toFixedFloat(x1 + (Math.cos(rad) * newDistance), precision),\n    y: toFixedFloat(y1 + (Math.sin(rad) * newDistance), precision),\n  }\n}\n\nexport function roundVertex(vertex, precision = 6) {\n  vertex.set('x', toFixedFloat(vertex.get('x'), precision));\n  vertex.set('y', toFixedFloat(vertex.get('y'), precision));\n\n  return vertex;\n}\n"]}