diff --git a/package-lock.json b/package-lock.json index a5772442..07b8395d 100644 --- a/package-lock.json +++ b/package-lock.json @@ -15,7 +15,7 @@ "@kitware/vtk.js": "^29.0.0", "@netlify/edge-functions": "^2.0.0", "@sentry/vue": "^7.54.0", - "@velipso/polybool": "^1.1.0", + "@velipso/polybool": "^2.0.11", "@vueuse/core": "^10.7.0", "core-js": "3.22.5", "deep-equal": "^2.0.5", @@ -5722,9 +5722,10 @@ } }, "node_modules/@velipso/polybool": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@velipso/polybool/-/polybool-1.1.0.tgz", - "integrity": "sha512-cnuAP1HtJ0I8sFgeuYHUQsalc8FAdPaKa3UQzyGeK4lSNDpPDg1AHggfAsh1CkGKvD6c8ezRhiAgjQ0xbpZsiw==", + "version": "2.0.11", + "resolved": "https://registry.npmjs.org/@velipso/polybool/-/polybool-2.0.11.tgz", + "integrity": "sha512-NT/1UOeNumugXhLBChGNnnFqYQ/CqyC/OpkwpSj+pGjEYak1OMm4mA4vsPpzm23NRwuUIbtr9kJRwEDL7VnrNA==", + "license": "0BSD", "dependencies": { "tslib": "^2.6.2" } @@ -27778,9 +27779,9 @@ } }, "@velipso/polybool": { - "version": "1.1.0", - "resolved": "https://registry.npmjs.org/@velipso/polybool/-/polybool-1.1.0.tgz", - "integrity": "sha512-cnuAP1HtJ0I8sFgeuYHUQsalc8FAdPaKa3UQzyGeK4lSNDpPDg1AHggfAsh1CkGKvD6c8ezRhiAgjQ0xbpZsiw==", + "version": "2.0.11", + "resolved": "https://registry.npmjs.org/@velipso/polybool/-/polybool-2.0.11.tgz", + "integrity": "sha512-NT/1UOeNumugXhLBChGNnnFqYQ/CqyC/OpkwpSj+pGjEYak1OMm4mA4vsPpzm23NRwuUIbtr9kJRwEDL7VnrNA==", "requires": { "tslib": "^2.6.2" } diff --git a/package.json b/package.json index 597e1df4..e4b63873 100644 --- a/package.json +++ b/package.json @@ -31,7 +31,7 @@ "@kitware/vtk.js": "^29.0.0", "@netlify/edge-functions": "^2.0.0", "@sentry/vue": "^7.54.0", - "@velipso/polybool": "^1.1.0", + "@velipso/polybool": "^2.0.11", "@vueuse/core": "^10.7.0", "core-js": "3.22.5", "deep-equal": "^2.0.5", diff --git a/patches/@velipso+polybool+1.1.0.patch b/patches/@velipso+polybool+1.1.0.patch deleted file mode 100644 index 2e256957..00000000 --- a/patches/@velipso+polybool+1.1.0.patch +++ /dev/null @@ -1,12 +0,0 @@ -diff --git a/node_modules/@velipso/polybool/package.json b/node_modules/@velipso/polybool/package.json -index c0bf880..00899ce 100644 ---- a/node_modules/@velipso/polybool/package.json -+++ b/node_modules/@velipso/polybool/package.json -@@ -11,6 +11,7 @@ - "require": "./dist/polybool.cjs.js" - } - }, -+ "types": "dist/polybool.d.ts", - "scripts": { - "test": "tsx src/polybool.test.ts", - "build": "rollup -c && rollup -c rollup.config.cjs.js", diff --git a/src/store/tools/polygons.ts b/src/store/tools/polygons.ts index ea3e89e8..66300a4d 100644 --- a/src/store/tools/polygons.ts +++ b/src/store/tools/polygons.ts @@ -1,4 +1,4 @@ -import polybool, { Polygon as LibPolygon } from '@velipso/polybool'; +import polybool, { Polygon as LibPolygon, Vec2, Vec6 } from '@velipso/polybool'; import type { Vector3, Vector2 } from '@kitware/vtk.js/types'; import { computed } from 'vue'; import { @@ -19,6 +19,17 @@ const toolDefaults = () => ({ name: 'Polygon', }); +const ensureVec2 = (regions: (Vec2 | Vec6)[][]) => { + const remapToVec2Needed = + regions.length > 0 && regions[0].length > 0 && regions[0][0].length === 6; + return !remapToVec2Needed + ? (regions as Vec2[][]) + : regions.map((region) => { + // ensure Vec2 points, and not Vec6 for bezier control points + return region.map((point) => [point[4], point[5]] as Vec2); + }); +}; + export const usePolygonStore = defineAnnotationToolStore('polygon', () => { const toolAPI = useAnnotationTool({ toolDefaults, @@ -53,7 +64,7 @@ export const usePolygonStore = defineAnnotationToolStore('polygon', () => { // After union, regions will have shared points because we require overlap to union. // Create one region/ring by splicing in the next region at the common point. - const mergeRegions = (regions: Array>) => { + const mergeRegions = (regions: Vector2[][]) => { const [mergedRegion, ...candidates] = regions; while (candidates.length > 0) { @@ -96,12 +107,13 @@ export const usePolygonStore = defineAnnotationToolStore('polygon', () => { const comb = polybool.combine(segments, seg2); segments = polybool.selectUnion(comb); } - const unionPoly = polybool.polygon(segments); + + const unionPolyRegions = polybool.polygon(segments).regions; + const singleRegion = mergeRegions(ensureVec2(unionPolyRegions)); const firstTool = polygons[0]; const { to3D } = getPlaneTransforms(firstTool.frameOfReference); - - const points = mergeRegions(unionPoly.regions).map(to3D); + const points = singleRegion.map(to3D); // eslint-disable-next-line @typescript-eslint/no-unused-vars const { id: _, ...toolProps } = polygons[0];