@cornerstonejs/tools 1.57.1 → 1.58.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (232) hide show
  1. package/dist/cjs/drawingSvg/drawPath.js +1 -1
  2. package/dist/cjs/drawingSvg/drawPath.js.map +1 -1
  3. package/dist/cjs/enums/WorkerTypes.d.ts +1 -1
  4. package/dist/cjs/enums/WorkerTypes.js +1 -1
  5. package/dist/cjs/enums/WorkerTypes.js.map +1 -1
  6. package/dist/cjs/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.d.ts +17 -0
  7. package/dist/cjs/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js +112 -0
  8. package/dist/cjs/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js.map +1 -0
  9. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts +3 -1
  10. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js +4 -1
  11. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js.map +1 -1
  12. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.d.ts +8 -0
  13. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js +121 -0
  14. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js.map +1 -0
  15. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.d.ts +3 -0
  16. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js +73 -0
  17. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js.map +1 -0
  18. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.d.ts +3 -0
  19. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js +25 -0
  20. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js.map +1 -0
  21. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.d.ts +1 -0
  22. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js +41 -0
  23. package/dist/cjs/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js.map +1 -0
  24. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js +2 -2
  25. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js.map +1 -1
  26. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js +1 -1
  27. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js.map +1 -1
  28. package/dist/cjs/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js.map +1 -1
  29. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js +1 -1
  30. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js.map +1 -1
  31. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js +1 -1
  32. package/dist/cjs/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js.map +1 -1
  33. package/dist/cjs/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js +1 -1
  34. package/dist/cjs/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js.map +1 -1
  35. package/dist/cjs/stateManagement/segmentation/triggerSegmentationEvents.js +2 -0
  36. package/dist/cjs/stateManagement/segmentation/triggerSegmentationEvents.js.map +1 -1
  37. package/dist/cjs/store/ToolGroupManager/getToolGroupForViewport.d.ts +1 -1
  38. package/dist/cjs/store/ToolGroupManager/getToolGroupForViewport.js +5 -0
  39. package/dist/cjs/store/ToolGroupManager/getToolGroupForViewport.js.map +1 -1
  40. package/dist/cjs/tools/annotation/SplineROITool.js +25 -20
  41. package/dist/cjs/tools/annotation/SplineROITool.js.map +1 -1
  42. package/dist/cjs/tools/base/BaseTool.js +3 -0
  43. package/dist/cjs/tools/base/BaseTool.js.map +1 -1
  44. package/dist/cjs/tools/base/ContourSegmentationBaseTool.js.map +1 -1
  45. package/dist/cjs/tools/displayTools/Contour/contourDisplay.js +13 -5
  46. package/dist/cjs/tools/displayTools/Contour/contourDisplay.js.map +1 -1
  47. package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js +1 -1
  48. package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
  49. package/dist/cjs/tools/displayTools/SegmentationDisplayTool.d.ts +1 -0
  50. package/dist/cjs/tools/displayTools/SegmentationDisplayTool.js +17 -0
  51. package/dist/cjs/tools/displayTools/SegmentationDisplayTool.js.map +1 -1
  52. package/dist/cjs/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js +4 -47
  53. package/dist/cjs/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js.map +1 -1
  54. package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.d.ts +3 -9
  55. package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.js +7 -148
  56. package/dist/cjs/tools/displayTools/Surface/surfaceDisplay.js.map +1 -1
  57. package/dist/cjs/types/PolySeg.d.ts +1 -1
  58. package/dist/cjs/utilities/contourSegmentation/addContourSegmentationAnnotation.js +4 -1
  59. package/dist/cjs/utilities/contourSegmentation/addContourSegmentationAnnotation.js.map +1 -1
  60. package/dist/cjs/utilities/contourSegmentation/removeContourSegmentationAnnotation.js +3 -0
  61. package/dist/cjs/utilities/contourSegmentation/removeContourSegmentationAnnotation.js.map +1 -1
  62. package/dist/cjs/utilities/math/polyline/getAABB.d.ts +3 -1
  63. package/dist/cjs/utilities/math/polyline/getAABB.js +30 -4
  64. package/dist/cjs/utilities/math/polyline/getAABB.js.map +1 -1
  65. package/dist/cjs/utilities/planar/index.d.ts +3 -1
  66. package/dist/cjs/utilities/planar/index.js +4 -1
  67. package/dist/cjs/utilities/planar/index.js.map +1 -1
  68. package/dist/cjs/utilities/planar/isPlaneIntersectingAABB.d.ts +1 -0
  69. package/dist/cjs/utilities/planar/isPlaneIntersectingAABB.js +32 -0
  70. package/dist/cjs/utilities/planar/isPlaneIntersectingAABB.js.map +1 -0
  71. package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.d.ts +3 -1
  72. package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.js +97 -47
  73. package/dist/cjs/utilities/segmentation/getUniqueSegmentIndices.js.map +1 -1
  74. package/dist/cjs/workers/polySegConverters.js +73 -0
  75. package/dist/cjs/workers/polySegConverters.js.map +1 -1
  76. package/dist/esm/drawingSvg/drawPath.js +1 -1
  77. package/dist/esm/drawingSvg/drawPath.js.map +1 -1
  78. package/dist/esm/enums/WorkerTypes.js +1 -1
  79. package/dist/esm/enums/WorkerTypes.js.map +1 -1
  80. package/dist/esm/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js +91 -0
  81. package/dist/esm/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.js.map +1 -0
  82. package/dist/esm/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js +4 -1
  83. package/dist/esm/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.js.map +1 -1
  84. package/dist/esm/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js +105 -0
  85. package/dist/esm/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.js.map +1 -0
  86. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js +72 -0
  87. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.js.map +1 -0
  88. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js +21 -0
  89. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.js.map +1 -0
  90. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js +26 -0
  91. package/dist/esm/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.js.map +1 -0
  92. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js +2 -2
  93. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.js.map +1 -1
  94. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js +1 -1
  95. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.js.map +1 -1
  96. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js +1 -1
  97. package/dist/esm/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.js.map +1 -1
  98. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js +1 -1
  99. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.js.map +1 -1
  100. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js +1 -1
  101. package/dist/esm/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.js.map +1 -1
  102. package/dist/esm/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js +1 -1
  103. package/dist/esm/stateManagement/segmentation/polySeg/computeAndAddRepresentation.js.map +1 -1
  104. package/dist/esm/stateManagement/segmentation/triggerSegmentationEvents.js +2 -0
  105. package/dist/esm/stateManagement/segmentation/triggerSegmentationEvents.js.map +1 -1
  106. package/dist/esm/store/ToolGroupManager/getToolGroupForViewport.js +4 -0
  107. package/dist/esm/store/ToolGroupManager/getToolGroupForViewport.js.map +1 -1
  108. package/dist/esm/tools/annotation/SplineROITool.js +25 -20
  109. package/dist/esm/tools/annotation/SplineROITool.js.map +1 -1
  110. package/dist/esm/tools/base/BaseTool.js +3 -0
  111. package/dist/esm/tools/base/BaseTool.js.map +1 -1
  112. package/dist/esm/tools/base/ContourSegmentationBaseTool.js.map +1 -1
  113. package/dist/esm/tools/displayTools/Contour/contourDisplay.js +13 -5
  114. package/dist/esm/tools/displayTools/Contour/contourDisplay.js.map +1 -1
  115. package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js +1 -1
  116. package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
  117. package/dist/esm/tools/displayTools/SegmentationDisplayTool.js +17 -0
  118. package/dist/esm/tools/displayTools/SegmentationDisplayTool.js.map +1 -1
  119. package/dist/esm/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js +3 -46
  120. package/dist/esm/tools/displayTools/Surface/addOrUpdateSurfaceToElement.js.map +1 -1
  121. package/dist/esm/tools/displayTools/Surface/surfaceDisplay.js +8 -139
  122. package/dist/esm/tools/displayTools/Surface/surfaceDisplay.js.map +1 -1
  123. package/dist/esm/utilities/contourSegmentation/addContourSegmentationAnnotation.js +4 -1
  124. package/dist/esm/utilities/contourSegmentation/addContourSegmentationAnnotation.js.map +1 -1
  125. package/dist/esm/utilities/contourSegmentation/removeContourSegmentationAnnotation.js +3 -0
  126. package/dist/esm/utilities/contourSegmentation/removeContourSegmentationAnnotation.js.map +1 -1
  127. package/dist/esm/utilities/math/polyline/getAABB.js +30 -4
  128. package/dist/esm/utilities/math/polyline/getAABB.js.map +1 -1
  129. package/dist/esm/utilities/planar/index.js +3 -1
  130. package/dist/esm/utilities/planar/index.js.map +1 -1
  131. package/dist/esm/utilities/planar/isPlaneIntersectingAABB.js +28 -0
  132. package/dist/esm/utilities/planar/isPlaneIntersectingAABB.js.map +1 -0
  133. package/dist/esm/utilities/segmentation/getUniqueSegmentIndices.js +92 -44
  134. package/dist/esm/utilities/segmentation/getUniqueSegmentIndices.js.map +1 -1
  135. package/dist/esm/workers/polySegConverters.js +74 -1
  136. package/dist/esm/workers/polySegConverters.js.map +1 -1
  137. package/dist/types/drawingSvg/drawPath.d.ts.map +1 -1
  138. package/dist/types/enums/WorkerTypes.d.ts +1 -1
  139. package/dist/types/enums/WorkerTypes.d.ts.map +1 -1
  140. package/dist/types/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.d.ts +18 -0
  141. package/dist/types/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.d.ts.map +1 -0
  142. package/dist/types/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts +3 -1
  143. package/dist/types/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.d.ts.map +1 -1
  144. package/dist/types/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.d.ts +9 -0
  145. package/dist/types/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.d.ts.map +1 -0
  146. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.d.ts +4 -0
  147. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.d.ts.map +1 -0
  148. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.d.ts +4 -0
  149. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.d.ts.map +1 -0
  150. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.d.ts +2 -0
  151. package/dist/types/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.d.ts.map +1 -0
  152. package/dist/types/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.d.ts.map +1 -1
  153. package/dist/types/stateManagement/segmentation/triggerSegmentationEvents.d.ts.map +1 -1
  154. package/dist/types/store/ToolGroupManager/getToolGroupForViewport.d.ts +1 -1
  155. package/dist/types/store/ToolGroupManager/getToolGroupForViewport.d.ts.map +1 -1
  156. package/dist/types/tools/annotation/SplineROITool.d.ts.map +1 -1
  157. package/dist/types/tools/base/BaseTool.d.ts.map +1 -1
  158. package/dist/types/tools/base/ContourSegmentationBaseTool.d.ts.map +1 -1
  159. package/dist/types/tools/displayTools/Contour/contourDisplay.d.ts.map +1 -1
  160. package/dist/types/tools/displayTools/SegmentationDisplayTool.d.ts +1 -0
  161. package/dist/types/tools/displayTools/SegmentationDisplayTool.d.ts.map +1 -1
  162. package/dist/types/tools/displayTools/Surface/addOrUpdateSurfaceToElement.d.ts.map +1 -1
  163. package/dist/types/tools/displayTools/Surface/surfaceDisplay.d.ts +3 -9
  164. package/dist/types/tools/displayTools/Surface/surfaceDisplay.d.ts.map +1 -1
  165. package/dist/types/types/PolySeg.d.ts +1 -1
  166. package/dist/types/types/PolySeg.d.ts.map +1 -1
  167. package/dist/types/utilities/contourSegmentation/addContourSegmentationAnnotation.d.ts.map +1 -1
  168. package/dist/types/utilities/contourSegmentation/removeContourSegmentationAnnotation.d.ts.map +1 -1
  169. package/dist/types/utilities/math/polyline/getAABB.d.ts +3 -1
  170. package/dist/types/utilities/math/polyline/getAABB.d.ts.map +1 -1
  171. package/dist/types/utilities/planar/index.d.ts +3 -1
  172. package/dist/types/utilities/planar/index.d.ts.map +1 -1
  173. package/dist/types/utilities/planar/isPlaneIntersectingAABB.d.ts +2 -0
  174. package/dist/types/utilities/planar/isPlaneIntersectingAABB.d.ts.map +1 -0
  175. package/dist/types/utilities/segmentation/getUniqueSegmentIndices.d.ts +3 -1
  176. package/dist/types/utilities/segmentation/getUniqueSegmentIndices.d.ts.map +1 -1
  177. package/dist/umd/985.index.js +1 -1
  178. package/dist/umd/985.index.js.map +1 -1
  179. package/dist/umd/index.js +1 -1
  180. package/dist/umd/index.js.map +1 -1
  181. package/package.json +4 -4
  182. package/src/drawingSvg/drawPath.ts +3 -1
  183. package/src/enums/WorkerTypes.ts +1 -1
  184. package/src/stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport.ts +203 -0
  185. package/src/stateManagement/segmentation/polySeg/Contour/computeAndAddContourRepresentation.ts +9 -2
  186. package/src/stateManagement/segmentation/polySeg/Contour/contourComputationStrategies.ts +201 -0
  187. package/src/stateManagement/segmentation/polySeg/Contour/utils/createAndAddContourSegmentationsFromClippedSurfaces.ts +103 -0
  188. package/src/stateManagement/segmentation/polySeg/Contour/utils/extractContourData.ts +38 -0
  189. package/src/stateManagement/segmentation/polySeg/Contour/utils/updateContoursOnCameraModified.ts +58 -0
  190. package/src/stateManagement/segmentation/polySeg/Labelmap/convertContourToLabelmap.ts +2 -2
  191. package/src/stateManagement/segmentation/polySeg/Labelmap/convertSurfaceToLabelmap.ts +1 -1
  192. package/src/stateManagement/segmentation/polySeg/Labelmap/labelmapComputationStrategies.ts +3 -8
  193. package/src/stateManagement/segmentation/polySeg/Surface/convertContourToSurface.ts +1 -1
  194. package/src/stateManagement/segmentation/polySeg/Surface/convertLabelmapToSurface.ts +1 -1
  195. package/src/stateManagement/segmentation/polySeg/computeAndAddRepresentation.ts +1 -1
  196. package/src/stateManagement/segmentation/triggerSegmentationEvents.ts +5 -0
  197. package/src/store/ToolGroupManager/getToolGroupForViewport.ts +8 -1
  198. package/src/tools/annotation/SplineROITool.ts +34 -27
  199. package/src/tools/base/BaseTool.ts +7 -0
  200. package/src/tools/base/ContourSegmentationBaseTool.ts +5 -0
  201. package/src/tools/displayTools/Contour/contourDisplay.ts +29 -11
  202. package/src/tools/displayTools/Labelmap/labelmapDisplay.ts +1 -1
  203. package/src/tools/displayTools/SegmentationDisplayTool.ts +26 -0
  204. package/src/tools/displayTools/Surface/addOrUpdateSurfaceToElement.ts +3 -65
  205. package/src/tools/displayTools/Surface/surfaceDisplay.ts +12 -247
  206. package/src/types/PolySeg.ts +1 -1
  207. package/src/utilities/contourSegmentation/addContourSegmentationAnnotation.ts +9 -1
  208. package/src/utilities/contourSegmentation/removeContourSegmentationAnnotation.ts +4 -0
  209. package/src/utilities/math/polyline/getAABB.ts +58 -4
  210. package/src/utilities/planar/index.ts +3 -0
  211. package/src/utilities/planar/isPlaneIntersectingAABB.ts +56 -0
  212. package/src/utilities/segmentation/getUniqueSegmentIndices.ts +115 -49
  213. package/src/workers/polySegConverters.js +117 -1
  214. package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.d.ts +0 -1
  215. package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.js +0 -27
  216. package/dist/cjs/tools/displayTools/registerDisplayToolsWorker.js.map +0 -1
  217. package/dist/cjs/workers/clippingPlaneWorker.d.ts +0 -1
  218. package/dist/cjs/workers/clippingPlaneWorker.js +0 -63
  219. package/dist/cjs/workers/clippingPlaneWorker.js.map +0 -1
  220. package/dist/esm/tools/displayTools/registerDisplayToolsWorker.js +0 -23
  221. package/dist/esm/tools/displayTools/registerDisplayToolsWorker.js.map +0 -1
  222. package/dist/esm/workers/clippingPlaneWorker.js +0 -58
  223. package/dist/esm/workers/clippingPlaneWorker.js.map +0 -1
  224. package/dist/types/tools/displayTools/registerDisplayToolsWorker.d.ts +0 -2
  225. package/dist/types/tools/displayTools/registerDisplayToolsWorker.d.ts.map +0 -1
  226. package/dist/types/workers/clippingPlaneWorker.d.ts +0 -2
  227. package/dist/types/workers/clippingPlaneWorker.d.ts.map +0 -1
  228. package/dist/umd/444.index.js +0 -3
  229. package/dist/umd/444.index.js.LICENSE.txt +0 -5
  230. package/dist/umd/444.index.js.map +0 -1
  231. package/src/tools/displayTools/registerDisplayToolsWorker.ts +0 -34
  232. package/src/workers/clippingPlaneWorker.js +0 -87
