@cornerstonejs/tools 1.52.0 → 1.54.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.
Files changed (909) hide show
  1. package/dist/cjs/drawingSvg/drawPath.d.ts +11 -0
  2. package/dist/cjs/drawingSvg/drawPath.js +55 -0
  3. package/dist/cjs/drawingSvg/drawPath.js.map +1 -0
  4. package/dist/cjs/drawingSvg/drawPolyline.d.ts +1 -1
  5. package/dist/cjs/drawingSvg/drawPolyline.js +2 -10
  6. package/dist/cjs/drawingSvg/drawPolyline.js.map +1 -1
  7. package/dist/cjs/drawingSvg/index.d.ts +2 -1
  8. package/dist/cjs/drawingSvg/index.js +3 -1
  9. package/dist/cjs/drawingSvg/index.js.map +1 -1
  10. package/dist/cjs/enums/WorkerTypes.d.ts +8 -0
  11. package/dist/cjs/enums/WorkerTypes.js +12 -0
  12. package/dist/cjs/enums/WorkerTypes.js.map +1 -0
  13. package/dist/cjs/enums/index.d.ts +2 -1
  14. package/dist/cjs/enums/index.js +3 -1
  15. package/dist/cjs/enums/index.js.map +1 -1
  16. package/dist/cjs/eventDispatchers/shared/getActiveToolForMouseEvent.js.map +1 -1
  17. package/dist/cjs/eventListeners/annotations/contourSegmentation/contourSegmentationCompleted.d.ts +1 -1
  18. package/dist/cjs/eventListeners/annotations/contourSegmentation/contourSegmentationCompleted.js +171 -89
  19. package/dist/cjs/eventListeners/annotations/contourSegmentation/contourSegmentationCompleted.js.map +1 -1
  20. package/dist/cjs/eventListeners/segmentation/imageChangeEventListener.js +4 -3
  21. package/dist/cjs/eventListeners/segmentation/imageChangeEventListener.js.map +1 -1
  22. package/dist/cjs/eventListeners/segmentation/labelmap/onLabelmapSegmentationDataModified.js +58 -47
  23. package/dist/cjs/eventListeners/segmentation/labelmap/onLabelmapSegmentationDataModified.js.map +1 -1
  24. package/dist/cjs/stateManagement/annotation/FrameOfReferenceSpecificAnnotationManager.d.ts +1 -0
  25. package/dist/cjs/stateManagement/annotation/FrameOfReferenceSpecificAnnotationManager.js +5 -0
  26. package/dist/cjs/stateManagement/annotation/FrameOfReferenceSpecificAnnotationManager.js.map +1 -1
  27. package/dist/cjs/stateManagement/annotation/annotationState.d.ts +7 -1
  28. package/dist/cjs/stateManagement/annotation/annotationState.js +54 -1
  29. package/dist/cjs/stateManagement/annotation/annotationState.js.map +1 -1
  30. package/dist/cjs/stateManagement/annotation/helpers/state.d.ts +2 -1
  31. package/dist/cjs/stateManagement/annotation/helpers/state.js +14 -3
  32. package/dist/cjs/stateManagement/annotation/helpers/state.js.map +1 -1
  33. package/dist/cjs/stateManagement/index.d.ts +6 -1
  34. package/dist/cjs/stateManagement/index.js +6 -1
  35. package/dist/cjs/stateManagement/index.js.map +1 -1
  36. package/dist/cjs/stateManagement/segmentation/SegmentationStateManager.js +4 -1
  37. package/dist/cjs/stateManagement/segmentation/SegmentationStateManager.js.map +1 -1
  38. package/dist/cjs/stateManagement/segmentation/addRepresentationData.d.ts +12 -0
  39. package/dist/cjs/stateManagement/segmentation/addRepresentationData.js +35 -0
  40. package/dist/cjs/stateManagement/segmentation/addRepresentationData.js.map +1 -0
  41. package/dist/cjs/stateManagement/segmentation/addSegmentationRepresentation.js +32 -14
  42. package/dist/cjs/stateManagement/segmentation/addSegmentationRepresentation.js.map +1 -1
  43. package/dist/cjs/stateManagement/segmentation/config/segmentationVisibility.js +3 -52
  44. package/dist/cjs/stateManagement/segmentation/config/segmentationVisibility.js.map +1 -1
  45. package/dist/cjs/stateManagement/segmentation/convertStackToVolumeSegmentation.d.ts +9 -2
  46. package/dist/cjs/stateManagement/segmentation/convertStackToVolumeSegmentation.js +44 -27
  47. package/dist/cjs/stateManagement/segmentation/convertStackToVolumeSegmentation.js.map +1 -1
  48. package/dist/cjs/stateManagement/segmentation/convertVolumeToStackSegmentation.d.ts +13 -0
  49. package/dist/cjs/stateManagement/segmentation/convertVolumeToStackSegmentation.js +52 -26
  50. package/dist/cjs/stateManagement/segmentation/convertVolumeToStackSegmentation.js.map +1 -1
  51. package/dist/cjs/stateManagement/segmentation/helpers/validateSegmentationInput.js +6 -9
  52. package/dist/cjs/stateManagement/segmentation/helpers/validateSegmentationInput.js.map +1 -1
  53. package/dist/cjs/stateManagement/segmentation/index.d.ts +3 -1
  54. package/dist/cjs/stateManagement/segmentation/index.js +5 -1
  55. package/dist/cjs/stateManagement/segmentation/index.js.map +1 -1
  56. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts +2 -0
  57. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js +8 -0
  58. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js.map +1 -0
  59. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/computeAndAddLabelmapRepresentation.d.ts +2 -0
  60. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/computeAndAddLabelmapRepresentation.js +11 -0
  61. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/computeAndAddLabelmapRepresentation.js.map +1 -0
  62. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.d.ts +7 -0
  63. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js +162 -0
  64. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js.map +1 -0
  65. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.d.ts +6 -0
  66. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js +71 -0
  67. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js.map +1 -0
  68. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.d.ts +6 -0
  69. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js +120 -0
  70. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js.map +1 -0
  71. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/computeAndAddSurfaceRepresentation.d.ts +4 -0
  72. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/computeAndAddSurfaceRepresentation.js +12 -0
  73. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/computeAndAddSurfaceRepresentation.js.map +1 -0
  74. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.d.ts +3 -0
  75. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js +52 -0
  76. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js.map +1 -0
  77. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.d.ts +3 -0
  78. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js +60 -0
  79. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js.map +1 -0
  80. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/createAndCacheSurfacesFromRaw.d.ts +5 -0
  81. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/createAndCacheSurfacesFromRaw.js +56 -0
  82. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/createAndCacheSurfacesFromRaw.js.map +1 -0
  83. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/surfaceComputationStrategies.d.ts +12 -0
  84. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/surfaceComputationStrategies.js +94 -0
  85. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/surfaceComputationStrategies.js.map +1 -0
  86. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/updateSurfaceData.d.ts +1 -0
  87. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/updateSurfaceData.js +74 -0
  88. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/updateSurfaceData.js.map +1 -0
  89. package/dist/cjs/stateManagement/segmentation/polySeg/canComputeRequestedRepresentation.d.ts +2 -0
  90. package/dist/cjs/stateManagement/segmentation/polySeg/canComputeRequestedRepresentation.js +83 -0
  91. package/dist/cjs/stateManagement/segmentation/polySeg/canComputeRequestedRepresentation.js.map +1 -0
  92. package/dist/cjs/stateManagement/segmentation/polySeg/computeAndAddRepresentation.d.ts +3 -0
  93. package/dist/cjs/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js +64 -0
  94. package/dist/cjs/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js.map +1 -0
  95. package/dist/cjs/stateManagement/segmentation/polySeg/index.d.ts +5 -0
  96. package/dist/cjs/stateManagement/segmentation/polySeg/index.js +12 -0
  97. package/dist/cjs/stateManagement/segmentation/polySeg/index.js.map +1 -0
  98. package/dist/cjs/stateManagement/segmentation/polySeg/registerPolySegWorker.d.ts +1 -0
  99. package/dist/cjs/stateManagement/segmentation/polySeg/registerPolySegWorker.js +27 -0
  100. package/dist/cjs/stateManagement/segmentation/polySeg/registerPolySegWorker.js.map +1 -0
  101. package/dist/cjs/stateManagement/segmentation/segmentIndex.js +4 -0
  102. package/dist/cjs/stateManagement/segmentation/segmentIndex.js.map +1 -1
  103. package/dist/cjs/stateManagement/segmentation/segmentationState.d.ts +6 -1
  104. package/dist/cjs/stateManagement/segmentation/segmentationState.js +30 -1
  105. package/dist/cjs/stateManagement/segmentation/segmentationState.js.map +1 -1
  106. package/dist/cjs/store/ToolGroupManager/ToolGroup.d.ts +3 -1
  107. package/dist/cjs/store/ToolGroupManager/ToolGroup.js +3 -2
  108. package/dist/cjs/store/ToolGroupManager/ToolGroup.js.map +1 -1
  109. package/dist/cjs/tools/ScaleOverlayTool.js +2 -1
  110. package/dist/cjs/tools/ScaleOverlayTool.js.map +1 -1
  111. package/dist/cjs/tools/SegmentationIntersectionTool.js +1 -1
  112. package/dist/cjs/tools/SegmentationIntersectionTool.js.map +1 -1
  113. package/dist/cjs/tools/annotation/LivewireContourSegmentationTool.js +1 -1
  114. package/dist/cjs/tools/annotation/LivewireContourSegmentationTool.js.map +1 -1
  115. package/dist/cjs/tools/annotation/LivewireContourTool.d.ts +4 -3
  116. package/dist/cjs/tools/annotation/LivewireContourTool.js +26 -26
  117. package/dist/cjs/tools/annotation/LivewireContourTool.js.map +1 -1
  118. package/dist/cjs/tools/annotation/PlanarFreehandContourSegmentationTool.d.ts +1 -2
  119. package/dist/cjs/tools/annotation/PlanarFreehandContourSegmentationTool.js +0 -11
  120. package/dist/cjs/tools/annotation/PlanarFreehandContourSegmentationTool.js.map +1 -1
  121. package/dist/cjs/tools/annotation/PlanarFreehandROITool.js +2 -2
  122. package/dist/cjs/tools/annotation/PlanarFreehandROITool.js.map +1 -1
  123. package/dist/cjs/tools/annotation/ProbeTool.js +3 -0
  124. package/dist/cjs/tools/annotation/ProbeTool.js.map +1 -1
  125. package/dist/cjs/tools/annotation/SplineROITool.d.ts +6 -3
  126. package/dist/cjs/tools/annotation/SplineROITool.js +37 -18
  127. package/dist/cjs/tools/annotation/SplineROITool.js.map +1 -1
  128. package/dist/cjs/tools/annotation/planarFreehandROITool/closedContourEditLoop.js +12 -7
  129. package/dist/cjs/tools/annotation/planarFreehandROITool/closedContourEditLoop.js.map +1 -1
  130. package/dist/cjs/tools/annotation/planarFreehandROITool/drawLoop.js +25 -19
  131. package/dist/cjs/tools/annotation/planarFreehandROITool/drawLoop.js.map +1 -1
  132. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEditLoop.js +16 -10
  133. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEditLoop.js.map +1 -1
  134. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js +1 -1
  135. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js.map +1 -1
  136. package/dist/cjs/tools/annotation/planarFreehandROITool/renderMethods.js +19 -7
  137. package/dist/cjs/tools/annotation/planarFreehandROITool/renderMethods.js.map +1 -1
  138. package/dist/cjs/tools/annotation/splines/LinearSpline.js +1 -1
  139. package/dist/cjs/tools/annotation/splines/LinearSpline.js.map +1 -1
  140. package/dist/cjs/tools/annotation/splines/Spline.d.ts +2 -0
  141. package/dist/cjs/tools/annotation/splines/Spline.js +7 -3
  142. package/dist/cjs/tools/annotation/splines/Spline.js.map +1 -1
  143. package/dist/cjs/tools/base/AnnotationTool.js +1 -1
  144. package/dist/cjs/tools/base/AnnotationTool.js.map +1 -1
  145. package/dist/cjs/tools/base/BaseTool.js.map +1 -1
  146. package/dist/cjs/tools/base/ContourBaseTool.d.ts +1 -0
  147. package/dist/cjs/tools/base/ContourBaseTool.js +18 -1
  148. package/dist/cjs/tools/base/ContourBaseTool.js.map +1 -1
  149. package/dist/cjs/tools/base/ContourSegmentationBaseTool.d.ts +1 -2
  150. package/dist/cjs/tools/base/ContourSegmentationBaseTool.js +28 -24
  151. package/dist/cjs/tools/base/ContourSegmentationBaseTool.js.map +1 -1
  152. package/dist/cjs/tools/displayTools/Contour/contourConfig.js +1 -0
  153. package/dist/cjs/tools/displayTools/Contour/contourConfig.js.map +1 -1
  154. package/dist/cjs/tools/displayTools/Contour/contourDisplay.js +9 -6
  155. package/dist/cjs/tools/displayTools/Contour/contourDisplay.js.map +1 -1
  156. package/dist/cjs/tools/displayTools/Contour/removeContourFromElement.js.map +1 -1
  157. package/dist/cjs/tools/displayTools/Contour/{addContourSetsToElement.d.ts → vtkContour/addContourSetsToElement.d.ts} +1 -1
  158. package/dist/cjs/tools/displayTools/Contour/vtkContour/addContourSetsToElement.js.map +1 -0
  159. package/dist/cjs/tools/displayTools/Contour/vtkContour/addOrUpdateVTKContourSets.d.ts +3 -0
  160. package/dist/cjs/tools/displayTools/Contour/vtkContour/addOrUpdateVTKContourSets.js +14 -0
  161. package/dist/cjs/tools/displayTools/Contour/vtkContour/addOrUpdateVTKContourSets.js.map +1 -0
  162. package/dist/cjs/tools/displayTools/Contour/vtkContour/contourConfigCache.js.map +1 -0
  163. package/dist/cjs/tools/displayTools/Contour/vtkContour/updateVTKContourSets.d.ts +3 -0
  164. package/dist/cjs/tools/displayTools/Contour/{updateContourSets.js → vtkContour/updateVTKContourSets.js} +4 -4
  165. package/dist/cjs/tools/displayTools/Contour/vtkContour/updateVTKContourSets.js.map +1 -0
  166. package/dist/cjs/tools/displayTools/Contour/{utils.d.ts → vtkContour/utils.d.ts} +2 -2
  167. package/dist/cjs/tools/displayTools/Contour/vtkContour/utils.js.map +1 -0
  168. package/dist/cjs/tools/displayTools/Labelmap/addLabelmapToElement.js +1 -1
  169. package/dist/cjs/tools/displayTools/Labelmap/addLabelmapToElement.js.map +1 -1
  170. package/dist/cjs/tools/displayTools/Labelmap/index.d.ts +2 -1
  171. package/dist/cjs/tools/displayTools/Labelmap/index.js +4 -1
  172. package/dist/cjs/tools/displayTools/Labelmap/index.js.map +1 -1
  173. package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js +20 -2
  174. package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
  175. package/dist/cjs/tools/displayTools/Labelmap/validateLabelmap.d.ts +4 -0
  176. package/dist/cjs/tools/displayTools/Labelmap/validateLabelmap.js +38 -0
  177. package/dist/cjs/tools/displayTools/Labelmap/validateLabelmap.js.map +1 -0
  178. package/dist/cjs/tools/displayTools/Surface/addOrUpdateSurfaceToElement.d.ts +3 -0
  179. package/dist/cjs/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js +112 -0
  180. package/dist/cjs/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js.map +1 -0
  181. package/dist/cjs/tools/displayTools/Surface/surfaceConfig.d.ts +3 -0
  182. package/dist/cjs/tools/displayTools/Surface/surfaceConfig.js +11 -0
  183. package/dist/cjs/tools/displayTools/Surface/surfaceConfig.js.map +1 -0
  184. package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.d.ts +7 -0
  185. package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.js +173 -27
  186. package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.js.map +1 -1
  187. package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.d.ts +1 -0
  188. package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.js +27 -0
  189. package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.js.map +1 -0
  190. package/dist/cjs/tools/segmentation/BrushTool.js +1 -1
  191. package/dist/cjs/tools/segmentation/BrushTool.js.map +1 -1
  192. package/dist/cjs/tools/segmentation/CircleScissorsTool.js +1 -1
  193. package/dist/cjs/tools/segmentation/CircleScissorsTool.js.map +1 -1
  194. package/dist/cjs/tools/segmentation/PaintFillTool.js +1 -1
  195. package/dist/cjs/tools/segmentation/PaintFillTool.js.map +1 -1
  196. package/dist/cjs/tools/segmentation/RectangleScissorsTool.js +1 -1
  197. package/dist/cjs/tools/segmentation/RectangleScissorsTool.js.map +1 -1
  198. package/dist/cjs/tools/segmentation/SegmentSelectTool.d.ts +6 -2
  199. package/dist/cjs/tools/segmentation/SegmentSelectTool.js +45 -35
  200. package/dist/cjs/tools/segmentation/SegmentSelectTool.js.map +1 -1
  201. package/dist/cjs/tools/segmentation/SphereScissorsTool.js +1 -1
  202. package/dist/cjs/tools/segmentation/SphereScissorsTool.js.map +1 -1
  203. package/dist/cjs/tools/segmentation/strategies/BrushStrategy.js +7 -5
  204. package/dist/cjs/tools/segmentation/strategies/BrushStrategy.js.map +1 -1
  205. package/dist/cjs/tools/segmentation/strategies/compositions/regionFill.js +1 -1
  206. package/dist/cjs/tools/segmentation/strategies/compositions/regionFill.js.map +1 -1
  207. package/dist/cjs/tools/segmentation/strategies/fillSphere.js +14 -5
  208. package/dist/cjs/tools/segmentation/strategies/fillSphere.js.map +1 -1
  209. package/dist/cjs/tools/segmentation/strategies/utils/getStrategyData.js +21 -9
  210. package/dist/cjs/tools/segmentation/strategies/utils/getStrategyData.js.map +1 -1
  211. package/dist/cjs/tools/segmentation/strategies/utils/stackVolumeCheck.d.ts +5 -5
  212. package/dist/cjs/tools/segmentation/strategies/utils/stackVolumeCheck.js +15 -8
  213. package/dist/cjs/tools/segmentation/strategies/utils/stackVolumeCheck.js.map +1 -1
  214. package/dist/cjs/types/AnnotationTypes.d.ts +2 -0
  215. package/dist/cjs/types/ContourAnnotation.d.ts +6 -0
  216. package/dist/cjs/types/ContourAnnotation.js +7 -0
  217. package/dist/cjs/types/ContourAnnotation.js.map +1 -1
  218. package/dist/cjs/types/ContourSegmentationAnnotation.d.ts +0 -1
  219. package/dist/cjs/types/ContourTypes.d.ts +1 -0
  220. package/dist/cjs/types/EventTypes.d.ts +4 -1
  221. package/dist/cjs/types/ISpline.d.ts +1 -0
  222. package/dist/cjs/types/LabelmapTypes.d.ts +5 -1
  223. package/dist/cjs/types/PolySeg.d.ts +6 -0
  224. package/dist/cjs/types/PolySeg.js +3 -0
  225. package/dist/cjs/types/PolySeg.js.map +1 -0
  226. package/dist/cjs/types/SegmentationStateTypes.d.ts +12 -2
  227. package/dist/cjs/types/SplineProps.d.ts +1 -0
  228. package/dist/cjs/types/SurfaceTypes.d.ts +1 -1
  229. package/dist/cjs/types/index.d.ts +2 -1
  230. package/dist/cjs/utilities/boundingBox/getBoundingBoxAroundShape.js +6 -6
  231. package/dist/cjs/utilities/boundingBox/getBoundingBoxAroundShape.js.map +1 -1
  232. package/dist/cjs/utilities/contourSegmentation/addContourSegmentationAnnotation.d.ts +2 -0
  233. package/dist/cjs/utilities/contourSegmentation/addContourSegmentationAnnotation.js +20 -0
  234. package/dist/cjs/utilities/contourSegmentation/addContourSegmentationAnnotation.js.map +1 -0
  235. package/dist/cjs/utilities/contourSegmentation/areSameSegment.js +0 -2
  236. package/dist/cjs/utilities/contourSegmentation/areSameSegment.js.map +1 -1
  237. package/dist/cjs/utilities/contourSegmentation/index.d.ts +2 -0
  238. package/dist/cjs/utilities/contourSegmentation/index.js +5 -1
  239. package/dist/cjs/utilities/contourSegmentation/index.js.map +1 -1
  240. package/dist/cjs/utilities/contourSegmentation/removeContourSegmentationAnnotation.d.ts +2 -0
  241. package/dist/cjs/utilities/contourSegmentation/removeContourSegmentationAnnotation.js +19 -0
  242. package/dist/cjs/utilities/contourSegmentation/removeContourSegmentationAnnotation.js.map +1 -0
  243. package/dist/cjs/utilities/contours/detectContourHoles.js.map +1 -1
  244. package/dist/cjs/utilities/contours/generateContourSetsFromLabelmap.js +2 -2
  245. package/dist/cjs/utilities/contours/generateContourSetsFromLabelmap.js.map +1 -1
  246. package/dist/cjs/utilities/contours/getContourHolesDataCanvas.d.ts +3 -0
  247. package/dist/cjs/utilities/contours/getContourHolesDataCanvas.js +21 -0
  248. package/dist/cjs/utilities/contours/getContourHolesDataCanvas.js.map +1 -0
  249. package/dist/cjs/utilities/contours/getContourHolesDataWorld.d.ts +3 -0
  250. package/dist/cjs/utilities/contours/getContourHolesDataWorld.js +10 -0
  251. package/dist/cjs/utilities/contours/getContourHolesDataWorld.js.map +1 -0
  252. package/dist/cjs/utilities/contours/getDeduplicatedVTKPolyDataPoints.d.ts +11 -0
  253. package/dist/cjs/utilities/contours/getDeduplicatedVTKPolyDataPoints.js +50 -0
  254. package/dist/cjs/utilities/contours/getDeduplicatedVTKPolyDataPoints.js.map +1 -0
  255. package/dist/cjs/utilities/contours/index.d.ts +5 -2
  256. package/dist/cjs/utilities/contours/index.js +9 -3
  257. package/dist/cjs/utilities/contours/index.js.map +1 -1
  258. package/dist/cjs/utilities/contours/updateContourPolyline.d.ts +10 -0
  259. package/dist/cjs/utilities/contours/updateContourPolyline.js +64 -0
  260. package/dist/cjs/utilities/contours/updateContourPolyline.js.map +1 -0
  261. package/dist/cjs/utilities/index.d.ts +3 -1
  262. package/dist/cjs/utilities/index.js +5 -1
  263. package/dist/cjs/utilities/index.js.map +1 -1
  264. package/dist/cjs/utilities/math/polyline/containsPoint.js.map +1 -1
  265. package/dist/cjs/utilities/math/polyline/containsPoints.d.ts +2 -0
  266. package/dist/cjs/utilities/math/polyline/containsPoints.js +16 -0
  267. package/dist/cjs/utilities/math/polyline/containsPoints.js.map +1 -0
  268. package/dist/cjs/utilities/math/polyline/getWindingDirection.d.ts +2 -0
  269. package/dist/cjs/utilities/math/polyline/getWindingDirection.js +12 -0
  270. package/dist/cjs/utilities/math/polyline/getWindingDirection.js.map +1 -0
  271. package/dist/cjs/utilities/math/polyline/index.d.ts +4 -1
  272. package/dist/cjs/utilities/math/polyline/index.js +7 -1
  273. package/dist/cjs/utilities/math/polyline/index.js.map +1 -1
  274. package/dist/cjs/utilities/math/polyline/isPointInsidePolyline3D.d.ts +2 -0
  275. package/dist/cjs/utilities/math/polyline/isPointInsidePolyline3D.js +34 -0
  276. package/dist/cjs/utilities/math/polyline/isPointInsidePolyline3D.js.map +1 -0
  277. package/dist/cjs/utilities/math/polyline/planarFreehandROIInternalTypes.d.ts +1 -0
  278. package/dist/cjs/utilities/segmentation/contourAndFindLargestBidirectional.js +0 -1
  279. package/dist/cjs/utilities/segmentation/contourAndFindLargestBidirectional.js.map +1 -1
  280. package/dist/cjs/utilities/segmentation/getHoveredContourSegmentationAnnotation.d.ts +1 -0
  281. package/dist/cjs/utilities/segmentation/getHoveredContourSegmentationAnnotation.js +18 -0
  282. package/dist/cjs/utilities/segmentation/getHoveredContourSegmentationAnnotation.js.map +1 -0
  283. package/dist/cjs/utilities/segmentation/getSegmentAtLabelmapBorder.d.ts +7 -0
  284. package/dist/cjs/utilities/segmentation/getSegmentAtLabelmapBorder.js +77 -0
  285. package/dist/cjs/utilities/segmentation/getSegmentAtLabelmapBorder.js.map +1 -0
  286. package/dist/cjs/utilities/segmentation/getSegmentAtWorldPoint.d.ts +11 -0
  287. package/dist/cjs/utilities/segmentation/getSegmentAtWorldPoint.js +82 -0
  288. package/dist/cjs/utilities/segmentation/getSegmentAtWorldPoint.js.map +1 -0
  289. package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.d.ts +2 -0
  290. package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.js +59 -0
  291. package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.js.map +1 -0
  292. package/dist/cjs/utilities/segmentation/index.d.ts +5 -1
  293. package/dist/cjs/utilities/segmentation/index.js +9 -1
  294. package/dist/cjs/utilities/segmentation/index.js.map +1 -1
  295. package/dist/cjs/utilities/triggerAnnotationRenderForToolGroupIds.d.ts +2 -0
  296. package/dist/cjs/utilities/triggerAnnotationRenderForToolGroupIds.js +32 -0
  297. package/dist/cjs/utilities/triggerAnnotationRenderForToolGroupIds.js.map +1 -0
  298. package/dist/cjs/workers/clippingPlaneWorker.d.ts +1 -0
  299. package/dist/cjs/workers/clippingPlaneWorker.js +63 -0
  300. package/dist/cjs/workers/clippingPlaneWorker.js.map +1 -0
  301. package/dist/cjs/workers/polySegConverters.d.ts +1 -0
  302. package/dist/cjs/workers/polySegConverters.js +267 -0
  303. package/dist/cjs/workers/polySegConverters.js.map +1 -0
  304. package/dist/esm/drawingSvg/drawPath.js +49 -0
  305. package/dist/esm/drawingSvg/drawPath.js.map +1 -0
  306. package/dist/esm/drawingSvg/drawPolyline.js +2 -10
  307. package/dist/esm/drawingSvg/drawPolyline.js.map +1 -1
  308. package/dist/esm/drawingSvg/index.js +2 -1
  309. package/dist/esm/drawingSvg/index.js.map +1 -1
  310. package/dist/esm/enums/WorkerTypes.js +10 -0
  311. package/dist/esm/enums/WorkerTypes.js.map +1 -0
  312. package/dist/esm/enums/index.js +2 -1
  313. package/dist/esm/enums/index.js.map +1 -1
  314. package/dist/esm/eventDispatchers/shared/getActiveToolForMouseEvent.js.map +1 -1
  315. package/dist/esm/eventListeners/annotations/contourSegmentation/contourSegmentationCompleted.js +112 -43
  316. package/dist/esm/eventListeners/annotations/contourSegmentation/contourSegmentationCompleted.js.map +1 -1
  317. package/dist/esm/eventListeners/segmentation/imageChangeEventListener.js +3 -3
  318. package/dist/esm/eventListeners/segmentation/imageChangeEventListener.js.map +1 -1
  319. package/dist/esm/eventListeners/segmentation/labelmap/onLabelmapSegmentationDataModified.js +59 -45
  320. package/dist/esm/eventListeners/segmentation/labelmap/onLabelmapSegmentationDataModified.js.map +1 -1
  321. package/dist/esm/stateManagement/annotation/FrameOfReferenceSpecificAnnotationManager.js +5 -0
  322. package/dist/esm/stateManagement/annotation/FrameOfReferenceSpecificAnnotationManager.js.map +1 -1
  323. package/dist/esm/stateManagement/annotation/annotationState.js +46 -1
  324. package/dist/esm/stateManagement/annotation/annotationState.js.map +1 -1
  325. package/dist/esm/stateManagement/annotation/helpers/state.js +12 -2
  326. package/dist/esm/stateManagement/annotation/helpers/state.js.map +1 -1
  327. package/dist/esm/stateManagement/index.js +2 -2
  328. package/dist/esm/stateManagement/index.js.map +1 -1
  329. package/dist/esm/stateManagement/segmentation/SegmentationStateManager.js +4 -1
  330. package/dist/esm/stateManagement/segmentation/SegmentationStateManager.js.map +1 -1
  331. package/dist/esm/stateManagement/segmentation/addRepresentationData.js +30 -0
  332. package/dist/esm/stateManagement/segmentation/addRepresentationData.js.map +1 -0
  333. package/dist/esm/stateManagement/segmentation/addSegmentationRepresentation.js +32 -15
  334. package/dist/esm/stateManagement/segmentation/addSegmentationRepresentation.js.map +1 -1
  335. package/dist/esm/stateManagement/segmentation/config/segmentationVisibility.js +1 -46
  336. package/dist/esm/stateManagement/segmentation/config/segmentationVisibility.js.map +1 -1
  337. package/dist/esm/stateManagement/segmentation/convertStackToVolumeSegmentation.js +42 -27
  338. package/dist/esm/stateManagement/segmentation/convertStackToVolumeSegmentation.js.map +1 -1
  339. package/dist/esm/stateManagement/segmentation/convertVolumeToStackSegmentation.js +49 -25
  340. package/dist/esm/stateManagement/segmentation/convertVolumeToStackSegmentation.js.map +1 -1
  341. package/dist/esm/stateManagement/segmentation/helpers/validateSegmentationInput.js +6 -6
  342. package/dist/esm/stateManagement/segmentation/helpers/validateSegmentationInput.js.map +1 -1
  343. package/dist/esm/stateManagement/segmentation/index.js +3 -1
  344. package/dist/esm/stateManagement/segmentation/index.js.map +1 -1
  345. package/dist/esm/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js +4 -0
  346. package/dist/esm/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js.map +1 -0
  347. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/computeAndAddLabelmapRepresentation.js +7 -0
  348. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/computeAndAddLabelmapRepresentation.js.map +1 -0
  349. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js +142 -0
  350. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js.map +1 -0
  351. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js +53 -0
  352. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js.map +1 -0
  353. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js +108 -0
  354. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js.map +1 -0
  355. package/dist/esm/stateManagement/segmentation/polySeg/Surface/computeAndAddSurfaceRepresentation.js +8 -0
  356. package/dist/esm/stateManagement/segmentation/polySeg/Surface/computeAndAddSurfaceRepresentation.js.map +1 -0
  357. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js +37 -0
  358. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js.map +1 -0
  359. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js +45 -0
  360. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js.map +1 -0
  361. package/dist/esm/stateManagement/segmentation/polySeg/Surface/createAndCacheSurfacesFromRaw.js +41 -0
  362. package/dist/esm/stateManagement/segmentation/polySeg/Surface/createAndCacheSurfacesFromRaw.js.map +1 -0
  363. package/dist/esm/stateManagement/segmentation/polySeg/Surface/surfaceComputationStrategies.js +78 -0
  364. package/dist/esm/stateManagement/segmentation/polySeg/Surface/surfaceComputationStrategies.js.map +1 -0
  365. package/dist/esm/stateManagement/segmentation/polySeg/Surface/updateSurfaceData.js +59 -0
  366. package/dist/esm/stateManagement/segmentation/polySeg/Surface/updateSurfaceData.js.map +1 -0
  367. package/dist/esm/stateManagement/segmentation/polySeg/canComputeRequestedRepresentation.js +68 -0
  368. package/dist/esm/stateManagement/segmentation/polySeg/canComputeRequestedRepresentation.js.map +1 -0
  369. package/dist/esm/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js +47 -0
  370. package/dist/esm/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js.map +1 -0
  371. package/dist/esm/stateManagement/segmentation/polySeg/index.js +6 -0
  372. package/dist/esm/stateManagement/segmentation/polySeg/index.js.map +1 -0
  373. package/dist/esm/stateManagement/segmentation/polySeg/registerPolySegWorker.js +23 -0
  374. package/dist/esm/stateManagement/segmentation/polySeg/registerPolySegWorker.js.map +1 -0
  375. package/dist/esm/stateManagement/segmentation/segmentIndex.js +4 -0
  376. package/dist/esm/stateManagement/segmentation/segmentIndex.js.map +1 -1
  377. package/dist/esm/stateManagement/segmentation/segmentationState.js +28 -1
  378. package/dist/esm/stateManagement/segmentation/segmentationState.js.map +1 -1
  379. package/dist/esm/store/ToolGroupManager/ToolGroup.js +3 -2
  380. package/dist/esm/store/ToolGroupManager/ToolGroup.js.map +1 -1
  381. package/dist/esm/tools/ScaleOverlayTool.js +2 -1
  382. package/dist/esm/tools/ScaleOverlayTool.js.map +1 -1
  383. package/dist/esm/tools/SegmentationIntersectionTool.js +1 -1
  384. package/dist/esm/tools/SegmentationIntersectionTool.js.map +1 -1
  385. package/dist/esm/tools/annotation/LivewireContourSegmentationTool.js +1 -1
  386. package/dist/esm/tools/annotation/LivewireContourSegmentationTool.js.map +1 -1
  387. package/dist/esm/tools/annotation/LivewireContourTool.js +28 -28
  388. package/dist/esm/tools/annotation/LivewireContourTool.js.map +1 -1
  389. package/dist/esm/tools/annotation/PlanarFreehandContourSegmentationTool.js +0 -11
  390. package/dist/esm/tools/annotation/PlanarFreehandContourSegmentationTool.js.map +1 -1
  391. package/dist/esm/tools/annotation/PlanarFreehandROITool.js +3 -3
  392. package/dist/esm/tools/annotation/PlanarFreehandROITool.js.map +1 -1
  393. package/dist/esm/tools/annotation/ProbeTool.js +3 -0
  394. package/dist/esm/tools/annotation/ProbeTool.js.map +1 -1
  395. package/dist/esm/tools/annotation/SplineROITool.js +37 -19
  396. package/dist/esm/tools/annotation/SplineROITool.js.map +1 -1
  397. package/dist/esm/tools/annotation/planarFreehandROITool/closedContourEditLoop.js +12 -7
  398. package/dist/esm/tools/annotation/planarFreehandROITool/closedContourEditLoop.js.map +1 -1
  399. package/dist/esm/tools/annotation/planarFreehandROITool/drawLoop.js +26 -20
  400. package/dist/esm/tools/annotation/planarFreehandROITool/drawLoop.js.map +1 -1
  401. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEditLoop.js +16 -10
  402. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEditLoop.js.map +1 -1
  403. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js +1 -1
  404. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js.map +1 -1
  405. package/dist/esm/tools/annotation/planarFreehandROITool/renderMethods.js +20 -8
  406. package/dist/esm/tools/annotation/planarFreehandROITool/renderMethods.js.map +1 -1
  407. package/dist/esm/tools/annotation/splines/LinearSpline.js +1 -1
  408. package/dist/esm/tools/annotation/splines/LinearSpline.js.map +1 -1
  409. package/dist/esm/tools/annotation/splines/Spline.js +5 -1
  410. package/dist/esm/tools/annotation/splines/Spline.js.map +1 -1
  411. package/dist/esm/tools/base/AnnotationTool.js +1 -1
  412. package/dist/esm/tools/base/AnnotationTool.js.map +1 -1
  413. package/dist/esm/tools/base/BaseTool.js +1 -1
  414. package/dist/esm/tools/base/BaseTool.js.map +1 -1
  415. package/dist/esm/tools/base/ContourBaseTool.js +20 -3
  416. package/dist/esm/tools/base/ContourBaseTool.js.map +1 -1
  417. package/dist/esm/tools/base/ContourSegmentationBaseTool.js +28 -24
  418. package/dist/esm/tools/base/ContourSegmentationBaseTool.js.map +1 -1
  419. package/dist/esm/tools/displayTools/Contour/contourConfig.js +1 -0
  420. package/dist/esm/tools/displayTools/Contour/contourConfig.js.map +1 -1
  421. package/dist/esm/tools/displayTools/Contour/contourDisplay.js +10 -7
  422. package/dist/esm/tools/displayTools/Contour/contourDisplay.js.map +1 -1
  423. package/dist/esm/tools/displayTools/Contour/removeContourFromElement.js.map +1 -1
  424. package/dist/esm/tools/displayTools/Contour/vtkContour/addContourSetsToElement.js.map +1 -0
  425. package/dist/esm/tools/displayTools/Contour/{addOrUpdateContourSets.js → vtkContour/addOrUpdateVTKContourSets.js} +4 -4
  426. package/dist/esm/tools/displayTools/Contour/vtkContour/addOrUpdateVTKContourSets.js.map +1 -0
  427. package/dist/esm/tools/displayTools/Contour/vtkContour/contourConfigCache.js.map +1 -0
  428. package/dist/esm/tools/displayTools/Contour/{updateContourSets.js → vtkContour/updateVTKContourSets.js} +2 -2
  429. package/dist/esm/tools/displayTools/Contour/vtkContour/updateVTKContourSets.js.map +1 -0
  430. package/dist/esm/tools/displayTools/Contour/vtkContour/utils.js.map +1 -0
  431. package/dist/esm/tools/displayTools/Labelmap/addLabelmapToElement.js +1 -1
  432. package/dist/esm/tools/displayTools/Labelmap/addLabelmapToElement.js.map +1 -1
  433. package/dist/esm/tools/displayTools/Labelmap/index.js +2 -1
  434. package/dist/esm/tools/displayTools/Labelmap/index.js.map +1 -1
  435. package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js +20 -2
  436. package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
  437. package/dist/esm/tools/displayTools/Labelmap/validateLabelmap.js +33 -0
  438. package/dist/esm/tools/displayTools/Labelmap/validateLabelmap.js.map +1 -0
  439. package/dist/esm/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js +106 -0
  440. package/dist/esm/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js.map +1 -0
  441. package/dist/esm/tools/displayTools/Surface/surfaceConfig.js +9 -0
  442. package/dist/esm/tools/displayTools/Surface/surfaceConfig.js.map +1 -0
  443. package/dist/esm/tools/displayTools/Surface/surfaceDisplay.js +162 -28
  444. package/dist/esm/tools/displayTools/Surface/surfaceDisplay.js.map +1 -1
  445. package/dist/esm/tools/displayTools/registerDisplayToolsWorker.js +23 -0
  446. package/dist/esm/tools/displayTools/registerDisplayToolsWorker.js.map +1 -0
  447. package/dist/esm/tools/segmentation/BrushTool.js +1 -1
  448. package/dist/esm/tools/segmentation/BrushTool.js.map +1 -1
  449. package/dist/esm/tools/segmentation/CircleScissorsTool.js +1 -1
  450. package/dist/esm/tools/segmentation/CircleScissorsTool.js.map +1 -1
  451. package/dist/esm/tools/segmentation/PaintFillTool.js +1 -1
  452. package/dist/esm/tools/segmentation/PaintFillTool.js.map +1 -1
  453. package/dist/esm/tools/segmentation/RectangleScissorsTool.js +1 -1
  454. package/dist/esm/tools/segmentation/RectangleScissorsTool.js.map +1 -1
  455. package/dist/esm/tools/segmentation/SegmentSelectTool.js +47 -37
  456. package/dist/esm/tools/segmentation/SegmentSelectTool.js.map +1 -1
  457. package/dist/esm/tools/segmentation/SphereScissorsTool.js +1 -1
  458. package/dist/esm/tools/segmentation/SphereScissorsTool.js.map +1 -1
  459. package/dist/esm/tools/segmentation/strategies/BrushStrategy.js +7 -5
  460. package/dist/esm/tools/segmentation/strategies/BrushStrategy.js.map +1 -1
  461. package/dist/esm/tools/segmentation/strategies/compositions/regionFill.js +1 -1
  462. package/dist/esm/tools/segmentation/strategies/compositions/regionFill.js.map +1 -1
  463. package/dist/esm/tools/segmentation/strategies/fillSphere.js +14 -5
  464. package/dist/esm/tools/segmentation/strategies/fillSphere.js.map +1 -1
  465. package/dist/esm/tools/segmentation/strategies/utils/getStrategyData.js +21 -9
  466. package/dist/esm/tools/segmentation/strategies/utils/getStrategyData.js.map +1 -1
  467. package/dist/esm/tools/segmentation/strategies/utils/stackVolumeCheck.js +15 -7
  468. package/dist/esm/tools/segmentation/strategies/utils/stackVolumeCheck.js.map +1 -1
  469. package/dist/esm/types/ContourAnnotation.js +6 -1
  470. package/dist/esm/types/ContourAnnotation.js.map +1 -1
  471. package/dist/esm/types/PolySeg.js +2 -0
  472. package/dist/esm/types/PolySeg.js.map +1 -0
  473. package/dist/esm/utilities/boundingBox/getBoundingBoxAroundShape.js +3 -2
  474. package/dist/esm/utilities/boundingBox/getBoundingBoxAroundShape.js.map +1 -1
  475. package/dist/esm/utilities/contourSegmentation/addContourSegmentationAnnotation.js +16 -0
  476. package/dist/esm/utilities/contourSegmentation/addContourSegmentationAnnotation.js.map +1 -0
  477. package/dist/esm/utilities/contourSegmentation/areSameSegment.js +0 -2
  478. package/dist/esm/utilities/contourSegmentation/areSameSegment.js.map +1 -1
  479. package/dist/esm/utilities/contourSegmentation/index.js +2 -0
  480. package/dist/esm/utilities/contourSegmentation/index.js.map +1 -1
  481. package/dist/esm/utilities/contourSegmentation/removeContourSegmentationAnnotation.js +15 -0
  482. package/dist/esm/utilities/contourSegmentation/removeContourSegmentationAnnotation.js.map +1 -0
  483. package/dist/esm/utilities/contours/detectContourHoles.js.map +1 -1
  484. package/dist/esm/utilities/contours/generateContourSetsFromLabelmap.js +2 -2
  485. package/dist/esm/utilities/contours/generateContourSetsFromLabelmap.js.map +1 -1
  486. package/dist/esm/utilities/contours/getContourHolesDataCanvas.js +15 -0
  487. package/dist/esm/utilities/contours/getContourHolesDataCanvas.js.map +1 -0
  488. package/dist/esm/utilities/contours/getContourHolesDataWorld.js +6 -0
  489. package/dist/esm/utilities/contours/getContourHolesDataWorld.js.map +1 -0
  490. package/dist/esm/utilities/contours/getDeduplicatedVTKPolyDataPoints.js +46 -0
  491. package/dist/esm/utilities/contours/getDeduplicatedVTKPolyDataPoints.js.map +1 -0
  492. package/dist/esm/utilities/contours/index.js +5 -2
  493. package/dist/esm/utilities/contours/index.js.map +1 -1
  494. package/dist/esm/utilities/contours/updateContourPolyline.js +38 -0
  495. package/dist/esm/utilities/contours/updateContourPolyline.js.map +1 -0
  496. package/dist/esm/utilities/index.js +3 -1
  497. package/dist/esm/utilities/index.js.map +1 -1
  498. package/dist/esm/utilities/math/polyline/containsPoint.js.map +1 -1
  499. package/dist/esm/utilities/math/polyline/containsPoints.js +10 -0
  500. package/dist/esm/utilities/math/polyline/containsPoints.js.map +1 -0
  501. package/dist/esm/utilities/math/polyline/getWindingDirection.js +6 -0
  502. package/dist/esm/utilities/math/polyline/getWindingDirection.js.map +1 -0
  503. package/dist/esm/utilities/math/polyline/index.js +4 -1
  504. package/dist/esm/utilities/math/polyline/index.js.map +1 -1
  505. package/dist/esm/utilities/math/polyline/isPointInsidePolyline3D.js +27 -0
  506. package/dist/esm/utilities/math/polyline/isPointInsidePolyline3D.js.map +1 -0
  507. package/dist/esm/utilities/segmentation/contourAndFindLargestBidirectional.js +0 -1
  508. package/dist/esm/utilities/segmentation/contourAndFindLargestBidirectional.js.map +1 -1
  509. package/dist/esm/utilities/segmentation/getHoveredContourSegmentationAnnotation.js +14 -0
  510. package/dist/esm/utilities/segmentation/getHoveredContourSegmentationAnnotation.js.map +1 -0
  511. package/dist/esm/utilities/segmentation/getSegmentAtLabelmapBorder.js +73 -0
  512. package/dist/esm/utilities/segmentation/getSegmentAtLabelmapBorder.js.map +1 -0
  513. package/dist/esm/utilities/segmentation/getSegmentAtWorldPoint.js +75 -0
  514. package/dist/esm/utilities/segmentation/getSegmentAtWorldPoint.js.map +1 -0
  515. package/dist/esm/utilities/segmentation/getUniqueSegmentIndices.js +55 -0
  516. package/dist/esm/utilities/segmentation/getUniqueSegmentIndices.js.map +1 -0
  517. package/dist/esm/utilities/segmentation/index.js +5 -1
  518. package/dist/esm/utilities/segmentation/index.js.map +1 -1
  519. package/dist/esm/utilities/triggerAnnotationRenderForToolGroupIds.js +25 -0
  520. package/dist/esm/utilities/triggerAnnotationRenderForToolGroupIds.js.map +1 -0
  521. package/dist/esm/workers/clippingPlaneWorker.js +58 -0
  522. package/dist/esm/workers/clippingPlaneWorker.js.map +1 -0
  523. package/dist/esm/workers/polySegConverters.js +241 -0
  524. package/dist/esm/workers/polySegConverters.js.map +1 -0
  525. package/dist/types/drawingSvg/drawPath.d.ts +12 -0
  526. package/dist/types/drawingSvg/drawPath.d.ts.map +1 -0
  527. package/dist/types/drawingSvg/drawPolyline.d.ts +1 -1
  528. package/dist/types/drawingSvg/drawPolyline.d.ts.map +1 -1
  529. package/dist/types/drawingSvg/index.d.ts +2 -1
  530. package/dist/types/drawingSvg/index.d.ts.map +1 -1
  531. package/dist/types/enums/WorkerTypes.d.ts +9 -0
  532. package/dist/types/enums/WorkerTypes.d.ts.map +1 -0
  533. package/dist/types/enums/index.d.ts +2 -1
  534. package/dist/types/eventListeners/annotations/contourSegmentation/contourSegmentationCompleted.d.ts +1 -1
  535. package/dist/types/eventListeners/annotations/contourSegmentation/contourSegmentationCompleted.d.ts.map +1 -1
  536. package/dist/types/eventListeners/segmentation/imageChangeEventListener.d.ts.map +1 -1
  537. package/dist/types/eventListeners/segmentation/labelmap/onLabelmapSegmentationDataModified.d.ts.map +1 -1
  538. package/dist/types/stateManagement/annotation/FrameOfReferenceSpecificAnnotationManager.d.ts +1 -0
  539. package/dist/types/stateManagement/annotation/FrameOfReferenceSpecificAnnotationManager.d.ts.map +1 -1
  540. package/dist/types/stateManagement/annotation/annotationState.d.ts +7 -1
  541. package/dist/types/stateManagement/annotation/annotationState.d.ts.map +1 -1
  542. package/dist/types/stateManagement/annotation/helpers/state.d.ts +2 -1
  543. package/dist/types/stateManagement/annotation/helpers/state.d.ts.map +1 -1
  544. package/dist/types/stateManagement/index.d.ts +6 -1
  545. package/dist/types/stateManagement/segmentation/SegmentationStateManager.d.ts.map +1 -1
  546. package/dist/types/stateManagement/segmentation/addRepresentationData.d.ts +13 -0
  547. package/dist/types/stateManagement/segmentation/addRepresentationData.d.ts.map +1 -0
  548. package/dist/types/stateManagement/segmentation/addSegmentationRepresentation.d.ts.map +1 -1
  549. package/dist/types/stateManagement/segmentation/config/segmentationVisibility.d.ts.map +1 -1
  550. package/dist/types/stateManagement/segmentation/convertStackToVolumeSegmentation.d.ts +9 -2
  551. package/dist/types/stateManagement/segmentation/convertStackToVolumeSegmentation.d.ts.map +1 -1
  552. package/dist/types/stateManagement/segmentation/convertVolumeToStackSegmentation.d.ts +13 -0
  553. package/dist/types/stateManagement/segmentation/convertVolumeToStackSegmentation.d.ts.map +1 -1
  554. package/dist/types/stateManagement/segmentation/helpers/validateSegmentationInput.d.ts.map +1 -1
  555. package/dist/types/stateManagement/segmentation/index.d.ts +3 -1
  556. package/dist/types/stateManagement/segmentation/index.d.ts.map +1 -1
  557. package/dist/types/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts +3 -0
  558. package/dist/types/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts.map +1 -0
  559. package/dist/types/stateManagement/segmentation/polySeg/Labelmap/computeAndAddLabelmapRepresentation.d.ts +3 -0
  560. package/dist/types/stateManagement/segmentation/polySeg/Labelmap/computeAndAddLabelmapRepresentation.d.ts.map +1 -0
  561. package/dist/types/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.d.ts +8 -0
  562. package/dist/types/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.d.ts.map +1 -0
  563. package/dist/types/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.d.ts +7 -0
  564. package/dist/types/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.d.ts.map +1 -0
  565. package/dist/types/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.d.ts +7 -0
  566. package/dist/types/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.d.ts.map +1 -0
  567. package/dist/types/stateManagement/segmentation/polySeg/Surface/computeAndAddSurfaceRepresentation.d.ts +5 -0
  568. package/dist/types/stateManagement/segmentation/polySeg/Surface/computeAndAddSurfaceRepresentation.d.ts.map +1 -0
  569. package/dist/types/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.d.ts +4 -0
  570. package/dist/types/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.d.ts.map +1 -0
  571. package/dist/types/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.d.ts +4 -0
  572. package/dist/types/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.d.ts.map +1 -0
  573. package/dist/types/stateManagement/segmentation/polySeg/Surface/createAndCacheSurfacesFromRaw.d.ts +6 -0
  574. package/dist/types/stateManagement/segmentation/polySeg/Surface/createAndCacheSurfacesFromRaw.d.ts.map +1 -0
  575. package/dist/types/stateManagement/segmentation/polySeg/Surface/surfaceComputationStrategies.d.ts +13 -0
  576. package/dist/types/stateManagement/segmentation/polySeg/Surface/surfaceComputationStrategies.d.ts.map +1 -0
  577. package/dist/types/stateManagement/segmentation/polySeg/Surface/updateSurfaceData.d.ts +2 -0
  578. package/dist/types/stateManagement/segmentation/polySeg/Surface/updateSurfaceData.d.ts.map +1 -0
  579. package/dist/types/stateManagement/segmentation/polySeg/canComputeRequestedRepresentation.d.ts +3 -0
  580. package/dist/types/stateManagement/segmentation/polySeg/canComputeRequestedRepresentation.d.ts.map +1 -0
  581. package/dist/types/stateManagement/segmentation/polySeg/computeAndAddRepresentation.d.ts +4 -0
  582. package/dist/types/stateManagement/segmentation/polySeg/computeAndAddRepresentation.d.ts.map +1 -0
  583. package/dist/types/stateManagement/segmentation/polySeg/index.d.ts +6 -0
  584. package/dist/types/stateManagement/segmentation/polySeg/index.d.ts.map +1 -0
  585. package/dist/types/stateManagement/segmentation/polySeg/registerPolySegWorker.d.ts +2 -0
  586. package/dist/types/stateManagement/segmentation/polySeg/registerPolySegWorker.d.ts.map +1 -0
  587. package/dist/types/stateManagement/segmentation/segmentIndex.d.ts.map +1 -1
  588. package/dist/types/stateManagement/segmentation/segmentationState.d.ts +6 -1
  589. package/dist/types/stateManagement/segmentation/segmentationState.d.ts.map +1 -1
  590. package/dist/types/store/ToolGroupManager/ToolGroup.d.ts +3 -1
  591. package/dist/types/store/ToolGroupManager/ToolGroup.d.ts.map +1 -1
  592. package/dist/types/tools/ScaleOverlayTool.d.ts.map +1 -1
  593. package/dist/types/tools/annotation/LivewireContourTool.d.ts +4 -3
  594. package/dist/types/tools/annotation/LivewireContourTool.d.ts.map +1 -1
  595. package/dist/types/tools/annotation/PlanarFreehandContourSegmentationTool.d.ts +1 -2
  596. package/dist/types/tools/annotation/PlanarFreehandContourSegmentationTool.d.ts.map +1 -1
  597. package/dist/types/tools/annotation/PlanarFreehandROITool.d.ts.map +1 -1
  598. package/dist/types/tools/annotation/ProbeTool.d.ts.map +1 -1
  599. package/dist/types/tools/annotation/SplineROITool.d.ts +6 -3
  600. package/dist/types/tools/annotation/SplineROITool.d.ts.map +1 -1
  601. package/dist/types/tools/annotation/planarFreehandROITool/closedContourEditLoop.d.ts.map +1 -1
  602. package/dist/types/tools/annotation/planarFreehandROITool/drawLoop.d.ts.map +1 -1
  603. package/dist/types/tools/annotation/planarFreehandROITool/openContourEditLoop.d.ts.map +1 -1
  604. package/dist/types/tools/annotation/planarFreehandROITool/renderMethods.d.ts.map +1 -1
  605. package/dist/types/tools/annotation/splines/Spline.d.ts +2 -0
  606. package/dist/types/tools/annotation/splines/Spline.d.ts.map +1 -1
  607. package/dist/types/tools/base/AnnotationTool.d.ts.map +1 -1
  608. package/dist/types/tools/base/BaseTool.d.ts.map +1 -1
  609. package/dist/types/tools/base/ContourBaseTool.d.ts +1 -0
  610. package/dist/types/tools/base/ContourBaseTool.d.ts.map +1 -1
  611. package/dist/types/tools/base/ContourSegmentationBaseTool.d.ts +1 -2
  612. package/dist/types/tools/base/ContourSegmentationBaseTool.d.ts.map +1 -1
  613. package/dist/types/tools/displayTools/Contour/contourConfig.d.ts.map +1 -1
  614. package/dist/types/tools/displayTools/Contour/contourDisplay.d.ts.map +1 -1
  615. package/dist/types/tools/displayTools/Contour/removeContourFromElement.d.ts.map +1 -1
  616. package/dist/types/tools/displayTools/Contour/{addContourSetsToElement.d.ts → vtkContour/addContourSetsToElement.d.ts} +1 -1
  617. package/dist/types/tools/displayTools/Contour/vtkContour/addContourSetsToElement.d.ts.map +1 -0
  618. package/dist/types/tools/displayTools/Contour/vtkContour/addOrUpdateVTKContourSets.d.ts +4 -0
  619. package/dist/types/tools/displayTools/Contour/vtkContour/addOrUpdateVTKContourSets.d.ts.map +1 -0
  620. package/dist/types/tools/displayTools/Contour/vtkContour/contourConfigCache.d.ts.map +1 -0
  621. package/dist/types/tools/displayTools/Contour/vtkContour/updateVTKContourSets.d.ts +4 -0
  622. package/dist/types/tools/displayTools/Contour/vtkContour/updateVTKContourSets.d.ts.map +1 -0
  623. package/dist/types/tools/displayTools/Contour/{utils.d.ts → vtkContour/utils.d.ts} +2 -2
  624. package/dist/types/tools/displayTools/Contour/vtkContour/utils.d.ts.map +1 -0
  625. package/dist/types/tools/displayTools/Labelmap/index.d.ts +2 -1
  626. package/dist/types/tools/displayTools/Labelmap/index.d.ts.map +1 -1
  627. package/dist/types/tools/displayTools/Labelmap/labelmapDisplay.d.ts.map +1 -1
  628. package/dist/types/tools/displayTools/Labelmap/validateLabelmap.d.ts +5 -0
  629. package/dist/types/tools/displayTools/Labelmap/validateLabelmap.d.ts.map +1 -0
  630. package/dist/types/tools/displayTools/Surface/addOrUpdateSurfaceToElement.d.ts +4 -0
  631. package/dist/types/tools/displayTools/Surface/addOrUpdateSurfaceToElement.d.ts.map +1 -0
  632. package/dist/types/tools/displayTools/Surface/surfaceConfig.d.ts +4 -0
  633. package/dist/types/tools/displayTools/Surface/surfaceConfig.d.ts.map +1 -0
  634. package/dist/types/tools/displayTools/Surface/surfaceDisplay.d.ts +7 -0
  635. package/dist/types/tools/displayTools/Surface/surfaceDisplay.d.ts.map +1 -1
  636. package/dist/types/tools/displayTools/registerDisplayToolsWorker.d.ts +2 -0
  637. package/dist/types/tools/displayTools/registerDisplayToolsWorker.d.ts.map +1 -0
  638. package/dist/types/tools/segmentation/CircleScissorsTool.d.ts.map +1 -1
  639. package/dist/types/tools/segmentation/RectangleScissorsTool.d.ts.map +1 -1
  640. package/dist/types/tools/segmentation/SegmentSelectTool.d.ts +6 -2
  641. package/dist/types/tools/segmentation/SegmentSelectTool.d.ts.map +1 -1
  642. package/dist/types/tools/segmentation/SphereScissorsTool.d.ts.map +1 -1
  643. package/dist/types/tools/segmentation/strategies/BrushStrategy.d.ts.map +1 -1
  644. package/dist/types/tools/segmentation/strategies/fillSphere.d.ts.map +1 -1
  645. package/dist/types/tools/segmentation/strategies/utils/getStrategyData.d.ts.map +1 -1
  646. package/dist/types/tools/segmentation/strategies/utils/stackVolumeCheck.d.ts +5 -5
  647. package/dist/types/tools/segmentation/strategies/utils/stackVolumeCheck.d.ts.map +1 -1
  648. package/dist/types/types/AnnotationTypes.d.ts +2 -0
  649. package/dist/types/types/AnnotationTypes.d.ts.map +1 -1
  650. package/dist/types/types/ContourAnnotation.d.ts +6 -0
  651. package/dist/types/types/ContourAnnotation.d.ts.map +1 -1
  652. package/dist/types/types/ContourSegmentationAnnotation.d.ts +0 -1
  653. package/dist/types/types/ContourSegmentationAnnotation.d.ts.map +1 -1
  654. package/dist/types/types/ContourTypes.d.ts +1 -0
  655. package/dist/types/types/ContourTypes.d.ts.map +1 -1
  656. package/dist/types/types/EventTypes.d.ts +4 -1
  657. package/dist/types/types/EventTypes.d.ts.map +1 -1
  658. package/dist/types/types/ISpline.d.ts +1 -0
  659. package/dist/types/types/ISpline.d.ts.map +1 -1
  660. package/dist/types/types/LabelmapTypes.d.ts +5 -1
  661. package/dist/types/types/LabelmapTypes.d.ts.map +1 -1
  662. package/dist/types/types/PolySeg.d.ts +7 -0
  663. package/dist/types/types/PolySeg.d.ts.map +1 -0
  664. package/dist/types/types/SegmentationStateTypes.d.ts +12 -2
  665. package/dist/types/types/SegmentationStateTypes.d.ts.map +1 -1
  666. package/dist/types/types/SplineProps.d.ts +1 -0
  667. package/dist/types/types/SplineProps.d.ts.map +1 -1
  668. package/dist/types/types/SurfaceTypes.d.ts +1 -1
  669. package/dist/types/types/SurfaceTypes.d.ts.map +1 -1
  670. package/dist/types/types/index.d.ts +2 -1
  671. package/dist/types/types/index.d.ts.map +1 -1
  672. package/dist/types/utilities/boundingBox/getBoundingBoxAroundShape.d.ts.map +1 -1
  673. package/dist/types/utilities/contourSegmentation/addContourSegmentationAnnotation.d.ts +3 -0
  674. package/dist/types/utilities/contourSegmentation/addContourSegmentationAnnotation.d.ts.map +1 -0
  675. package/dist/types/utilities/contourSegmentation/areSameSegment.d.ts.map +1 -1
  676. package/dist/types/utilities/contourSegmentation/index.d.ts +2 -0
  677. package/dist/types/utilities/contourSegmentation/index.d.ts.map +1 -1
  678. package/dist/types/utilities/contourSegmentation/removeContourSegmentationAnnotation.d.ts +3 -0
  679. package/dist/types/utilities/contourSegmentation/removeContourSegmentationAnnotation.d.ts.map +1 -0
  680. package/dist/types/utilities/contours/detectContourHoles.d.ts.map +1 -1
  681. package/dist/types/utilities/contours/getContourHolesDataCanvas.d.ts +4 -0
  682. package/dist/types/utilities/contours/getContourHolesDataCanvas.d.ts.map +1 -0
  683. package/dist/types/utilities/contours/getContourHolesDataWorld.d.ts +4 -0
  684. package/dist/types/utilities/contours/getContourHolesDataWorld.d.ts.map +1 -0
  685. package/dist/types/utilities/contours/getDeduplicatedVTKPolyDataPoints.d.ts +12 -0
  686. package/dist/types/utilities/contours/getDeduplicatedVTKPolyDataPoints.d.ts.map +1 -0
  687. package/dist/types/utilities/contours/index.d.ts +5 -2
  688. package/dist/types/utilities/contours/index.d.ts.map +1 -1
  689. package/dist/types/utilities/contours/updateContourPolyline.d.ts +11 -0
  690. package/dist/types/utilities/contours/updateContourPolyline.d.ts.map +1 -0
  691. package/dist/types/utilities/index.d.ts +3 -1
  692. package/dist/types/utilities/index.d.ts.map +1 -1
  693. package/dist/types/utilities/math/polyline/containsPoint.d.ts.map +1 -1
  694. package/dist/types/utilities/math/polyline/containsPoints.d.ts +3 -0
  695. package/dist/types/utilities/math/polyline/containsPoints.d.ts.map +1 -0
  696. package/dist/types/utilities/math/polyline/getWindingDirection.d.ts +3 -0
  697. package/dist/types/utilities/math/polyline/getWindingDirection.d.ts.map +1 -0
  698. package/dist/types/utilities/math/polyline/index.d.ts +4 -1
  699. package/dist/types/utilities/math/polyline/index.d.ts.map +1 -1
  700. package/dist/types/utilities/math/polyline/isPointInsidePolyline3D.d.ts +3 -0
  701. package/dist/types/utilities/math/polyline/isPointInsidePolyline3D.d.ts.map +1 -0
  702. package/dist/types/utilities/math/polyline/planarFreehandROIInternalTypes.d.ts +1 -0
  703. package/dist/types/utilities/math/polyline/planarFreehandROIInternalTypes.d.ts.map +1 -1
  704. package/dist/types/utilities/segmentation/contourAndFindLargestBidirectional.d.ts.map +1 -1
  705. package/dist/types/utilities/segmentation/getHoveredContourSegmentationAnnotation.d.ts +2 -0
  706. package/dist/types/utilities/segmentation/getHoveredContourSegmentationAnnotation.d.ts.map +1 -0
  707. package/dist/types/utilities/segmentation/getSegmentAtLabelmapBorder.d.ts +8 -0
  708. package/dist/types/utilities/segmentation/getSegmentAtLabelmapBorder.d.ts.map +1 -0
  709. package/dist/types/utilities/segmentation/getSegmentAtWorldPoint.d.ts +12 -0
  710. package/dist/types/utilities/segmentation/getSegmentAtWorldPoint.d.ts.map +1 -0
  711. package/dist/types/utilities/segmentation/getUniqueSegmentIndices.d.ts +3 -0
  712. package/dist/types/utilities/segmentation/getUniqueSegmentIndices.d.ts.map +1 -0
  713. package/dist/types/utilities/segmentation/index.d.ts +5 -1
  714. package/dist/types/utilities/segmentation/index.d.ts.map +1 -1
  715. package/dist/types/utilities/triggerAnnotationRenderForToolGroupIds.d.ts +3 -0
  716. package/dist/types/utilities/triggerAnnotationRenderForToolGroupIds.d.ts.map +1 -0
  717. package/dist/types/workers/clippingPlaneWorker.d.ts +2 -0
  718. package/dist/types/workers/clippingPlaneWorker.d.ts.map +1 -0
  719. package/dist/types/workers/polySegConverters.d.ts +2 -0
  720. package/dist/types/workers/polySegConverters.d.ts.map +1 -0
  721. package/dist/umd/17dd54813d5acc10bf8f.wasm +0 -0
  722. package/dist/umd/444.index.js +3 -0
  723. package/dist/umd/444.index.js.LICENSE.txt +5 -0
  724. package/dist/umd/444.index.js.map +1 -0
  725. package/dist/umd/78.index.js +3 -0
  726. package/dist/umd/78.index.js.LICENSE.txt +5 -0
  727. package/dist/umd/78.index.js.map +1 -0
  728. package/dist/umd/985.index.js +2 -0
  729. package/dist/umd/985.index.js.map +1 -0
  730. package/dist/umd/index.js +1 -1
  731. package/dist/umd/index.js.map +1 -1
  732. package/package.json +5 -3
  733. package/src/drawingSvg/drawPath.ts +96 -0
  734. package/src/drawingSvg/drawPolyline.ts +12 -16
  735. package/src/drawingSvg/index.ts +2 -0
  736. package/src/enums/WorkerTypes.ts +16 -0
  737. package/src/enums/index.js +2 -0
  738. package/src/eventDispatchers/shared/getActiveToolForMouseEvent.ts +1 -1
  739. package/src/eventListeners/annotations/contourSegmentation/contourSegmentationCompleted.ts +204 -75
  740. package/src/eventListeners/segmentation/imageChangeEventListener.ts +3 -4
  741. package/src/eventListeners/segmentation/labelmap/onLabelmapSegmentationDataModified.ts +97 -69
  742. package/src/stateManagement/annotation/FrameOfReferenceSpecificAnnotationManager.ts +11 -0
  743. package/src/stateManagement/annotation/annotationState.ts +107 -0
  744. package/src/stateManagement/annotation/helpers/state.ts +29 -1
  745. package/src/stateManagement/index.js +10 -0
  746. package/src/stateManagement/segmentation/SegmentationStateManager.ts +4 -1
  747. package/src/stateManagement/segmentation/addRepresentationData.ts +71 -0
  748. package/src/stateManagement/segmentation/addSegmentationRepresentation.ts +39 -16
  749. package/src/stateManagement/segmentation/config/segmentationVisibility.ts +1 -59
  750. package/src/stateManagement/segmentation/convertStackToVolumeSegmentation.ts +74 -37
  751. package/src/stateManagement/segmentation/convertVolumeToStackSegmentation.ts +102 -38
  752. package/src/stateManagement/segmentation/helpers/validateSegmentationInput.ts +13 -8
  753. package/src/stateManagement/segmentation/index.ts +9 -2
  754. package/src/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.ts +17 -0
  755. package/src/stateManagement/segmentation/polySeg/Labelmap/computeAndAddLabelmapRepresentation.ts +25 -0
  756. package/src/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.ts +273 -0
  757. package/src/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.ts +89 -0
  758. package/src/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.ts +193 -0
  759. package/src/stateManagement/segmentation/polySeg/Surface/computeAndAddSurfaceRepresentation.ts +26 -0
  760. package/src/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.ts +62 -0
  761. package/src/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.ts +81 -0
  762. package/src/stateManagement/segmentation/polySeg/Surface/createAndCacheSurfacesFromRaw.ts +81 -0
  763. package/src/stateManagement/segmentation/polySeg/Surface/surfaceComputationStrategies.ts +167 -0
  764. package/src/stateManagement/segmentation/polySeg/Surface/updateSurfaceData.ts +95 -0
  765. package/src/stateManagement/segmentation/polySeg/canComputeRequestedRepresentation.ts +123 -0
  766. package/src/stateManagement/segmentation/polySeg/computeAndAddRepresentation.ts +97 -0
  767. package/src/stateManagement/segmentation/polySeg/index.ts +12 -0
  768. package/src/stateManagement/segmentation/polySeg/registerPolySegWorker.ts +34 -0
  769. package/src/stateManagement/segmentation/segmentIndex.ts +5 -0
  770. package/src/stateManagement/segmentation/segmentationState.ts +62 -0
  771. package/src/store/ToolGroupManager/ToolGroup.ts +9 -2
  772. package/src/tools/ScaleOverlayTool.ts +4 -1
  773. package/src/tools/SegmentationIntersectionTool.ts +1 -1
  774. package/src/tools/annotation/LivewireContourSegmentationTool.ts +1 -1
  775. package/src/tools/annotation/LivewireContourTool.ts +65 -38
  776. package/src/tools/annotation/PlanarFreehandContourSegmentationTool.ts +1 -22
  777. package/src/tools/annotation/PlanarFreehandROITool.ts +8 -5
  778. package/src/tools/annotation/ProbeTool.ts +4 -0
  779. package/src/tools/annotation/SplineROITool.ts +76 -29
  780. package/src/tools/annotation/planarFreehandROITool/closedContourEditLoop.ts +20 -11
  781. package/src/tools/annotation/planarFreehandROITool/drawLoop.ts +42 -23
  782. package/src/tools/annotation/planarFreehandROITool/openContourEditLoop.ts +28 -13
  783. package/src/tools/annotation/planarFreehandROITool/openContourEndEditLoop.ts +1 -1
  784. package/src/tools/annotation/planarFreehandROITool/renderMethods.ts +28 -10
  785. package/src/tools/annotation/splines/LinearSpline.ts +1 -1
  786. package/src/tools/annotation/splines/Spline.ts +13 -1
  787. package/src/tools/base/AnnotationTool.ts +2 -1
  788. package/src/tools/base/BaseTool.ts +1 -6
  789. package/src/tools/base/ContourBaseTool.ts +46 -4
  790. package/src/tools/base/ContourSegmentationBaseTool.ts +51 -42
  791. package/src/tools/displayTools/Contour/contourConfig.ts +1 -0
  792. package/src/tools/displayTools/Contour/contourDisplay.ts +82 -9
  793. package/src/tools/displayTools/Contour/removeContourFromElement.ts +2 -0
  794. package/src/tools/displayTools/Contour/{addContourSetsToElement.ts → vtkContour/addContourSetsToElement.ts} +1 -1
  795. package/src/tools/displayTools/Contour/{addOrUpdateContourSets.ts → vtkContour/addOrUpdateVTKContourSets.ts} +4 -4
  796. package/src/tools/displayTools/Contour/{updateContourSets.ts → vtkContour/updateVTKContourSets.ts} +2 -2
  797. package/src/tools/displayTools/Contour/{utils.ts → vtkContour/utils.ts} +1 -1
  798. package/src/tools/displayTools/Labelmap/addLabelmapToElement.ts +1 -1
  799. package/src/tools/displayTools/Labelmap/index.ts +10 -1
  800. package/src/tools/displayTools/Labelmap/labelmapDisplay.ts +39 -4
  801. package/src/tools/displayTools/Labelmap/validateLabelmap.ts +71 -0
  802. package/src/tools/displayTools/Surface/addOrUpdateSurfaceToElement.ts +172 -0
  803. package/src/tools/displayTools/Surface/surfaceConfig.ts +12 -0
  804. package/src/tools/displayTools/Surface/surfaceDisplay.ts +275 -35
  805. package/src/tools/displayTools/registerDisplayToolsWorker.ts +34 -0
  806. package/src/tools/segmentation/BrushTool.ts +1 -1
  807. package/src/tools/segmentation/CircleScissorsTool.ts +3 -1
  808. package/src/tools/segmentation/PaintFillTool.ts +1 -1
  809. package/src/tools/segmentation/RectangleScissorsTool.ts +3 -1
  810. package/src/tools/segmentation/SegmentSelectTool.ts +70 -75
  811. package/src/tools/segmentation/SphereScissorsTool.ts +3 -1
  812. package/src/tools/segmentation/strategies/BrushStrategy.ts +12 -9
  813. package/src/tools/segmentation/strategies/compositions/regionFill.ts +1 -1
  814. package/src/tools/segmentation/strategies/fillSphere.ts +13 -5
  815. package/src/tools/segmentation/strategies/utils/getStrategyData.ts +30 -15
  816. package/src/tools/segmentation/strategies/utils/stackVolumeCheck.ts +24 -17
  817. package/src/types/AnnotationTypes.ts +14 -0
  818. package/src/types/ContourAnnotation.ts +13 -0
  819. package/src/types/ContourSegmentationAnnotation.ts +0 -1
  820. package/src/types/ContourTypes.ts +3 -0
  821. package/src/types/EventTypes.ts +9 -0
  822. package/src/types/ISpline.ts +3 -0
  823. package/src/types/LabelmapTypes.ts +7 -1
  824. package/src/types/PolySeg.ts +7 -0
  825. package/src/types/SegmentationStateTypes.ts +20 -4
  826. package/src/types/SplineProps.ts +10 -0
  827. package/src/types/SurfaceTypes.ts +1 -1
  828. package/src/types/index.ts +3 -0
  829. package/src/utilities/boundingBox/getBoundingBoxAroundShape.ts +4 -2
  830. package/src/utilities/contourSegmentation/addContourSegmentationAnnotation.ts +29 -0
  831. package/src/utilities/contourSegmentation/areSameSegment.ts +0 -2
  832. package/src/utilities/contourSegmentation/index.ts +2 -0
  833. package/src/utilities/contourSegmentation/removeContourSegmentationAnnotation.ts +30 -0
  834. package/src/utilities/contours/detectContourHoles.ts +2 -0
  835. package/src/utilities/contours/generateContourSetsFromLabelmap.ts +2 -2
  836. package/src/utilities/contours/getContourHolesDataCanvas.ts +33 -0
  837. package/src/utilities/contours/getContourHolesDataWorld.ts +19 -0
  838. package/src/utilities/contours/getDeduplicatedVTKPolyDataPoints.ts +66 -0
  839. package/src/utilities/contours/index.ts +8 -2
  840. package/src/utilities/contours/updateContourPolyline.ts +74 -0
  841. package/src/utilities/index.ts +4 -0
  842. package/src/utilities/math/polyline/containsPoint.ts +4 -2
  843. package/src/utilities/math/polyline/containsPoints.ts +22 -0
  844. package/src/utilities/math/polyline/getWindingDirection.ts +14 -0
  845. package/src/utilities/math/polyline/index.ts +6 -0
  846. package/src/utilities/math/polyline/isPointInsidePolyline3D.ts +56 -0
  847. package/src/utilities/math/polyline/planarFreehandROIInternalTypes.ts +1 -0
  848. package/src/utilities/segmentation/contourAndFindLargestBidirectional.ts +0 -1
  849. package/src/utilities/segmentation/getHoveredContourSegmentationAnnotation.ts +25 -0
  850. package/src/utilities/segmentation/getSegmentAtLabelmapBorder.ts +179 -0
  851. package/src/utilities/segmentation/getSegmentAtWorldPoint.ts +173 -0
  852. package/src/utilities/segmentation/getUniqueSegmentIndices.ts +76 -0
  853. package/src/utilities/segmentation/index.ts +8 -0
  854. package/src/utilities/triggerAnnotationRenderForToolGroupIds.ts +38 -0
  855. package/src/workers/clippingPlaneWorker.js +87 -0
  856. package/src/workers/polySegConverters.js +467 -0
  857. package/dist/cjs/tools/displayTools/Contour/addContourSetsToElement.js.map +0 -1
  858. package/dist/cjs/tools/displayTools/Contour/addOrUpdateContourSets.d.ts +0 -3
  859. package/dist/cjs/tools/displayTools/Contour/addOrUpdateContourSets.js +0 -14
  860. package/dist/cjs/tools/displayTools/Contour/addOrUpdateContourSets.js.map +0 -1
  861. package/dist/cjs/tools/displayTools/Contour/contourConfigCache.js.map +0 -1
  862. package/dist/cjs/tools/displayTools/Contour/updateContourSets.d.ts +0 -3
  863. package/dist/cjs/tools/displayTools/Contour/updateContourSets.js.map +0 -1
  864. package/dist/cjs/tools/displayTools/Contour/utils.js.map +0 -1
  865. package/dist/cjs/tools/displayTools/Labelmap/validateRepresentationData.d.ts +0 -3
  866. package/dist/cjs/tools/displayTools/Labelmap/validateRepresentationData.js +0 -20
  867. package/dist/cjs/tools/displayTools/Labelmap/validateRepresentationData.js.map +0 -1
  868. package/dist/cjs/tools/displayTools/Surface/addSurfaceToElement.d.ts +0 -2
  869. package/dist/cjs/tools/displayTools/Surface/addSurfaceToElement.js +0 -84
  870. package/dist/cjs/tools/displayTools/Surface/addSurfaceToElement.js.map +0 -1
  871. package/dist/cjs/utilities/contours/mergePoints.d.ts +0 -8
  872. package/dist/cjs/utilities/contours/mergePoints.js +0 -77
  873. package/dist/cjs/utilities/contours/mergePoints.js.map +0 -1
  874. package/dist/esm/tools/displayTools/Contour/addContourSetsToElement.js.map +0 -1
  875. package/dist/esm/tools/displayTools/Contour/addOrUpdateContourSets.js.map +0 -1
  876. package/dist/esm/tools/displayTools/Contour/contourConfigCache.js.map +0 -1
  877. package/dist/esm/tools/displayTools/Contour/updateContourSets.js.map +0 -1
  878. package/dist/esm/tools/displayTools/Contour/utils.js.map +0 -1
  879. package/dist/esm/tools/displayTools/Labelmap/validateRepresentationData.js +0 -18
  880. package/dist/esm/tools/displayTools/Labelmap/validateRepresentationData.js.map +0 -1
  881. package/dist/esm/tools/displayTools/Surface/addSurfaceToElement.js +0 -79
  882. package/dist/esm/tools/displayTools/Surface/addSurfaceToElement.js.map +0 -1
  883. package/dist/esm/utilities/contours/mergePoints.js +0 -73
  884. package/dist/esm/utilities/contours/mergePoints.js.map +0 -1
  885. package/dist/types/tools/displayTools/Contour/addContourSetsToElement.d.ts.map +0 -1
  886. package/dist/types/tools/displayTools/Contour/addOrUpdateContourSets.d.ts +0 -4
  887. package/dist/types/tools/displayTools/Contour/addOrUpdateContourSets.d.ts.map +0 -1
  888. package/dist/types/tools/displayTools/Contour/contourConfigCache.d.ts.map +0 -1
  889. package/dist/types/tools/displayTools/Contour/updateContourSets.d.ts +0 -4
  890. package/dist/types/tools/displayTools/Contour/updateContourSets.d.ts.map +0 -1
  891. package/dist/types/tools/displayTools/Contour/utils.d.ts.map +0 -1
  892. package/dist/types/tools/displayTools/Labelmap/validateRepresentationData.d.ts +0 -4
  893. package/dist/types/tools/displayTools/Labelmap/validateRepresentationData.d.ts.map +0 -1
  894. package/dist/types/tools/displayTools/Surface/addSurfaceToElement.d.ts +0 -3
  895. package/dist/types/tools/displayTools/Surface/addSurfaceToElement.d.ts.map +0 -1
  896. package/dist/types/utilities/contours/mergePoints.d.ts +0 -9
  897. package/dist/types/utilities/contours/mergePoints.d.ts.map +0 -1
  898. package/src/tools/displayTools/Labelmap/validateRepresentationData.ts +0 -36
  899. package/src/tools/displayTools/Surface/addSurfaceToElement.ts +0 -115
  900. package/src/utilities/contours/mergePoints.ts +0 -108
  901. /package/dist/cjs/tools/displayTools/Contour/{addContourSetsToElement.js → vtkContour/addContourSetsToElement.js} +0 -0
  902. /package/dist/cjs/tools/displayTools/Contour/{contourConfigCache.d.ts → vtkContour/contourConfigCache.d.ts} +0 -0
  903. /package/dist/cjs/tools/displayTools/Contour/{contourConfigCache.js → vtkContour/contourConfigCache.js} +0 -0
  904. /package/dist/cjs/tools/displayTools/Contour/{utils.js → vtkContour/utils.js} +0 -0
  905. /package/dist/esm/tools/displayTools/Contour/{addContourSetsToElement.js → vtkContour/addContourSetsToElement.js} +0 -0
  906. /package/dist/esm/tools/displayTools/Contour/{contourConfigCache.js → vtkContour/contourConfigCache.js} +0 -0
  907. /package/dist/esm/tools/displayTools/Contour/{utils.js → vtkContour/utils.js} +0 -0
  908. /package/dist/types/tools/displayTools/Contour/{contourConfigCache.d.ts → vtkContour/contourConfigCache.d.ts} +0 -0
  909. /package/src/tools/displayTools/Contour/{contourConfigCache.ts → vtkContour/contourConfigCache.ts} +0 -0
