@cornerstonejs/tools 1.57.2 → 1.58.1

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.
Files changed (226) hide show
  1. package/dist/cjs/drawingSvg/drawPath.js +1 -1
  2. package/dist/cjs/drawingSvg/drawPath.js.map +1 -1
  3. package/dist/cjs/enums/WorkerTypes.d.ts +1 -1
  4. package/dist/cjs/enums/WorkerTypes.js +1 -1
  5. package/dist/cjs/enums/WorkerTypes.js.map +1 -1
  6. package/dist/cjs/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.d.ts +17 -0
  7. package/dist/cjs/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js +112 -0
  8. package/dist/cjs/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js.map +1 -0
  9. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts +3 -1
  10. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js +4 -1
  11. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js.map +1 -1
  12. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.d.ts +8 -0
  13. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js +121 -0
  14. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js.map +1 -0
  15. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.d.ts +3 -0
  16. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js +73 -0
  17. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js.map +1 -0
  18. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.d.ts +3 -0
  19. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js +25 -0
  20. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js.map +1 -0
  21. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.d.ts +1 -0
  22. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js +41 -0
  23. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js.map +1 -0
  24. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js +2 -2
  25. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js.map +1 -1
  26. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js +1 -1
  27. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js.map +1 -1
  28. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js.map +1 -1
  29. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js +1 -1
  30. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js.map +1 -1
  31. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js +1 -1
  32. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js.map +1 -1
  33. package/dist/cjs/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js +1 -1
  34. package/dist/cjs/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js.map +1 -1
  35. package/dist/cjs/stateManagement/segmentation/triggerSegmentationEvents.js +2 -0
  36. package/dist/cjs/stateManagement/segmentation/triggerSegmentationEvents.js.map +1 -1
  37. package/dist/cjs/store/ToolGroupManager/getToolGroupForViewport.d.ts +1 -1
  38. package/dist/cjs/store/ToolGroupManager/getToolGroupForViewport.js +5 -0
  39. package/dist/cjs/store/ToolGroupManager/getToolGroupForViewport.js.map +1 -1
  40. package/dist/cjs/tools/base/BaseTool.js +3 -0
  41. package/dist/cjs/tools/base/BaseTool.js.map +1 -1
  42. package/dist/cjs/tools/base/ContourSegmentationBaseTool.js.map +1 -1
  43. package/dist/cjs/tools/displayTools/Contour/contourDisplay.js +13 -5
  44. package/dist/cjs/tools/displayTools/Contour/contourDisplay.js.map +1 -1
  45. package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js +1 -1
  46. package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
  47. package/dist/cjs/tools/displayTools/SegmentationDisplayTool.d.ts +1 -0
  48. package/dist/cjs/tools/displayTools/SegmentationDisplayTool.js +17 -0
  49. package/dist/cjs/tools/displayTools/SegmentationDisplayTool.js.map +1 -1
  50. package/dist/cjs/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js +4 -47
  51. package/dist/cjs/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js.map +1 -1
  52. package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.d.ts +3 -9
  53. package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.js +7 -148
  54. package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.js.map +1 -1
  55. package/dist/cjs/types/PolySeg.d.ts +1 -1
  56. package/dist/cjs/utilities/contourSegmentation/addContourSegmentationAnnotation.js +4 -1
  57. package/dist/cjs/utilities/contourSegmentation/addContourSegmentationAnnotation.js.map +1 -1
  58. package/dist/cjs/utilities/contourSegmentation/removeContourSegmentationAnnotation.js +3 -0
  59. package/dist/cjs/utilities/contourSegmentation/removeContourSegmentationAnnotation.js.map +1 -1
  60. package/dist/cjs/utilities/math/polyline/getAABB.d.ts +3 -1
  61. package/dist/cjs/utilities/math/polyline/getAABB.js +30 -4
  62. package/dist/cjs/utilities/math/polyline/getAABB.js.map +1 -1
  63. package/dist/cjs/utilities/planar/index.d.ts +3 -1
  64. package/dist/cjs/utilities/planar/index.js +4 -1
  65. package/dist/cjs/utilities/planar/index.js.map +1 -1
  66. package/dist/cjs/utilities/planar/isPlaneIntersectingAABB.d.ts +1 -0
  67. package/dist/cjs/utilities/planar/isPlaneIntersectingAABB.js +32 -0
  68. package/dist/cjs/utilities/planar/isPlaneIntersectingAABB.js.map +1 -0
  69. package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.d.ts +3 -1
  70. package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.js +97 -47
  71. package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.js.map +1 -1
  72. package/dist/cjs/workers/polySegConverters.js +73 -0
  73. package/dist/cjs/workers/polySegConverters.js.map +1 -1
  74. package/dist/esm/drawingSvg/drawPath.js +1 -1
  75. package/dist/esm/drawingSvg/drawPath.js.map +1 -1
  76. package/dist/esm/enums/WorkerTypes.js +1 -1
  77. package/dist/esm/enums/WorkerTypes.js.map +1 -1
  78. package/dist/esm/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js +91 -0
  79. package/dist/esm/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js.map +1 -0
  80. package/dist/esm/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js +4 -1
  81. package/dist/esm/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js.map +1 -1
  82. package/dist/esm/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js +105 -0
  83. package/dist/esm/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js.map +1 -0
  84. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js +72 -0
  85. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js.map +1 -0
  86. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js +21 -0
  87. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js.map +1 -0
  88. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js +26 -0
  89. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js.map +1 -0
  90. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js +2 -2
  91. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js.map +1 -1
  92. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js +1 -1
  93. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js.map +1 -1
  94. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js +1 -1
  95. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js.map +1 -1
  96. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js +1 -1
  97. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js.map +1 -1
  98. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js +1 -1
  99. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js.map +1 -1
  100. package/dist/esm/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js +1 -1
  101. package/dist/esm/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js.map +1 -1
  102. package/dist/esm/stateManagement/segmentation/triggerSegmentationEvents.js +2 -0
  103. package/dist/esm/stateManagement/segmentation/triggerSegmentationEvents.js.map +1 -1
  104. package/dist/esm/store/ToolGroupManager/getToolGroupForViewport.js +4 -0
  105. package/dist/esm/store/ToolGroupManager/getToolGroupForViewport.js.map +1 -1
  106. package/dist/esm/tools/base/BaseTool.js +3 -0
  107. package/dist/esm/tools/base/BaseTool.js.map +1 -1
  108. package/dist/esm/tools/base/ContourSegmentationBaseTool.js.map +1 -1
  109. package/dist/esm/tools/displayTools/Contour/contourDisplay.js +13 -5
  110. package/dist/esm/tools/displayTools/Contour/contourDisplay.js.map +1 -1
  111. package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js +1 -1
  112. package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
  113. package/dist/esm/tools/displayTools/SegmentationDisplayTool.js +17 -0
  114. package/dist/esm/tools/displayTools/SegmentationDisplayTool.js.map +1 -1
  115. package/dist/esm/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js +3 -46
  116. package/dist/esm/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js.map +1 -1
  117. package/dist/esm/tools/displayTools/Surface/surfaceDisplay.js +8 -139
  118. package/dist/esm/tools/displayTools/Surface/surfaceDisplay.js.map +1 -1
  119. package/dist/esm/utilities/contourSegmentation/addContourSegmentationAnnotation.js +4 -1
  120. package/dist/esm/utilities/contourSegmentation/addContourSegmentationAnnotation.js.map +1 -1
  121. package/dist/esm/utilities/contourSegmentation/removeContourSegmentationAnnotation.js +3 -0
  122. package/dist/esm/utilities/contourSegmentation/removeContourSegmentationAnnotation.js.map +1 -1
  123. package/dist/esm/utilities/math/polyline/getAABB.js +30 -4
  124. package/dist/esm/utilities/math/polyline/getAABB.js.map +1 -1
  125. package/dist/esm/utilities/planar/index.js +3 -1
  126. package/dist/esm/utilities/planar/index.js.map +1 -1
  127. package/dist/esm/utilities/planar/isPlaneIntersectingAABB.js +28 -0
  128. package/dist/esm/utilities/planar/isPlaneIntersectingAABB.js.map +1 -0
  129. package/dist/esm/utilities/segmentation/getUniqueSegmentIndices.js +92 -44
  130. package/dist/esm/utilities/segmentation/getUniqueSegmentIndices.js.map +1 -1
  131. package/dist/esm/workers/polySegConverters.js +74 -1
  132. package/dist/esm/workers/polySegConverters.js.map +1 -1
  133. package/dist/types/drawingSvg/drawPath.d.ts.map +1 -1
  134. package/dist/types/enums/WorkerTypes.d.ts +1 -1
  135. package/dist/types/enums/WorkerTypes.d.ts.map +1 -1
  136. package/dist/types/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.d.ts +18 -0
  137. package/dist/types/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.d.ts.map +1 -0
  138. package/dist/types/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts +3 -1
  139. package/dist/types/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts.map +1 -1
  140. package/dist/types/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.d.ts +9 -0
  141. package/dist/types/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.d.ts.map +1 -0
  142. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.d.ts +4 -0
  143. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.d.ts.map +1 -0
  144. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.d.ts +4 -0
  145. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.d.ts.map +1 -0
  146. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.d.ts +2 -0
  147. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.d.ts.map +1 -0
  148. package/dist/types/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.d.ts.map +1 -1
  149. package/dist/types/stateManagement/segmentation/triggerSegmentationEvents.d.ts.map +1 -1
  150. package/dist/types/store/ToolGroupManager/getToolGroupForViewport.d.ts +1 -1
  151. package/dist/types/store/ToolGroupManager/getToolGroupForViewport.d.ts.map +1 -1
  152. package/dist/types/tools/base/BaseTool.d.ts.map +1 -1
  153. package/dist/types/tools/base/ContourSegmentationBaseTool.d.ts.map +1 -1
  154. package/dist/types/tools/displayTools/Contour/contourDisplay.d.ts.map +1 -1
  155. package/dist/types/tools/displayTools/SegmentationDisplayTool.d.ts +1 -0
  156. package/dist/types/tools/displayTools/SegmentationDisplayTool.d.ts.map +1 -1
  157. package/dist/types/tools/displayTools/Surface/addOrUpdateSurfaceToElement.d.ts.map +1 -1
  158. package/dist/types/tools/displayTools/Surface/surfaceDisplay.d.ts +3 -9
  159. package/dist/types/tools/displayTools/Surface/surfaceDisplay.d.ts.map +1 -1
  160. package/dist/types/types/PolySeg.d.ts +1 -1
  161. package/dist/types/types/PolySeg.d.ts.map +1 -1
  162. package/dist/types/utilities/contourSegmentation/addContourSegmentationAnnotation.d.ts.map +1 -1
  163. package/dist/types/utilities/contourSegmentation/removeContourSegmentationAnnotation.d.ts.map +1 -1
  164. package/dist/types/utilities/math/polyline/getAABB.d.ts +3 -1
  165. package/dist/types/utilities/math/polyline/getAABB.d.ts.map +1 -1
  166. package/dist/types/utilities/planar/index.d.ts +3 -1
  167. package/dist/types/utilities/planar/index.d.ts.map +1 -1
  168. package/dist/types/utilities/planar/isPlaneIntersectingAABB.d.ts +2 -0
  169. package/dist/types/utilities/planar/isPlaneIntersectingAABB.d.ts.map +1 -0
  170. package/dist/types/utilities/segmentation/getUniqueSegmentIndices.d.ts +3 -1
  171. package/dist/types/utilities/segmentation/getUniqueSegmentIndices.d.ts.map +1 -1
  172. package/dist/umd/985.index.js +1 -1
  173. package/dist/umd/985.index.js.map +1 -1
  174. package/dist/umd/index.js +1 -1
  175. package/dist/umd/index.js.map +1 -1
  176. package/package.json +4 -4
  177. package/src/drawingSvg/drawPath.ts +3 -1
  178. package/src/enums/WorkerTypes.ts +1 -1
  179. package/src/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.ts +203 -0
  180. package/src/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.ts +9 -2
  181. package/src/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.ts +201 -0
  182. package/src/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.ts +103 -0
  183. package/src/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.ts +38 -0
  184. package/src/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.ts +58 -0
  185. package/src/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.ts +2 -2
  186. package/src/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.ts +1 -1
  187. package/src/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.ts +3 -8
  188. package/src/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.ts +1 -1
  189. package/src/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.ts +1 -1
  190. package/src/stateManagement/segmentation/polySeg/computeAndAddRepresentation.ts +1 -1
  191. package/src/stateManagement/segmentation/triggerSegmentationEvents.ts +5 -0
  192. package/src/store/ToolGroupManager/getToolGroupForViewport.ts +8 -1
  193. package/src/tools/base/BaseTool.ts +7 -0
  194. package/src/tools/base/ContourSegmentationBaseTool.ts +5 -0
  195. package/src/tools/displayTools/Contour/contourDisplay.ts +29 -11
  196. package/src/tools/displayTools/Labelmap/labelmapDisplay.ts +1 -1
  197. package/src/tools/displayTools/SegmentationDisplayTool.ts +26 -0
  198. package/src/tools/displayTools/Surface/addOrUpdateSurfaceToElement.ts +3 -65
  199. package/src/tools/displayTools/Surface/surfaceDisplay.ts +12 -247
  200. package/src/types/PolySeg.ts +1 -1
  201. package/src/utilities/contourSegmentation/addContourSegmentationAnnotation.ts +9 -1
  202. package/src/utilities/contourSegmentation/removeContourSegmentationAnnotation.ts +4 -0
  203. package/src/utilities/math/polyline/getAABB.ts +58 -4
  204. package/src/utilities/planar/index.ts +3 -0
  205. package/src/utilities/planar/isPlaneIntersectingAABB.ts +56 -0
  206. package/src/utilities/segmentation/getUniqueSegmentIndices.ts +115 -49
  207. package/src/workers/polySegConverters.js +117 -1
  208. package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.d.ts +0 -1
  209. package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.js +0 -27
  210. package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.js.map +0 -1
  211. package/dist/cjs/workers/clippingPlaneWorker.d.ts +0 -1
  212. package/dist/cjs/workers/clippingPlaneWorker.js +0 -63
  213. package/dist/cjs/workers/clippingPlaneWorker.js.map +0 -1
  214. package/dist/esm/tools/displayTools/registerDisplayToolsWorker.js +0 -23
  215. package/dist/esm/tools/displayTools/registerDisplayToolsWorker.js.map +0 -1
  216. package/dist/esm/workers/clippingPlaneWorker.js +0 -58
  217. package/dist/esm/workers/clippingPlaneWorker.js.map +0 -1
  218. package/dist/types/tools/displayTools/registerDisplayToolsWorker.d.ts +0 -2
  219. package/dist/types/tools/displayTools/registerDisplayToolsWorker.d.ts.map +0 -1
  220. package/dist/types/workers/clippingPlaneWorker.d.ts +0 -2
  221. package/dist/types/workers/clippingPlaneWorker.d.ts.map +0 -1
  222. package/dist/umd/444.index.js +0 -3
  223. package/dist/umd/444.index.js.LICENSE.txt +0 -5
  224. package/dist/umd/444.index.js.map +0 -1
  225. package/src/tools/displayTools/registerDisplayToolsWorker.ts +0 -34
  226. package/src/workers/clippingPlaneWorker.js +0 -87