@@ -6,13 +6,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const core_1 = require("@cornerstonejs/core");
7
7
  const Mapper_1 = __importDefault(require("@kitware/vtk.js/Rendering/Core/Mapper"));
8
8
  const Actor_1 = __importDefault(require("@kitware/vtk.js/Rendering/Core/Actor"));
9
- const ClipClosedSurface_1 = __importDefault(require("@kitware/vtk.js/Filters/General/ClipClosedSurface"));
10
9
  const PolyData_1 = __importDefault(require("@kitware/vtk.js/Common/DataModel/PolyData"));
11
10
  const CellArray_1 = __importDefault(require("@kitware/vtk.js/Common/Core/CellArray"));
12
- const surfaceDisplay_1 = require("./surfaceDisplay");
11
+ const clipAndCacheSurfacesForViewport_1 = require("../../../stateManagement/segmentation/helpers/clipAndCacheSurfacesForViewport");
13
12
  function addOrUpdateSurfaceToElement(element, surface, segmentationRepresentationUID) {
14
- var _a, _b;
15
- const actorUID = (0, surfaceDisplay_1.getSurfaceActorUID)(segmentationRepresentationUID, surface.id);
13
+ var _a;
14
+ const actorUID = (0, clipAndCacheSurfacesForViewport_1.getSurfaceActorUID)(segmentationRepresentationUID, surface.id);
16
15
  const enabledElement = (0, core_1.getEnabledElement)(element);
17
16
  const { viewport } = enabledElement;
18
17
  const surfaceActor = (_a = viewport.getActor(actorUID)) === null || _a === void 0 ? void 0 : _a.actor;
@@ -51,37 +50,7 @@ function addOrUpdateSurfaceToElement(element, surface, segmentationRepresentatio
51
50
  surfacePolyData.setPolys(triangles);
52
51
  const mapper = Mapper_1.default.newInstance({});
53
52
  let clippingFilter;
54
- if (!(viewport instanceof core_1.VolumeViewport3D)) {
55
- clippingFilter = ClipClosedSurface_1.default.newInstance({
56
- clippingPlanes: [],
57
- activePlaneId: 2,
58
- passPointData: false,
59
- });
60
- clippingFilter.setInputData(surfacePolyData);
61
- clippingFilter.setGenerateOutline(true);
62
- clippingFilter.setGenerateFaces(false);
63
- clippingFilter.update();
64
- const filteredData = clippingFilter.getOutputData();
65
- mapper.setInputData(filteredData);
66
- const viewportPlanes = (_b = viewport.getClippingPlanesForActor) === null || _b === void 0 ? void 0 : _b.call(viewport);
67
- const evt = {
68
- detail: {
69
- actorEntry: {
70
- actor: {
71
- getMapper: () => mapper,
72
- },
73
- clippingFilter,
74
- uid: actorUID,
75
- },
76
- vtkPlanes: viewportPlanes,
77
- },
78
- };
79
- updateSurfacePlanes(evt);
80
- element.addEventListener(core_1.Enums.Events.CLIPPING_PLANES_UPDATED, updateSurfacePlanes);
81
- }
82
- else {
83
- mapper.setInputData(surfacePolyData);
84
- }
53
+ mapper.setInputData(surfacePolyData);
85
54
  const actor = Actor_1.default.newInstance();
86
55
  actor.setMapper(mapper);
87
56
  actor.getProperty().setColor(color[0] / 255, color[1] / 255, color[2] / 255);
@@ -97,17 +66,5 @@ function addOrUpdateSurfaceToElement(element, surface, segmentationRepresentatio
97
66
  viewport.getRenderer().resetCameraClippingRange();
98
67
  }, 0);
99
68
  }
