You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
25 lines
58 KiB
JavaScript
25 lines
58 KiB
JavaScript
"use strict";
|
|
/*
|
|
* ATTENTION: An "eval-source-map" devtool has been used.
|
|
* This devtool is neither made for production nor for readable output files.
|
|
* It uses "eval()" calls to create a separate source file with attached SourceMaps in the browser devtools.
|
|
* If you are trying to read the output file, select a different devtool (https://webpack.js.org/configuration/devtool/)
|
|
* or disable the default devtool with "devtool: false".
|
|
* If you are looking for production-ready output files, see mode: "production" (https://webpack.js.org/configuration/mode/).
|
|
*/
|
|
exports.id = "vendor-chunks/delaunator";
|
|
exports.ids = ["vendor-chunks/delaunator"];
|
|
exports.modules = {
|
|
|
|
/***/ "(ssr)/./node_modules/delaunator/index.js":
|
|
/*!******************************************!*\
|
|
!*** ./node_modules/delaunator/index.js ***!
|
|
\******************************************/
|
|
/***/ ((__unused_webpack___webpack_module__, __webpack_exports__, __webpack_require__) => {
|
|
|
|
eval("__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (/* binding */ Delaunator)\n/* harmony export */ });\n/* harmony import */ var robust_predicates__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! robust-predicates */ \"(ssr)/./node_modules/robust-predicates/index.js\");\nconst EPSILON = Math.pow(2, -52);\nconst EDGE_STACK = new Uint32Array(512);\n\nclass Delaunator {\n static from(points, getX = defaultGetX, getY = defaultGetY) {\n const n = points.length;\n const coords = new Float64Array(n * 2);\n for(let i = 0; i < n; i++){\n const p = points[i];\n coords[2 * i] = getX(p);\n coords[2 * i + 1] = getY(p);\n }\n return new Delaunator(coords);\n }\n constructor(coords){\n const n = coords.length >> 1;\n if (n > 0 && typeof coords[0] !== \"number\") throw new Error(\"Expected coords to contain numbers.\");\n this.coords = coords;\n // arrays that will store the triangulation graph\n const maxTriangles = Math.max(2 * n - 5, 0);\n this._triangles = new Uint32Array(maxTriangles * 3);\n this._halfedges = new Int32Array(maxTriangles * 3);\n // temporary arrays for tracking the edges of the advancing convex hull\n this._hashSize = Math.ceil(Math.sqrt(n));\n this._hullPrev = new Uint32Array(n); // edge to prev edge\n this._hullNext = new Uint32Array(n); // edge to next edge\n this._hullTri = new Uint32Array(n); // edge to adjacent triangle\n this._hullHash = new Int32Array(this._hashSize).fill(-1); // angular edge hash\n // temporary arrays for sorting points\n this._ids = new Uint32Array(n);\n this._dists = new Float64Array(n);\n this.update();\n }\n update() {\n const { coords, _hullPrev: hullPrev, _hullNext: hullNext, _hullTri: hullTri, _hullHash: hullHash } = this;\n const n = coords.length >> 1;\n // populate an array of point indices; calculate input data bbox\n let minX = Infinity;\n let minY = Infinity;\n let maxX = -Infinity;\n let maxY = -Infinity;\n for(let i = 0; i < n; i++){\n const x = coords[2 * i];\n const y = coords[2 * i + 1];\n if (x < minX) minX = x;\n if (y < minY) minY = y;\n if (x > maxX) maxX = x;\n if (y > maxY) maxY = y;\n this._ids[i] = i;\n }\n const cx = (minX + maxX) / 2;\n const cy = (minY + maxY) / 2;\n let minDist = Infinity;\n let i0, i1, i2;\n // pick a seed point close to the center\n for(let i = 0; i < n; i++){\n const d = dist(cx, cy, coords[2 * i], coords[2 * i + 1]);\n if (d < minDist) {\n i0 = i;\n minDist = d;\n }\n }\n const i0x = coords[2 * i0];\n const i0y = coords[2 * i0 + 1];\n minDist = Infinity;\n // find the point closest to the seed\n for(let i = 0; i < n; i++){\n if (i === i0) continue;\n const d = dist(i0x, i0y, coords[2 * i], coords[2 * i + 1]);\n if (d < minDist && d > 0) {\n i1 = i;\n minDist = d;\n }\n }\n let i1x = coords[2 * i1];\n let i1y = coords[2 * i1 + 1];\n let minRadius = Infinity;\n // find the third point which forms the smallest circumcircle with the first two\n for(let i = 0; i < n; i++){\n if (i === i0 || i === i1) continue;\n const r = circumradius(i0x, i0y, i1x, i1y, coords[2 * i], coords[2 * i + 1]);\n if (r < minRadius) {\n i2 = i;\n minRadius = r;\n }\n }\n let i2x = coords[2 * i2];\n let i2y = coords[2 * i2 + 1];\n if (minRadius === Infinity) {\n // order collinear points by dx (or dy if all x are identical)\n // and return the list as a hull\n for(let i = 0; i < n; i++){\n this._dists[i] = coords[2 * i] - coords[0] || coords[2 * i + 1] - coords[1];\n }\n quicksort(this._ids, this._dists, 0, n - 1);\n const hull = new Uint32Array(n);\n let j = 0;\n for(let i = 0, d0 = -Infinity; i < n; i++){\n const id = this._ids[i];\n if (this._dists[id] > d0) {\n hull[j++] = id;\n d0 = this._dists[id];\n }\n }\n this.hull = hull.subarray(0, j);\n this.triangles = new Uint32Array(0);\n this.halfedges = new Uint32Array(0);\n return;\n }\n // swap the order of the seed points for counter-clockwise orientation\n if ((0,robust_predicates__WEBPACK_IMPORTED_MODULE_0__.orient2d)(i0x, i0y, i1x, i1y, i2x, i2y) < 0) {\n const i = i1;\n const x = i1x;\n const y = i1y;\n i1 = i2;\n i1x = i2x;\n i1y = i2y;\n i2 = i;\n i2x = x;\n i2y = y;\n }\n const center = circumcenter(i0x, i0y, i1x, i1y, i2x, i2y);\n this._cx = center.x;\n this._cy = center.y;\n for(let i = 0; i < n; i++){\n this._dists[i] = dist(coords[2 * i], coords[2 * i + 1], center.x, center.y);\n }\n // sort the points by distance from the seed triangle circumcenter\n quicksort(this._ids, this._dists, 0, n - 1);\n // set up the seed triangle as the starting hull\n this._hullStart = i0;\n let hullSize = 3;\n hullNext[i0] = hullPrev[i2] = i1;\n hullNext[i1] = hullPrev[i0] = i2;\n hullNext[i2] = hullPrev[i1] = i0;\n hullTri[i0] = 0;\n hullTri[i1] = 1;\n hullTri[i2] = 2;\n hullHash.fill(-1);\n hullHash[this._hashKey(i0x, i0y)] = i0;\n hullHash[this._hashKey(i1x, i1y)] = i1;\n hullHash[this._hashKey(i2x, i2y)] = i2;\n this.trianglesLen = 0;\n this._addTriangle(i0, i1, i2, -1, -1, -1);\n for(let k = 0, xp, yp; k < this._ids.length; k++){\n const i = this._ids[k];\n const x = coords[2 * i];\n const y = coords[2 * i + 1];\n // skip near-duplicate points\n if (k > 0 && Math.abs(x - xp) <= EPSILON && Math.abs(y - yp) <= EPSILON) continue;\n xp = x;\n yp = y;\n // skip seed triangle points\n if (i === i0 || i === i1 || i === i2) continue;\n // find a visible edge on the convex hull using edge hash\n let start = 0;\n for(let j = 0, key = this._hashKey(x, y); j < this._hashSize; j++){\n start = hullHash[(key + j) % this._hashSize];\n if (start !== -1 && start !== hullNext[start]) break;\n }\n start = hullPrev[start];\n let e = start, q;\n while(q = hullNext[e], (0,robust_predicates__WEBPACK_IMPORTED_MODULE_0__.orient2d)(x, y, coords[2 * e], coords[2 * e + 1], coords[2 * q], coords[2 * q + 1]) >= 0){\n e = q;\n if (e === start) {\n e = -1;\n break;\n }\n }\n if (e === -1) continue; // likely a near-duplicate point; skip it\n // add the first triangle from the point\n let t = this._addTriangle(e, i, hullNext[e], -1, -1, hullTri[e]);\n // recursively flip triangles from the point until they satisfy the Delaunay condition\n hullTri[i] = this._legalize(t + 2);\n hullTri[e] = t; // keep track of boundary triangles on the hull\n hullSize++;\n // walk forward through the hull, adding more triangles and flipping recursively\n let n = hullNext[e];\n while(q = hullNext[n], (0,robust_predicates__WEBPACK_IMPORTED_MODULE_0__.orient2d)(x, y, coords[2 * n], coords[2 * n + 1], coords[2 * q], coords[2 * q + 1]) < 0){\n t = this._addTriangle(n, i, q, hullTri[i], -1, hullTri[n]);\n hullTri[i] = this._legalize(t + 2);\n hullNext[n] = n; // mark as removed\n hullSize--;\n n = q;\n }\n // walk backward from the other side, adding more triangles and flipping\n if (e === start) {\n while(q = hullPrev[e], (0,robust_predicates__WEBPACK_IMPORTED_MODULE_0__.orient2d)(x, y, coords[2 * q], coords[2 * q + 1], coords[2 * e], coords[2 * e + 1]) < 0){\n t = this._addTriangle(q, i, e, -1, hullTri[e], hullTri[q]);\n this._legalize(t + 2);\n hullTri[q] = t;\n hullNext[e] = e; // mark as removed\n hullSize--;\n e = q;\n }\n }\n // update the hull indices\n this._hullStart = hullPrev[i] = e;\n hullNext[e] = hullPrev[n] = i;\n hullNext[i] = n;\n // save the two new edges in the hash table\n hullHash[this._hashKey(x, y)] = i;\n hullHash[this._hashKey(coords[2 * e], coords[2 * e + 1])] = e;\n }\n this.hull = new Uint32Array(hullSize);\n for(let i = 0, e = this._hullStart; i < hullSize; i++){\n this.hull[i] = e;\n e = hullNext[e];\n }\n // trim typed triangle mesh arrays\n this.triangles = this._triangles.subarray(0, this.trianglesLen);\n this.halfedges = this._halfedges.subarray(0, this.trianglesLen);\n }\n _hashKey(x, y) {\n return Math.floor(pseudoAngle(x - this._cx, y - this._cy) * this._hashSize) % this._hashSize;\n }\n _legalize(a) {\n const { _triangles: triangles, _halfedges: halfedges, coords } = this;\n let i = 0;\n let ar = 0;\n // recursion eliminated with a fixed-size stack\n while(true){\n const b = halfedges[a];\n /* if the pair of triangles doesn't satisfy the Delaunay condition\n * (p1 is inside the circumcircle of [p0, pl, pr]), flip them,\n * then do the same check/flip recursively for the new pair of triangles\n *\n * pl pl\n * /||\\ / \\\n * al/ || \\bl al/ \\a\n * / || \\ / \\\n * / a||b \\ flip /___ar___\\\n * p0\\ || /p1 => p0\\---bl---/p1\n * \\ || / \\ /\n * ar\\ || /br b\\ /br\n * \\||/ \\ /\n * pr pr\n */ const a0 = a - a % 3;\n ar = a0 + (a + 2) % 3;\n if (b === -1) {\n if (i === 0) break;\n a = EDGE_STACK[--i];\n continue;\n }\n const b0 = b - b % 3;\n const al = a0 + (a + 1) % 3;\n const bl = b0 + (b + 2) % 3;\n const p0 = triangles[ar];\n const pr = triangles[a];\n const pl = triangles[al];\n const p1 = triangles[bl];\n const illegal = inCircle(coords[2 * p0], coords[2 * p0 + 1], coords[2 * pr], coords[2 * pr + 1], coords[2 * pl], coords[2 * pl + 1], coords[2 * p1], coords[2 * p1 + 1]);\n if (illegal) {\n triangles[a] = p1;\n triangles[b] = p0;\n const hbl = halfedges[bl];\n // edge swapped on the other side of the hull (rare); fix the halfedge reference\n if (hbl === -1) {\n let e = this._hullStart;\n do {\n if (this._hullTri[e] === bl) {\n this._hullTri[e] = a;\n break;\n }\n e = this._hullPrev[e];\n }while (e !== this._hullStart);\n }\n this._link(a, hbl);\n this._link(b, halfedges[ar]);\n this._link(ar, bl);\n const br = b0 + (b + 1) % 3;\n // don't worry about hitting the cap: it can only happen on extremely degenerate input\n if (i < EDGE_STACK.length) {\n EDGE_STACK[i++] = br;\n }\n } else {\n if (i === 0) break;\n a = EDGE_STACK[--i];\n }\n }\n return ar;\n }\n _link(a, b) {\n this._halfedges[a] = b;\n if (b !== -1) this._halfedges[b] = a;\n }\n // add a new triangle given vertex indices and adjacent half-edge ids\n _addTriangle(i0, i1, i2, a, b, c) {\n const t = this.trianglesLen;\n this._triangles[t] = i0;\n this._triangles[t + 1] = i1;\n this._triangles[t + 2] = i2;\n this._link(t, a);\n this._link(t + 1, b);\n this._link(t + 2, c);\n this.trianglesLen += 3;\n return t;\n }\n}\n// monotonically increases with real angle, but doesn't need expensive trigonometry\nfunction pseudoAngle(dx, dy) {\n const p = dx / (Math.abs(dx) + Math.abs(dy));\n return (dy > 0 ? 3 - p : 1 + p) / 4; // [0..1]\n}\nfunction dist(ax, ay, bx, by) {\n const dx = ax - bx;\n const dy = ay - by;\n return dx * dx + dy * dy;\n}\nfunction inCircle(ax, ay, bx, by, cx, cy, px, py) {\n const dx = ax - px;\n const dy = ay - py;\n const ex = bx - px;\n const ey = by - py;\n const fx = cx - px;\n const fy = cy - py;\n const ap = dx * dx + dy * dy;\n const bp = ex * ex + ey * ey;\n const cp = fx * fx + fy * fy;\n return dx * (ey * cp - bp * fy) - dy * (ex * cp - bp * fx) + ap * (ex * fy - ey * fx) < 0;\n}\nfunction circumradius(ax, ay, bx, by, cx, cy) {\n const dx = bx - ax;\n const dy = by - ay;\n const ex = cx - ax;\n const ey = cy - ay;\n const bl = dx * dx + dy * dy;\n const cl = ex * ex + ey * ey;\n const d = 0.5 / (dx * ey - dy * ex);\n const x = (ey * bl - dy * cl) * d;\n const y = (dx * cl - ex * bl) * d;\n return x * x + y * y;\n}\nfunction circumcenter(ax, ay, bx, by, cx, cy) {\n const dx = bx - ax;\n const dy = by - ay;\n const ex = cx - ax;\n const ey = cy - ay;\n const bl = dx * dx + dy * dy;\n const cl = ex * ex + ey * ey;\n const d = 0.5 / (dx * ey - dy * ex);\n const x = ax + (ey * bl - dy * cl) * d;\n const y = ay + (dx * cl - ex * bl) * d;\n return {\n x,\n y\n };\n}\nfunction quicksort(ids, dists, left, right) {\n if (right - left <= 20) {\n for(let i = left + 1; i <= right; i++){\n const temp = ids[i];\n const tempDist = dists[temp];\n let j = i - 1;\n while(j >= left && dists[ids[j]] > tempDist)ids[j + 1] = ids[j--];\n ids[j + 1] = temp;\n }\n } else {\n const median = left + right >> 1;\n let i = left + 1;\n let j = right;\n swap(ids, median, i);\n if (dists[ids[left]] > dists[ids[right]]) swap(ids, left, right);\n if (dists[ids[i]] > dists[ids[right]]) swap(ids, i, right);\n if (dists[ids[left]] > dists[ids[i]]) swap(ids, left, i);\n const temp = ids[i];\n const tempDist = dists[temp];\n while(true){\n do i++;\n while (dists[ids[i]] < tempDist);\n do j--;\n while (dists[ids[j]] > tempDist);\n if (j < i) break;\n swap(ids, i, j);\n }\n ids[left + 1] = ids[j];\n ids[j] = temp;\n if (right - i + 1 >= j - left) {\n quicksort(ids, dists, i, right);\n quicksort(ids, dists, left, j - 1);\n } else {\n quicksort(ids, dists, left, j - 1);\n quicksort(ids, dists, i, right);\n }\n }\n}\nfunction swap(arr, i, j) {\n const tmp = arr[i];\n arr[i] = arr[j];\n arr[j] = tmp;\n}\nfunction defaultGetX(p) {\n return p[0];\n}\nfunction defaultGetY(p) {\n return p[1];\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"(ssr)/./node_modules/delaunator/index.js","mappings":"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","sources":["webpack://nextchat/./node_modules/delaunator/index.js?3c85"],"sourcesContent":["\nconst EPSILON = Math.pow(2, -52);\nconst EDGE_STACK = new Uint32Array(512);\n\nimport {orient2d} from 'robust-predicates';\n\nexport default class Delaunator {\n\n    static from(points, getX = defaultGetX, getY = defaultGetY) {\n        const n = points.length;\n        const coords = new Float64Array(n * 2);\n\n        for (let i = 0; i < n; i++) {\n            const p = points[i];\n            coords[2 * i] = getX(p);\n            coords[2 * i + 1] = getY(p);\n        }\n\n        return new Delaunator(coords);\n    }\n\n    constructor(coords) {\n        const n = coords.length >> 1;\n        if (n > 0 && typeof coords[0] !== 'number') throw new Error('Expected coords to contain numbers.');\n\n        this.coords = coords;\n\n        // arrays that will store the triangulation graph\n        const maxTriangles = Math.max(2 * n - 5, 0);\n        this._triangles = new Uint32Array(maxTriangles * 3);\n        this._halfedges = new Int32Array(maxTriangles * 3);\n\n        // temporary arrays for tracking the edges of the advancing convex hull\n        this._hashSize = Math.ceil(Math.sqrt(n));\n        this._hullPrev = new Uint32Array(n); // edge to prev edge\n        this._hullNext = new Uint32Array(n); // edge to next edge\n        this._hullTri = new Uint32Array(n); // edge to adjacent triangle\n        this._hullHash = new Int32Array(this._hashSize).fill(-1); // angular edge hash\n\n        // temporary arrays for sorting points\n        this._ids = new Uint32Array(n);\n        this._dists = new Float64Array(n);\n\n        this.update();\n    }\n\n    update() {\n        const {coords, _hullPrev: hullPrev, _hullNext: hullNext, _hullTri: hullTri, _hullHash: hullHash} =  this;\n        const n = coords.length >> 1;\n\n        // populate an array of point indices; calculate input data bbox\n        let minX = Infinity;\n        let minY = Infinity;\n        let maxX = -Infinity;\n        let maxY = -Infinity;\n\n        for (let i = 0; i < n; i++) {\n            const x = coords[2 * i];\n            const y = coords[2 * i + 1];\n            if (x < minX) minX = x;\n            if (y < minY) minY = y;\n            if (x > maxX) maxX = x;\n            if (y > maxY) maxY = y;\n            this._ids[i] = i;\n        }\n        const cx = (minX + maxX) / 2;\n        const cy = (minY + maxY) / 2;\n\n        let minDist = Infinity;\n        let i0, i1, i2;\n\n        // pick a seed point close to the center\n        for (let i = 0; i < n; i++) {\n            const d = dist(cx, cy, coords[2 * i], coords[2 * i + 1]);\n            if (d < minDist) {\n                i0 = i;\n                minDist = d;\n            }\n        }\n        const i0x = coords[2 * i0];\n        const i0y = coords[2 * i0 + 1];\n\n        minDist = Infinity;\n\n        // find the point closest to the seed\n        for (let i = 0; i < n; i++) {\n            if (i === i0) continue;\n            const d = dist(i0x, i0y, coords[2 * i], coords[2 * i + 1]);\n            if (d < minDist && d > 0) {\n                i1 = i;\n                minDist = d;\n            }\n        }\n        let i1x = coords[2 * i1];\n        let i1y = coords[2 * i1 + 1];\n\n        let minRadius = Infinity;\n\n        // find the third point which forms the smallest circumcircle with the first two\n        for (let i = 0; i < n; i++) {\n            if (i === i0 || i === i1) continue;\n            const r = circumradius(i0x, i0y, i1x, i1y, coords[2 * i], coords[2 * i + 1]);\n            if (r < minRadius) {\n                i2 = i;\n                minRadius = r;\n            }\n        }\n        let i2x = coords[2 * i2];\n        let i2y = coords[2 * i2 + 1];\n\n        if (minRadius === Infinity) {\n            // order collinear points by dx (or dy if all x are identical)\n            // and return the list as a hull\n            for (let i = 0; i < n; i++) {\n                this._dists[i] = (coords[2 * i] - coords[0]) || (coords[2 * i + 1] - coords[1]);\n            }\n            quicksort(this._ids, this._dists, 0, n - 1);\n            const hull = new Uint32Array(n);\n            let j = 0;\n            for (let i = 0, d0 = -Infinity; i < n; i++) {\n                const id = this._ids[i];\n                if (this._dists[id] > d0) {\n                    hull[j++] = id;\n                    d0 = this._dists[id];\n                }\n            }\n            this.hull = hull.subarray(0, j);\n            this.triangles = new Uint32Array(0);\n            this.halfedges = new Uint32Array(0);\n            return;\n        }\n\n        // swap the order of the seed points for counter-clockwise orientation\n        if (orient2d(i0x, i0y, i1x, i1y, i2x, i2y) < 0) {\n            const i = i1;\n            const x = i1x;\n            const y = i1y;\n            i1 = i2;\n            i1x = i2x;\n            i1y = i2y;\n            i2 = i;\n            i2x = x;\n            i2y = y;\n        }\n\n        const center = circumcenter(i0x, i0y, i1x, i1y, i2x, i2y);\n        this._cx = center.x;\n        this._cy = center.y;\n\n        for (let i = 0; i < n; i++) {\n            this._dists[i] = dist(coords[2 * i], coords[2 * i + 1], center.x, center.y);\n        }\n\n        // sort the points by distance from the seed triangle circumcenter\n        quicksort(this._ids, this._dists, 0, n - 1);\n\n        // set up the seed triangle as the starting hull\n        this._hullStart = i0;\n        let hullSize = 3;\n\n        hullNext[i0] = hullPrev[i2] = i1;\n        hullNext[i1] = hullPrev[i0] = i2;\n        hullNext[i2] = hullPrev[i1] = i0;\n\n        hullTri[i0] = 0;\n        hullTri[i1] = 1;\n        hullTri[i2] = 2;\n\n        hullHash.fill(-1);\n        hullHash[this._hashKey(i0x, i0y)] = i0;\n        hullHash[this._hashKey(i1x, i1y)] = i1;\n        hullHash[this._hashKey(i2x, i2y)] = i2;\n\n        this.trianglesLen = 0;\n        this._addTriangle(i0, i1, i2, -1, -1, -1);\n\n        for (let k = 0, xp, yp; k < this._ids.length; k++) {\n            const i = this._ids[k];\n            const x = coords[2 * i];\n            const y = coords[2 * i + 1];\n\n            // skip near-duplicate points\n            if (k > 0 && Math.abs(x - xp) <= EPSILON && Math.abs(y - yp) <= EPSILON) continue;\n            xp = x;\n            yp = y;\n\n            // skip seed triangle points\n            if (i === i0 || i === i1 || i === i2) continue;\n\n            // find a visible edge on the convex hull using edge hash\n            let start = 0;\n            for (let j = 0, key = this._hashKey(x, y); j < this._hashSize; j++) {\n                start = hullHash[(key + j) % this._hashSize];\n                if (start !== -1 && start !== hullNext[start]) break;\n            }\n\n            start = hullPrev[start];\n            let e = start, q;\n            while (q = hullNext[e], orient2d(x, y, coords[2 * e], coords[2 * e + 1], coords[2 * q], coords[2 * q + 1]) >= 0) {\n                e = q;\n                if (e === start) {\n                    e = -1;\n                    break;\n                }\n            }\n            if (e === -1) continue; // likely a near-duplicate point; skip it\n\n            // add the first triangle from the point\n            let t = this._addTriangle(e, i, hullNext[e], -1, -1, hullTri[e]);\n\n            // recursively flip triangles from the point until they satisfy the Delaunay condition\n            hullTri[i] = this._legalize(t + 2);\n            hullTri[e] = t; // keep track of boundary triangles on the hull\n            hullSize++;\n\n            // walk forward through the hull, adding more triangles and flipping recursively\n            let n = hullNext[e];\n            while (q = hullNext[n], orient2d(x, y, coords[2 * n], coords[2 * n + 1], coords[2 * q], coords[2 * q + 1]) < 0) {\n                t = this._addTriangle(n, i, q, hullTri[i], -1, hullTri[n]);\n                hullTri[i] = this._legalize(t + 2);\n                hullNext[n] = n; // mark as removed\n                hullSize--;\n                n = q;\n            }\n\n            // walk backward from the other side, adding more triangles and flipping\n            if (e === start) {\n                while (q = hullPrev[e], orient2d(x, y, coords[2 * q], coords[2 * q + 1], coords[2 * e], coords[2 * e + 1]) < 0) {\n                    t = this._addTriangle(q, i, e, -1, hullTri[e], hullTri[q]);\n                    this._legalize(t + 2);\n                    hullTri[q] = t;\n                    hullNext[e] = e; // mark as removed\n                    hullSize--;\n                    e = q;\n                }\n            }\n\n            // update the hull indices\n            this._hullStart = hullPrev[i] = e;\n            hullNext[e] = hullPrev[n] = i;\n            hullNext[i] = n;\n\n            // save the two new edges in the hash table\n            hullHash[this._hashKey(x, y)] = i;\n            hullHash[this._hashKey(coords[2 * e], coords[2 * e + 1])] = e;\n        }\n\n        this.hull = new Uint32Array(hullSize);\n        for (let i = 0, e = this._hullStart; i < hullSize; i++) {\n            this.hull[i] = e;\n            e = hullNext[e];\n        }\n\n        // trim typed triangle mesh arrays\n        this.triangles = this._triangles.subarray(0, this.trianglesLen);\n        this.halfedges = this._halfedges.subarray(0, this.trianglesLen);\n    }\n\n    _hashKey(x, y) {\n        return Math.floor(pseudoAngle(x - this._cx, y - this._cy) * this._hashSize) % this._hashSize;\n    }\n\n    _legalize(a) {\n        const {_triangles: triangles, _halfedges: halfedges, coords} = this;\n\n        let i = 0;\n        let ar = 0;\n\n        // recursion eliminated with a fixed-size stack\n        while (true) {\n            const b = halfedges[a];\n\n            /* if the pair of triangles doesn't satisfy the Delaunay condition\n             * (p1 is inside the circumcircle of [p0, pl, pr]), flip them,\n             * then do the same check/flip recursively for the new pair of triangles\n             *\n             *           pl                    pl\n             *          /||\\                  /  \\\n             *       al/ || \\bl            al/    \\a\n             *        /  ||  \\              /      \\\n             *       /  a||b  \\    flip    /___ar___\\\n             *     p0\\   ||   /p1   =>   p0\\---bl---/p1\n             *        \\  ||  /              \\      /\n             *       ar\\ || /br             b\\    /br\n             *          \\||/                  \\  /\n             *           pr                    pr\n             */\n            const a0 = a - a % 3;\n            ar = a0 + (a + 2) % 3;\n\n            if (b === -1) { // convex hull edge\n                if (i === 0) break;\n                a = EDGE_STACK[--i];\n                continue;\n            }\n\n            const b0 = b - b % 3;\n            const al = a0 + (a + 1) % 3;\n            const bl = b0 + (b + 2) % 3;\n\n            const p0 = triangles[ar];\n            const pr = triangles[a];\n            const pl = triangles[al];\n            const p1 = triangles[bl];\n\n            const illegal = inCircle(\n                coords[2 * p0], coords[2 * p0 + 1],\n                coords[2 * pr], coords[2 * pr + 1],\n                coords[2 * pl], coords[2 * pl + 1],\n                coords[2 * p1], coords[2 * p1 + 1]);\n\n            if (illegal) {\n                triangles[a] = p1;\n                triangles[b] = p0;\n\n                const hbl = halfedges[bl];\n\n                // edge swapped on the other side of the hull (rare); fix the halfedge reference\n                if (hbl === -1) {\n                    let e = this._hullStart;\n                    do {\n                        if (this._hullTri[e] === bl) {\n                            this._hullTri[e] = a;\n                            break;\n                        }\n                        e = this._hullPrev[e];\n                    } while (e !== this._hullStart);\n                }\n                this._link(a, hbl);\n                this._link(b, halfedges[ar]);\n                this._link(ar, bl);\n\n                const br = b0 + (b + 1) % 3;\n\n                // don't worry about hitting the cap: it can only happen on extremely degenerate input\n                if (i < EDGE_STACK.length) {\n                    EDGE_STACK[i++] = br;\n                }\n            } else {\n                if (i === 0) break;\n                a = EDGE_STACK[--i];\n            }\n        }\n\n        return ar;\n    }\n\n    _link(a, b) {\n        this._halfedges[a] = b;\n        if (b !== -1) this._halfedges[b] = a;\n    }\n\n    // add a new triangle given vertex indices and adjacent half-edge ids\n    _addTriangle(i0, i1, i2, a, b, c) {\n        const t = this.trianglesLen;\n\n        this._triangles[t] = i0;\n        this._triangles[t + 1] = i1;\n        this._triangles[t + 2] = i2;\n\n        this._link(t, a);\n        this._link(t + 1, b);\n        this._link(t + 2, c);\n\n        this.trianglesLen += 3;\n\n        return t;\n    }\n}\n\n// monotonically increases with real angle, but doesn't need expensive trigonometry\nfunction pseudoAngle(dx, dy) {\n    const p = dx / (Math.abs(dx) + Math.abs(dy));\n    return (dy > 0 ? 3 - p : 1 + p) / 4; // [0..1]\n}\n\nfunction dist(ax, ay, bx, by) {\n    const dx = ax - bx;\n    const dy = ay - by;\n    return dx * dx + dy * dy;\n}\n\nfunction inCircle(ax, ay, bx, by, cx, cy, px, py) {\n    const dx = ax - px;\n    const dy = ay - py;\n    const ex = bx - px;\n    const ey = by - py;\n    const fx = cx - px;\n    const fy = cy - py;\n\n    const ap = dx * dx + dy * dy;\n    const bp = ex * ex + ey * ey;\n    const cp = fx * fx + fy * fy;\n\n    return dx * (ey * cp - bp * fy) -\n           dy * (ex * cp - bp * fx) +\n           ap * (ex * fy - ey * fx) < 0;\n}\n\nfunction circumradius(ax, ay, bx, by, cx, cy) {\n    const dx = bx - ax;\n    const dy = by - ay;\n    const ex = cx - ax;\n    const ey = cy - ay;\n\n    const bl = dx * dx + dy * dy;\n    const cl = ex * ex + ey * ey;\n    const d = 0.5 / (dx * ey - dy * ex);\n\n    const x = (ey * bl - dy * cl) * d;\n    const y = (dx * cl - ex * bl) * d;\n\n    return x * x + y * y;\n}\n\nfunction circumcenter(ax, ay, bx, by, cx, cy) {\n    const dx = bx - ax;\n    const dy = by - ay;\n    const ex = cx - ax;\n    const ey = cy - ay;\n\n    const bl = dx * dx + dy * dy;\n    const cl = ex * ex + ey * ey;\n    const d = 0.5 / (dx * ey - dy * ex);\n\n    const x = ax + (ey * bl - dy * cl) * d;\n    const y = ay + (dx * cl - ex * bl) * d;\n\n    return {x, y};\n}\n\nfunction quicksort(ids, dists, left, right) {\n    if (right - left <= 20) {\n        for (let i = left + 1; i <= right; i++) {\n            const temp = ids[i];\n            const tempDist = dists[temp];\n            let j = i - 1;\n            while (j >= left && dists[ids[j]] > tempDist) ids[j + 1] = ids[j--];\n            ids[j + 1] = temp;\n        }\n    } else {\n        const median = (left + right) >> 1;\n        let i = left + 1;\n        let j = right;\n        swap(ids, median, i);\n        if (dists[ids[left]] > dists[ids[right]]) swap(ids, left, right);\n        if (dists[ids[i]] > dists[ids[right]]) swap(ids, i, right);\n        if (dists[ids[left]] > dists[ids[i]]) swap(ids, left, i);\n\n        const temp = ids[i];\n        const tempDist = dists[temp];\n        while (true) {\n            do i++; while (dists[ids[i]] < tempDist);\n            do j--; while (dists[ids[j]] > tempDist);\n            if (j < i) break;\n            swap(ids, i, j);\n        }\n        ids[left + 1] = ids[j];\n        ids[j] = temp;\n\n        if (right - i + 1 >= j - left) {\n            quicksort(ids, dists, i, right);\n            quicksort(ids, dists, left, j - 1);\n        } else {\n            quicksort(ids, dists, left, j - 1);\n            quicksort(ids, dists, i, right);\n        }\n    }\n}\n\nfunction swap(arr, i, j) {\n    const tmp = arr[i];\n    arr[i] = arr[j];\n    arr[j] = tmp;\n}\n\nfunction defaultGetX(p) {\n    return p[0];\n}\nfunction defaultGetY(p) {\n    return p[1];\n}\n"],"names":["EPSILON","Math","pow","EDGE_STACK","Uint32Array","orient2d","Delaunator","from","points","getX","defaultGetX","getY","defaultGetY","n","length","coords","Float64Array","i","p","constructor","Error","maxTriangles","max","_triangles","_halfedges","Int32Array","_hashSize","ceil","sqrt","_hullPrev","_hullNext","_hullTri","_hullHash","fill","_ids","_dists","update","hullPrev","hullNext","hullTri","hullHash","minX","Infinity","minY","maxX","maxY","x","y","cx","cy","minDist","i0","i1","i2","d","dist","i0x","i0y","i1x","i1y","minRadius","r","circumradius","i2x","i2y","quicksort","hull","j","d0","id","subarray","triangles","halfedges","center","circumcenter","_cx","_cy","_hullStart","hullSize","_hashKey","trianglesLen","_addTriangle","k","xp","yp","abs","start","key","e","q","t","_legalize","floor","pseudoAngle","a","ar","b","a0","b0","al","bl","p0","pr","pl","p1","illegal","inCircle","hbl","_link","br","c","dx","dy","ax","ay","bx","by","px","py","ex","ey","fx","fy","ap","bp","cp","cl","ids","dists","left","right","temp","tempDist","median","swap","arr","tmp"],"sourceRoot":""}\n//# sourceURL=webpack-internal:///(ssr)/./node_modules/delaunator/index.js\n");
|
|
|
|
/***/ })
|
|
|
|
};
|
|
; |