@cornerstonejs/tools 1.57.1 → 1.58.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/drawingSvg/drawPath.js +1 -1
- package/dist/cjs/drawingSvg/drawPath.js.map +1 -1
- package/dist/cjs/enums/WorkerTypes.d.ts +1 -1
- package/dist/cjs/enums/WorkerTypes.js +1 -1
- package/dist/cjs/enums/WorkerTypes.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.d.ts +17 -0
- package/dist/cjs/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js +112 -0
- package/dist/cjs/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js.map +1 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts +3 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js +4 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.d.ts +8 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js +121 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js.map +1 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.d.ts +3 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js +73 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js.map +1 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.d.ts +3 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js +25 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js.map +1 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.d.ts +1 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js +41 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js.map +1 -0
- package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js +2 -2
- package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js +1 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js +1 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js +1 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js +1 -1
- package/dist/cjs/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js.map +1 -1
- package/dist/cjs/stateManagement/segmentation/triggerSegmentationEvents.js +2 -0
- package/dist/cjs/stateManagement/segmentation/triggerSegmentationEvents.js.map +1 -1
- package/dist/cjs/store/ToolGroupManager/getToolGroupForViewport.d.ts +1 -1
- package/dist/cjs/store/ToolGroupManager/getToolGroupForViewport.js +5 -0
- package/dist/cjs/store/ToolGroupManager/getToolGroupForViewport.js.map +1 -1
- package/dist/cjs/tools/annotation/SplineROITool.js +25 -20
- package/dist/cjs/tools/annotation/SplineROITool.js.map +1 -1
- package/dist/cjs/tools/base/BaseTool.js +3 -0
- package/dist/cjs/tools/base/BaseTool.js.map +1 -1
- package/dist/cjs/tools/base/ContourSegmentationBaseTool.js.map +1 -1
- package/dist/cjs/tools/displayTools/Contour/contourDisplay.js +13 -5
- package/dist/cjs/tools/displayTools/Contour/contourDisplay.js.map +1 -1
- package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js +1 -1
- package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
- package/dist/cjs/tools/displayTools/SegmentationDisplayTool.d.ts +1 -0
- package/dist/cjs/tools/displayTools/SegmentationDisplayTool.js +17 -0
- package/dist/cjs/tools/displayTools/SegmentationDisplayTool.js.map +1 -1
- package/dist/cjs/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js +4 -47
- package/dist/cjs/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js.map +1 -1
- package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.d.ts +3 -9
- package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.js +7 -148
- package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.js.map +1 -1
- package/dist/cjs/types/PolySeg.d.ts +1 -1
- package/dist/cjs/utilities/contourSegmentation/addContourSegmentationAnnotation.js +4 -1
- package/dist/cjs/utilities/contourSegmentation/addContourSegmentationAnnotation.js.map +1 -1
- package/dist/cjs/utilities/contourSegmentation/removeContourSegmentationAnnotation.js +3 -0
- package/dist/cjs/utilities/contourSegmentation/removeContourSegmentationAnnotation.js.map +1 -1
- package/dist/cjs/utilities/math/polyline/getAABB.d.ts +3 -1
- package/dist/cjs/utilities/math/polyline/getAABB.js +30 -4
- package/dist/cjs/utilities/math/polyline/getAABB.js.map +1 -1
- package/dist/cjs/utilities/planar/index.d.ts +3 -1
- package/dist/cjs/utilities/planar/index.js +4 -1
- package/dist/cjs/utilities/planar/index.js.map +1 -1
- package/dist/cjs/utilities/planar/isPlaneIntersectingAABB.d.ts +1 -0
- package/dist/cjs/utilities/planar/isPlaneIntersectingAABB.js +32 -0
- package/dist/cjs/utilities/planar/isPlaneIntersectingAABB.js.map +1 -0
- package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.d.ts +3 -1
- package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.js +97 -47
- package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.js.map +1 -1
- package/dist/cjs/workers/polySegConverters.js +73 -0
- package/dist/cjs/workers/polySegConverters.js.map +1 -1
- package/dist/esm/drawingSvg/drawPath.js +1 -1
- package/dist/esm/drawingSvg/drawPath.js.map +1 -1
- package/dist/esm/enums/WorkerTypes.js +1 -1
- package/dist/esm/enums/WorkerTypes.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js +91 -0
- package/dist/esm/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js.map +1 -0
- package/dist/esm/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js +4 -1
- package/dist/esm/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js +105 -0
- package/dist/esm/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js.map +1 -0
- package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js +72 -0
- package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js.map +1 -0
- package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js +21 -0
- package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js.map +1 -0
- package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js +26 -0
- package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js.map +1 -0
- package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js +2 -2
- package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js +1 -1
- package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js +1 -1
- package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js +1 -1
- package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js +1 -1
- package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js +1 -1
- package/dist/esm/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js.map +1 -1
- package/dist/esm/stateManagement/segmentation/triggerSegmentationEvents.js +2 -0
- package/dist/esm/stateManagement/segmentation/triggerSegmentationEvents.js.map +1 -1
- package/dist/esm/store/ToolGroupManager/getToolGroupForViewport.js +4 -0
- package/dist/esm/store/ToolGroupManager/getToolGroupForViewport.js.map +1 -1
- package/dist/esm/tools/annotation/SplineROITool.js +25 -20
- package/dist/esm/tools/annotation/SplineROITool.js.map +1 -1
- package/dist/esm/tools/base/BaseTool.js +3 -0
- package/dist/esm/tools/base/BaseTool.js.map +1 -1
- package/dist/esm/tools/base/ContourSegmentationBaseTool.js.map +1 -1
- package/dist/esm/tools/displayTools/Contour/contourDisplay.js +13 -5
- package/dist/esm/tools/displayTools/Contour/contourDisplay.js.map +1 -1
- package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js +1 -1
- package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
- package/dist/esm/tools/displayTools/SegmentationDisplayTool.js +17 -0
- package/dist/esm/tools/displayTools/SegmentationDisplayTool.js.map +1 -1
- package/dist/esm/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js +3 -46
- package/dist/esm/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js.map +1 -1
- package/dist/esm/tools/displayTools/Surface/surfaceDisplay.js +8 -139
- package/dist/esm/tools/displayTools/Surface/surfaceDisplay.js.map +1 -1
- package/dist/esm/utilities/contourSegmentation/addContourSegmentationAnnotation.js +4 -1
- package/dist/esm/utilities/contourSegmentation/addContourSegmentationAnnotation.js.map +1 -1
- package/dist/esm/utilities/contourSegmentation/removeContourSegmentationAnnotation.js +3 -0
- package/dist/esm/utilities/contourSegmentation/removeContourSegmentationAnnotation.js.map +1 -1
- package/dist/esm/utilities/math/polyline/getAABB.js +30 -4
- package/dist/esm/utilities/math/polyline/getAABB.js.map +1 -1
- package/dist/esm/utilities/planar/index.js +3 -1
- package/dist/esm/utilities/planar/index.js.map +1 -1
- package/dist/esm/utilities/planar/isPlaneIntersectingAABB.js +28 -0
- package/dist/esm/utilities/planar/isPlaneIntersectingAABB.js.map +1 -0
- package/dist/esm/utilities/segmentation/getUniqueSegmentIndices.js +92 -44
- package/dist/esm/utilities/segmentation/getUniqueSegmentIndices.js.map +1 -1
- package/dist/esm/workers/polySegConverters.js +74 -1
- package/dist/esm/workers/polySegConverters.js.map +1 -1
- package/dist/types/drawingSvg/drawPath.d.ts.map +1 -1
- package/dist/types/enums/WorkerTypes.d.ts +1 -1
- package/dist/types/enums/WorkerTypes.d.ts.map +1 -1
- package/dist/types/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.d.ts +18 -0
- package/dist/types/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.d.ts.map +1 -0
- package/dist/types/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts +3 -1
- package/dist/types/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts.map +1 -1
- package/dist/types/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.d.ts +9 -0
- package/dist/types/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.d.ts.map +1 -0
- package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.d.ts +4 -0
- package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.d.ts.map +1 -0
- package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.d.ts +4 -0
- package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.d.ts.map +1 -0
- package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.d.ts +2 -0
- package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.d.ts.map +1 -0
- package/dist/types/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.d.ts.map +1 -1
- package/dist/types/stateManagement/segmentation/triggerSegmentationEvents.d.ts.map +1 -1
- package/dist/types/store/ToolGroupManager/getToolGroupForViewport.d.ts +1 -1
- package/dist/types/store/ToolGroupManager/getToolGroupForViewport.d.ts.map +1 -1
- package/dist/types/tools/annotation/SplineROITool.d.ts.map +1 -1
- package/dist/types/tools/base/BaseTool.d.ts.map +1 -1
- package/dist/types/tools/base/ContourSegmentationBaseTool.d.ts.map +1 -1
- package/dist/types/tools/displayTools/Contour/contourDisplay.d.ts.map +1 -1
- package/dist/types/tools/displayTools/SegmentationDisplayTool.d.ts +1 -0
- package/dist/types/tools/displayTools/SegmentationDisplayTool.d.ts.map +1 -1
- package/dist/types/tools/displayTools/Surface/addOrUpdateSurfaceToElement.d.ts.map +1 -1
- package/dist/types/tools/displayTools/Surface/surfaceDisplay.d.ts +3 -9
- package/dist/types/tools/displayTools/Surface/surfaceDisplay.d.ts.map +1 -1
- package/dist/types/types/PolySeg.d.ts +1 -1
- package/dist/types/types/PolySeg.d.ts.map +1 -1
- package/dist/types/utilities/contourSegmentation/addContourSegmentationAnnotation.d.ts.map +1 -1
- package/dist/types/utilities/contourSegmentation/removeContourSegmentationAnnotation.d.ts.map +1 -1
- package/dist/types/utilities/math/polyline/getAABB.d.ts +3 -1
- package/dist/types/utilities/math/polyline/getAABB.d.ts.map +1 -1
- package/dist/types/utilities/planar/index.d.ts +3 -1
- package/dist/types/utilities/planar/index.d.ts.map +1 -1
- package/dist/types/utilities/planar/isPlaneIntersectingAABB.d.ts +2 -0
- package/dist/types/utilities/planar/isPlaneIntersectingAABB.d.ts.map +1 -0
- package/dist/types/utilities/segmentation/getUniqueSegmentIndices.d.ts +3 -1
- package/dist/types/utilities/segmentation/getUniqueSegmentIndices.d.ts.map +1 -1
- package/dist/umd/985.index.js +1 -1
- package/dist/umd/985.index.js.map +1 -1
- package/dist/umd/index.js +1 -1
- package/dist/umd/index.js.map +1 -1
- package/package.json +4 -4
- package/src/drawingSvg/drawPath.ts +3 -1
- package/src/enums/WorkerTypes.ts +1 -1
- package/src/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.ts +203 -0
- package/src/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.ts +9 -2
- package/src/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.ts +201 -0
- package/src/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.ts +103 -0
- package/src/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.ts +38 -0
- package/src/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.ts +58 -0
- package/src/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.ts +2 -2
- package/src/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.ts +1 -1
- package/src/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.ts +3 -8
- package/src/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.ts +1 -1
- package/src/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.ts +1 -1
- package/src/stateManagement/segmentation/polySeg/computeAndAddRepresentation.ts +1 -1
- package/src/stateManagement/segmentation/triggerSegmentationEvents.ts +5 -0
- package/src/store/ToolGroupManager/getToolGroupForViewport.ts +8 -1
- package/src/tools/annotation/SplineROITool.ts +34 -27
- package/src/tools/base/BaseTool.ts +7 -0
- package/src/tools/base/ContourSegmentationBaseTool.ts +5 -0
- package/src/tools/displayTools/Contour/contourDisplay.ts +29 -11
- package/src/tools/displayTools/Labelmap/labelmapDisplay.ts +1 -1
- package/src/tools/displayTools/SegmentationDisplayTool.ts +26 -0
- package/src/tools/displayTools/Surface/addOrUpdateSurfaceToElement.ts +3 -65
- package/src/tools/displayTools/Surface/surfaceDisplay.ts +12 -247
- package/src/types/PolySeg.ts +1 -1
- package/src/utilities/contourSegmentation/addContourSegmentationAnnotation.ts +9 -1
- package/src/utilities/contourSegmentation/removeContourSegmentationAnnotation.ts +4 -0
- package/src/utilities/math/polyline/getAABB.ts +58 -4
- package/src/utilities/planar/index.ts +3 -0
- package/src/utilities/planar/isPlaneIntersectingAABB.ts +56 -0
- package/src/utilities/segmentation/getUniqueSegmentIndices.ts +115 -49
- package/src/workers/polySegConverters.js +117 -1
- package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.d.ts +0 -1
- package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.js +0 -27
- package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.js.map +0 -1
- package/dist/cjs/workers/clippingPlaneWorker.d.ts +0 -1
- package/dist/cjs/workers/clippingPlaneWorker.js +0 -63
- package/dist/cjs/workers/clippingPlaneWorker.js.map +0 -1
- package/dist/esm/tools/displayTools/registerDisplayToolsWorker.js +0 -23
- package/dist/esm/tools/displayTools/registerDisplayToolsWorker.js.map +0 -1
- package/dist/esm/workers/clippingPlaneWorker.js +0 -58
- package/dist/esm/workers/clippingPlaneWorker.js.map +0 -1
- package/dist/types/tools/displayTools/registerDisplayToolsWorker.d.ts +0 -2
- package/dist/types/tools/displayTools/registerDisplayToolsWorker.d.ts.map +0 -1
- package/dist/types/workers/clippingPlaneWorker.d.ts +0 -2
- package/dist/types/workers/clippingPlaneWorker.d.ts.map +0 -1
- package/dist/umd/444.index.js +0 -3
- package/dist/umd/444.index.js.LICENSE.txt +0 -5
- package/dist/umd/444.index.js.map +0 -1
- package/src/tools/displayTools/registerDisplayToolsWorker.ts +0 -34
- package/src/workers/clippingPlaneWorker.js +0 -87
|
@@ -1,59 +1,109 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.getUniqueSegmentIndices = void 0;
|
|
3
|
+
exports.getUniqueSegmentIndices = exports.setSegmentationClean = exports.setSegmentationDirty = void 0;
|
|
4
4
|
const core_1 = require("@cornerstonejs/core");
|
|
5
|
-
const enums_1 = require("../../enums");
|
|
6
5
|
const segmentationState_1 = require("../../stateManagement/segmentation/segmentationState");
|
|
7
6
|
const stackVolumeCheck_1 = require("../../tools/segmentation/strategies/utils/stackVolumeCheck");
|
|
7
|
+
const enums_1 = require("../../enums");
|
|
8
|
+
const segmentIndicesCache = new Map();
|
|
9
|
+
const setSegmentationDirty = (segmentationId) => {
|
|
10
|
+
const cached = segmentIndicesCache.get(segmentationId);
|
|
11
|
+
if (cached) {
|
|
12
|
+
cached.isDirty = true;
|
|
13
|
+
}
|
|
14
|
+
};
|
|
15
|
+
exports.setSegmentationDirty = setSegmentationDirty;
|
|
16
|
+
const setSegmentationClean = (segmentationId) => {
|
|
17
|
+
const cached = segmentIndicesCache.get(segmentationId);
|
|
18
|
+
if (cached) {
|
|
19
|
+
cached.isDirty = false;
|
|
20
|
+
}
|
|
21
|
+
};
|
|
22
|
+
exports.setSegmentationClean = setSegmentationClean;
|
|
23
|
+
function getCachedSegmentIndices(segmentationId) {
|
|
24
|
+
const cached = segmentIndicesCache.get(segmentationId);
|
|
25
|
+
if (cached && !cached.isDirty) {
|
|
26
|
+
return cached.indices;
|
|
27
|
+
}
|
|
28
|
+
return null;
|
|
29
|
+
}
|
|
8
30
|
function getUniqueSegmentIndices(segmentationId) {
|
|
9
|
-
|
|
31
|
+
const cachedResult = getCachedSegmentIndices(segmentationId);
|
|
32
|
+
if (cachedResult) {
|
|
33
|
+
return cachedResult;
|
|
34
|
+
}
|
|
10
35
|
const segmentation = (0, segmentationState_1.getSegmentation)(segmentationId);
|
|
11
|
-
if (segmentation
|
|
12
|
-
|
|
13
|
-
const keySet = new Set();
|
|
14
|
-
if ((0, stackVolumeCheck_1.isVolumeSegmentation)(labelmapData)) {
|
|
15
|
-
const volume = core_1.cache.getVolume(segmentationId);
|
|
16
|
-
const scalarData = volume.getScalarData();
|
|
17
|
-
for (let i = 0; i < scalarData.length; i++) {
|
|
18
|
-
const segmentIndex = scalarData[i];
|
|
19
|
-
if (segmentIndex !== 0) {
|
|
20
|
-
keySet.add(segmentIndex);
|
|
21
|
-
}
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
else {
|
|
25
|
-
labelmapData.imageIdReferenceMap.forEach((segmentationImageId) => {
|
|
26
|
-
const image = core_1.cache.getImage(segmentationImageId);
|
|
27
|
-
const scalarData = image.getPixelData();
|
|
28
|
-
for (let i = 0; i < scalarData.length; i++) {
|
|
29
|
-
const segmentIndex = scalarData[i];
|
|
30
|
-
if (segmentIndex !== 0) {
|
|
31
|
-
keySet.add(segmentIndex);
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
});
|
|
35
|
-
}
|
|
36
|
-
return Array.from(keySet)
|
|
37
|
-
.map((it) => parseInt(it))
|
|
38
|
-
.sort();
|
|
39
|
-
}
|
|
40
|
-
else if (segmentation.type === enums_1.SegmentationRepresentations.Contour) {
|
|
41
|
-
const annotationUIDsMap = (_a = segmentation.representationData.CONTOUR) === null || _a === void 0 ? void 0 : _a.annotationUIDsMap;
|
|
42
|
-
const indices = new Set(annotationUIDsMap.keys());
|
|
43
|
-
const geometryIds = (_b = segmentation.representationData.CONTOUR) === null || _b === void 0 ? void 0 : _b.geometryIds;
|
|
44
|
-
if (!geometryIds) {
|
|
45
|
-
throw new Error(`No geometryIds found for segmentationId ${segmentationId}`);
|
|
46
|
-
}
|
|
47
|
-
geometryIds.forEach((geometryId) => {
|
|
48
|
-
const geometry = core_1.cache.getGeometry(geometryId);
|
|
49
|
-
indices.add(geometry.data.getSegmentIndex());
|
|
50
|
-
});
|
|
51
|
-
return Array.from(indices.values()).sort();
|
|
36
|
+
if (!segmentation) {
|
|
37
|
+
throw new Error(`No segmentation found for segmentationId ${segmentationId}`);
|
|
52
38
|
}
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
39
|
+
let indices;
|
|
40
|
+
switch (segmentation.type) {
|
|
41
|
+
case enums_1.SegmentationRepresentations.Labelmap:
|
|
42
|
+
indices = handleLabelmapSegmentation(segmentation, segmentationId);
|
|
43
|
+
break;
|
|
44
|
+
case enums_1.SegmentationRepresentations.Contour:
|
|
45
|
+
indices = handleContourSegmentation(segmentation);
|
|
46
|
+
break;
|
|
47
|
+
case enums_1.SegmentationRepresentations.Surface:
|
|
48
|
+
indices = handleSurfaceSegmentation(segmentation);
|
|
49
|
+
break;
|
|
50
|
+
default:
|
|
51
|
+
throw new Error(`Unsupported segmentation type: ${segmentation.type}`);
|
|
56
52
|
}
|
|
53
|
+
segmentIndicesCache.set(segmentationId, { indices, isDirty: false });
|
|
54
|
+
return indices;
|
|
57
55
|
}
|
|
58
56
|
exports.getUniqueSegmentIndices = getUniqueSegmentIndices;
|
|
57
|
+
function handleLabelmapSegmentation(segmentation, segmentationId) {
|
|
58
|
+
const labelmapData = segmentation.representationData[enums_1.SegmentationRepresentations.Labelmap];
|
|
59
|
+
const keySet = new Set();
|
|
60
|
+
if ((0, stackVolumeCheck_1.isVolumeSegmentation)(labelmapData)) {
|
|
61
|
+
addVolumeSegmentIndices(keySet, segmentationId);
|
|
62
|
+
}
|
|
63
|
+
else {
|
|
64
|
+
addImageSegmentIndices(keySet, labelmapData.imageIdReferenceMap);
|
|
65
|
+
}
|
|
66
|
+
return Array.from(keySet)
|
|
67
|
+
.map(Number)
|
|
68
|
+
.sort((a, b) => a - b);
|
|
69
|
+
}
|
|
70
|
+
function addVolumeSegmentIndices(keySet, segmentationId) {
|
|
71
|
+
const volume = core_1.cache.getVolume(segmentationId);
|
|
72
|
+
const scalarData = volume.getScalarData();
|
|
73
|
+
scalarData.forEach((segmentIndex) => {
|
|
74
|
+
if (segmentIndex !== 0) {
|
|
75
|
+
keySet.add(segmentIndex);
|
|
76
|
+
}
|
|
77
|
+
});
|
|
78
|
+
}
|
|
79
|
+
function addImageSegmentIndices(keySet, imageIdReferenceMap) {
|
|
80
|
+
imageIdReferenceMap.forEach((segmentationImageId) => {
|
|
81
|
+
const image = core_1.cache.getImage(segmentationImageId);
|
|
82
|
+
const scalarData = image.getPixelData();
|
|
83
|
+
scalarData.forEach((segmentIndex) => {
|
|
84
|
+
if (segmentIndex !== 0) {
|
|
85
|
+
keySet.add(segmentIndex);
|
|
86
|
+
}
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
function handleContourSegmentation(segmentation) {
|
|
91
|
+
const { annotationUIDsMap, geometryIds } = segmentation.representationData.CONTOUR || {};
|
|
92
|
+
if (!geometryIds) {
|
|
93
|
+
throw new Error(`No geometryIds found for segmentationId ${segmentation.segmentationId}`);
|
|
94
|
+
}
|
|
95
|
+
const indices = new Set([...annotationUIDsMap.keys()]);
|
|
96
|
+
geometryIds.forEach((geometryId) => {
|
|
97
|
+
const geometry = core_1.cache.getGeometry(geometryId);
|
|
98
|
+
indices.add(geometry.data.getSegmentIndex());
|
|
99
|
+
});
|
|
100
|
+
return Array.from(indices).sort((a, b) => a - b);
|
|
101
|
+
}
|
|
102
|
+
function handleSurfaceSegmentation(segmentation) {
|
|
103
|
+
var _a, _b;
|
|
104
|
+
const geometryIds = (_b = (_a = segmentation.representationData.SURFACE) === null || _a === void 0 ? void 0 : _a.geometryIds) !== null && _b !== void 0 ? _b : [];
|
|
105
|
+
return Array.from(geometryIds.keys())
|
|
106
|
+
.map(Number)
|
|
107
|
+
.sort((a, b) => a - b);
|
|
108
|
+
}
|
|
59
109
|
//# sourceMappingURL=getUniqueSegmentIndices.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getUniqueSegmentIndices.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/getUniqueSegmentIndices.ts"],"names":[],"mappings":";;;AAAA,8CAAmD;AACnD,
|
|
1
|
+
{"version":3,"file":"getUniqueSegmentIndices.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/getUniqueSegmentIndices.ts"],"names":[],"mappings":"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"}
|
|
@@ -17,9 +17,14 @@ const ImageData_1 = __importDefault(require("@kitware/vtk.js/Common/DataModel/Im
|
|
|
17
17
|
const DataArray_1 = __importDefault(require("@kitware/vtk.js/Common/Core/DataArray"));
|
|
18
18
|
const polyseg_wasm_1 = __importDefault(require("@icr/polyseg-wasm"));
|
|
19
19
|
const core_1 = require("@cornerstonejs/core");
|
|
20
|
+
const Plane_1 = __importDefault(require("@kitware/vtk.js/Common/DataModel/Plane"));
|
|
21
|
+
const PolyData_1 = __importDefault(require("@kitware/vtk.js/Common/DataModel/PolyData"));
|
|
22
|
+
const ContourLoopExtraction_1 = __importDefault(require("@kitware/vtk.js/Filters/General/ContourLoopExtraction"));
|
|
23
|
+
const Cutter_1 = __importDefault(require("@kitware/vtk.js/Filters/Core/Cutter"));
|
|
20
24
|
const boundingBox_1 = require("../utilities/boundingBox");
|
|
21
25
|
const utilities_1 = require("../utilities");
|
|
22
26
|
const polyline_1 = require("../utilities/math/polyline");
|
|
27
|
+
const planar_1 = require("../utilities/planar");
|
|
23
28
|
const polySegConverters = {
|
|
24
29
|
polySeg: null,
|
|
25
30
|
polySegInitializing: false,
|
|
@@ -262,6 +267,74 @@ const polySegConverters = {
|
|
|
262
267
|
return segmentationVoxelManager.scalarData;
|
|
263
268
|
});
|
|
264
269
|
},
|
|
270
|
+
getSurfacesAABBs({ surfacesInfo }) {
|
|
271
|
+
const aabbs = new Map();
|
|
272
|
+
for (const { points, id } of surfacesInfo) {
|
|
273
|
+
const aabb = (0, polyline_1.getAABB)(points, { numDimensions: 3 });
|
|
274
|
+
aabbs.set(id, aabb);
|
|
275
|
+
}
|
|
276
|
+
return aabbs;
|
|
277
|
+
},
|
|
278
|
+
cutSurfacesIntoPlanes({ planesInfo, surfacesInfo, surfacesAABB = new Map() }, progressCallback, updateCacheCallback) {
|
|
279
|
+
const numberOfPlanes = planesInfo.length;
|
|
280
|
+
const cutter = Cutter_1.default.newInstance();
|
|
281
|
+
const plane1 = Plane_1.default.newInstance();
|
|
282
|
+
cutter.setCutFunction(plane1);
|
|
283
|
+
const surfacePolyData = PolyData_1.default.newInstance();
|
|
284
|
+
try {
|
|
285
|
+
for (const [index, planeInfo] of planesInfo.entries()) {
|
|
286
|
+
const { sliceIndex, planes } = planeInfo;
|
|
287
|
+
const polyDataResults = new Map();
|
|
288
|
+
for (const polyDataInfo of surfacesInfo) {
|
|
289
|
+
const { points, polys, id } = polyDataInfo;
|
|
290
|
+
const aabb3 = surfacesAABB.get(id) || (0, polyline_1.getAABB)(points, { numDimensions: 3 });
|
|
291
|
+
if (!surfacesAABB.has(id)) {
|
|
292
|
+
surfacesAABB.set(id, aabb3);
|
|
293
|
+
}
|
|
294
|
+
const { minX, minY, minZ, maxX, maxY, maxZ } = aabb3;
|
|
295
|
+
const { origin, normal } = planes[0];
|
|
296
|
+
if (!(0, planar_1.isPlaneIntersectingAABB)(origin, normal, minX, minY, minZ, maxX, maxY, maxZ)) {
|
|
297
|
+
continue;
|
|
298
|
+
}
|
|
299
|
+
surfacePolyData.getPoints().setData(points, 3);
|
|
300
|
+
surfacePolyData.getPolys().setData(polys, 3);
|
|
301
|
+
surfacePolyData.modified();
|
|
302
|
+
cutter.setInputData(surfacePolyData);
|
|
303
|
+
plane1.setOrigin(origin);
|
|
304
|
+
plane1.setNormal(normal);
|
|
305
|
+
try {
|
|
306
|
+
cutter.update();
|
|
307
|
+
}
|
|
308
|
+
catch (e) {
|
|
309
|
+
console.warn('Error during clipping', e);
|
|
310
|
+
continue;
|
|
311
|
+
}
|
|
312
|
+
const polyData = cutter.getOutputData();
|
|
313
|
+
const cutterOutput = polyData;
|
|
314
|
+
cutterOutput.buildLinks();
|
|
315
|
+
const loopExtraction = ContourLoopExtraction_1.default.newInstance();
|
|
316
|
+
loopExtraction.setInputData(cutterOutput);
|
|
317
|
+
const loopOutput = loopExtraction.getOutputData();
|
|
318
|
+
if (polyData) {
|
|
319
|
+
polyDataResults.set(id, {
|
|
320
|
+
points: loopOutput.getPoints().getData(),
|
|
321
|
+
lines: loopOutput.getLines().getData(),
|
|
322
|
+
numberOfCells: loopOutput.getLines().getNumberOfCells(),
|
|
323
|
+
});
|
|
324
|
+
}
|
|
325
|
+
}
|
|
326
|
+
progressCallback({ progress: (index + 1) / numberOfPlanes });
|
|
327
|
+
updateCacheCallback({ sliceIndex, polyDataResults });
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
catch (e) {
|
|
331
|
+
console.warn('Error during processing', e);
|
|
332
|
+
}
|
|
333
|
+
finally {
|
|
334
|
+
surfacesInfo = null;
|
|
335
|
+
plane1.delete();
|
|
336
|
+
}
|
|
337
|
+
},
|
|
265
338
|
};
|
|
266
339
|
(0, comlink_1.expose)(polySegConverters);
|
|
267
340
|
//# sourceMappingURL=polySegConverters.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"polySegConverters.js","sourceRoot":"","sources":["../../../src/workers/polySegConverters.js"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"polySegConverters.js","sourceRoot":"","sources":["../../../src/workers/polySegConverters.js"],"names":[],"mappings":"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"}
|
|
@@ -19,7 +19,7 @@ export default function drawPath(svgDrawingHelper, annotationUID, pathUID, point
|
|
|
19
19
|
for (let j = 0; j < numPoints; j++) {
|
|
20
20
|
const point = points[j];
|
|
21
21
|
const cmd = j ? 'L' : 'M';
|
|
22
|
-
pointsAttribute += `${cmd} ${point[0]}
|
|
22
|
+
pointsAttribute += `${cmd} ${point[0].toFixed(1)}, ${point[1].toFixed(1)} `;
|
|
23
23
|
}
|
|
24
24
|
if (closePath) {
|
|
25
25
|
pointsAttribute += 'Z ';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"drawPath.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawPath.ts"],"names":[],"mappings":"AACA,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,uBAAuB,MAAM,2BAA2B,CAAC;AAChE,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AASlE,MAAM,CAAC,OAAO,UAAU,QAAQ,CAC9B,gBAAkC,EAClC,aAAqB,EACrB,OAAe,EACf,MAAyC,EACzC,OAQC;IAID,MAAM,YAAY,GAChB,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAEnE,MAAM,YAAY,GAAG,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IACtD,MAAM,EACJ,KAAK,GAAG,YAAY,EACpB,KAAK,GAAG,EAAE,EACV,SAAS,GAAG,MAAM,EAClB,WAAW,GAAG,CAAC,EACf,SAAS,EACT,QAAQ,EACR,SAAS,GAAG,KAAK,GAClB,GAAG,OAAO,CAAC;IAGZ,MAAM,WAAW,GAAG,SAAS,IAAI,KAAK,CAAC;IAEvC,MAAM,KAAK,GAAG,4BAA4B,CAAC;IAC3C,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IAC7D,MAAM,YAAY,GAAG,gBAAgB,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;IAC9D,IAAI,eAAe,GAAG,EAAE,CAAC;IAEzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,SAAS,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE;QACnE,MAAM,MAAM,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC;QAEhC,IAAI,SAAS,GAAG,CAAC,EAAE;YACjB,SAAS;SACV;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE;YAClC,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YACxB,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;YAE1B,eAAe,IAAI,GAAG,GAAG,IAAI,KAAK,CAAC,CAAC,CAAC,
|
|
1
|
+
{"version":3,"file":"drawPath.js","sourceRoot":"","sources":["../../../src/drawingSvg/drawPath.ts"],"names":[],"mappings":"AACA,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,uBAAuB,MAAM,2BAA2B,CAAC;AAChE,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AASlE,MAAM,CAAC,OAAO,UAAU,QAAQ,CAC9B,gBAAkC,EAClC,aAAqB,EACrB,OAAe,EACf,MAAyC,EACzC,OAQC;IAID,MAAM,YAAY,GAChB,MAAM,CAAC,MAAM,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,IAAI,KAAK,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;IAEnE,MAAM,YAAY,GAAG,YAAY,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC;IACtD,MAAM,EACJ,KAAK,GAAG,YAAY,EACpB,KAAK,GAAG,EAAE,EACV,SAAS,GAAG,MAAM,EAClB,WAAW,GAAG,CAAC,EACf,SAAS,EACT,QAAQ,EACR,SAAS,GAAG,KAAK,GAClB,GAAG,OAAO,CAAC;IAGZ,MAAM,WAAW,GAAG,SAAS,IAAI,KAAK,CAAC;IAEvC,MAAM,KAAK,GAAG,4BAA4B,CAAC;IAC3C,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,EAAE,MAAM,EAAE,OAAO,CAAC,CAAC;IAC7D,MAAM,YAAY,GAAG,gBAAgB,CAAC,UAAU,CAAC,WAAW,CAAC,CAAC;IAC9D,IAAI,eAAe,GAAG,EAAE,CAAC;IAEzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,SAAS,GAAG,YAAY,CAAC,MAAM,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE;QACnE,MAAM,MAAM,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QAC/B,MAAM,SAAS,GAAG,MAAM,CAAC,MAAM,CAAC;QAEhC,IAAI,SAAS,GAAG,CAAC,EAAE;YACjB,SAAS;SACV;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE;YAClC,MAAM,KAAK,GAAG,MAAM,CAAC,CAAC,CAAC,CAAC;YACxB,MAAM,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC;YAE1B,eAAe,IAAI,GAAG,GAAG,IAAI,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,KAAK,KAAK,CAAC,CAAC,CAAC,CAAC,OAAO,CACnE,CAAC,CACF,GAAG,CAAC;SACN;QAED,IAAI,SAAS,EAAE;YACb,eAAe,IAAI,IAAI,CAAC;SACzB;KACF;IAED,IAAI,CAAC,eAAe,EAAE;QACpB,OAAO;KACR;IAED,MAAM,UAAU,GAAG;QACjB,CAAC,EAAE,eAAe;QAClB,MAAM,EAAE,KAAK;QACb,IAAI,EAAE,SAAS;QACf,cAAc,EAAE,WAAW;QAC3B,cAAc,EAAE,WAAW;QAC3B,kBAAkB,EAAE,QAAQ;KAC7B,CAAC;IAEF,IAAI,YAAY,EAAE;QAEhB,wBAAwB,CAAC,UAAU,EAAE,YAAY,CAAC,CAAC;QAEnD,gBAAgB,CAAC,cAAc,CAAC,WAAW,CAAC,CAAC;KAC9C;SAAM;QACL,MAAM,OAAO,GAAG,QAAQ,CAAC,eAAe,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;QAExD,uBAAuB,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;QAC7C,gBAAgB,CAAC,UAAU,CAAC,OAAO,EAAE,WAAW,CAAC,CAAC;KACnD;AACH,CAAC"}
|
|
@@ -4,7 +4,7 @@ var ChangeTypes;
|
|
|
4
4
|
ChangeTypes["POLYSEG_SURFACE_TO_LABELMAP"] = "polySeg/convertSurfacesToVolumeLabelmap";
|
|
5
5
|
ChangeTypes["POLYSEG_CONTOUR_TO_SURFACE"] = "polySeg/convertContourToSurface";
|
|
6
6
|
ChangeTypes["POLYSEG_LABELMAP_TO_SURFACE"] = "polySeg/convertLabelmapToSurface";
|
|
7
|
-
ChangeTypes["
|
|
7
|
+
ChangeTypes["SURFACE_CLIPPING"] = "surfaceClipping";
|
|
8
8
|
})(ChangeTypes || (ChangeTypes = {}));
|
|
9
9
|
export default ChangeTypes;
|
|
10
10
|
//# sourceMappingURL=WorkerTypes.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"WorkerTypes.js","sourceRoot":"","sources":["../../../src/enums/WorkerTypes.ts"],"names":[],"mappings":"AAGA,IAAK,WAUJ;AAVD,WAAK,WAAW;IACd,qFAAsE,CAAA;IAEtE,sFAAuE,CAAA;IAEvE,6EAA8D,CAAA;IAE9D,+EAAgE,CAAA;IAEhE,
|
|
1
|
+
{"version":3,"file":"WorkerTypes.js","sourceRoot":"","sources":["../../../src/enums/WorkerTypes.ts"],"names":[],"mappings":"AAGA,IAAK,WAUJ;AAVD,WAAK,WAAW;IACd,qFAAsE,CAAA;IAEtE,sFAAuE,CAAA;IAEvE,6EAA8D,CAAA;IAE9D,+EAAgE,CAAA;IAEhE,mDAAoC,CAAA;AACtC,CAAC,EAVI,WAAW,KAAX,WAAW,QAUf;AAED,eAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
import { Enums, getWebWorkerManager, eventTarget, triggerEvent, } from '@cornerstonejs/core';
|
|
2
|
+
import { WorkerTypes } from '../../../enums';
|
|
3
|
+
import { pointToString } from '../../../utilities';
|
|
4
|
+
import { registerPolySegWorker } from '../polySeg/registerPolySegWorker';
|
|
5
|
+
const workerManager = getWebWorkerManager();
|
|
6
|
+
const polyDataCache = new Map();
|
|
7
|
+
const surfacesAABBCache = new Map();
|
|
8
|
+
const triggerWorkerProgress = (eventTarget, progress) => {
|
|
9
|
+
triggerEvent(eventTarget, Enums.Events.WEB_WORKER_PROGRESS, {
|
|
10
|
+
progress,
|
|
11
|
+
type: WorkerTypes.SURFACE_CLIPPING,
|
|
12
|
+
});
|
|
13
|
+
};
|
|
14
|
+
export async function clipAndCacheSurfacesForViewport(surfacesInfo, viewport, segmentationRepresentationUID) {
|
|
15
|
+
registerPolySegWorker();
|
|
16
|
+
const planesInfo = viewport.getSlicesClippingPlanes?.();
|
|
17
|
+
if (!planesInfo) {
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
const currentSliceIndex = viewport.getSliceIndex();
|
|
21
|
+
planesInfo.sort((a, b) => {
|
|
22
|
+
const diffA = Math.abs(a.sliceIndex - currentSliceIndex);
|
|
23
|
+
const diffB = Math.abs(b.sliceIndex - currentSliceIndex);
|
|
24
|
+
return diffA - diffB;
|
|
25
|
+
});
|
|
26
|
+
triggerWorkerProgress(eventTarget, 0);
|
|
27
|
+
await updateSurfacesAABBCache(surfacesInfo);
|
|
28
|
+
const surfacesAABB = new Map();
|
|
29
|
+
surfacesInfo.forEach((surface) => {
|
|
30
|
+
surfacesAABB.set(surface.id, surfacesAABBCache.get(surface.id));
|
|
31
|
+
});
|
|
32
|
+
const camera = viewport.getCamera();
|
|
33
|
+
await workerManager
|
|
34
|
+
.executeTask('polySeg', 'cutSurfacesIntoPlanes', {
|
|
35
|
+
surfacesInfo,
|
|
36
|
+
planesInfo,
|
|
37
|
+
surfacesAABB,
|
|
38
|
+
}, {
|
|
39
|
+
callbacks: [
|
|
40
|
+
({ progress }) => {
|
|
41
|
+
triggerWorkerProgress(eventTarget, progress);
|
|
42
|
+
},
|
|
43
|
+
({ sliceIndex, polyDataResults }) => {
|
|
44
|
+
polyDataResults.forEach((polyDataResult, surfaceId) => {
|
|
45
|
+
const actorUID = `${segmentationRepresentationUID}_${surfaceId}`;
|
|
46
|
+
const cacheId = generateCacheId(viewport, camera.viewPlaneNormal, sliceIndex);
|
|
47
|
+
updatePolyDataCache(actorUID, cacheId, polyDataResult);
|
|
48
|
+
});
|
|
49
|
+
},
|
|
50
|
+
],
|
|
51
|
+
})
|
|
52
|
+
.catch((error) => {
|
|
53
|
+
console.error(error);
|
|
54
|
+
});
|
|
55
|
+
triggerWorkerProgress(eventTarget, 1);
|
|
56
|
+
return polyDataCache;
|
|
57
|
+
}
|
|
58
|
+
async function updateSurfacesAABBCache(surfacesInfo) {
|
|
59
|
+
const surfacesWithoutAABB = surfacesInfo.filter((surface) => !surfacesAABBCache.has(surface.id));
|
|
60
|
+
if (!surfacesWithoutAABB.length) {
|
|
61
|
+
return;
|
|
62
|
+
}
|
|
63
|
+
const surfacesAABB = await workerManager.executeTask('polySeg', 'getSurfacesAABBs', {
|
|
64
|
+
surfacesInfo: surfacesWithoutAABB,
|
|
65
|
+
}, {
|
|
66
|
+
callbacks: [
|
|
67
|
+
({ progress }) => {
|
|
68
|
+
triggerWorkerProgress(eventTarget, progress);
|
|
69
|
+
},
|
|
70
|
+
],
|
|
71
|
+
});
|
|
72
|
+
surfacesAABB.forEach((aabb, id) => {
|
|
73
|
+
surfacesAABBCache.set(id, aabb);
|
|
74
|
+
});
|
|
75
|
+
}
|
|
76
|
+
export function getSurfaceActorUID(segmentationRepresentationUID, surfaceId) {
|
|
77
|
+
return `${segmentationRepresentationUID}_${surfaceId}`;
|
|
78
|
+
}
|
|
79
|
+
export function generateCacheId(viewport, viewPlaneNormal, sliceIndex) {
|
|
80
|
+
return `${viewport.id}-${pointToString(viewPlaneNormal)}-${sliceIndex}`;
|
|
81
|
+
}
|
|
82
|
+
export function updatePolyDataCache(actorUID, cacheId, polyDataResult) {
|
|
83
|
+
const { points, lines, numberOfCells } = polyDataResult;
|
|
84
|
+
let actorCache = polyDataCache.get(actorUID);
|
|
85
|
+
if (!actorCache) {
|
|
86
|
+
actorCache = new Map();
|
|
87
|
+
polyDataCache.set(actorUID, actorCache);
|
|
88
|
+
}
|
|
89
|
+
actorCache.set(cacheId, { points, lines, numberOfCells });
|
|
90
|
+
}
|
|
91
|
+
//# sourceMappingURL=clipAndCacheSurfacesForViewport.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"clipAndCacheSurfacesForViewport.js","sourceRoot":"","sources":["../../../../../src/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.ts"],"names":[],"mappings":"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"}
|
package/dist/esm/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js
CHANGED
|
@@ -1,4 +1,7 @@
|
|
|
1
|
+
import { SegmentationRepresentations } from '../../../../enums';
|
|
2
|
+
import { computeAndAddRepresentation } from '../computeAndAddRepresentation';
|
|
3
|
+
import { computeContourData } from './contourComputationStrategies';
|
|
1
4
|
export function computeAndAddContourRepresentation(segmentationId, options = {}) {
|
|
2
|
-
|
|
5
|
+
return computeAndAddRepresentation(segmentationId, SegmentationRepresentations.Contour, () => computeContourData(segmentationId, options), () => undefined);
|
|
3
6
|
}
|
|
4
7
|
//# sourceMappingURL=computeAndAddContourRepresentation.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"computeAndAddContourRepresentation.js","sourceRoot":"","sources":["../../../../../../src/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"computeAndAddContourRepresentation.js","sourceRoot":"","sources":["../../../../../../src/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,MAAM,mBAAmB,CAAC;AAEhE,OAAO,EAAE,2BAA2B,EAAE,MAAM,gCAAgC,CAAC;AAC7E,OAAO,EAAE,kBAAkB,EAAE,MAAM,gCAAgC,CAAC;AAUpE,MAAM,UAAU,kCAAkC,CAChD,cAAsB,EACtB,UAAoC,EAAE;IAEtC,OAAO,2BAA2B,CAChC,cAAc,EACd,2BAA2B,CAAC,OAAO,EACnC,GAAG,EAAE,CAAC,kBAAkB,CAAC,cAAc,EAAE,OAAO,CAAC,EACjD,GAAG,EAAE,CAAC,SAAS,CAChB,CAAC;AACJ,CAAC"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import { cache } from '@cornerstonejs/core';
|
|
2
|
+
import { getUniqueSegmentIndices } from '../../../../utilities/segmentation';
|
|
3
|
+
import { getSegmentation, setSegmentationRepresentationSpecificConfig, } from '../../segmentationState';
|
|
4
|
+
import { computeSurfaceFromLabelmapSegmentation } from '../Surface/surfaceComputationStrategies';
|
|
5
|
+
import { clipAndCacheSurfacesForViewport, } from '../../helpers/clipAndCacheSurfacesForViewport';
|
|
6
|
+
import { extractContourData } from './utils/extractContourData';
|
|
7
|
+
import { createAndAddContourSegmentationsFromClippedSurfaces } from './utils/createAndAddContourSegmentationsFromClippedSurfaces';
|
|
8
|
+
import { getToolGroupForViewport } from '../../../../store/ToolGroupManager';
|
|
9
|
+
export async function computeContourData(segmentationId, options = {}) {
|
|
10
|
+
const segmentIndices = options.segmentIndices?.length
|
|
11
|
+
? options.segmentIndices
|
|
12
|
+
: getUniqueSegmentIndices(segmentationId);
|
|
13
|
+
let rawContourData;
|
|
14
|
+
const segmentation = getSegmentation(segmentationId);
|
|
15
|
+
const representationData = segmentation.representationData;
|
|
16
|
+
try {
|
|
17
|
+
if (representationData.SURFACE) {
|
|
18
|
+
rawContourData = await computeContourFromSurfaceSegmentation(segmentationId, {
|
|
19
|
+
segmentIndices,
|
|
20
|
+
...options,
|
|
21
|
+
});
|
|
22
|
+
}
|
|
23
|
+
else if (representationData.LABELMAP) {
|
|
24
|
+
rawContourData = await computeContourFromLabelmapSegmentation(segmentationId, {
|
|
25
|
+
segmentIndices,
|
|
26
|
+
...options,
|
|
27
|
+
});
|
|
28
|
+
}
|
|
29
|
+
}
|
|
30
|
+
catch (error) {
|
|
31
|
+
console.error(error);
|
|
32
|
+
throw error;
|
|
33
|
+
}
|
|
34
|
+
if (!rawContourData) {
|
|
35
|
+
throw new Error('Not enough data to convert to contour, currently only support converting volume labelmap to contour if available');
|
|
36
|
+
}
|
|
37
|
+
const { viewport, segmentationRepresentationUID } = options;
|
|
38
|
+
const annotationUIDsMap = createAndAddContourSegmentationsFromClippedSurfaces(rawContourData, viewport, segmentationId);
|
|
39
|
+
const toolGroupId = getToolGroupForViewport(viewport.id)?.id;
|
|
40
|
+
setSegmentationRepresentationSpecificConfig(toolGroupId, segmentationRepresentationUID, {
|
|
41
|
+
CONTOUR: {
|
|
42
|
+
fillAlpha: 0,
|
|
43
|
+
},
|
|
44
|
+
});
|
|
45
|
+
return {
|
|
46
|
+
annotationUIDsMap,
|
|
47
|
+
};
|
|
48
|
+
}
|
|
49
|
+
async function computeContourFromLabelmapSegmentation(segmentationId, options = {}) {
|
|
50
|
+
if (!options.viewport) {
|
|
51
|
+
throw new Error('Viewport is required to compute contour from labelmap');
|
|
52
|
+
}
|
|
53
|
+
const results = await computeSurfaceFromLabelmapSegmentation(segmentationId, options);
|
|
54
|
+
if (!results?.length) {
|
|
55
|
+
console.error('Failed to convert labelmap to surface or labelmap is empty');
|
|
56
|
+
return;
|
|
57
|
+
}
|
|
58
|
+
const { viewport, segmentationRepresentationUID } = options;
|
|
59
|
+
const pointsAndPolys = results.map((surface) => {
|
|
60
|
+
return {
|
|
61
|
+
id: surface.segmentIndex.toString(),
|
|
62
|
+
points: surface.data.points,
|
|
63
|
+
polys: surface.data.polys,
|
|
64
|
+
segmentIndex: surface.segmentIndex,
|
|
65
|
+
};
|
|
66
|
+
});
|
|
67
|
+
const polyDataCache = await clipAndCacheSurfacesForViewport(pointsAndPolys, viewport, segmentationRepresentationUID);
|
|
68
|
+
const rawResults = extractContourData(polyDataCache);
|
|
69
|
+
return rawResults;
|
|
70
|
+
}
|
|
71
|
+
async function computeContourFromSurfaceSegmentation(segmentationId, options = {}) {
|
|
72
|
+
if (!options.viewport) {
|
|
73
|
+
throw new Error('Viewport is required to compute contour from surface');
|
|
74
|
+
}
|
|
75
|
+
const { viewport, segmentationRepresentationUID } = options;
|
|
76
|
+
const segmentIndices = options.segmentIndices?.length
|
|
77
|
+
? options.segmentIndices
|
|
78
|
+
: getUniqueSegmentIndices(segmentationId);
|
|
79
|
+
const segmentIndexToSurfaceId = new Map();
|
|
80
|
+
const surfaceIdToSegmentIndex = new Map();
|
|
81
|
+
const segmentation = getSegmentation(segmentationId);
|
|
82
|
+
const representationData = segmentation.representationData.SURFACE;
|
|
83
|
+
const surfacesInfo = [];
|
|
84
|
+
representationData.geometryIds.forEach((geometryId, segmentIndex) => {
|
|
85
|
+
if (segmentIndices.includes(segmentIndex)) {
|
|
86
|
+
segmentIndexToSurfaceId.set(segmentIndex, geometryId);
|
|
87
|
+
const surface = cache.getGeometry(geometryId)?.data;
|
|
88
|
+
if (surface) {
|
|
89
|
+
surfacesInfo.push({
|
|
90
|
+
id: geometryId,
|
|
91
|
+
points: surface.getPoints(),
|
|
92
|
+
polys: surface.getPolys(),
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
segmentIndexToSurfaceId.forEach((surfaceId, segmentIndex) => {
|
|
98
|
+
surfaceIdToSegmentIndex.set(surfaceId, segmentIndex);
|
|
99
|
+
});
|
|
100
|
+
const polyDataCache = await clipAndCacheSurfacesForViewport(surfacesInfo, viewport, segmentationRepresentationUID);
|
|
101
|
+
const rawResults = extractContourData(polyDataCache, surfaceIdToSegmentIndex);
|
|
102
|
+
return rawResults;
|
|
103
|
+
}
|
|
104
|
+
export { computeContourFromLabelmapSegmentation };
|
|
105
|
+
//# sourceMappingURL=contourComputationStrategies.js.map
|
package/dist/esm/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"contourComputationStrategies.js","sourceRoot":"","sources":["../../../../../../src/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.ts"],"names":[],"mappings":"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"}
|