100
- function updateSurfacePlanes(evt) {
101
- const { actorEntry, vtkPlanes, viewport } = evt.detail;
102
- if (!(actorEntry === null || actorEntry === void 0 ? void 0 : actorEntry.clippingFilter) || vtkPlanes.length === 0) {
103
- return;
104
- }
105
- const sliceIndex = viewport.getSliceIndex();
106
- const mapper = actorEntry.actor.getMapper();
107
- const { viewPlaneNormal } = viewport.getCamera();
108
- const cacheId = (0, surfaceDisplay_1.generateCacheId)(viewport, viewPlaneNormal, sliceIndex);
109
- const polyData = (0, surfaceDisplay_1.getOrCreatePolyData)(actorEntry, cacheId, vtkPlanes);
110
- mapper.setInputData(polyData);
111
- }
112
69
  exports.default = addOrUpdateSurfaceToElement;
113
70
  //# sourceMappingURL=addOrUpdateSurfaceToElement.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"addOrUpdateSurfaceToElement.js","sourceRoot":"","sources":["../../../../../src/tools/displayTools/Surface/addOrUpdateSurfaceToElement.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"addOrUpdateSurfaceToElement.js","sourceRoot":"","sources":["../../../../../src/tools/displayTools/Surface/addOrUpdateSurfaceToElement.ts"],"names":[],"mappings":";;;;;AAAA,8CAAwD;AAExD,mFAA8D;AAC9D,iFAA4D;AAC5D,yFAAoE;AACpE,sFAAiE;AACjE,mIAAmH;AAEnH,SAAS,2BAA2B,CAClC,OAAuB,EACvB,OAAuB,EACvB,6BAAqC;;IAErC,MAAM,QAAQ,GAAG,IAAA,oDAAkB,EACjC,6BAA6B,EAC7B,OAAO,CAAC,EAAE,CACX,CAAC;IAEF,MAAM,cAAc,GAAG,IAAA,wBAAiB,EAAC,OAAO,CAAC,CAAC;IAClD,MAAM,EAAE,QAAQ,EAAE,GAAG,cAAc,CAAC;IACpC,MAAM,YAAY,GAAG,MAAA,QAAQ,CAAC,QAAQ,CAAC,QAAQ,CAAC,0CAAE,KAAoB,CAAC;IAEvE,IAAI,YAAY,EAAE;QAKhB,MAAM,aAAa,GAAG,YAAY,CAAC,SAAS,EAAE,CAAC;QAC/C,MAAM,eAAe,GAAG,aAAa,CAAC,YAAY,EAAE,CAAC;QAKrD,MAAM,SAAS,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;QACtC,MAAM,QAAQ,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;QAEpC,MAAM,aAAa,GAAG,eAAe,CAAC,SAAS,EAAE,CAAC,OAAO,EAAE,CAAC;QAC5D,MAAM,YAAY,GAAG,eAAe,CAAC,QAAQ,EAAE,CAAC,OAAO,EAAE,CAAC;QAE1D,IACE,SAAS,CAAC,MAAM,KAAK,aAAa,CAAC,MAAM;YACzC,QAAQ,CAAC,MAAM,KAAK,YAAY,CAAC,MAAM,EACvC;YAGA,OAAO;SACR;QAED,MAAM,QAAQ,GAAG,kBAAW,CAAC,WAAW,EAAE,CAAC;QAC3C,QAAQ,CAAC,SAAS,EAAE,CAAC,OAAO,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC;QAE3C,MAAM,SAAS,GAAG,mBAAY,CAAC,WAAW,CAAC;YACzC,MAAM,EAAE,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC;SACpC,CAAC,CAAC;QAEH,QAAQ,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;QAE7B,aAAa,CAAC,YAAY,CAAC,QAAQ,CAAC,CAAC;QACrC,aAAa,CAAC,QAAQ,EAAE,CAAC;QAEzB,UAAU,CAAC,GAAG,EAAE;YACd,QAAQ,CAAC,WAAW,EAAE,CAAC,wBAAwB,EAAE,CAAC;QACpD,CAAC,EAAE,CAAC,CAAC,CAAC;QAEN,OAAO;KACR;IAKD,MAAM,MAAM,GAAG,OAAO,CAAC,SAAS,EAAE,CAAC;IACnC,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IACjC,MAAM,KAAK,GAAG,OAAO,CAAC,QAAQ,EAAE,CAAC;IAEjC,MAAM,eAAe,GAAG,kBAAW,CAAC,WAAW,EAAE,CAAC;IAClD,eAAe,CAAC,SAAS,EAAE,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC,CAAC;IAE/C,MAAM,SAAS,GAAG,mBAAY,CAAC,WAAW,CAAC;QACzC,MAAM,EAAE,YAAY,CAAC,IAAI,CAAC,KAAK,CAAC;KACjC,CAAC,CAAC;IACH,eAAe,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IAEpC,MAAM,MAAM,GAAG,gBAAS,CAAC,WAAW,CAAC,EAAE,CAAC,CAAC;IAEzC,IAAI,cAAc,CAAC;IACnB,MAAM,CAAC,YAAY,CAAC,eAAe,CAAC,CAAC;IAErC,MAAM,KAAK,GAAG,eAAQ,CAAC,WAAW,EAAE,CAAC;IACrC,KAAK,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC;IAGxB,KAAK,CAAC,WAAW,EAAE,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,GAAG,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC;IAI7E,KAAK,CAAC,WAAW,EAAE,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC;IAEpC,QAAQ,CAAC,QAAQ,CAAC;QAChB,KAAK;QACL,GAAG,EAAE,QAAQ;QACb,cAAc;KACf,CAAC,CAAC;IAEH,QAAQ,CAAC,WAAW,EAAE,CAAC;IACvB,QAAQ,CAAC,MAAM,EAAE,CAAC;IAElB,UAAU,CAAC,GAAG,EAAE;QACd,QAAQ,CAAC,WAAW,EAAE,CAAC,wBAAwB,EAAE,CAAC;IACpD,CAAC,EAAE,CAAC,CAAC,CAAC;AACR,CAAC;AAED,kBAAe,2BAA2B,CAAC"}