@@ -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]},${point[1]} `;
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,IAAI,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC;SACtD;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"}
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["DISPLAY_TOOL_CLIP_SURFACE"] = "displayTool/clipSurface";
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,oEAAqD,CAAA;AACvD,CAAC,EAVI,WAAW,KAAX,WAAW,QAUf;AAED,eAAe,WAAW,CAAC"}
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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"}
@@ -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
- throw new Error('Not implemented yet');
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":"AAWA,MAAM,UAAU,kCAAkC,CAChD,cAAsB,EACtB,UAAoC,EAAE;IAEtC,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;AACzC,CAAC"}
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
@@ -0,0 +1 @@
1
+ {"version":3,"file":"contourComputationStrategies.js","sourceRoot":"","sources":["../../../../../../src/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,72 @@
1
+ import { PlanarFreehandContourSegmentationTool } from '../../../../../tools';
2
+ import { addAnnotation } from '../../../../annotation/annotationState';
3
+ import { utilities } from '@cornerstonejs/core';
4
+ export function createAndAddContourSegmentationsFromClippedSurfaces(rawContourData, viewport, segmentationId) {
5
+ const annotationUIDsMap = new Map();
6
+ for (const [segmentIndex, contoursData] of rawContourData) {
7
+ for (const contourData of contoursData) {
8
+ const { points } = contourData;
9
+ const { lineSegments, linesNumberOfPoints } = _extractLineSegments(contourData);
10
+ for (let i = 0; i < lineSegments.length; i++) {
11
+ const line = lineSegments[i];
12
+ const polyline = [];
13
+ for (let j = 0; j < linesNumberOfPoints[i]; j++) {
14
+ const pointIndex = line[j];
15
+ polyline.push([
16
+ points[3 * pointIndex],
17
+ points[3 * pointIndex + 1],
18
+ points[3 * pointIndex + 2],
19
+ ]);
20
+ }
21
+ if (polyline.length < 3) {
22
+ continue;
23
+ }
24
+ const contourSegmentationAnnotation = {
25
+ annotationUID: utilities.uuidv4(),
26
+ data: {
27
+ contour: {
28
+ closed: true,
29
+ polyline,
30
+ },
31
+ segmentation: {
32
+ segmentationId,
33
+ segmentIndex,
34
+ },
35
+ handles: {},
36
+ },
37
+ handles: {},
38
+ highlighted: false,
39
+ autoGenerated: false,
40
+ invalidated: false,
41
+ isLocked: false,
42
+ isVisible: true,
43
+ metadata: {
44
+ toolName: PlanarFreehandContourSegmentationTool.toolName,
45
+ ...viewport.getViewReference(),
46
+ },
47
+ };
48
+ addAnnotation(contourSegmentationAnnotation, viewport.element);
49
+ const currentSet = annotationUIDsMap.get(segmentIndex) || new Set();
50
+ currentSet.add(contourSegmentationAnnotation.annotationUID);
51
+ annotationUIDsMap.set(segmentIndex, currentSet);
52
+ }
53
+ }
54
+ }
55
+ return annotationUIDsMap;
56
+ }
57
+ const _extractLineSegments = (contourData) => {
58
+ const { numberOfCells, lines } = contourData;
59
+ const lineSegments = [];
60
+ const linesNumberOfPoints = [];
61
+ for (let i = 0; i < lines.length;) {
62
+ const pointsInLine = lines[i];
63
+ linesNumberOfPoints.push(pointsInLine);
64
+ lineSegments.push(lines.slice(i + 1, i + pointsInLine + 1));
65
+ i += pointsInLine + 1;
66
+ if (lineSegments.length === numberOfCells) {
67
+ break;
68
+ }
69
+ }
70
+ return { lineSegments, linesNumberOfPoints };
71
+ };
72
+ //# sourceMappingURL=createAndAddContourSegmentationsFromClippedSurfaces.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createAndAddContourSegmentationsFromClippedSurfaces.js","sourceRoot":"","sources":["../../../../../../../src/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,21 @@
1
+ export function extractContourData(polyDataCache, segmentIndexMap) {
2
+ const rawResults = new Map();
3
+ for (const [cacheId, intersectionInfo] of polyDataCache) {
4
+ const surfaceId = cacheId.split('_')[1];
5
+ for (const [_, result] of intersectionInfo) {
6
+ if (!result) {
7
+ continue;
8
+ }
9
+ const segmentIndex = Number(surfaceId) || segmentIndexMap?.get(surfaceId);
10
+ if (!segmentIndex) {
11
+ continue;
12
+ }
13
+ if (!rawResults.has(segmentIndex)) {
14
+ rawResults.set(segmentIndex, []);
15
+ }
16
+ rawResults.get(segmentIndex).push(result);
17
+ }
18
+ }
19
+ return rawResults;
20
+ }
21
+ //# sourceMappingURL=extractContourData.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extractContourData.js","sourceRoot":"","sources":["../../../../../../../src/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.ts"],"names":[],"mappings":"AASA,MAAM,UAAU,kBAAkB,CAChC,aAAoC,EACpC,eAAqC;IAErC,MAAM,UAAU,GAAG,IAAI,GAAG,EAAoB,CAAC;IAE/C,KAAK,MAAM,CAAC,OAAO,EAAE,gBAAgB,CAAC,IAAI,aAAa,EAAE;QAEvD,MAAM,SAAS,GAAG,OAAO,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;QAExC,KAAK,MAAM,CAAC,CAAC,EAAE,MAAM,CAAC,IAAI,gBAAgB,EAAE;YAC1C,IAAI,CAAC,MAAM,EAAE;gBACX,SAAS;aACV;YACD,MAAM,YAAY,GAAG,MAAM,CAAC,SAAS,CAAC,IAAI,eAAe,EAAE,GAAG,CAAC,SAAS,CAAC,CAAC;YAE1E,IAAI,CAAC,YAAY,EAAE;gBACjB,SAAS;aACV;YAED,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,YAAY,CAAC,EAAE;gBACjC,UAAU,CAAC,GAAG,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;aAClC;YAED,UAAU,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAC3C;KACF;IACD,OAAO,UAAU,CAAC;AACpB,CAAC"}
@@ -0,0 +1,26 @@
1
+ import { utilities, Enums } from '@cornerstonejs/core';
2
+ import { extractContourData } from './extractContourData';
3
+ import { clipAndCacheSurfacesForViewport } from '../../../helpers/clipAndCacheSurfacesForViewport';
4
+ import { createAndAddContourSegmentationsFromClippedSurfaces } from './createAndAddContourSegmentationsFromClippedSurfaces';
5
+ const currentViewportNormal = new Map();
6
+ export function updateContoursOnCameraModified(surfacesInfo, viewport, segmentationRepresentationUID) {
7
+ async function cameraModifiedCallback(evt) {
8
+ const { camera } = evt.detail;
9
+ const { viewPlaneNormal } = camera;
10
+ const surface1 = surfacesInfo[0];
11
+ const currentNormal = currentViewportNormal.get(surface1.id);
12
+ if (utilities.isEqual(viewPlaneNormal, currentNormal)) {
13
+ return;
14
+ }
15
+ currentViewportNormal.set(surface1.id, viewPlaneNormal);
16
+ const polyDataCache = await clipAndCacheSurfacesForViewport(surfacesInfo, viewport, segmentationRepresentationUID);
17
+ const results = extractContourData(polyDataCache);
18
+ createAndAddContourSegmentationsFromClippedSurfaces(results, viewport, segmentationRepresentationUID);
19
+ viewport.render();
20
+ }
21
+ const camera = viewport.getCamera();
22
+ currentViewportNormal.set(surfacesInfo[0].id, camera.viewPlaneNormal);
23
+ viewport.element.removeEventListener(Enums.Events.CAMERA_MODIFIED, cameraModifiedCallback);
24
+ viewport.element.addEventListener(Enums.Events.CAMERA_MODIFIED);
25
+ }
26
+ //# sourceMappingURL=updateContoursOnCameraModified.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"updateContoursOnCameraModified.js","sourceRoot":"","sources":["../../../../../../../src/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,KAAK,EAAE,MAAM,qBAAqB,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAC1D,OAAO,EAAE,+BAA+B,EAAE,MAAM,kDAAkD,CAAC;AACnG,OAAO,EAAE,mDAAmD,EAAE,MAAM,uDAAuD,CAAC;AAE5H,MAAM,qBAAqB,GAAG,IAAI,GAAG,EAAE,CAAC;AAExC,MAAM,UAAU,8BAA8B,CAC5C,YAAY,EACZ,QAAQ,EACR,6BAA6B;IAE7B,KAAK,UAAU,sBAAsB,CACnC,GAAyC;QAEzC,MAAM,EAAE,MAAM,EAAE,GAAG,GAAG,CAAC,MAAM,CAAC;QAC9B,MAAM,EAAE,eAAe,EAAE,GAAG,MAAM,CAAC;QAKnC,MAAM,QAAQ,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QAEjC,MAAM,aAAa,GAAG,qBAAqB,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAC7D,IAAI,SAAS,CAAC,OAAO,CAAC,eAAe,EAAE,aAAa,CAAC,EAAE;YACrD,OAAO;SACR;QACD,qBAAqB,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,EAAE,eAAe,CAAC,CAAC;QAExD,MAAM,aAAa,GAAG,MAAM,+BAA+B,CACzD,YAAY,EACZ,QAAiC,EACjC,6BAA6B,CAC9B,CAAC;QAEF,MAAM,OAAO,GAAG,kBAAkB,CAAC,aAAa,CAAC,CAAC;QAElD,mDAAmD,CACjD,OAAO,EACP,QAAQ,EACR,6BAA6B,CAC9B,CAAC;QAEF,QAAQ,CAAC,MAAM,EAAE,CAAC;IACpB,CAAC;IAED,MAAM,MAAM,GAAG,QAAQ,CAAC,SAAS,EAAE,CAAC;IACpC,qBAAqB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,EAAE,EAAE,MAAM,CAAC,eAAe,CAAC,CAAC;IAGtE,QAAQ,CAAC,OAAO,CAAC,mBAAmB,CAClC,KAAK,CAAC,MAAM,CAAC,eAAe,EAC5B,sBAAsB,CACvB,CAAC;IAGF,QAAQ,CAAC,OAAO,CAAC,gBAAgB,CAAC,KAAK,CAAC,MAAM,CAAC,eAAe,CAAC,CAAC;AAClE,CAAC"}
@@ -44,7 +44,7 @@ export async function convertContourToVolumeLabelmap(contourRepresentationData,
44
44
  },
45
45
  ],
46
46
  });
47
- triggerWorkerProgress(eventTarget, 100);
47
+ triggerWorkerProgress(eventTarget, 1);
48
48
  segmentationVolume.imageData
49
49
  .getPointData()
50
50
  .getScalars()
@@ -109,7 +109,7 @@ export async function convertContourToStackLabelmap(contourRepresentationData, o
109
109
  },
110
110
  ],
111
111
  });
112
- triggerWorkerProgress(eventTarget, 100);
112
+ triggerWorkerProgress(eventTarget, 1);
113
113
  const imageIdReferenceMap = new Map();
114
114
  newSegmentationsScalarData.forEach(({ scalarData }, referencedImageId) => {
115
115
  const segmentationInfo = segmentationsInfo.get(referencedImageId);
@@ -1 +1 @@
1
- {"version":3,"file":"convertContourToLabelmap.js","sourceRoot":"","sources":["../../../../../../src/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAEL,KAAK,EACL,SAAS,EACT,mBAAmB,EACnB,YAAY,EACZ,WAAW,EACX,QAAQ,EACR,KAAK,EACL,YAAY,EACZ,WAAW,GACZ,MAAM,qBAAqB,CAAC;AAM7B,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AACzC,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,MAAM,aAAa,GAAG,mBAAmB,EAAE,CAAC;AAE5C,MAAM,qBAAqB,GAAG,CAAC,WAAW,EAAE,QAAQ,EAAE,EAAE;IACtD,YAAY,CAAC,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,mBAAmB,EAAE;QAC1D,QAAQ;QACR,IAAI,EAAE,WAAW,CAAC,2BAA2B;KAC9C,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,8BAA8B,CAClD,yBAAkD,EAClD,UAAoC,EAAE;IAEtC,MAAM,EAAE,QAAQ,EAAE,GAAG,OAAO,CAAC;IAE7B,MAAM,QAAQ,GAAG,SAAS,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC;IAEzD,IAAI,CAAC,QAAQ,EAAE;QACb,MAAM,IAAI,KAAK,CACb,uFAAuF,CACxF,CAAC;KACH;IAED,MAAM,oBAAoB,GAAG,SAAS,CAAC,MAAM,EAAE,CAAC;IAEhD,MAAM,WAAW,GAAG,SAAS,CAAC,+BAA+B,CAC3D,QAAQ,EACR,oBAAoB,CACrB,CAAC;IAEF,MAAM,EAAE,QAAQ,EAAE,UAAU,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,UAAU,EAAE,GACpE,WAAW,CAAC;IAEd,MAAM,kBAAkB,GAAG,MAAM,YAAY,CAAC,6BAA6B,CACzE;QACE,UAAU;QACV,MAAM;QACN,SAAS;QACT,OAAO;QACP,QAAQ;QACR,QAAQ,EAAE,QAAQ,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC,eAAe,OAAO,EAAE,CAAC;QAC7D,kBAAkB,EAAE,QAAQ;KAC7B,EACD,oBAAoB,CACrB,CAAC;IAEF,MAAM,EAAE,cAAc,EAAE,0BAA0B,EAAE,GAClD,iCAAiC,CAAC,yBAAyB,EAAE,OAAO,CAAC,CAAC;IAExE,qBAAqB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;IAEtC,MAAM,aAAa,GAAG,MAAM,aAAa,CAAC,WAAW,CACnD,SAAS,EACT,gCAAgC,EAChC;QACE,cAAc;QACd,UAAU;QACV,UAAU;QACV,MAAM;QACN,SAAS;QACT,OAAO;QACP,0BAA0B;KAC3B,EACD;QACE,SAAS,EAAE;YACT,CAAC,QAAQ,EAAE,EAAE;gBACX,qBAAqB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YAC/C,CAAC;SACF;KACF,CACF,CAAC;IAEF,qBAAqB,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;IAExC,kBAAkB,CAAC,SAAS;SACzB,YAAY,EAAE;SACd,UAAU,EAAE;SACZ,OAAO,CAAC,aAAa,CAAC,CAAC;IAC1B,kBAAkB,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAGxC,kBAAkB,CAAC,QAAQ,EAAE,CAAC;IAE9B,OAAO;QACL,QAAQ,EAAE,kBAAkB,CAAC,QAAQ;KACtC,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,6BAA6B,CACjD,yBAAkD,EAClD,UAAoC,EAAE;IAEtC,IAAI,CAAC,OAAO,CAAC,QAAQ,EAAE;QACrB,MAAM,IAAI,KAAK,CACb,4EAA4E,CAC7E,CAAC;KACH;IAED,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAgC,CAAC;IAE1D,MAAM,QAAQ,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;IAExC,IAAI,CAAC,QAAQ,EAAE;QACb,MAAM,IAAI,KAAK,CACb,uFAAuF,CACxF,CAAC;KACH;IAGD,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC3B,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,OAAO,CAAC,EAAE;YACtC,MAAM,IAAI,KAAK,CACb,+DAA+D,CAChE,CAAC;SACH;IACH,CAAC,CAAC,CAAC;IAGH,MAAM,EAAE,QAAQ,EAAE,oBAAoB,EAAE,GACtC,MAAM,WAAW,CAAC,uCAAuC,CAAC,QAAQ,CAAC,CAAC;IAEtE,MAAM,EAAE,cAAc,EAAE,0BAA0B,EAAE,GAClD,iCAAiC,CAAC,yBAAyB,EAAE,OAAO,CAAC,CAAC;IAIxE,MAAM,iBAAiB,GAAG,IAAI,GAAG,EAAE,CAAC;IAGpC,oBAAoB,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,KAAK,EAAE,EAAE;QAEjD,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;QAG5C,MAAM,gBAAgB,GAAG,QAAQ,CAAC,GAAG,CACnC,KAAK,CAAC,eAAe,CAAC,WAAW,EACjC,UAAU,CACX,CAAC;QAGF,IAAI,EACF,aAAa,EACb,UAAU,EACV,eAAe,EACf,kBAAkB,EAClB,oBAAoB,GACrB,GAAG,gBAAgB,CAAC;QAGrB,aAAa,GAAG,aAAa,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAC3C,UAAU,GAAG,UAAU,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QACrC,eAAe,GAAG,eAAe,IAAI,CAAC,CAAC;QACvC,kBAAkB,GAAG,kBAAkB,IAAI,CAAC,CAAC;QAC7C,oBAAoB,GAAG,oBAAoB,IAAI,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;QAGzD,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAClC,UAAU,CAAC,CAAC,CAAC,EACb,UAAU,CAAC,CAAC,CAAC,EACb,UAAU,CAAC,CAAC,CAAC,CACd,CAAC;QACF,MAAM,YAAY,GAAG,IAAI,CAAC,UAAU,CAClC,aAAa,CAAC,CAAC,CAAC,EAChB,aAAa,CAAC,CAAC,CAAC,EAChB,aAAa,CAAC,CAAC,CAAC,CACjB,CAAC;QAGF,MAAM,cAAc,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QACrC,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC;QAGvD,MAAM,SAAS,GAAG,CAAC,GAAG,YAAY,EAAE,GAAG,YAAY,EAAE,GAAG,cAAc,CAAC,CAAC;QACxE,MAAM,OAAO,GAAG,CAAC,eAAe,EAAE,kBAAkB,EAAE,CAAC,CAAC,CAAC;QAGzD,MAAM,MAAM,GAAG,oBAAoB,CAAC;QAGpC,iBAAiB,CAAC,GAAG,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;YACrC,SAAS;YACT,OAAO;YACP,MAAM;YACN,UAAU,EAAE,QAAQ,CAAC,YAAY,EAAE;YACnC,OAAO,EAAE,UAAU;YACnB,UAAU,EAAE,CAAC,QAAQ,CAAC,KAAK,EAAE,QAAQ,CAAC,MAAM,EAAE,CAAC,CAAC;SACjD,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,qBAAqB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;IAEtC,MAAM,0BAA0B,GAAG,MAAM,aAAa,CAAC,WAAW,CAChE,SAAS,EACT,+BAA+B,EAC/B;QACE,iBAAiB;QACjB,0BAA0B;QAC1B,cAAc;KACf,EACD;QACE,SAAS,EAAE;YACT,CAAC,QAAQ,EAAE,EAAE;gBACX,qBAAqB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YAC/C,CAAC;SACF;KACF,CACF,CAAC;IAEF,qBAAqB,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;IAExC,MAAM,mBAAmB,GAAG,IAAI,GAAG,EAAE,CAAC;IACtC,0BAA0B,CAAC,OAAO,CAAC,CAAC,EAAE,UAAU,EAAE,EAAE,iBAAiB,EAAE,EAAE;QACvE,MAAM,gBAAgB,GAAG,iBAAiB,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;QAClE,MAAM,EAAE,OAAO,EAAE,UAAU,EAAE,GAAG,gBAAgB,CAAC;QAEjD,MAAM,QAAQ,GAAG,KAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC;QAC5C,QAAQ,CAAC,YAAY,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACxC,QAAQ,CAAC,UAAU,EAAE,SAAS,EAAE,GAAG,CAAC,UAAU,CAAC,CAAC;QAEhD,mBAAmB,CAAC,GAAG,CAAC,iBAAiB,EAAE,UAAU,CAAC,CAAC;IACzD,CAAC,CAAC,CAAC;IAEH,OAAO;QACL,mBAAmB;KACpB,CAAC;AACJ,CAAC;AAED,SAAS,iCAAiC,CACxC,yBAAkD,EAClD,UAAoC,EAAE;IAEtC,MAAM,aAAa,GAAG,yBAAyB,CAAC,iBAAiB,CAAC;IAElE,MAAM,cAAc,GAAG,OAAO,CAAC,cAAc,EAAE,MAAM;QACnD,CAAC,CAAC,OAAO,CAAC,cAAc;QACxB,CAAC,CAAC,KAAK,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,EAAE,CAAC,CAAC;IAErC,MAAM,0BAA0B,GAAG,IAAI,GAAG,EAAwB,CAAC;IACnE,cAAc,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;QAC/B,MAAM,uBAAuB,GAAG,aAAa,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAEzD,MAAM,WAAW,GAAG,KAAK,CAAC,IAAI,CAAC,uBAAuB,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE;YAClE,MAAM,UAAU,GAAG,aAAa,CAAC,GAAG,CAAC,CAAC;YAEtC,OAAO,UAAU,CAAC;QACpB,CAAC,CAAC,CAAC;QAEH,0BAA0B,CAAC,GAAG,CAAC,KAAK,EAAE,WAAW,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;IAEH,OAAO,EAAE,cAAc,EAAE,0BAA0B,EAAE,CAAC;AACxD,CAAC"}
1
+ {"version":3,"file":"convertContourToLabelmap.js","sourceRoot":"","sources":["../../../../../../src/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.ts"],"names":[],"mappings":"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"}
@@ -38,7 +38,7 @@ export async function convertSurfaceToVolumeLabelmap(surfaceRepresentationData,
38
38
  },
39
39
  ],
40
40
  });
41
- triggerWorkerProgress(eventTarget, 100);
41
+ triggerWorkerProgress(eventTarget, 1);
42
42
  segmentationVolume.imageData
43
43
  .getPointData()
44
44
  .getScalars()
@@ -1 +1 @@
1
- {"version":3,"file":"convertSurfaceToLabelmap.js","sourceRoot":"","sources":["../../../../../../src/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EAEL,KAAK,EACL,WAAW,EACX,mBAAmB,EACnB,YAAY,GACb,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,MAAM,aAAa,GAAG,mBAAmB,EAAE,CAAC;AAE5C,MAAM,qBAAqB,GAAG,CAAC,WAAW,EAAE,QAAQ,EAAE,EAAE;IACtD,YAAY,CAAC,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,mBAAmB,EAAE;QAC1D,QAAQ;QACR,IAAI,EAAE,WAAW,CAAC,2BAA2B;KAC9C,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,8BAA8B,CAClD,yBAAkD,EAClD,kBAAsC;IAEtC,MAAM,EAAE,WAAW,EAAE,GAAG,yBAAyB,CAAC;IAClD,IAAI,CAAC,WAAW,EAAE,IAAI,EAAE;QACtB,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;KACrE;IAED,MAAM,YAAY,GAAG,IAAI,GAAG,EAM3B,CAAC;IAEF,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,YAAY,EAAE,EAAE;QAC/C,MAAM,QAAQ,GAAG,KAAK,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QAC/C,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAsB,CAAC;QACrD,MAAM,MAAM,GAAG,YAAY,CAAC,SAAS,EAAE,CAAC;QACxC,MAAM,KAAK,GAAG,YAAY,CAAC,QAAQ,EAAE,CAAC;QAEtC,YAAY,CAAC,GAAG,CAAC,YAAY,EAAE;YAC7B,MAAM;YACN,KAAK;SACN,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,kBAAkB,CAAC;IAEtE,qBAAqB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;IAEtC,MAAM,aAAa,GAAG,MAAM,aAAa,CAAC,WAAW,CACnD,SAAS,EACT,iCAAiC,EACjC;QACE,YAAY;QACZ,UAAU;QACV,OAAO;QACP,SAAS;QACT,MAAM;KACP,EACD;QACE,SAAS,EAAE;YACT,CAAC,QAAQ,EAAE,EAAE;gBACX,qBAAqB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YAC/C,CAAC;SACF;KACF,CACF,CAAC;IAEF,qBAAqB,CAAC,WAAW,EAAE,GAAG,CAAC,CAAC;IAExC,kBAAkB,CAAC,SAAS;SACzB,YAAY,EAAE;SACd,UAAU,EAAE;SACZ,OAAO,CAAC,aAAa,CAAC,CAAC;IAC1B,kBAAkB,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAGxC,kBAAkB,CAAC,QAAQ,EAAE,CAAC;IAE9B,OAAO;QACL,QAAQ,EAAE,kBAAkB,CAAC,QAAQ;KACtC,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,6BAA6B;AAEnD,CAAC"}
1
+ {"version":3,"file":"convertSurfaceToLabelmap.js","sourceRoot":"","sources":["../../../../../../src/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,EAEL,KAAK,EACL,WAAW,EACX,mBAAmB,EACnB,YAAY,GACb,MAAM,qBAAqB,CAAC;AAE7B,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,MAAM,aAAa,GAAG,mBAAmB,EAAE,CAAC;AAE5C,MAAM,qBAAqB,GAAG,CAAC,WAAW,EAAE,QAAQ,EAAE,EAAE;IACtD,YAAY,CAAC,WAAW,EAAE,KAAK,CAAC,MAAM,CAAC,mBAAmB,EAAE;QAC1D,QAAQ;QACR,IAAI,EAAE,WAAW,CAAC,2BAA2B;KAC9C,CAAC,CAAC;AACL,CAAC,CAAC;AAEF,MAAM,CAAC,KAAK,UAAU,8BAA8B,CAClD,yBAAkD,EAClD,kBAAsC;IAEtC,MAAM,EAAE,WAAW,EAAE,GAAG,yBAAyB,CAAC;IAClD,IAAI,CAAC,WAAW,EAAE,IAAI,EAAE;QACtB,MAAM,IAAI,KAAK,CAAC,kDAAkD,CAAC,CAAC;KACrE;IAED,MAAM,YAAY,GAAG,IAAI,GAAG,EAM3B,CAAC;IAEF,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,YAAY,EAAE,EAAE;QAC/C,MAAM,QAAQ,GAAG,KAAK,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;QAC/C,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAsB,CAAC;QACrD,MAAM,MAAM,GAAG,YAAY,CAAC,SAAS,EAAE,CAAC;QACxC,MAAM,KAAK,GAAG,YAAY,CAAC,QAAQ,EAAE,CAAC;QAEtC,YAAY,CAAC,GAAG,CAAC,YAAY,EAAE;YAC7B,MAAM;YACN,KAAK;SACN,CAAC,CAAC;IACL,CAAC,CAAC,CAAC;IAEH,MAAM,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,kBAAkB,CAAC;IAEtE,qBAAqB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;IAEtC,MAAM,aAAa,GAAG,MAAM,aAAa,CAAC,WAAW,CACnD,SAAS,EACT,iCAAiC,EACjC;QACE,YAAY;QACZ,UAAU;QACV,OAAO;QACP,SAAS;QACT,MAAM;KACP,EACD;QACE,SAAS,EAAE;YACT,CAAC,QAAQ,EAAE,EAAE;gBACX,qBAAqB,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAC;YAC/C,CAAC;SACF;KACF,CACF,CAAC;IAEF,qBAAqB,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;IAEtC,kBAAkB,CAAC,SAAS;SACzB,YAAY,EAAE;SACd,UAAU,EAAE;SACZ,OAAO,CAAC,aAAa,CAAC,CAAC;IAC1B,kBAAkB,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAGxC,kBAAkB,CAAC,QAAQ,EAAE,CAAC;IAE9B,OAAO;QACL,QAAQ,EAAE,kBAAkB,CAAC,QAAQ;KACtC,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,KAAK,UAAU,6BAA6B;AAEnD,CAAC"}