@@ -26,6 +26,7 @@ type CurveSegmentDistanceSquared = {
26
26
  abstract class Spline implements ISpline {
27
27
  private _controlPoints: Types.Point2[] = [];
28
28
  private _resolution: number;
29
+ private _fixedResolution: boolean;
29
30
  private _closed: boolean;
30
31
  private _invalidated = false;
31
32
  private _curveSegments: SplineCurveSegment[];
@@ -35,6 +36,7 @@ abstract class Spline implements ISpline {
35
36
  constructor(props?: SplineProps) {
36
37
  this._controlPoints = [];
37
38
  this._resolution = props?.resolution ?? 20;
39
+ this._fixedResolution = props?.fixedResolution ?? false;
38
40
  this._closed = props?.closed ?? false;
39
41
  this._invalidated = true;
40
42
  }
@@ -61,7 +63,7 @@ abstract class Spline implements ISpline {
61
63
 
62
64
  /** Set the resolution of the spline curve */
63
65
  public set resolution(resolution: number) {
64
- if (this._resolution === resolution) {
66
+ if (this._fixedResolution || this._resolution === resolution) {
65
67
  return;
66
68
  }
67
69
 
@@ -69,6 +71,16 @@ abstract class Spline implements ISpline {
69
71
  this.invalidated = true;
70
72
  }
71
73
 
74
+ /** Fixed resolution
75
+ *
76
+ * Linar spline is one of the splines that does not allow changing the resolution
77
+ * for better performance otherwise it would calculate and render 20 line segments
78
+ * instead of a single one..
79
+ */
80
+ public get fixedResolution() {
81
+ return this._fixedResolution;
82
+ }
83
+
72
84
  /** Flag that is set to true when the curve is already closed */
73
85
  public get closed(): boolean {
74
86
  return this._closed;
@@ -19,6 +19,7 @@ import {
19
19
  InteractionTypes,
20
20
  ToolProps,
21
21
  PublicToolProps,
22
+ IToolBinding,
22
23
  } from '../../types';
23
24
  import { StyleSpecifier } from '../../types/AnnotationStyle';
24
25
 
@@ -223,7 +224,7 @@ abstract class AnnotationTool extends AnnotationDisplayTool {
223
224
  }
224
225
  }
225
226
 
226
- for (let i = 0; i < points.length; i++) {
227
+ for (let i = 0; i < points?.length; i++) {
227
228
  const point = points[i];
228
229
  const annotationCanvasCoordinate = viewport.worldToCanvas(point);
229
230
 
@@ -1,9 +1,4 @@
1
- import {
2
- StackViewport,
3
- utilities,
4
- BaseVolumeViewport,
5
- VideoViewport,
6
- } from '@cornerstonejs/core';
1
+ import { utilities, BaseVolumeViewport } from '@cornerstonejs/core';
7
2
  import { Types } from '@cornerstonejs/core';
8
3
  import ToolModes from '../../enums/ToolModes';
9
4
  import StrategyCallbacks from '../../enums/StrategyCallbacks';
@@ -3,6 +3,7 @@ import type { Types } from '@cornerstonejs/core';
3
3
  import {
4
4
  addAnnotation,
5
5
  getAnnotations,
6
+ getChildAnnotations,
6
7
  } from '../../stateManagement/annotation/annotationState';
7
8
  import type {
8
9
  Annotation,
@@ -13,9 +14,10 @@ import type {
13
14
  SVGDrawingHelper,
14
15
  AnnotationRenderContext,
15
16
  } from '../../types';
16
- import { drawPolyline as drawPolylineSvg } from '../../drawingSvg';
17
+ import { drawPath as drawPathSvg } from '../../drawingSvg';
17
18
  import { StyleSpecifier } from '../../types/AnnotationStyle';
18
19
  import AnnotationTool from './AnnotationTool';
20
+ import { getContourHolesDataCanvas } from '../../utilities/contours';
19
21
 
20
22
  /**
21
23
  * A contour base class responsible for rendering contour instances such as
@@ -177,6 +179,37 @@ abstract class ContourBaseTool extends AnnotationTool {
177
179
  // noop method just to give a chance for child classes to override it
178
180
  }
179
181
 
182
+ /**
183
+ * Move an annotation and all its child annotations in a recursive way.
184
+ *
185
+ * That is useful when clicking on a spline contour to completely translate
186
+ * it to a different place. In that case all holes (child annotations) must
187
+ * also be translated too.
188
+ *
189
+ * @param annotation - Annotation
190
+ * @param worldPosDelta - Delta in world space
191
+ */
192
+ protected moveAnnotation(
193
+ annotation: Annotation,
194
+ worldPosDelta: Types.Point3
195
+ ): void {
196
+ const { points } = annotation.data.handles;
197
+
198
+ for (let i = 0, numPoints = points.length; i < numPoints; i++) {
199
+ const point = points[i];
200
+
201
+ point[0] += worldPosDelta[0];
202
+ point[1] += worldPosDelta[1];
203
+ point[2] += worldPosDelta[2];
204
+ }
205
+
206
+ annotation.invalidated = true;
207
+
208
+ getChildAnnotations(annotation).forEach((childAnnotation) =>
209
+ this.moveAnnotation(childAnnotation, worldPosDelta)
210
+ );
211
+ }
212
+
180
213
  /**
181
214
  * Get polyline points in world space.
182
215
  * Just to give a chance for child classes to override it.
@@ -184,7 +217,7 @@ abstract class ContourBaseTool extends AnnotationTool {
184
217
  * @returns Polyline points in world space
185
218
  */
186
219
  protected getPolylinePoints(annotation: ContourAnnotation): Types.Point3[] {
187
- // Attenttion: `contour.polyline` is the new way to store a polyline but it
220
+ // Attention: `contour.polyline` is the new way to store a polyline but it
188
221
  // may be undefined because it was `data.polyline` before (fallback)
189
222
  return annotation.data.contour?.polyline ?? annotation.data.polyline;
190
223
  }
@@ -197,6 +230,12 @@ abstract class ContourBaseTool extends AnnotationTool {
197
230
  ): boolean {
198
231
  const { enabledElement, annotationStyle, svgDrawingHelper } = renderContext;
199
232
  const annotation = renderContext.annotation as ContourAnnotation;
233
+
234
+ // Do not render the contour because it must be rendered by the parent annotation
235
+ if (annotation.parentAnnotationUID) {
236
+ return;
237
+ }
238
+
200
239
  const { annotationUID } = annotation;
201
240
  const { viewport } = enabledElement;
202
241
  const { worldToCanvas } = viewport;
@@ -206,11 +245,14 @@ abstract class ContourBaseTool extends AnnotationTool {
206
245
  const { lineWidth, lineDash, color, fillColor, fillOpacity } =
207
246
  annotationStyle;
208
247
 
209
- drawPolylineSvg(
248
+ const childContours = getContourHolesDataCanvas(annotation, viewport);
249
+ const allContours = [polylineCanvasPoints, ...childContours];
250
+
251
+ drawPathSvg(
210
252
  svgDrawingHelper,
211
253
  annotationUID,
212
254
  'contourPolyline',
213
- polylineCanvasPoints,
255
+ allContours,
214
256
  {
215
257
  color,
216
258
  lineDash,
@@ -20,10 +20,16 @@ import { SegmentationRepresentations } from '../../enums';
20
20
  import ContourBaseTool from './ContourBaseTool';
21
21
  import { triggerSegmentationDataModified } from '../../stateManagement/segmentation/triggerSegmentationEvents';
22
22
  import { InterpolationManager } from '../../utilities/contours/interpolation';
23
+ import {
24
+ addContourSegmentationAnnotation,
25
+ removeContourSegmentationAnnotation,
26
+ } from '../../utilities/contourSegmentation';
27
+ import { getToolGroupIdsWithSegmentation } from '../../stateManagement/segmentation/segmentationState';
28
+ import { triggerAnnotationRenderForToolGroupIds } from '../../utilities';
23
29
 
24
30
  /**
25
31
  * A base contour segmentation class responsible for rendering, registering
26
- * and unregistering contour segmentation annotations.
32
+ * and unregister contour segmentation annotations.
27
33
  */
28
34
  abstract class ContourSegmentationBaseTool extends ContourBaseTool {
29
35
  constructor(toolProps: PublicToolProps, defaultToolProps: ToolProps) {
@@ -70,8 +76,7 @@ abstract class ContourSegmentationBaseTool extends ContourBaseTool {
70
76
  throw new Error(`A contour segmentation must be active`);
71
77
  }
72
78
 
73
- const { segmentationId, segmentationRepresentationUID } =
74
- activeSegmentationRepresentation;
79
+ const { segmentationId } = activeSegmentationRepresentation;
75
80
  const segmentIndex =
76
81
  segmentIndexController.getActiveSegmentIndex(segmentationId);
77
82
 
@@ -82,7 +87,6 @@ abstract class ContourSegmentationBaseTool extends ContourBaseTool {
82
87
  segmentation: {
83
88
  segmentationId,
84
89
  segmentIndex,
85
- segmentationRepresentationUID,
86
90
  },
87
91
  },
88
92
  }
@@ -94,11 +98,10 @@ abstract class ContourSegmentationBaseTool extends ContourBaseTool {
94
98
  element: HTMLDivElement
95
99
  ): string {
96
100
  const annotationUID = super.addAnnotation(annotation, element);
97
-
98
101
  if (this.isContourSegmentationTool()) {
99
102
  const contourSegAnnotation = annotation as ContourSegmentationAnnotation;
100
103
 
101
- this._registerContourSegmentationAnnotation(contourSegAnnotation);
104
+ addContourSegmentationAnnotation(contourSegAnnotation);
102
105
  }
103
106
 
104
107
  return annotationUID;
@@ -110,7 +113,7 @@ abstract class ContourSegmentationBaseTool extends ContourBaseTool {
110
113
  */
111
114
  protected cancelAnnotation(annotation: Annotation): void {
112
115
  if (this.isContourSegmentationTool()) {
113
- this._unregisterContourSegmentationAnnotation(
116
+ removeContourSegmentationAnnotation(
114
117
  annotation as ContourSegmentationAnnotation
115
118
  );
116
119
  }
@@ -148,16 +151,21 @@ abstract class ContourSegmentationBaseTool extends ContourBaseTool {
148
151
  ): boolean {
149
152
  const { annotation } = renderContext;
150
153
  const { invalidated } = annotation;
151
-
152
154
  // Render the annotation before triggering events
153
155
  const renderResult = super.renderAnnotationInstance(renderContext);
154
-
155
156
  if (invalidated && this.isContourSegmentationTool()) {
156
157
  const { segmentationId } = (<SplineContourSegmentationAnnotation>(
157
158
  annotation
158
159
  )).data.segmentation;
159
-
160
160
  triggerSegmentationDataModified(segmentationId);
161
+
162
+ // check which other viewport is rendering the same segmentationId
163
+ // and trigger the event for them to be able to render the segmentation
164
+ // annotation as well
165
+
166
+ const toolGroupIds = getToolGroupIdsWithSegmentation(segmentationId);
167
+
168
+ triggerAnnotationRenderForToolGroupIds(toolGroupIds);
161
169
  }
162
170
 
163
171
  return renderResult;
@@ -173,14 +181,16 @@ abstract class ContourSegmentationBaseTool extends ContourBaseTool {
173
181
  }): Record<string, any> {
174
182
  const { toolGroupId } = this;
175
183
  const annotation = context.annotation as ContourSegmentationAnnotation;
176
- const { segmentationRepresentationUID, segmentationId, segmentIndex } =
177
- annotation.data.segmentation;
184
+ const { segmentationId, segmentIndex } = annotation.data.segmentation;
185
+ const segmentation = segmentationState.getSegmentation(segmentationId);
178
186
  const segmentationRepresentation =
179
- segmentationState.getSegmentationRepresentationByUID(
180
- toolGroupId,
181
- segmentationRepresentationUID
182
- );
187
+ this._getSegmentationRepresentation(segmentationId);
183
188
 
189
+ if (!segmentationRepresentation) {
190
+ // return defaults if no segmentation representation is found
191
+ return {};
192
+ }
193
+ const { segmentationRepresentationUID } = segmentationRepresentation;
184
194
  const { active } = segmentationRepresentation;
185
195
  const { autoGenerated } = annotation;
186
196
  const segmentsLocked = segmentLocking.getLockedSegments(segmentationId);
@@ -252,6 +262,11 @@ abstract class ContourSegmentationBaseTool extends ContourBaseTool {
252
262
  fillOpacity = mergedConfig.fillAlphaInactive ?? fillOpacity;
253
263
  }
254
264
 
265
+ // Change the line thickness when the mouse is over the contour segment
266
+ if (segmentation.activeSegmentIndex === segmentIndex) {
267
+ lineWidth += mergedConfig.activeSegmentOutlineWidthDelta;
268
+ }
269
+
255
270
  lineWidth = mergedConfig.renderOutline ? lineWidth : 0;
256
271
  fillOpacity = mergedConfig.renderFill ? fillOpacity : 0;
257
272
 
@@ -272,37 +287,31 @@ abstract class ContourSegmentationBaseTool extends ContourBaseTool {
272
287
  };
273
288
  }
274
289
 
275
- private _registerContourSegmentationAnnotation(
276
- annotation: ContourSegmentationAnnotation
277
- ) {
278
- const { segmentationId, segmentIndex } = annotation.data.segmentation;
279
- const segmentation = segmentationState.getSegmentation(segmentationId);
280
- const { annotationUIDsMap } = segmentation.representationData.CONTOUR;
290
+ private _getSegmentationRepresentation(segmentationId) {
291
+ const segmentationRepresentations =
292
+ segmentationState.getSegmentationRepresentations(this.toolGroupId);
281
293
 
282
- let annotationsUIDsSet = annotationUIDsMap.get(segmentIndex);
294
+ const validSegmentationRepresentations = segmentationRepresentations.filter(
295
+ (representation) => representation.segmentationId === segmentationId
296
+ );
283
297
 
284
- if (!annotationsUIDsSet) {
285
- annotationsUIDsSet = new Set();
286
- annotationUIDsMap.set(segmentIndex, annotationsUIDsSet);
298
+ if (!validSegmentationRepresentations) {
299
+ console.warn(
300
+ `No segmentation representation found for toolGroupId: ${this.toolGroupId}`
301
+ );
302
+ return;
287
303
  }
288
304
 
289
- annotationsUIDsSet.add(annotation.annotationUID);
290
- }
291
-
292
- private _unregisterContourSegmentationAnnotation(
293
- annotation: ContourSegmentationAnnotation
294
- ) {
295
- const { segmentationId, segmentIndex } = annotation.data.segmentation;
296
- const segmentation = segmentationState.getSegmentation(segmentationId);
297
- const { annotationUIDsMap } = segmentation.representationData.CONTOUR;
298
- const annotationsUIDsSet = annotationUIDsMap.get(segmentIndex);
299
-
300
- annotationsUIDsSet.delete(annotation.annotationUID);
301
-
302
- // Delete segmentIndex Set if there is no more annotations
303
- if (!annotationsUIDsSet.size) {
304
- annotationUIDsMap.delete(segmentIndex);
305
+ if (
306
+ segmentationState.getSegmentationRepresentations(this.toolGroupId)
307
+ .length > 1
308
+ ) {
309
+ console.warn(
310
+ 'Multiple segmentation representations detected for this tool group. The first one will be used.'
311
+ );
305
312
  }
313
+
314
+ return validSegmentationRepresentations[0];
306
315
  }
307
316
  }
308
317
 
@@ -10,6 +10,7 @@ const defaultContourConfig: ContourConfig = {
10
10
  outlineDashActive: undefined,
11
11
  outlineDashInactive: undefined,
12
12
  outlineDashAutoGenerated: '5,3',
13
+ activeSegmentOutlineWidthDelta: 0,
13
14
  renderFill: true,
14
15
  fillAlpha: 0.5,
15
16
  fillAlphaInactive: 0.3,
@@ -2,6 +2,7 @@ import {
2
2
  getEnabledElementByIds,
3
3
  Types,
4
4
  StackViewport,
5
+ BaseVolumeViewport,
5
6
  } from '@cornerstonejs/core';
6
7
 
7
8
  import Representations from '../../../enums/SegmentationRepresentations';
@@ -11,9 +12,9 @@ import {
11
12
  SegmentationRepresentationConfig,
12
13
  ToolGroupSpecificRepresentation,
13
14
  } from '../../../types/SegmentationStateTypes';
14
- import { addOrUpdateContourSets } from './addOrUpdateContourSets';
15
+ import { addOrUpdateVTKContourSets } from './vtkContour/addOrUpdateVTKContourSets';
15
16
  import removeContourFromElement from './removeContourFromElement';
16
- import { deleteConfigCache } from './contourConfigCache';
17
+ import { deleteConfigCache } from './vtkContour/contourConfigCache';
17
18
 
18
19
  /**
19
20
  * It removes a segmentation representation from the tool group's viewports and
@@ -66,27 +67,99 @@ async function render(
66
67
  ): Promise<void> {
67
68
  const { segmentationId } = representationConfig;
68
69
  const segmentation = SegmentationState.getSegmentation(segmentationId);
70
+
71
+ if (!segmentation) {
72
+ return;
73
+ }
74
+
69
75
  const contourData = segmentation.representationData[Representations.Contour];
70
- const { geometryIds } = contourData;
71
76
 
72
- // We don't have a good way to handle stack viewports for contours at the moment.
73
- // Plus, if we add a segmentation to one viewport, it gets added to all the viewports in the toolGroup too.
74
- if (viewport instanceof StackViewport) {
77
+ const { geometryIds, annotationUIDsMap } = contourData;
78
+
79
+ if (!geometryIds?.length && !annotationUIDsMap?.size) {
75
80
  return;
76
81
  }
77
82
 
78
- if (!geometryIds?.length) {
79
- // This is a normal occurrence when contours activated, but not yet drawn
83
+ // this means we would like to use vtk actors for contour data
84
+
85
+ if (!(viewport instanceof BaseVolumeViewport)) {
86
+ // We don't have a good way to handle stack viewports for contours at the moment.
87
+ // Plus, if we add a segmentation to one viewport, it gets added to all the viewports in the toolGroup too.
80
88
  return;
81
89
  }
82
90
 
83
91
  // add the contour sets to the viewport
84
- addOrUpdateContourSets(
92
+ addOrUpdateVTKContourSets(
85
93
  viewport,
86
94
  geometryIds,
87
95
  representationConfig,
88
96
  toolGroupConfig
89
97
  );
98
+
99
+ /**
100
+ * The following logic could be added if we want to support the use case
101
+ * where the contour representation data is initiated using annotations
102
+ * in the state from the get-go , and not when the user draws a contour.
103
+ */
104
+ // if (contourData?.points?.length) {
105
+ // // contourData = createAnnotationsFromPoints(contourData.points);
106
+ // const contourSegmentationAnnotation = {
107
+ // annotationUID: csUtils.uuidv4(),
108
+ // data: {
109
+ // contour: {
110
+ // closed: true,
111
+ // polyline: contourData.points,
112
+ // },
113
+ // segmentation: {
114
+ // segmentationId,
115
+ // segmentIndex: 1, // Todo
116
+ // segmentationRepresentationUID:
117
+ // representationConfig.segmentationRepresentationUID,
118
+ // },
119
+ // },
120
+ // highlighted: false,
121
+ // invalidated: false,
122
+ // isLocked: false,
123
+ // isVisible: true,
124
+ // metadata: {
125
+ // toolName: 'PlanarFreehandContourSegmentationTool',
126
+ // FrameOfReferenceUID: viewport.getFrameOfReferenceUID(),
127
+ // viewPlaneNormal: viewport.getCamera().viewPlaneNormal,
128
+ // },
129
+ // };
130
+
131
+ // addAnnotation(contourSegmentationAnnotation, viewport.element);
132
+ // } else if (
133
+ // !contourData &&
134
+ // polySeg.canComputeRequestedRepresentation(
135
+ // representationConfig.segmentationRepresentationUID
136
+ // )
137
+ // ) {
138
+ // contourData = await polySeg.computeAndAddContourRepresentation(
139
+ // segmentationId,
140
+ // {
141
+ // segmentationRepresentationUID:
142
+ // representationConfig.segmentationRepresentationUID,
143
+ // viewport,
144
+ // }
145
+ // );
146
+ // }
147
+
148
+ // if (contourData?.geometryIds?.length) {
149
+ // handleVTKContour({
150
+ // viewport,
151
+ // representationConfig,
152
+ // toolGroupConfig,
153
+ // geometryIds: contourData.geometryIds,
154
+ // });
155
+ // } else if (contourData.annotationUIDsMap?.size) {
156
+ // handleContourAnnotationSegmentation({
157
+ // viewport,
158
+ // representationConfig,
159
+ // toolGroupConfig,
160
+ // annotationUIDsMap: contourData.annotationUIDsMap,
161
+ // });
162
+ // }
90
163
  }
91
164
 
92
165
  function _removeContourFromToolGroupViewports(
@@ -30,6 +30,8 @@ function removeContourFromElement(
30
30
 
31
31
  // @ts-ignore
32
32
  viewport.removeActors(actorUIDsToRemove);
33
+
34
+ // Todo: add the logic to remove the svg contour segmentation representations as well
33
35
  }
34
36
 
35
37
  export default removeContourFromElement;
@@ -13,7 +13,7 @@ import {
13
13
  import {
14
14
  SegmentationRepresentationConfig,
15
15
  ToolGroupSpecificContourRepresentation,
16
- } from '../../../types';
16
+ } from '../../../../types';
17
17
  import { getConfigCache, setConfigCache } from './contourConfigCache';
18
18
 
19
19
  export function addContourSetsToElement(
@@ -3,11 +3,11 @@ import { Types } from '@cornerstonejs/core';
3
3
  import {
4
4
  SegmentationRepresentationConfig,
5
5
  ToolGroupSpecificContourRepresentation,
6
- } from '../../../types';
6
+ } from '../../../../types';
7
7
  import { addContourSetsToElement } from './addContourSetsToElement';
8
- import { updateContourSets } from './updateContourSets';
8
+ import { updateVTKContourSets } from './updateVTKContourSets';
9
9
 
10
- export function addOrUpdateContourSets(
10
+ export function addOrUpdateVTKContourSets(
11
11
  viewport: Types.IVolumeViewport,
12
12
  geometryIds: string[],
13
13
  contourRepresentation: ToolGroupSpecificContourRepresentation,
@@ -17,7 +17,7 @@ export function addOrUpdateContourSets(
17
17
  const actorUID = `CONTOUR_${segmentationRepresentationUID}`;
18
18
  const actor = viewport.getActor(actorUID);
19
19
 
20
- const addOrUpdateFn = actor ? updateContourSets : addContourSetsToElement;
20
+ const addOrUpdateFn = actor ? updateVTKContourSets : addContourSetsToElement;
21
21
  addOrUpdateFn(
22
22
  viewport,
23
23
  geometryIds,
@@ -4,11 +4,11 @@ import vtkActor from '@kitware/vtk.js/Rendering/Core/Actor';
4
4
  import {
5
5
  SegmentationRepresentationConfig,
6
6
  ToolGroupSpecificContourRepresentation,
7
- } from '../../../types';
7
+ } from '../../../../types';
8
8
  import { getConfigCache, setConfigCache } from './contourConfigCache';
9
9
  import { getSegmentSpecificConfig } from './utils';
10
10
 
11
- export function updateContourSets(
11
+ export function updateVTKContourSets(
12
12
  viewport: Types.IVolumeViewport,
13
13
  geometryIds: string[],
14
14
  contourRepresentation: ToolGroupSpecificContourRepresentation,
@@ -2,7 +2,7 @@ import { Enums, Types } from '@cornerstonejs/core';
2
2
  import vtkCellArray from '@kitware/vtk.js/Common/Core/CellArray';
3
3
  import vtkPoints from '@kitware/vtk.js/Common/Core/Points';
4
4
  import vtkPolyData from '@kitware/vtk.js/Common/DataModel/PolyData';
5
- import { ToolGroupSpecificContourRepresentation } from '../../../types';
5
+ import { ToolGroupSpecificContourRepresentation } from '../../../../types';
6
6
 
7
7
  /**
8
8
  * If the segment specific config exists for the given segment id, it returns
@@ -36,7 +36,7 @@ async function addLabelmapToElement(
36
36
  const immediateRender = false;
37
37
  const suppressEvents = true;
38
38
 
39
- if (isVolumeSegmentation(labelMapData)) {
39
+ if (isVolumeSegmentation(labelMapData, viewport)) {
40
40
  // Todo: Right now we use MIP blend mode for the labelmap, since the
41
41
  // composite blend mode has a non linear behavior regarding fill and line
42
42
  // opacity. This should be changed to a custom labelmap blendMode which does
@@ -1,4 +1,13 @@
1
1
  import labelmapDisplay from './labelmapDisplay';
2
2
  import labelmapConfig from './labelmapConfig';
3
+ import {
4
+ validate as validateLabelmap,
5
+ validatePublic as validateLabelmapPublic,
6
+ } from './validateLabelmap';
3
7
 
4
- export { labelmapDisplay, labelmapConfig };
8
+ export {
9
+ labelmapDisplay,
10
+ labelmapConfig,
11
+ validateLabelmap,
12
+ validateLabelmapPublic,
13
+ };
@@ -23,9 +23,9 @@ import {
23
23
  } from '../../../types/SegmentationStateTypes';
24
24
 
25
25
  import addLabelmapToElement from './addLabelmapToElement';
26
-
27
26
  import removeLabelmapFromElement from './removeLabelmapFromElement';
28
27
  import { isVolumeSegmentation } from '../../segmentation/strategies/utils/stackVolumeCheck';
28
+ import { polySeg } from '../../../stateManagement/segmentation';
29
29
 
30
30
  const MAX_NUMBER_COLORS = 255;
31
31
  const labelMapConfigCache = new Map();
@@ -40,6 +40,8 @@ function getRepresentationRenderingConfig() {
40
40
  };
41
41
  }
42
42
 
43
+ let polySegConversionInProgress = false;
44
+
43
45
  /**
44
46
  * For each viewport, and for each segmentation, set the segmentation for the viewport's enabled element
45
47
  * Initializes the global and viewport specific state for the segmentation in the
@@ -136,11 +138,44 @@ async function render(
136
138
  return;
137
139
  }
138
140
 
139
- const labelmapData =
140
- segmentation.representationData[Representations.Labelmap];
141
+ let labelmapData = segmentation.representationData[Representations.Labelmap];
141
142
 
142
143
  let actorEntry = viewport.getActor(segmentationRepresentationUID);
143
- if (isVolumeSegmentation(labelmapData)) {
144
+
145
+ if (
146
+ !actorEntry &&
147
+ polySeg.canComputeRequestedRepresentation(segmentationRepresentationUID) &&
148
+ !polySegConversionInProgress
149
+ ) {
150
+ // meaning the requested segmentation representationUID does not have
151
+ // labelmap data, BUT we might be able to request a conversion from
152
+ // another representation to labelmap
153
+ // we need to check if we can request polySEG to convert the other
154
+ // underlying representations to Surface
155
+ polySegConversionInProgress = true;
156
+
157
+ labelmapData = await polySeg.computeAndAddLabelmapRepresentation(
158
+ segmentationId,
159
+ {
160
+ segmentationRepresentationUID,
161
+ viewport,
162
+ }
163
+ );
164
+
165
+ if (!labelmapData) {
166
+ throw new Error(
167
+ `No labelmap data found for segmentationId ${segmentationId}.`
168
+ );
169
+ }
170
+
171
+ polySegConversionInProgress = false;
172
+ }
173
+
174
+ if (!labelmapData) {
175
+ return;
176
+ }
177
+
178
+ if (isVolumeSegmentation(labelmapData, viewport)) {
144
179
  if (viewport instanceof StackViewport) {
145
180
  return;
146
181
  }