@@ -1,16 +1,10 @@
1
1
  import { Types } from '@cornerstonejs/core';
2
- import { SegmentationRepresentationConfig, ToolGroupSpecificRepresentation } from '../../../types/SegmentationStateTypes';
3
- declare const polyDataCache: Map<any, any>;
2
+ import { ToolGroupSpecificRepresentation } from '../../../types/SegmentationStateTypes';
4
3
  declare function removeSegmentationRepresentation(toolGroupId: string, segmentationRepresentationUID: string, renderImmediate?: boolean): void;
5
- declare function render(viewport: Types.IVolumeViewport, representation: ToolGroupSpecificRepresentation, toolGroupConfig: SegmentationRepresentationConfig): Promise<void>;
6
- export declare function getSurfaceActorUID(segmentationRepresentationUID: string, surfaceId: string): string;
7
- export declare function generateCacheId(viewport: any, viewPlaneNormal: any, sliceIndex: any): string;
8
- export declare function getOrCreatePolyData(actorEntry: any, cacheId: any, vtkPlanes: any): any;
9
- export declare function updatePolyDataCache(actorUID: any, cacheId: any, polyDataResult: any): void;
10
- export declare function getSortedPlanesInfo(viewport: any): any;
4
+ declare function render(viewport: Types.IVolumeViewport, representation: ToolGroupSpecificRepresentation): Promise<void>;
11
5
  declare const _default: {
12
6
  render: typeof render;
13
7
  removeSegmentationRepresentation: typeof removeSegmentationRepresentation;
14
8
  };
15
9
  export default _default;
16
- export { render, removeSegmentationRepresentation, polyDataCache };
10
+ export { render, removeSegmentationRepresentation };
@@ -35,29 +35,14 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
35
35
  return (mod && mod.__esModule) ? mod : { "default": mod };
36
36
  };
37
37
  Object.defineProperty(exports, "__esModule", { value: true });
38
- exports.polyDataCache = exports.removeSegmentationRepresentation = exports.render = exports.getSortedPlanesInfo = exports.updatePolyDataCache = exports.getOrCreatePolyData = exports.generateCacheId = exports.getSurfaceActorUID = void 0;
39
- const PolyData_1 = __importDefault(require("@kitware/vtk.js/Common/DataModel/PolyData"));
40
- const CellArray_1 = __importDefault(require("@kitware/vtk.js/Common/Core/CellArray"));
38
+ exports.removeSegmentationRepresentation = exports.render = void 0;
41
39
  const core_1 = require("@cornerstonejs/core");
42
40
  const SegmentationState = __importStar(require("../../../stateManagement/segmentation/segmentationState"));
43
41
  const SegmentationRepresentations_1 = __importDefault(require("../../../enums/SegmentationRepresentations"));
44
42
  const ToolGroupManager_1 = require("../../../store/ToolGroupManager");
45
- const registerDisplayToolsWorker_1 = require("../registerDisplayToolsWorker");
46
43
  const removeSurfaceFromElement_1 = __importDefault(require("./removeSurfaceFromElement"));
47
44
  const addOrUpdateSurfaceToElement_1 = __importDefault(require("./addOrUpdateSurfaceToElement"));
48
45
  const segmentation_1 = require("../../../stateManagement/segmentation");
49
- const utilities_1 = require("../../../utilities");
50
- const enums_1 = require("../../../enums");
51
- const workerManager = (0, core_1.getWebWorkerManager)();
52
- const polyDataCache = new Map();
53
- exports.polyDataCache = polyDataCache;
54
- const currentViewportNormal = new Map();
55
- const triggerWorkerProgress = (eventTarget, progress) => {
56
- (0, core_1.triggerEvent)(eventTarget, core_1.Enums.Events.WEB_WORKER_PROGRESS, {
57
- progress,
58
- type: enums_1.WorkerTypes.DISPLAY_TOOL_CLIP_SURFACE,
59
- });
60
- };
61
46
  function removeSegmentationRepresentation(toolGroupId, segmentationRepresentationUID, renderImmediate = false) {
62
47
  _removeSurfaceFromToolGroupViewports(toolGroupId, segmentationRepresentationUID);
63
48
  SegmentationState.removeSegmentationRepresentation(toolGroupId, segmentationRepresentationUID);
@@ -70,13 +55,16 @@ function removeSegmentationRepresentation(toolGroupId, segmentationRepresentatio
70
55
  }
71
56
  }
72
57
  exports.removeSegmentationRepresentation = removeSegmentationRepresentation;
73
- function render(viewport, representation, toolGroupConfig) {
58
+ function render(viewport, representation) {
74
59
  return __awaiter(this, void 0, void 0, function* () {
75
- const { colorLUTIndex, active, segmentationId, segmentationRepresentationUID, segmentsHidden, } = representation;
60
+ const { colorLUTIndex, segmentationId, segmentationRepresentationUID } = representation;
76
61
  const segmentation = SegmentationState.getSegmentation(segmentationId);
77
62
  if (!segmentation) {
78
63
  return;
79
64
  }
65
+ if (!(viewport instanceof core_1.VolumeViewport3D)) {
66
+ throw new Error('Surface rendering is only supported in 3D viewports, if you need to visualize the surface cuts in 2D viewports, you can use the Contour representation, see polySeg converters');
67
+ }
80
68
  let SurfaceData = segmentation.representationData[SegmentationRepresentations_1.default.Surface];
81
69
  if (!SurfaceData &&
82
70
  segmentation_1.polySeg.canComputeRequestedRepresentation(segmentationRepresentationUID)) {
@@ -95,13 +83,7 @@ function render(viewport, representation, toolGroupConfig) {
95
83
  const surfaces = [];
96
84
  geometryIds.forEach((geometryId, segmentIndex) => {
97
85
  const geometry = core_1.cache.getGeometry(geometryId);
98
- if (!geometry) {
99
- throw new Error(`No Surfaces found for geometryId ${geometryId}`);
100
- }
101
- if (geometry.type !== core_1.Enums.GeometryType.SURFACE) {
102
- throw new Error(`Geometry type ${geometry.type} not supported for rendering.`);
103
- }
104
- if (!geometry.data) {
86
+ if (!(geometry === null || geometry === void 0 ? void 0 : geometry.data)) {
105
87
  console.warn(`No Surfaces found for geometryId ${geometryId}. Skipping render.`);
106
88
  return;
107
89
  }
@@ -111,9 +93,6 @@ function render(viewport, representation, toolGroupConfig) {
111
93
  (0, addOrUpdateSurfaceToElement_1.default)(viewport.element, surface, segmentationRepresentationUID);
112
94
  surfaces.push(surface);
113
95
  });
114
- if (!(viewport instanceof core_1.VolumeViewport3D)) {
115
- generateAndCacheClippedSurfaces(surfaces, viewport, segmentationRepresentationUID);
116
- }
117
96
  viewport.render();
118
97
  });
119
98
  }
@@ -130,126 +109,6 @@ function _removeSurfaceFromToolGroupViewports(toolGroupId, segmentationRepresent
130
109
  (0, removeSurfaceFromElement_1.default)(enabledElement.viewport.element, segmentationRepresentationUID);
131
110
  }
132
111
  }
133
- function generateAndCacheClippedSurfaces(surfaces, viewport, segmentationRepresentationUID) {
134
- var _a;
135
- return __awaiter(this, void 0, void 0, function* () {
136
- (0, registerDisplayToolsWorker_1.registerDisplayToolsWorker)();
137
- const planesInfo = (_a = viewport.getSlicesClippingPlanes) === null || _a === void 0 ? void 0 : _a.call(viewport);
138
- if (!planesInfo) {
139
- return;
140
- }
141
- const currentSliceIndex = viewport.getSliceIndex();
142
- planesInfo.sort((a, b) => {
143
- const diffA = Math.abs(a.sliceIndex - currentSliceIndex);
144
- const diffB = Math.abs(b.sliceIndex - currentSliceIndex);
145
- return diffA - diffB;
146
- });
147
- const pointsAndPolys = surfaces.map((surface) => {
148
- const id = surface.id;
149
- const points = surface.getPoints();
150
- const polys = surface.getPolys();
151
- return { id, points, polys };
152
- });
153
- const camera = viewport.getCamera();
154
- function cameraModifiedCallback(evt) {
155
- const { camera } = evt.detail;
156
- const { viewPlaneNormal } = camera;
157
- const surface1 = surfaces[0];
158
- if (core_1.utilities.isEqual(viewPlaneNormal, currentViewportNormal.get(surface1.id))) {
159
- return;
160
- }
161
- currentViewportNormal.set(surface1.id, viewPlaneNormal);
162
- workerManager.terminate('displayTools');
163
- setTimeout(() => {
164
- generateAndCacheClippedSurfaces(surfaces, viewport, segmentationRepresentationUID);
165
- }, 0);
166
- viewport.render();
167
- }
168
- viewport.element.removeEventListener(core_1.Enums.Events.CAMERA_MODIFIED, cameraModifiedCallback);
169
- viewport.element.addEventListener(core_1.Enums.Events.CAMERA_MODIFIED, cameraModifiedCallback);
170
- triggerWorkerProgress(core_1.eventTarget, 0);
171
- yield workerManager
172
- .executeTask('displayTools', 'clipSurfaceWithPlanes', {
173
- planesInfo,
174
- pointsAndPolys,
175
- }, {
176
- callbacks: [
177
- ({ progress }) => {
178
- triggerWorkerProgress(core_1.eventTarget, progress);
179
- },
180
- ({ sliceIndex, polyDataResults }) => {
181
- polyDataResults.forEach((polyDataResult, surfaceId) => {
182
- const actorUID = `${segmentationRepresentationUID}_${surfaceId}`;
183
- const cacheId = generateCacheId(viewport, camera.viewPlaneNormal, sliceIndex);
184
- updatePolyDataCache(actorUID, cacheId, polyDataResult);
185
- });
186
- },
187
- ],
188
- })
189
- .catch((error) => {
190
- console.error(error);
191
- });
192
- triggerWorkerProgress(core_1.eventTarget, 100);
193
- });
194
- }
195
- function getSurfaceActorUID(segmentationRepresentationUID, surfaceId) {
196
- return `${segmentationRepresentationUID}_${surfaceId}`;
197
- }
198
- exports.getSurfaceActorUID = getSurfaceActorUID;
199
- function generateCacheId(viewport, viewPlaneNormal, sliceIndex) {
200
- return `${viewport.id}-${(0, utilities_1.pointToString)(viewPlaneNormal)}-${sliceIndex}`;
201
- }
202
- exports.generateCacheId = generateCacheId;
203
- function getOrCreatePolyData(actorEntry, cacheId, vtkPlanes) {
204
- let actorCache = polyDataCache.get(actorEntry.uid);
205
- if (!actorCache) {
206
- actorCache = new Map();
207
- polyDataCache.set(actorEntry.uid, actorCache);
208
- }
209
- let polyData = actorCache.get(cacheId);
210
- if (!polyData) {
211
- const clippingFilter = actorEntry.clippingFilter;
212
- clippingFilter.setClippingPlanes(vtkPlanes);
213
- try {
214
- clippingFilter.update();
215
- polyData = clippingFilter.getOutputData();
216
- actorCache.set(cacheId, polyData);
217
- }
218
- catch (e) {
219
- console.error('Error clipping surface', e);
220
- }
221
- }
222
- return polyData;
223
- }
224
- exports.getOrCreatePolyData = getOrCreatePolyData;
225
- function updatePolyDataCache(actorUID, cacheId, polyDataResult) {
226
- const { points, lines } = polyDataResult;
227
- const polyData = PolyData_1.default.newInstance();
228
- polyData.getPoints().setData(points, 3);
229
- const linesArray = CellArray_1.default.newInstance({
230
- values: Int16Array.from(lines),
231
- });
232
- polyData.setLines(linesArray);
233
- let actorCache = polyDataCache.get(actorUID);
234
- if (!actorCache) {
235
- actorCache = new Map();
236
- polyDataCache.set(actorUID, actorCache);
237
- }
238
- actorCache.set(cacheId, polyData);
239
- }
240
- exports.updatePolyDataCache = updatePolyDataCache;
241
- function getSortedPlanesInfo(viewport) {
242
- var _a;
243
- const planesInfo = (_a = viewport.getSlicesClippingPlanes) === null || _a === void 0 ? void 0 : _a.call(viewport);
244
- const currentSliceIndex = viewport.getSliceIndex();
245
- planesInfo.sort((a, b) => {
246
- const diffA = Math.abs(a.sliceIndex - currentSliceIndex);
247
- const diffB = Math.abs(b.sliceIndex - currentSliceIndex);
248
- return diffA - diffB;
249
- });
250
- return planesInfo;
251
- }
252
- exports.getSortedPlanesInfo = getSortedPlanesInfo;
253
112
  exports.default = {
254
113
  render,
255
114
  removeSegmentationRepresentation,
@@ -1 +1 @@
1
- {"version":3,"file":"surfaceDisplay.js","sourceRoot":"","sources":["../../../../../src/tools/displayTools/Surface/surfaceDisplay.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"surfaceDisplay.js","sourceRoot":"","sources":["../../../../../src/tools/displayTools/Surface/surfaceDisplay.ts"],"names":[],"mappings":"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"}
@@ -2,5 +2,5 @@ import type { Types } from '@cornerstonejs/core';
2
2
  export declare type PolySegConversionOptions = {
3
3
  segmentIndices?: number[];
4
4
  segmentationRepresentationUID?: string;
5
- viewport?: Types.IViewport;
5
+ viewport?: Types.IStackViewport | Types.IVolumeViewport;
6
6
  };
@@ -8,13 +8,16 @@ function addContourSegmentationAnnotation(annotation) {
8
8
  }
9
9
  const { segmentationId, segmentIndex } = annotation.data.segmentation;
10
10
  const segmentation = (0, segmentationState_1.getSegmentation)(segmentationId);
11
+ if (!segmentation.representationData.CONTOUR) {
12
+ segmentation.representationData.CONTOUR = { annotationUIDsMap: new Map() };
13
+ }
11
14
  const { annotationUIDsMap } = segmentation.representationData.CONTOUR;
12
15
  let annotationsUIDsSet = annotationUIDsMap.get(segmentIndex);
13
16
  if (!annotationsUIDsSet) {
14
17
  annotationsUIDsSet = new Set();
15
18
  annotationUIDsMap.set(segmentIndex, annotationsUIDsSet);
16
19
  }
17
- annotationsUIDsSet.add(annotation.annotationUID);
20
+ annotationUIDsMap.set(segmentIndex, annotationsUIDsSet.add(annotation.annotationUID));
18
21
  }
19
22
  exports.addContourSegmentationAnnotation = addContourSegmentationAnnotation;
20
23
  //# sourceMappingURL=addContourSegmentationAnnotation.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"addContourSegmentationAnnotation.js","sourceRoot":"","sources":["../../../../src/utilities/contourSegmentation/addContourSegmentationAnnotation.ts"],"names":[],"mappings":";;;AAAA,4FAAuF;AAOvF,SAAgB,gCAAgC,CAC9C,UAAyC;IAEzC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,EAAE;QACjC,MAAM,IAAI,KAAK,CACb,gFAAgF,CACjF,CAAC;KACH;IAED,MAAM,EAAE,cAAc,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC;IACtE,MAAM,YAAY,GAAG,IAAA,mCAAe,EAAC,cAAc,CAAC,CAAC;IACrD,MAAM,EAAE,iBAAiB,EAAE,GAAG,YAAY,CAAC,kBAAkB,CAAC,OAAO,CAAC;IAEtE,IAAI,kBAAkB,GAAG,iBAAiB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IAE7D,IAAI,CAAC,kBAAkB,EAAE;QACvB,kBAAkB,GAAG,IAAI,GAAG,EAAE,CAAC;QAC/B,iBAAiB,CAAC,GAAG,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;KACzD;IAED,kBAAkB,CAAC,GAAG,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;AACnD,CAAC;AArBD,4EAqBC"}
1
+ {"version":3,"file":"addContourSegmentationAnnotation.js","sourceRoot":"","sources":["../../../../src/utilities/contourSegmentation/addContourSegmentationAnnotation.ts"],"names":[],"mappings":";;;AAAA,4FAAuF;AAOvF,SAAgB,gCAAgC,CAC9C,UAAyC;IAEzC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,EAAE;QACjC,MAAM,IAAI,KAAK,CACb,gFAAgF,CACjF,CAAC;KACH;IAED,MAAM,EAAE,cAAc,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC;IACtE,MAAM,YAAY,GAAG,IAAA,mCAAe,EAAC,cAAc,CAAC,CAAC;IAErD,IAAI,CAAC,YAAY,CAAC,kBAAkB,CAAC,OAAO,EAAE;QAC5C,YAAY,CAAC,kBAAkB,CAAC,OAAO,GAAG,EAAE,iBAAiB,EAAE,IAAI,GAAG,EAAE,EAAE,CAAC;KAC5E;IAED,MAAM,EAAE,iBAAiB,EAAE,GAAG,YAAY,CAAC,kBAAkB,CAAC,OAAO,CAAC;IAEtE,IAAI,kBAAkB,GAAG,iBAAiB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IAE7D,IAAI,CAAC,kBAAkB,EAAE;QACvB,kBAAkB,GAAG,IAAI,GAAG,EAAE,CAAC;QAC/B,iBAAiB,CAAC,GAAG,CAAC,YAAY,EAAE,kBAAkB,CAAC,CAAC;KACzD;IAED,iBAAiB,CAAC,GAAG,CACnB,YAAY,EACZ,kBAAkB,CAAC,GAAG,CAAC,UAAU,CAAC,aAAa,CAAC,CACjD,CAAC;AACJ,CAAC;AA7BD,4EA6BC"}
@@ -10,6 +10,9 @@ function removeContourSegmentationAnnotation(annotation) {
10
10
  const segmentation = segmentation_1.state.getSegmentation(segmentationId);
11
11
  const { annotationUIDsMap } = segmentation.representationData.CONTOUR;
12
12
  const annotationsUIDsSet = annotationUIDsMap.get(segmentIndex);
13
+ if (!annotationsUIDsSet) {
14
+ return;
15
+ }
13
16
  annotationsUIDsSet.delete(annotation.annotationUID);
14
17
  if (!annotationsUIDsSet.size) {
15
18
  annotationUIDsMap.delete(segmentIndex);
@@ -1 +1 @@
1
- {"version":3,"file":"removeContourSegmentationAnnotation.js","sourceRoot":"","sources":["../../../../src/utilities/contourSegmentation/removeContourSegmentationAnnotation.ts"],"names":[],"mappings":";;;AAAA,qEAA2D;AAS3D,SAAgB,mCAAmC,CACjD,UAAyC;IAEzC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,EAAE;QACjC,MAAM,IAAI,KAAK,CACb,mFAAmF,CACpF,CAAC;KACH;IAED,MAAM,EAAE,cAAc,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC;IACtE,MAAM,YAAY,GAAG,oBAAK,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC;IAC3D,MAAM,EAAE,iBAAiB,EAAE,GAAG,YAAY,CAAC,kBAAkB,CAAC,OAAO,CAAC;IACtE,MAAM,kBAAkB,GAAG,iBAAiB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IAE/D,kBAAkB,CAAC,MAAM,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IAGpD,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE;QAC5B,iBAAiB,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;KACxC;AACH,CAAC;AApBD,kFAoBC"}
1
+ {"version":3,"file":"removeContourSegmentationAnnotation.js","sourceRoot":"","sources":["../../../../src/utilities/contourSegmentation/removeContourSegmentationAnnotation.ts"],"names":[],"mappings":";;;AAAA,qEAA2D;AAS3D,SAAgB,mCAAmC,CACjD,UAAyC;IAEzC,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,YAAY,EAAE;QACjC,MAAM,IAAI,KAAK,CACb,mFAAmF,CACpF,CAAC;KACH;IAED,MAAM,EAAE,cAAc,EAAE,YAAY,EAAE,GAAG,UAAU,CAAC,IAAI,CAAC,YAAY,CAAC;IACtE,MAAM,YAAY,GAAG,oBAAK,CAAC,eAAe,CAAC,cAAc,CAAC,CAAC;IAC3D,MAAM,EAAE,iBAAiB,EAAE,GAAG,YAAY,CAAC,kBAAkB,CAAC,OAAO,CAAC;IACtE,MAAM,kBAAkB,GAAG,iBAAiB,CAAC,GAAG,CAAC,YAAY,CAAC,CAAC;IAE/D,IAAI,CAAC,kBAAkB,EAAE;QACvB,OAAO;KACR;IAED,kBAAkB,CAAC,MAAM,CAAC,UAAU,CAAC,aAAa,CAAC,CAAC;IAGpD,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE;QAC5B,iBAAiB,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;KACxC;AACH,CAAC;AAxBD,kFAwBC"}
@@ -1,2 +1,4 @@
1
1
  import { Types } from '@cornerstonejs/core';
2
- export default function getAABB(polyline: Types.Point2[]): Types.AABB2;
2
+ export default function getAABB(polyline: Types.Point2[] | Types.Point3[] | number[], options?: {
3
+ numDimensions: number;
4
+ }): Types.AABB2 | Types.AABB3;
@@ -1,18 +1,44 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- function getAABB(polyline) {
3
+ function getAABB(polyline, options) {
4
+ let polylineToUse = polyline;
5
+ const numDimensions = (options === null || options === void 0 ? void 0 : options.numDimensions) || 2;
6
+ const is3D = numDimensions === 3;
7
+ if (!Array.isArray(polyline[0])) {
8
+ const currentPolyline = polyline;
9
+ const totalPoints = currentPolyline.length / numDimensions;
10
+ polylineToUse = new Array(currentPolyline.length / numDimensions);
11
+ for (let i = 0, len = totalPoints; i < len; i++) {
12
+ polylineToUse[i] = [
13
+ currentPolyline[i * numDimensions],
14
+ currentPolyline[i * numDimensions + 1],
15
+ ];
16
+ if (is3D) {
17
+ polylineToUse[i].push(currentPolyline[i * numDimensions + 2]);
18
+ }
19
+ }
20
+ }
4
21
  let minX = Infinity;
5
22
  let minY = Infinity;
6
23
  let maxX = -Infinity;
7
24
  let maxY = -Infinity;
8
- for (let i = 0, len = polyline.length; i < len; i++) {
9
- const [x, y] = polyline[i];
25
+ let minZ = Infinity;
26
+ let maxZ = -Infinity;
27
+ polylineToUse = polylineToUse;
28
+ for (let i = 0, len = polylineToUse.length; i < len; i++) {
29
+ const [x, y, z] = polylineToUse[i];
10
30
  minX = minX < x ? minX : x;
11
31
  minY = minY < y ? minY : y;
12
32
  maxX = maxX > x ? maxX : x;
13
33
  maxY = maxY > y ? maxY : y;
34
+ if (is3D) {
35
+ minZ = minZ < z ? minZ : z;
36
+ maxZ = maxZ > z ? maxZ : z;
37
+ }
14
38
  }
15
- return { minX, maxX, minY, maxY };
39
+ return is3D
40
+ ? { minX, maxX, minY, maxY, minZ, maxZ }
41
+ : { minX, maxX, minY, maxY };
16
42
  }
17
43
  exports.default = getAABB;
18
44
  //# sourceMappingURL=getAABB.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"getAABB.js","sourceRoot":"","sources":["../../../../../src/utilities/math/polyline/getAABB.ts"],"names":[],"mappings":";;AAEA,SAAwB,OAAO,CAAC,QAAwB;IACtD,IAAI,IAAI,GAAG,QAAQ,CAAC;IACpB,IAAI,IAAI,GAAG,QAAQ,CAAC;IACpB,IAAI,IAAI,GAAG,CAAC,QAAQ,CAAC;IACrB,IAAI,IAAI,GAAG,CAAC,QAAQ,CAAC;IAErB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,QAAQ,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;QACnD,MAAM,CAAC,CAAC,EAAE,CAAC,CAAC,GAAG,QAAQ,CAAC,CAAC,CAAC,CAAC;QAG3B,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3B,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3B,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3B,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;KAC5B;IAED,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;AACpC,CAAC;AAjBD,0BAiBC"}
1
+ {"version":3,"file":"getAABB.js","sourceRoot":"","sources":["../../../../../src/utilities/math/polyline/getAABB.ts"],"names":[],"mappings":";;AAWA,SAAwB,OAAO,CAC7B,QAAoD,EACpD,OAEC;IAID,IAAI,aAAa,GAAG,QAAQ,CAAC;IAC7B,MAAM,aAAa,GAAG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,aAAa,KAAI,CAAC,CAAC;IAClD,MAAM,IAAI,GAAG,aAAa,KAAK,CAAC,CAAC;IAEjC,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE;QAC/B,MAAM,eAAe,GAAG,QAAoB,CAAC;QAI7C,MAAM,WAAW,GAAG,eAAe,CAAC,MAAM,GAAG,aAAa,CAAC;QAE3D,aAAa,GAAG,IAAI,KAAK,CAAC,eAAe,CAAC,MAAM,GAAG,aAAa,CAE9C,CAAC;QAEnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,WAAW,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;YAC/C,aAAa,CAAC,CAAC,CAAC,GAAG;gBACjB,eAAe,CAAC,CAAC,GAAG,aAAa,CAAC;gBAClC,eAAe,CAAC,CAAC,GAAG,aAAa,GAAG,CAAC,CAAC;aACvC,CAAC;YAEF,IAAI,IAAI,EAAE;gBACR,aAAa,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC,GAAG,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC;aAC/D;SACF;KACF;IAED,IAAI,IAAI,GAAG,QAAQ,CAAC;IACpB,IAAI,IAAI,GAAG,QAAQ,CAAC;IACpB,IAAI,IAAI,GAAG,CAAC,QAAQ,CAAC;IACrB,IAAI,IAAI,GAAG,CAAC,QAAQ,CAAC;IACrB,IAAI,IAAI,GAAG,QAAQ,CAAC;IACpB,IAAI,IAAI,GAAG,CAAC,QAAQ,CAAC;IAErB,aAAa,GAAG,aAAgD,CAAC;IAEjE,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,GAAG,aAAa,CAAC,MAAM,EAAE,CAAC,GAAG,GAAG,EAAE,CAAC,EAAE,EAAE;QACxD,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,aAAa,CAAC,CAAC,CAAC,CAAC;QAGnC,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3B,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3B,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC3B,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAE3B,IAAI,IAAI,EAAE;YACR,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;YAC3B,IAAI,GAAG,IAAI,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;SAC5B;KACF;IAED,OAAO,IAAI;QACT,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE;QACxC,CAAC,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,CAAC;AACjC,CAAC;AA9DD,0BA8DC"}
@@ -2,11 +2,13 @@ import filterAnnotationsWithinSlice from './filterAnnotationsWithinSlice';
2
2
  import getWorldWidthAndHeightFromCorners from './getWorldWidthAndHeightFromCorners';
3
3
  import filterAnnotationsForDisplay from './filterAnnotationsForDisplay';
4
4
  import getPointInLineOfSightWithCriteria from './getPointInLineOfSightWithCriteria';
5
+ import { isPlaneIntersectingAABB } from './isPlaneIntersectingAABB';
5
6
  declare const _default: {
6
7
  filterAnnotationsWithinSlice: typeof filterAnnotationsWithinSlice;
7
8
  getWorldWidthAndHeightFromCorners: typeof getWorldWidthAndHeightFromCorners;
8
9
  filterAnnotationsForDisplay: typeof filterAnnotationsForDisplay;
9
10
  getPointInLineOfSightWithCriteria: typeof getPointInLineOfSightWithCriteria;
11
+ isPlaneIntersectingAABB: (origin: any, normal: any, minX: any, minY: any, minZ: any, maxX: any, maxY: any, maxZ: any) => boolean;
10
12
  };
11
13
  export default _default;
12
- export { filterAnnotationsWithinSlice, getWorldWidthAndHeightFromCorners, filterAnnotationsForDisplay, getPointInLineOfSightWithCriteria, };
14
+ export { filterAnnotationsWithinSlice, getWorldWidthAndHeightFromCorners, filterAnnotationsForDisplay, getPointInLineOfSightWithCriteria, isPlaneIntersectingAABB, };
@@ -3,7 +3,7 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.getPointInLineOfSightWithCriteria = exports.filterAnnotationsForDisplay = exports.getWorldWidthAndHeightFromCorners = exports.filterAnnotationsWithinSlice = void 0;
6
+ exports.isPlaneIntersectingAABB = exports.getPointInLineOfSightWithCriteria = exports.filterAnnotationsForDisplay = exports.getWorldWidthAndHeightFromCorners = exports.filterAnnotationsWithinSlice = void 0;
7
7
  const filterAnnotationsWithinSlice_1 = __importDefault(require("./filterAnnotationsWithinSlice"));
8
8
  exports.filterAnnotationsWithinSlice = filterAnnotationsWithinSlice_1.default;
9
9
  const getWorldWidthAndHeightFromCorners_1 = __importDefault(require("./getWorldWidthAndHeightFromCorners"));
@@ -12,10 +12,13 @@ const filterAnnotationsForDisplay_1 = __importDefault(require("./filterAnnotatio
12
12
  exports.filterAnnotationsForDisplay = filterAnnotationsForDisplay_1.default;
13
13
  const getPointInLineOfSightWithCriteria_1 = __importDefault(require("./getPointInLineOfSightWithCriteria"));
14
14
  exports.getPointInLineOfSightWithCriteria = getPointInLineOfSightWithCriteria_1.default;
15
+ const isPlaneIntersectingAABB_1 = require("./isPlaneIntersectingAABB");
16
+ Object.defineProperty(exports, "isPlaneIntersectingAABB", { enumerable: true, get: function () { return isPlaneIntersectingAABB_1.isPlaneIntersectingAABB; } });
15
17
  exports.default = {
16
18
  filterAnnotationsWithinSlice: filterAnnotationsWithinSlice_1.default,
17
19
  getWorldWidthAndHeightFromCorners: getWorldWidthAndHeightFromCorners_1.default,
18
20
  filterAnnotationsForDisplay: filterAnnotationsForDisplay_1.default,
19
21
  getPointInLineOfSightWithCriteria: getPointInLineOfSightWithCriteria_1.default,
22
+ isPlaneIntersectingAABB: isPlaneIntersectingAABB_1.isPlaneIntersectingAABB,
20
23
  };
21
24
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/planar/index.ts"],"names":[],"mappings":";;;;;;AAAA,kGAA0E;AAaxE,uCAbK,sCAA4B,CAaL;AAZ9B,4GAAoF;AAalF,4CAbK,2CAAiC,CAaL;AAZnC,gGAAwE;AAatE,sCAbK,qCAA2B,CAaL;AAZ7B,4GAAoF;AAalF,4CAbK,2CAAiC,CAaL;AAXnC,kBAAe;IACb,4BAA4B,EAA5B,sCAA4B;IAC5B,iCAAiC,EAAjC,2CAAiC;IACjC,2BAA2B,EAA3B,qCAA2B;IAC3B,iCAAiC,EAAjC,2CAAiC;CAClC,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/planar/index.ts"],"names":[],"mappings":";;;;;;AAAA,kGAA0E;AAexE,uCAfK,sCAA4B,CAeL;AAd9B,4GAAoF;AAelF,4CAfK,2CAAiC,CAeL;AAdnC,gGAAwE;AAetE,sCAfK,qCAA2B,CAeL;AAd7B,4GAAoF;AAelF,4CAfK,2CAAiC,CAeL;AAdnC,uEAAoE;AAelE,wGAfO,iDAAuB,OAeP;AAbzB,kBAAe;IACb,4BAA4B,EAA5B,sCAA4B;IAC5B,iCAAiC,EAAjC,2CAAiC;IACjC,2BAA2B,EAA3B,qCAA2B;IAC3B,iCAAiC,EAAjC,2CAAiC;IACjC,uBAAuB,EAAvB,iDAAuB;CACxB,CAAC"}
@@ -0,0 +1 @@
1
+ export declare const isPlaneIntersectingAABB: (origin: any, normal: any, minX: any, minY: any, minZ: any, maxX: any, maxY: any, maxZ: any) => boolean;
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isPlaneIntersectingAABB = void 0;
4
+ const gl_matrix_1 = require("gl-matrix");
5
+ const isPlaneIntersectingAABB = (origin, normal, minX, minY, minZ, maxX, maxY, maxZ) => {
6
+ const vertices = [
7
+ gl_matrix_1.vec3.fromValues(minX, minY, minZ),
8
+ gl_matrix_1.vec3.fromValues(maxX, minY, minZ),
9
+ gl_matrix_1.vec3.fromValues(minX, maxY, minZ),
10
+ gl_matrix_1.vec3.fromValues(maxX, maxY, minZ),
11
+ gl_matrix_1.vec3.fromValues(minX, minY, maxZ),
12
+ gl_matrix_1.vec3.fromValues(maxX, minY, maxZ),
13
+ gl_matrix_1.vec3.fromValues(minX, maxY, maxZ),
14
+ gl_matrix_1.vec3.fromValues(maxX, maxY, maxZ),
15
+ ];
16
+ const normalVec = gl_matrix_1.vec3.fromValues(normal[0], normal[1], normal[2]);
17
+ const originVec = gl_matrix_1.vec3.fromValues(origin[0], origin[1], origin[2]);
18
+ const planeDistance = -gl_matrix_1.vec3.dot(normalVec, originVec);
19
+ let initialSign = null;
20
+ for (const vertex of vertices) {
21
+ const distance = gl_matrix_1.vec3.dot(normalVec, vertex) + planeDistance;
22
+ if (initialSign === null) {
23
+ initialSign = Math.sign(distance);
24
+ }
25
+ else if (Math.sign(distance) !== initialSign) {
26
+ return true;
27
+ }
28
+ }
29
+ return false;
30
+ };
31
+ exports.isPlaneIntersectingAABB = isPlaneIntersectingAABB;
32
+ //# sourceMappingURL=isPlaneIntersectingAABB.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isPlaneIntersectingAABB.js","sourceRoot":"","sources":["../../../../src/utilities/planar/isPlaneIntersectingAABB.ts"],"names":[],"mappings":";;;AAAA,yCAAiC;AAe1B,MAAM,uBAAuB,GAAG,CACrC,MAAM,EACN,MAAM,EACN,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,IAAI,EACJ,EAAE;IACF,MAAM,QAAQ,GAAG;QACf,gBAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;QACjC,gBAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;QACjC,gBAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;QACjC,gBAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;QACjC,gBAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;QACjC,gBAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;QACjC,gBAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;QACjC,gBAAI,CAAC,UAAU,CAAC,IAAI,EAAE,IAAI,EAAE,IAAI,CAAC;KAClC,CAAC;IAEF,MAAM,SAAS,GAAG,gBAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IACnE,MAAM,SAAS,GAAG,gBAAI,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,EAAE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC;IAGnE,MAAM,aAAa,GAAG,CAAC,gBAAI,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC;IAGtD,IAAI,WAAW,GAAG,IAAI,CAAC;IACvB,KAAK,MAAM,MAAM,IAAI,QAAQ,EAAE;QAE7B,MAAM,QAAQ,GAAG,gBAAI,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,GAAG,aAAa,CAAC;QAC7D,IAAI,WAAW,KAAK,IAAI,EAAE;YACxB,WAAW,GAAG,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACnC;aAAM,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,WAAW,EAAE;YAC9C,OAAO,IAAI,CAAC;SACb;KACF;IAED,OAAO,KAAK,CAAC;AACf,CAAC,CAAC;AAxCW,QAAA,uBAAuB,2BAwClC"}
@@ -1,2 +1,4 @@
1
- declare function getUniqueSegmentIndices(segmentationId: any): number[];
1
+ export declare const setSegmentationDirty: (segmentationId: string) => void;
2
+ export declare const setSegmentationClean: (segmentationId: string) => void;
3
+ declare function getUniqueSegmentIndices(segmentationId: any): any;
2
4
  export { getUniqueSegmentIndices };