@cornerstonejs/tools 1.41.0 → 1.42.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (280) hide show
  1. package/dist/cjs/eventDispatchers/keyboardEventHandlers/keyDown.js +2 -1
  2. package/dist/cjs/eventDispatchers/keyboardEventHandlers/keyDown.js.map +1 -1
  3. package/dist/cjs/eventListeners/segmentation/imageChangeEventListener.js +18 -5
  4. package/dist/cjs/eventListeners/segmentation/imageChangeEventListener.js.map +1 -1
  5. package/dist/cjs/stateManagement/annotation/annotationState.js +3 -0
  6. package/dist/cjs/stateManagement/annotation/annotationState.js.map +1 -1
  7. package/dist/cjs/stateManagement/segmentation/convertStackToVolumeSegmentation.d.ts +10 -0
  8. package/dist/cjs/stateManagement/segmentation/convertStackToVolumeSegmentation.js +65 -0
  9. package/dist/cjs/stateManagement/segmentation/convertStackToVolumeSegmentation.js.map +1 -0
  10. package/dist/cjs/stateManagement/segmentation/convertVolumeToStackSegmentation.d.ts +8 -0
  11. package/dist/cjs/stateManagement/segmentation/convertVolumeToStackSegmentation.js +92 -0
  12. package/dist/cjs/stateManagement/segmentation/convertVolumeToStackSegmentation.js.map +1 -0
  13. package/dist/cjs/stateManagement/segmentation/index.d.ts +3 -1
  14. package/dist/cjs/stateManagement/segmentation/index.js +5 -1
  15. package/dist/cjs/stateManagement/segmentation/index.js.map +1 -1
  16. package/dist/cjs/stateManagement/segmentation/segmentationState.d.ts +2 -1
  17. package/dist/cjs/stateManagement/segmentation/segmentationState.js +8 -1
  18. package/dist/cjs/stateManagement/segmentation/segmentationState.js.map +1 -1
  19. package/dist/cjs/store/ToolGroupManager/ToolGroup.js +3 -0
  20. package/dist/cjs/store/ToolGroupManager/ToolGroup.js.map +1 -1
  21. package/dist/cjs/tools/annotation/AngleTool.js +2 -2
  22. package/dist/cjs/tools/annotation/AngleTool.js.map +1 -1
  23. package/dist/cjs/tools/annotation/BidirectionalTool.js +8 -7
  24. package/dist/cjs/tools/annotation/BidirectionalTool.js.map +1 -1
  25. package/dist/cjs/tools/annotation/CircleROITool.js +8 -8
  26. package/dist/cjs/tools/annotation/CircleROITool.js.map +1 -1
  27. package/dist/cjs/tools/annotation/EllipticalROITool.js +7 -7
  28. package/dist/cjs/tools/annotation/EllipticalROITool.js.map +1 -1
  29. package/dist/cjs/tools/annotation/LengthTool.js +2 -2
  30. package/dist/cjs/tools/annotation/LengthTool.js.map +1 -1
  31. package/dist/cjs/tools/annotation/PlanarFreehandROITool.js +5 -5
  32. package/dist/cjs/tools/annotation/PlanarFreehandROITool.js.map +1 -1
  33. package/dist/cjs/tools/annotation/ProbeTool.js +3 -3
  34. package/dist/cjs/tools/annotation/ProbeTool.js.map +1 -1
  35. package/dist/cjs/tools/annotation/RectangleROITool.js +7 -7
  36. package/dist/cjs/tools/annotation/RectangleROITool.js.map +1 -1
  37. package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js +10 -0
  38. package/dist/cjs/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
  39. package/dist/cjs/tools/segmentation/BrushTool.js +8 -4
  40. package/dist/cjs/tools/segmentation/BrushTool.js.map +1 -1
  41. package/dist/cjs/tools/segmentation/strategies/fillCircle.js +4 -6
  42. package/dist/cjs/tools/segmentation/strategies/fillCircle.js.map +1 -1
  43. package/dist/cjs/tools/segmentation/strategies/utils/isWithinThreshold.d.ts +1 -1
  44. package/dist/cjs/tools/segmentation/strategies/utils/isWithinThreshold.js.map +1 -1
  45. package/dist/cjs/types/index.d.ts +2 -1
  46. package/dist/cjs/utilities/contours/AnnotationToPointData.d.ts +11 -0
  47. package/dist/cjs/utilities/contours/AnnotationToPointData.js +44 -0
  48. package/dist/cjs/utilities/contours/AnnotationToPointData.js.map +1 -0
  49. package/dist/cjs/utilities/contours/RectangleROIStartEndThreshold.d.ts +6 -0
  50. package/dist/cjs/utilities/contours/RectangleROIStartEndThreshold.js +43 -0
  51. package/dist/cjs/utilities/contours/RectangleROIStartEndThreshold.js.map +1 -0
  52. package/dist/cjs/utilities/contours/contourFinder.d.ts +7 -0
  53. package/dist/cjs/utilities/contours/contourFinder.js +68 -0
  54. package/dist/cjs/utilities/contours/contourFinder.js.map +1 -0
  55. package/dist/cjs/utilities/contours/detectContourHoles.d.ts +5 -0
  56. package/dist/cjs/utilities/contours/detectContourHoles.js +78 -0
  57. package/dist/cjs/utilities/contours/detectContourHoles.js.map +1 -0
  58. package/dist/cjs/utilities/contours/generateContourSetsFromLabelmap.d.ts +4 -0
  59. package/dist/cjs/utilities/contours/generateContourSetsFromLabelmap.js +124 -0
  60. package/dist/cjs/utilities/contours/generateContourSetsFromLabelmap.js.map +1 -0
  61. package/dist/cjs/utilities/contours/index.d.ts +6 -0
  62. package/dist/cjs/utilities/contours/index.js +17 -0
  63. package/dist/cjs/utilities/contours/index.js.map +1 -0
  64. package/dist/cjs/utilities/contours/mergePoints.d.ts +8 -0
  65. package/dist/cjs/utilities/contours/mergePoints.js +77 -0
  66. package/dist/cjs/utilities/contours/mergePoints.js.map +1 -0
  67. package/dist/cjs/utilities/index.d.ts +4 -2
  68. package/dist/cjs/utilities/index.js +8 -5
  69. package/dist/cjs/utilities/index.js.map +1 -1
  70. package/dist/cjs/utilities/segmentation/contourAndFindLargestBidirectional.d.ts +1 -0
  71. package/dist/cjs/utilities/segmentation/contourAndFindLargestBidirectional.js +31 -0
  72. package/dist/cjs/utilities/segmentation/contourAndFindLargestBidirectional.js.map +1 -0
  73. package/dist/cjs/utilities/segmentation/createBidirectionalToolData.d.ts +14 -0
  74. package/dist/cjs/utilities/segmentation/createBidirectionalToolData.js +43 -0
  75. package/dist/cjs/utilities/segmentation/createBidirectionalToolData.js.map +1 -0
  76. package/dist/cjs/utilities/segmentation/createImageIdReferenceMap.d.ts +2 -0
  77. package/dist/cjs/utilities/segmentation/createImageIdReferenceMap.js +11 -0
  78. package/dist/cjs/utilities/segmentation/createImageIdReferenceMap.js.map +1 -0
  79. package/dist/cjs/utilities/segmentation/findLargestBidirectional.d.ts +1 -0
  80. package/dist/cjs/utilities/segmentation/findLargestBidirectional.js +94 -0
  81. package/dist/cjs/utilities/segmentation/findLargestBidirectional.js.map +1 -0
  82. package/dist/cjs/utilities/segmentation/index.d.ts +5 -1
  83. package/dist/cjs/utilities/segmentation/index.js +9 -1
  84. package/dist/cjs/utilities/segmentation/index.js.map +1 -1
  85. package/dist/cjs/utilities/segmentation/isLineInSegment.d.ts +9 -0
  86. package/dist/cjs/utilities/segmentation/isLineInSegment.js +55 -0
  87. package/dist/cjs/utilities/segmentation/isLineInSegment.js.map +1 -0
  88. package/dist/cjs/utilities/segmentation/segmentContourAction.d.ts +17 -0
  89. package/dist/cjs/utilities/segmentation/segmentContourAction.js +122 -0
  90. package/dist/cjs/utilities/segmentation/segmentContourAction.js.map +1 -0
  91. package/dist/cjs/utilities/segmentation/thresholdSegmentationByRange.js.map +1 -1
  92. package/dist/cjs/utilities/segmentation/triggerSegmentationRender.js +8 -4
  93. package/dist/cjs/utilities/segmentation/triggerSegmentationRender.js.map +1 -1
  94. package/dist/cjs/utilities/stackPrefetch/stackContextPrefetch.js +2 -5
  95. package/dist/cjs/utilities/stackPrefetch/stackContextPrefetch.js.map +1 -1
  96. package/dist/cjs/utilities/stackPrefetch/stackPrefetchUtils.js +2 -1
  97. package/dist/cjs/utilities/stackPrefetch/stackPrefetchUtils.js.map +1 -1
  98. package/dist/esm/eventDispatchers/keyboardEventHandlers/keyDown.js +2 -1
  99. package/dist/esm/eventDispatchers/keyboardEventHandlers/keyDown.js.map +1 -1
  100. package/dist/esm/eventListeners/segmentation/imageChangeEventListener.js +18 -5
  101. package/dist/esm/eventListeners/segmentation/imageChangeEventListener.js.map +1 -1
  102. package/dist/esm/stateManagement/annotation/annotationState.js +3 -0
  103. package/dist/esm/stateManagement/annotation/annotationState.js.map +1 -1
  104. package/dist/esm/stateManagement/segmentation/convertStackToVolumeSegmentation.js +47 -0
  105. package/dist/esm/stateManagement/segmentation/convertStackToVolumeSegmentation.js.map +1 -0
  106. package/dist/esm/stateManagement/segmentation/convertVolumeToStackSegmentation.js +72 -0
  107. package/dist/esm/stateManagement/segmentation/convertVolumeToStackSegmentation.js.map +1 -0
  108. package/dist/esm/stateManagement/segmentation/index.js +3 -1
  109. package/dist/esm/stateManagement/segmentation/index.js.map +1 -1
  110. package/dist/esm/stateManagement/segmentation/segmentationState.js +7 -1
  111. package/dist/esm/stateManagement/segmentation/segmentationState.js.map +1 -1
  112. package/dist/esm/store/ToolGroupManager/ToolGroup.js +3 -0
  113. package/dist/esm/store/ToolGroupManager/ToolGroup.js.map +1 -1
  114. package/dist/esm/tools/annotation/AngleTool.js +1 -1
  115. package/dist/esm/tools/annotation/AngleTool.js.map +1 -1
  116. package/dist/esm/tools/annotation/BidirectionalTool.js +8 -7
  117. package/dist/esm/tools/annotation/BidirectionalTool.js.map +1 -1
  118. package/dist/esm/tools/annotation/CircleROITool.js +1 -1
  119. package/dist/esm/tools/annotation/CircleROITool.js.map +1 -1
  120. package/dist/esm/tools/annotation/EllipticalROITool.js +1 -1
  121. package/dist/esm/tools/annotation/EllipticalROITool.js.map +1 -1
  122. package/dist/esm/tools/annotation/LengthTool.js +1 -1
  123. package/dist/esm/tools/annotation/LengthTool.js.map +1 -1
  124. package/dist/esm/tools/annotation/PlanarFreehandROITool.js +1 -1
  125. package/dist/esm/tools/annotation/PlanarFreehandROITool.js.map +1 -1
  126. package/dist/esm/tools/annotation/ProbeTool.js +1 -1
  127. package/dist/esm/tools/annotation/ProbeTool.js.map +1 -1
  128. package/dist/esm/tools/annotation/RectangleROITool.js +1 -1
  129. package/dist/esm/tools/annotation/RectangleROITool.js.map +1 -1
  130. package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js +11 -1
  131. package/dist/esm/tools/displayTools/Labelmap/labelmapDisplay.js.map +1 -1
  132. package/dist/esm/tools/segmentation/BrushTool.js +8 -4
  133. package/dist/esm/tools/segmentation/BrushTool.js.map +1 -1
  134. package/dist/esm/tools/segmentation/strategies/fillCircle.js +4 -6
  135. package/dist/esm/tools/segmentation/strategies/fillCircle.js.map +1 -1
  136. package/dist/esm/tools/segmentation/strategies/utils/isWithinThreshold.js.map +1 -1
  137. package/dist/esm/utilities/contours/AnnotationToPointData.js +39 -0
  138. package/dist/esm/utilities/contours/AnnotationToPointData.js.map +1 -0
  139. package/dist/esm/utilities/contours/RectangleROIStartEndThreshold.js +41 -0
  140. package/dist/esm/utilities/contours/RectangleROIStartEndThreshold.js.map +1 -0
  141. package/dist/esm/utilities/contours/contourFinder.js +63 -0
  142. package/dist/esm/utilities/contours/contourFinder.js.map +1 -0
  143. package/dist/esm/utilities/contours/detectContourHoles.js +74 -0
  144. package/dist/esm/utilities/contours/detectContourHoles.js.map +1 -0
  145. package/dist/esm/utilities/contours/generateContourSetsFromLabelmap.js +117 -0
  146. package/dist/esm/utilities/contours/generateContourSetsFromLabelmap.js.map +1 -0
  147. package/dist/esm/utilities/contours/index.js +7 -0
  148. package/dist/esm/utilities/contours/index.js.map +1 -0
  149. package/dist/esm/utilities/contours/mergePoints.js +73 -0
  150. package/dist/esm/utilities/contours/mergePoints.js.map +1 -0
  151. package/dist/esm/utilities/index.js +4 -2
  152. package/dist/esm/utilities/index.js.map +1 -1
  153. package/dist/esm/utilities/segmentation/contourAndFindLargestBidirectional.js +25 -0
  154. package/dist/esm/utilities/segmentation/contourAndFindLargestBidirectional.js.map +1 -0
  155. package/dist/esm/utilities/segmentation/createBidirectionalToolData.js +40 -0
  156. package/dist/esm/utilities/segmentation/createBidirectionalToolData.js.map +1 -0
  157. package/dist/esm/utilities/segmentation/createImageIdReferenceMap.js +8 -0
  158. package/dist/esm/utilities/segmentation/createImageIdReferenceMap.js.map +1 -0
  159. package/dist/esm/utilities/segmentation/findLargestBidirectional.js +96 -0
  160. package/dist/esm/utilities/segmentation/findLargestBidirectional.js.map +1 -0
  161. package/dist/esm/utilities/segmentation/index.js +5 -1
  162. package/dist/esm/utilities/segmentation/index.js.map +1 -1
  163. package/dist/esm/utilities/segmentation/isLineInSegment.js +50 -0
  164. package/dist/esm/utilities/segmentation/isLineInSegment.js.map +1 -0
  165. package/dist/esm/utilities/segmentation/segmentContourAction.js +98 -0
  166. package/dist/esm/utilities/segmentation/segmentContourAction.js.map +1 -0
  167. package/dist/esm/utilities/segmentation/thresholdSegmentationByRange.js.map +1 -1
  168. package/dist/esm/utilities/segmentation/triggerSegmentationRender.js +8 -4
  169. package/dist/esm/utilities/segmentation/triggerSegmentationRender.js.map +1 -1
  170. package/dist/esm/utilities/stackPrefetch/stackContextPrefetch.js +1 -1
  171. package/dist/esm/utilities/stackPrefetch/stackContextPrefetch.js.map +1 -1
  172. package/dist/esm/utilities/stackPrefetch/stackPrefetchUtils.js +2 -1
  173. package/dist/esm/utilities/stackPrefetch/stackPrefetchUtils.js.map +1 -1
  174. package/dist/types/eventDispatchers/keyboardEventHandlers/keyDown.d.ts.map +1 -1
  175. package/dist/types/eventListeners/segmentation/imageChangeEventListener.d.ts.map +1 -1
  176. package/dist/types/stateManagement/annotation/annotationState.d.ts.map +1 -1
  177. package/dist/types/stateManagement/segmentation/convertStackToVolumeSegmentation.d.ts +11 -0
  178. package/dist/types/stateManagement/segmentation/convertStackToVolumeSegmentation.d.ts.map +1 -0
  179. package/dist/types/stateManagement/segmentation/convertVolumeToStackSegmentation.d.ts +9 -0
  180. package/dist/types/stateManagement/segmentation/convertVolumeToStackSegmentation.d.ts.map +1 -0
  181. package/dist/types/stateManagement/segmentation/index.d.ts +3 -1
  182. package/dist/types/stateManagement/segmentation/index.d.ts.map +1 -1
  183. package/dist/types/stateManagement/segmentation/segmentationState.d.ts +2 -1
  184. package/dist/types/stateManagement/segmentation/segmentationState.d.ts.map +1 -1
  185. package/dist/types/store/ToolGroupManager/ToolGroup.d.ts.map +1 -1
  186. package/dist/types/tools/annotation/AngleTool.d.ts.map +1 -1
  187. package/dist/types/tools/annotation/BidirectionalTool.d.ts.map +1 -1
  188. package/dist/types/tools/annotation/PlanarFreehandROITool.d.ts.map +1 -1
  189. package/dist/types/tools/displayTools/Labelmap/labelmapDisplay.d.ts.map +1 -1
  190. package/dist/types/tools/segmentation/BrushTool.d.ts.map +1 -1
  191. package/dist/types/tools/segmentation/strategies/fillCircle.d.ts.map +1 -1
  192. package/dist/types/tools/segmentation/strategies/utils/isWithinThreshold.d.ts +1 -1
  193. package/dist/types/tools/segmentation/strategies/utils/isWithinThreshold.d.ts.map +1 -1
  194. package/dist/types/types/LabelmapTypes.d.ts.map +1 -1
  195. package/dist/types/types/index.d.ts +2 -1
  196. package/dist/types/types/index.d.ts.map +1 -1
  197. package/dist/types/utilities/contours/AnnotationToPointData.d.ts +12 -0
  198. package/dist/types/utilities/contours/AnnotationToPointData.d.ts.map +1 -0
  199. package/dist/types/utilities/contours/RectangleROIStartEndThreshold.d.ts +7 -0
  200. package/dist/types/utilities/contours/RectangleROIStartEndThreshold.d.ts.map +1 -0
  201. package/dist/types/utilities/contours/contourFinder.d.ts +8 -0
  202. package/dist/types/utilities/contours/contourFinder.d.ts.map +1 -0
  203. package/dist/types/utilities/contours/detectContourHoles.d.ts +6 -0
  204. package/dist/types/utilities/contours/detectContourHoles.d.ts.map +1 -0
  205. package/dist/types/utilities/contours/generateContourSetsFromLabelmap.d.ts +5 -0
  206. package/dist/types/utilities/contours/generateContourSetsFromLabelmap.d.ts.map +1 -0
  207. package/dist/types/utilities/contours/index.d.ts +7 -0
  208. package/dist/types/utilities/contours/index.d.ts.map +1 -0
  209. package/dist/types/utilities/contours/mergePoints.d.ts +9 -0
  210. package/dist/types/utilities/contours/mergePoints.d.ts.map +1 -0
  211. package/dist/types/utilities/index.d.ts +4 -2
  212. package/dist/types/utilities/index.d.ts.map +1 -1
  213. package/dist/types/utilities/segmentation/contourAndFindLargestBidirectional.d.ts +2 -0
  214. package/dist/types/utilities/segmentation/contourAndFindLargestBidirectional.d.ts.map +1 -0
  215. package/dist/types/utilities/segmentation/createBidirectionalToolData.d.ts +15 -0
  216. package/dist/types/utilities/segmentation/createBidirectionalToolData.d.ts.map +1 -0
  217. package/dist/types/utilities/segmentation/createImageIdReferenceMap.d.ts +3 -0
  218. package/dist/types/utilities/segmentation/createImageIdReferenceMap.d.ts.map +1 -0
  219. package/dist/types/utilities/segmentation/findLargestBidirectional.d.ts +2 -0
  220. package/dist/types/utilities/segmentation/findLargestBidirectional.d.ts.map +1 -0
  221. package/dist/types/utilities/segmentation/index.d.ts +5 -1
  222. package/dist/types/utilities/segmentation/index.d.ts.map +1 -1
  223. package/dist/types/utilities/segmentation/isLineInSegment.d.ts +10 -0
  224. package/dist/types/utilities/segmentation/isLineInSegment.d.ts.map +1 -0
  225. package/dist/types/utilities/segmentation/segmentContourAction.d.ts +18 -0
  226. package/dist/types/utilities/segmentation/segmentContourAction.d.ts.map +1 -0
  227. package/dist/types/utilities/segmentation/triggerSegmentationRender.d.ts.map +1 -1
  228. package/dist/types/utilities/stackPrefetch/stackPrefetchUtils.d.ts.map +1 -1
  229. package/dist/umd/index.js +1 -1
  230. package/dist/umd/index.js.map +1 -1
  231. package/package.json +3 -3
  232. package/src/eventDispatchers/keyboardEventHandlers/keyDown.ts +7 -1
  233. package/src/eventListeners/segmentation/imageChangeEventListener.ts +42 -6
  234. package/src/stateManagement/annotation/annotationState.ts +3 -0
  235. package/src/stateManagement/segmentation/convertStackToVolumeSegmentation.ts +98 -0
  236. package/src/stateManagement/segmentation/convertVolumeToStackSegmentation.ts +153 -0
  237. package/src/stateManagement/segmentation/index.ts +4 -0
  238. package/src/stateManagement/segmentation/segmentationState.ts +17 -0
  239. package/src/store/ToolGroupManager/ToolGroup.ts +4 -0
  240. package/src/tools/annotation/AngleTool.ts +1 -2
  241. package/src/tools/annotation/BidirectionalTool.ts +10 -6
  242. package/src/tools/annotation/CircleROITool.ts +1 -1
  243. package/src/tools/annotation/EllipticalROITool.ts +1 -1
  244. package/src/tools/annotation/LengthTool.ts +1 -1
  245. package/src/tools/annotation/PlanarFreehandROITool.ts +1 -2
  246. package/src/tools/annotation/ProbeTool.ts +1 -1
  247. package/src/tools/annotation/RectangleROITool.ts +1 -1
  248. package/src/tools/displayTools/Labelmap/labelmapDisplay.ts +16 -2
  249. package/src/tools/segmentation/BrushTool.ts +11 -7
  250. package/src/tools/segmentation/strategies/fillCircle.ts +4 -7
  251. package/src/tools/segmentation/strategies/utils/isWithinThreshold.ts +1 -1
  252. package/src/types/LabelmapTypes.ts +2 -5
  253. package/src/types/index.ts +2 -0
  254. package/src/utilities/contours/AnnotationToPointData.ts +61 -0
  255. package/src/utilities/contours/RectangleROIStartEndThreshold.ts +60 -0
  256. package/src/utilities/contours/contourFinder.ts +78 -0
  257. package/src/utilities/contours/detectContourHoles.ts +147 -0
  258. package/src/utilities/contours/generateContourSetsFromLabelmap.ts +160 -0
  259. package/src/utilities/contours/index.ts +14 -0
  260. package/src/utilities/contours/mergePoints.ts +108 -0
  261. package/src/utilities/index.ts +6 -1
  262. package/src/utilities/segmentation/contourAndFindLargestBidirectional.ts +46 -0
  263. package/src/utilities/segmentation/createBidirectionalToolData.ts +68 -0
  264. package/src/utilities/segmentation/createImageIdReferenceMap.ts +23 -0
  265. package/src/utilities/segmentation/findLargestBidirectional.ts +159 -0
  266. package/src/utilities/segmentation/index.ts +8 -0
  267. package/src/utilities/segmentation/isLineInSegment.ts +84 -0
  268. package/src/utilities/segmentation/segmentContourAction.ts +169 -0
  269. package/src/utilities/segmentation/thresholdSegmentationByRange.ts +2 -2
  270. package/src/utilities/segmentation/triggerSegmentationRender.ts +15 -10
  271. package/src/utilities/stackPrefetch/stackContextPrefetch.ts +1 -1
  272. package/src/utilities/stackPrefetch/stackPrefetchUtils.ts +5 -1
  273. package/dist/cjs/utilities/roundNumber.d.ts +0 -2
  274. package/dist/cjs/utilities/roundNumber.js +0 -30
  275. package/dist/cjs/utilities/roundNumber.js.map +0 -1
  276. package/dist/esm/utilities/roundNumber.js +0 -28
  277. package/dist/esm/utilities/roundNumber.js.map +0 -1
  278. package/dist/types/utilities/roundNumber.d.ts +0 -3
  279. package/dist/types/utilities/roundNumber.d.ts.map +0 -1
  280. package/src/utilities/roundNumber.ts +0 -44
@@ -0,0 +1,77 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.removeDuplicatePoints = void 0;
4
+ function ptInArray(array, pt) {
5
+ let index = -1;
6
+ for (let i = 0; i < array.length; i++) {
7
+ if (isSamePoint(pt, array[i])) {
8
+ index = i;
9
+ }
10
+ }
11
+ return index;
12
+ }
13
+ function isSamePoint(ptA, ptB) {
14
+ if (ptA[0] == ptB[0] && ptA[1] == ptB[1] && ptA[2] == ptB[2]) {
15
+ return true;
16
+ }
17
+ else {
18
+ return false;
19
+ }
20
+ }
21
+ function replacePointIndexReferences(linesArray, oldIndex, newIndex) {
22
+ for (let i = 0; i < linesArray.length; i++) {
23
+ const line = linesArray[i];
24
+ if (line.a == oldIndex) {
25
+ line.a = newIndex;
26
+ }
27
+ else if (line.b == oldIndex) {
28
+ line.b = newIndex;
29
+ }
30
+ }
31
+ }
32
+ function removeDuplicatePoints(polyData, bypass = false) {
33
+ const points = polyData.getPoints();
34
+ const lines = polyData.getLines();
35
+ const pointsArray = [];
36
+ for (let i = 0; i < points.getNumberOfPoints(); i++) {
37
+ const pt = points.getPoint(i).slice();
38
+ pointsArray.push(pt);
39
+ }
40
+ const linesArray = [];
41
+ for (let i = 0; i < lines.getNumberOfCells(); i++) {
42
+ const cell = lines.getCell(i * 3).slice();
43
+ const a = cell[0];
44
+ const b = cell[1];
45
+ const line = {
46
+ a,
47
+ b,
48
+ };
49
+ linesArray.push(line);
50
+ }
51
+ if (bypass) {
52
+ return { points: pointsArray, lines: linesArray };
53
+ }
54
+ const newPoints = [];
55
+ for (let i = 0; i < pointsArray.length; i++) {
56
+ const pt = pointsArray[i];
57
+ let index = ptInArray(newPoints, pt);
58
+ if (index >= 0) {
59
+ replacePointIndexReferences(linesArray, i, index);
60
+ }
61
+ else {
62
+ index = newPoints.length;
63
+ newPoints.push(pt);
64
+ replacePointIndexReferences(linesArray, i, index);
65
+ }
66
+ }
67
+ const newLines = [];
68
+ linesArray.forEach((line) => {
69
+ if (line.a != line.b) {
70
+ newLines.push(line);
71
+ }
72
+ });
73
+ return { points: newPoints, lines: newLines };
74
+ }
75
+ exports.removeDuplicatePoints = removeDuplicatePoints;
76
+ exports.default = { removeDuplicatePoints };
77
+ //# sourceMappingURL=mergePoints.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"mergePoints.js","sourceRoot":"","sources":["../../../../src/utilities/contours/mergePoints.ts"],"names":[],"mappings":"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"}
@@ -1,3 +1,4 @@
1
+ import { utilities } from '@cornerstonejs/core';
1
2
  import { getAnnotationNearPoint, getAnnotationNearPointOnEnabledElement } from './getAnnotationNearPoint';
2
3
  import debounce from './debounce';
3
4
  import throttle from './throttle';
@@ -11,9 +12,9 @@ import jumpToSlice from './viewport/jumpToSlice';
11
12
  import pointInShapeCallback from './pointInShapeCallback';
12
13
  import pointInSurroundingSphereCallback from './pointInSurroundingSphereCallback';
13
14
  import scroll from './scroll';
14
- import roundNumber from './roundNumber';
15
15
  import { pointToString } from './pointToString';
16
16
  import annotationFrameRange from './annotationFrameRange';
17
+ import * as contours from './contours';
17
18
  import * as segmentation from './segmentation';
18
19
  import * as drawing from './drawing';
19
20
  import * as math from './math';
@@ -30,5 +31,6 @@ import * as touch from './touch';
30
31
  import * as dynamicVolume from './dynamicVolume';
31
32
  import * as polyDataUtils from './polyData/utils';
32
33
  import * as voi from './voi';
34
+ declare const roundNumber: typeof utilities.roundNumber;
33
35
  import { triggerEvent } from '@cornerstonejs/core';
34
- export { math, planar, viewportFilters, drawing, debounce, dynamicVolume, throttle, orientation, isObject, touch, triggerEvent, calibrateImageSpacing, getCalibratedLengthUnits, getCalibratedAreaUnits, getCalibratedScale, segmentation, triggerAnnotationRenderForViewportIds, triggerAnnotationRender, pointInShapeCallback, pointInSurroundingSphereCallback, getAnnotationNearPoint, getAnnotationNearPointOnEnabledElement, jumpToSlice, viewport, cine, clip, boundingBox, rectangleROITool, planarFreehandROITool, stackPrefetch, stackContextPrefetch, scroll, roundNumber, pointToString, polyDataUtils, voi, annotationFrameRange, };
36
+ export { math, planar, viewportFilters, drawing, debounce, dynamicVolume, throttle, orientation, isObject, touch, triggerEvent, calibrateImageSpacing, getCalibratedLengthUnits, getCalibratedAreaUnits, getCalibratedScale, segmentation, contours, triggerAnnotationRenderForViewportIds, triggerAnnotationRender, pointInShapeCallback, pointInSurroundingSphereCallback, getAnnotationNearPoint, getAnnotationNearPointOnEnabledElement, jumpToSlice, viewport, cine, clip, boundingBox, rectangleROITool, planarFreehandROITool, stackPrefetch, stackContextPrefetch, scroll, roundNumber, pointToString, polyDataUtils, voi, annotationFrameRange, };
@@ -26,7 +26,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
26
26
  return (mod && mod.__esModule) ? mod : { "default": mod };
27
27
  };
28
28
  Object.defineProperty(exports, "__esModule", { value: true });
29
- exports.annotationFrameRange = exports.voi = exports.polyDataUtils = exports.pointToString = exports.roundNumber = exports.scroll = exports.stackContextPrefetch = exports.stackPrefetch = exports.planarFreehandROITool = exports.rectangleROITool = exports.boundingBox = exports.clip = exports.cine = exports.viewport = exports.jumpToSlice = exports.getAnnotationNearPointOnEnabledElement = exports.getAnnotationNearPoint = exports.pointInSurroundingSphereCallback = exports.pointInShapeCallback = exports.triggerAnnotationRender = exports.triggerAnnotationRenderForViewportIds = exports.segmentation = exports.getCalibratedScale = exports.getCalibratedAreaUnits = exports.getCalibratedLengthUnits = exports.calibrateImageSpacing = exports.triggerEvent = exports.touch = exports.isObject = exports.orientation = exports.throttle = exports.dynamicVolume = exports.debounce = exports.drawing = exports.viewportFilters = exports.planar = exports.math = void 0;
29
+ exports.annotationFrameRange = exports.voi = exports.polyDataUtils = exports.pointToString = exports.roundNumber = exports.scroll = exports.stackContextPrefetch = exports.stackPrefetch = exports.planarFreehandROITool = exports.rectangleROITool = exports.boundingBox = exports.clip = exports.cine = exports.viewport = exports.jumpToSlice = exports.getAnnotationNearPointOnEnabledElement = exports.getAnnotationNearPoint = exports.pointInSurroundingSphereCallback = exports.pointInShapeCallback = exports.triggerAnnotationRender = exports.triggerAnnotationRenderForViewportIds = exports.contours = exports.segmentation = exports.getCalibratedScale = exports.getCalibratedAreaUnits = exports.getCalibratedLengthUnits = exports.calibrateImageSpacing = exports.triggerEvent = exports.touch = exports.isObject = exports.orientation = exports.throttle = exports.dynamicVolume = exports.debounce = exports.drawing = exports.viewportFilters = exports.planar = exports.math = void 0;
30
+ const core_1 = require("@cornerstonejs/core");
30
31
  const getAnnotationNearPoint_1 = require("./getAnnotationNearPoint");
31
32
  Object.defineProperty(exports, "getAnnotationNearPoint", { enumerable: true, get: function () { return getAnnotationNearPoint_1.getAnnotationNearPoint; } });
32
33
  Object.defineProperty(exports, "getAnnotationNearPointOnEnabledElement", { enumerable: true, get: function () { return getAnnotationNearPoint_1.getAnnotationNearPointOnEnabledElement; } });
@@ -56,12 +57,12 @@ const pointInSurroundingSphereCallback_1 = __importDefault(require("./pointInSur
56
57
  exports.pointInSurroundingSphereCallback = pointInSurroundingSphereCallback_1.default;
57
58
  const scroll_1 = __importDefault(require("./scroll"));
58
59
  exports.scroll = scroll_1.default;
59
- const roundNumber_1 = __importDefault(require("./roundNumber"));
60
- exports.roundNumber = roundNumber_1.default;
61
60
  const pointToString_1 = require("./pointToString");
62
61
  Object.defineProperty(exports, "pointToString", { enumerable: true, get: function () { return pointToString_1.pointToString; } });
63
62
  const annotationFrameRange_1 = __importDefault(require("./annotationFrameRange"));
64
63
  exports.annotationFrameRange = annotationFrameRange_1.default;
64
+ const contours = __importStar(require("./contours"));
65
+ exports.contours = contours;
65
66
  const segmentation = __importStar(require("./segmentation"));
66
67
  exports.segmentation = segmentation;
67
68
  const drawing = __importStar(require("./drawing"));
@@ -95,6 +96,8 @@ const polyDataUtils = __importStar(require("./polyData/utils"));
95
96
  exports.polyDataUtils = polyDataUtils;
96
97
  const voi = __importStar(require("./voi"));
97
98
  exports.voi = voi;
98
- const core_1 = require("@cornerstonejs/core");
99
- Object.defineProperty(exports, "triggerEvent", { enumerable: true, get: function () { return core_1.triggerEvent; } });
99
+ const roundNumber = core_1.utilities.roundNumber;
100
+ exports.roundNumber = roundNumber;
101
+ const core_2 = require("@cornerstonejs/core");
102
+ Object.defineProperty(exports, "triggerEvent", { enumerable: true, get: function () { return core_2.triggerEvent; } });
100
103
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utilities/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,qEAGkC;AAkEhC,uGApEA,+CAAsB,OAoEA;AACtB,uHApEA,+DAAsC,OAoEA;AAhExC,0DAAkC;AA+ChC,mBA/CK,kBAAQ,CA+CL;AA9CV,0DAAkC;AAgDhC,mBAhDK,kBAAQ,CAgDL;AA/CV,0DAAkC;AAiDhC,mBAjDK,kBAAQ,CAiDL;AAhDV,kDAA0B;AAiExB,eAjEK,cAAI,CAiEL;AAhEN,oFAA4D;AAkD1D,gCAlDK,+BAAqB,CAkDL;AAjDvB,6DAI8B;AA8C5B,yGAjDA,6CAAwB,OAiDA;AACxB,uGAjDA,2CAAsB,OAiDA;AACtB,mGAjDA,uCAAkB,OAiDA;AA/CpB,oHAA4F;AAiD1F,gDAjDK,+CAAqC,CAiDL;AAhDvC,wFAAgE;AAiD9D,kCAjDK,iCAAuB,CAiDL;AAhDzB,yEAAiD;AAqD/C,sBArDK,qBAAW,CAqDL;AAnDb,kFAA0D;AA+CxD,+BA/CK,8BAAoB,CA+CL;AA9CtB,0GAAkF;AA+ChF,2CA/CK,0CAAgC,CA+CL;AA9ClC,sDAA8B;AA0D5B,iBA1DK,gBAAM,CA0DL;AAzDR,gEAAwC;AA0DtC,sBA1DK,qBAAW,CA0DL;AAzDb,mDAAgD;AA0D9C,8FA1DO,6BAAa,OA0DP;AAzDf,kFAA0D;AA4DxD,+BA5DK,8BAAoB,CA4DL;AAzDtB,6DAA+C;AAoC7C,oCAAY;AAnCd,mDAAqC;AAuBnC,0BAAO;AAtBT,6CAA+B;AAmB7B,oBAAI;AAlBN,iDAAmC;AAmBjC,wBAAM;AAlBR,mEAAqD;AAmBnD,0CAAe;AAlBjB,2DAA6C;AAuB3C,kCAAW;AAtBb,6CAA+B;AAuC7B,oBAAI;AAtCN,2DAA6C;AAwC3C,kCAAW;AAvCb,+EAAiE;AAyC/D,sDAAqB;AAxCvB,qEAAuD;AAuCrD,4CAAgB;AAtClB,mDAAsE;AAwCpE,8FAxCO,6BAAa,OAwCP;AACb,qGAzCsB,oCAAoB,OAyCtB;AAxCtB,qDAAuC;AAiCrC,4BAAQ;AAhCV,+CAAiC;AAkB/B,sBAAK;AAjBP,+DAAiD;AAa/C,sCAAa;AAZf,gEAAkD;AAyChD,sCAAa;AAxCf,2CAA6B;AAyC3B,kBAAG;AAtCL,8CAAmD;AAajD,6FAbO,mBAAY,OAaP"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utilities/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,8CAAgD;AAEhD,qEAGkC;AAqEhC,uGAvEA,+CAAsB,OAuEA;AACtB,uHAvEA,+DAAsC,OAuEA;AAnExC,0DAAkC;AAiDhC,mBAjDK,kBAAQ,CAiDL;AAhDV,0DAAkC;AAkDhC,mBAlDK,kBAAQ,CAkDL;AAjDV,0DAAkC;AAmDhC,mBAnDK,kBAAQ,CAmDL;AAlDV,kDAA0B;AAoExB,eApEK,cAAI,CAoEL;AAnEN,oFAA4D;AAoD1D,gCApDK,+BAAqB,CAoDL;AAnDvB,6DAI8B;AAgD5B,yGAnDA,6CAAwB,OAmDA;AACxB,uGAnDA,2CAAsB,OAmDA;AACtB,mGAnDA,uCAAkB,OAmDA;AAjDpB,oHAA4F;AAoD1F,gDApDK,+CAAqC,CAoDL;AAnDvC,wFAAgE;AAoD9D,kCApDK,iCAAuB,CAoDL;AAnDzB,yEAAiD;AAwD/C,sBAxDK,qBAAW,CAwDL;AAtDb,kFAA0D;AAkDxD,+BAlDK,8BAAoB,CAkDL;AAjDtB,0GAAkF;AAkDhF,2CAlDK,0CAAgC,CAkDL;AAjDlC,sDAA8B;AA6D5B,iBA7DK,gBAAM,CA6DL;AA5DR,mDAAgD;AA8D9C,8FA9DO,6BAAa,OA8DP;AA7Df,kFAA0D;AAgExD,+BAhEK,8BAAoB,CAgEL;AA7DtB,qDAAuC;AAwCrC,4BAAQ;AAvCV,6DAA+C;AAsC7C,oCAAY;AArCd,mDAAqC;AAyBnC,0BAAO;AAxBT,6CAA+B;AAqB7B,oBAAI;AApBN,iDAAmC;AAqBjC,wBAAM;AApBR,mEAAqD;AAqBnD,0CAAe;AApBjB,2DAA6C;AAyB3C,kCAAW;AAxBb,6CAA+B;AA0C7B,oBAAI;AAzCN,2DAA6C;AA2C3C,kCAAW;AA1Cb,+EAAiE;AA4C/D,sDAAqB;AA3CvB,qEAAuD;AA0CrD,4CAAgB;AAzClB,mDAAsE;AA2CpE,8FA3CO,6BAAa,OA2CP;AACb,qGA5CsB,oCAAoB,OA4CtB;AA3CtB,qDAAuC;AAoCrC,4BAAQ;AAnCV,+CAAiC;AAoB/B,sBAAK;AAnBP,+DAAiD;AAe/C,sCAAa;AAdf,gEAAkD;AA4ChD,sCAAa;AA3Cf,2CAA6B;AA4C3B,kBAAG;AA1CL,MAAM,WAAW,GAAG,gBAAS,CAAC,WAAW,CAAC;AAuCxC,kCAAW;AApCb,8CAAmD;AAajD,6FAbO,mBAAY,OAaP"}
@@ -0,0 +1 @@
1
+ export default function contourAndFindLargestBidirectional(segmentation: any): any;
@@ -0,0 +1,31 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const contours_1 = require("../contours");
7
+ const SegmentationRepresentations_1 = __importDefault(require("../../enums/SegmentationRepresentations"));
8
+ const findLargestBidirectional_1 = __importDefault(require("./findLargestBidirectional"));
9
+ const EPSILON = 1e-2;
10
+ const { Labelmap } = SegmentationRepresentations_1.default;
11
+ function contourAndFindLargestBidirectional(segmentation) {
12
+ const contours = (0, contours_1.generateContourSetsFromLabelmap)({
13
+ segmentations: segmentation,
14
+ });
15
+ if (!(contours === null || contours === void 0 ? void 0 : contours.length) || !contours[0].sliceContours.length) {
16
+ return;
17
+ }
18
+ const { representationData, segments = [
19
+ null,
20
+ { label: 'Unspecified', color: null, containedSegmentIndices: null },
21
+ ], } = segmentation;
22
+ const { volumeId: segVolumeId } = representationData[Labelmap];
23
+ const segmentIndex = segments.findIndex((it) => !!it);
24
+ if (segmentIndex === -1) {
25
+ return;
26
+ }
27
+ segments[segmentIndex].segmentIndex = segmentIndex;
28
+ return (0, findLargestBidirectional_1.default)(contours[0], segVolumeId, segments[segmentIndex]);
29
+ }
30
+ exports.default = contourAndFindLargestBidirectional;
31
+ //# sourceMappingURL=contourAndFindLargestBidirectional.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"contourAndFindLargestBidirectional.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/contourAndFindLargestBidirectional.ts"],"names":[],"mappings":";;;;;AAAA,0CAA8D;AAC9D,0GAAkF;AAClF,0FAAkE;AAElE,MAAM,OAAO,GAAG,IAAI,CAAC;AACrB,MAAM,EAAE,QAAQ,EAAE,GAAG,qCAA2B,CAAC;AAYjD,SAAwB,kCAAkC,CAAC,YAAY;IACrE,MAAM,QAAQ,GAAG,IAAA,0CAA+B,EAAC;QAC/C,aAAa,EAAE,YAAY;KAC5B,CAAC,CAAC;IAEH,IAAI,CAAC,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,MAAM,CAAA,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC,MAAM,EAAE;QAC1D,OAAO;KACR;IAED,MAAM,EACJ,kBAAkB,EAClB,QAAQ,GAAG;QACT,IAAI;QACJ,EAAE,KAAK,EAAE,aAAa,EAAE,KAAK,EAAE,IAAI,EAAE,uBAAuB,EAAE,IAAI,EAAE;KACrE,GACF,GAAG,YAAY,CAAC;IACjB,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,GAAG,kBAAkB,CAAC,QAAQ,CAAC,CAAC;IAE/D,MAAM,YAAY,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC;IACtD,IAAI,YAAY,KAAK,CAAC,CAAC,EAAE;QACvB,OAAO;KACR;IACD,QAAQ,CAAC,YAAY,CAAC,CAAC,YAAY,GAAG,YAAY,CAAC;IACnD,OAAO,IAAA,kCAAwB,EAC7B,QAAQ,CAAC,CAAC,CAAC,EACX,WAAW,EACX,QAAQ,CAAC,YAAY,CAAC,CACvB,CAAC;AACJ,CAAC;AA5BD,qDA4BC"}
@@ -0,0 +1,14 @@
1
+ import type { Types } from '@cornerstonejs/core';
2
+ import type { Annotation } from '../../types/AnnotationTypes';
3
+ export declare type BidirectionalData = {
4
+ majorAxis: [Types.Point3, Types.Point3];
5
+ minorAxis: [Types.Point3, Types.Point3];
6
+ maxMajor: number;
7
+ maxMinor: number;
8
+ segmentIndex: number;
9
+ label?: string;
10
+ color?: string | number[];
11
+ referencedImageId: string;
12
+ FrameOfReferenceUID: string;
13
+ };
14
+ export default function createBidirectionalToolData(bidirectionalData: BidirectionalData, viewport: any): Annotation;
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ function createBidirectionalToolData(bidirectionalData, viewport) {
4
+ const { majorAxis, minorAxis, label = '', FrameOfReferenceUID, referencedImageId, } = bidirectionalData;
5
+ const [major0, major1] = majorAxis;
6
+ const [minor0, minor1] = minorAxis;
7
+ const { viewUp, viewPlaneNormal } = viewport.getCamera();
8
+ const points = [major0, major1, minor0, minor1];
9
+ const bidirectionalToolData = {
10
+ highlighted: true,
11
+ invalidated: true,
12
+ metadata: {
13
+ toolName: 'Bidirectional',
14
+ viewPlaneNormal,
15
+ viewUp,
16
+ FrameOfReferenceUID,
17
+ referencedImageId,
18
+ },
19
+ data: {
20
+ handles: {
21
+ points,
22
+ textBox: {
23
+ hasMoved: false,
24
+ worldPosition: [0, 0, 0],
25
+ worldBoundingBox: {
26
+ topLeft: [0, 0, 0],
27
+ topRight: [0, 0, 0],
28
+ bottomLeft: [0, 0, 0],
29
+ bottomRight: [0, 0, 0],
30
+ },
31
+ },
32
+ activeHandleIndex: null,
33
+ },
34
+ label,
35
+ cachedStats: {},
36
+ },
37
+ isLocked: false,
38
+ isVisible: true,
39
+ };
40
+ return bidirectionalToolData;
41
+ }
42
+ exports.default = createBidirectionalToolData;
43
+ //# sourceMappingURL=createBidirectionalToolData.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createBidirectionalToolData.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/createBidirectionalToolData.ts"],"names":[],"mappings":";;AAmBA,SAAwB,2BAA2B,CACjD,iBAAoC,EACpC,QAAQ;IAER,MAAM,EACJ,SAAS,EACT,SAAS,EACT,KAAK,GAAG,EAAE,EACV,mBAAmB,EACnB,iBAAiB,GAClB,GAAG,iBAAiB,CAAC;IACtB,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,SAAS,CAAC;IACnC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,GAAG,SAAS,CAAC;IAEnC,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,GAAG,QAAQ,CAAC,SAAS,EAAE,CAAC;IACzD,MAAM,MAAM,GAAG,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,CAAC,CAAC;IAChD,MAAM,qBAAqB,GAAG;QAC5B,WAAW,EAAE,IAAI;QACjB,WAAW,EAAE,IAAI;QACjB,QAAQ,EAAE;YACR,QAAQ,EAAE,eAAe;YACzB,eAAe;YACf,MAAM;YACN,mBAAmB;YACnB,iBAAiB;SAClB;QACD,IAAI,EAAE;YACJ,OAAO,EAAE;gBACP,MAAM;gBACN,OAAO,EAAE;oBACP,QAAQ,EAAE,KAAK;oBACf,aAAa,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAiB;oBACxC,gBAAgB,EAAE;wBAChB,OAAO,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAiB;wBAClC,QAAQ,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAiB;wBACnC,UAAU,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAiB;wBACrC,WAAW,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAiB;qBACvC;iBACF;gBACD,iBAAiB,EAAE,IAAI;aACxB;YACD,KAAK;YACL,WAAW,EAAE,EAAE;SAChB;QACD,QAAQ,EAAE,KAAK;QACf,SAAS,EAAE,IAAI;KAChB,CAAC;IACF,OAAO,qBAAqB,CAAC;AAC/B,CAAC;AAhDD,8CAgDC"}
@@ -0,0 +1,2 @@
1
+ declare function createImageIdReferenceMap(imageIdsArray: string[], segmentationImageIds: string[]): Map<string, string>;
2
+ export { createImageIdReferenceMap };
@@ -0,0 +1,11 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.createImageIdReferenceMap = void 0;
4
+ function createImageIdReferenceMap(imageIdsArray, segmentationImageIds) {
5
+ const imageIdReferenceMap = new Map(imageIdsArray.map((imageId, index) => {
6
+ return [imageId, segmentationImageIds[index]];
7
+ }));
8
+ return imageIdReferenceMap;
9
+ }
10
+ exports.createImageIdReferenceMap = createImageIdReferenceMap;
11
+ //# sourceMappingURL=createImageIdReferenceMap.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"createImageIdReferenceMap.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/createImageIdReferenceMap.ts"],"names":[],"mappings":";;;AASA,SAAS,yBAAyB,CAChC,aAAuB,EACvB,oBAA8B;IAE9B,MAAM,mBAAmB,GAAG,IAAI,GAAG,CACjC,aAAa,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE;QACnC,OAAO,CAAC,OAAO,EAAE,oBAAoB,CAAC,KAAK,CAAC,CAAC,CAAC;IAChD,CAAC,CAAC,CACH,CAAC;IAEF,OAAO,mBAAmB,CAAC;AAC7B,CAAC;AAEQ,8DAAyB"}
@@ -0,0 +1 @@
1
+ export default function findLargestBidirectional(contours: any, segVolumeId: string, segment: any): any;
@@ -0,0 +1,94 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const gl_matrix_1 = require("gl-matrix");
4
+ const isLineInSegment_1 = require("./isLineInSegment");
5
+ const EPSILON = 1e-2;
6
+ function findLargestBidirectional(contours, segVolumeId, segment) {
7
+ const { sliceContours } = contours;
8
+ const { segmentIndex, containedSegmentIndices } = segment;
9
+ let maxBidirectional;
10
+ const isInSegment = (0, isLineInSegment_1.createIsInSegment)(segVolumeId, segmentIndex, containedSegmentIndices);
11
+ for (const sliceContour of sliceContours) {
12
+ const bidirectional = createBidirectionalForSlice(sliceContour, isInSegment, maxBidirectional);
13
+ if (!bidirectional) {
14
+ continue;
15
+ }
16
+ maxBidirectional = bidirectional;
17
+ }
18
+ if (maxBidirectional) {
19
+ Object.assign(maxBidirectional, segment);
20
+ }
21
+ return maxBidirectional;
22
+ }
23
+ exports.default = findLargestBidirectional;
24
+ function createBidirectionalForSlice(sliceContour, isInSegment, currentMax = { maxMajor: 0, maxMinor: 0 }) {
25
+ const { points } = sliceContour.polyData;
26
+ const { maxMinor: currentMaxMinor, maxMajor: currentMaxMajor } = currentMax;
27
+ let maxMajor = currentMaxMajor * currentMaxMajor;
28
+ let maxMinor = currentMaxMinor * currentMaxMinor;
29
+ let maxMajorPoints;
30
+ for (let index1 = 0; index1 < points.length; index1++) {
31
+ for (let index2 = index1 + 1; index2 < points.length; index2++) {
32
+ const point1 = points[index1];
33
+ const point2 = points[index2];
34
+ const distance2 = gl_matrix_1.vec3.sqrDist(point1, point2);
35
+ if (distance2 < maxMajor) {
36
+ continue;
37
+ }
38
+ if (distance2 - EPSILON < maxMajor + EPSILON && maxMajorPoints) {
39
+ continue;
40
+ }
41
+ if (!isInSegment.testCenter(point1, point2)) {
42
+ continue;
43
+ }
44
+ if (!(0, isLineInSegment_1.isLineInSegment)(point1, point2, isInSegment)) {
45
+ continue;
46
+ }
47
+ maxMajor = distance2 - EPSILON;
48
+ maxMajorPoints = [index1, index2];
49
+ maxMinor = 0;
50
+ }
51
+ }
52
+ if (!maxMajorPoints) {
53
+ return;
54
+ }
55
+ maxMajor = Math.sqrt(maxMajor + EPSILON);
56
+ const handle0 = points[maxMajorPoints[0]];
57
+ const handle1 = points[maxMajorPoints[1]];
58
+ const unitMajor = gl_matrix_1.vec3.sub(gl_matrix_1.vec3.create(), handle0, handle1);
59
+ gl_matrix_1.vec3.scale(unitMajor, unitMajor, 1 / maxMajor);
60
+ let maxMinorPoints;
61
+ for (let index1 = 0; index1 < points.length; index1++) {
62
+ for (let index2 = index1 + 1; index2 < points.length; index2++) {
63
+ const point1 = points[index1];
64
+ const point2 = points[index2];
65
+ const distance2 = gl_matrix_1.vec3.sqrDist(point1, point2);
66
+ if (distance2 <= maxMinor) {
67
+ continue;
68
+ }
69
+ const delta = gl_matrix_1.vec3.sub(gl_matrix_1.vec3.create(), point1, point2);
70
+ const dot = Math.abs(gl_matrix_1.vec3.dot(delta, unitMajor)) / Math.sqrt(distance2);
71
+ if (dot > EPSILON) {
72
+ continue;
73
+ }
74
+ if (!isInSegment.testCenter(point1, point2)) {
75
+ continue;
76
+ }
77
+ if (!(0, isLineInSegment_1.isLineInSegment)(point1, point2, isInSegment)) {
78
+ continue;
79
+ }
80
+ maxMinor = distance2;
81
+ maxMinorPoints = [index1, index2];
82
+ }
83
+ }
84
+ if (!maxMinorPoints) {
85
+ return;
86
+ }
87
+ maxMinor = Math.sqrt(maxMinor);
88
+ const handle2 = points[maxMinorPoints[0]];
89
+ const handle3 = points[maxMinorPoints[1]];
90
+ const bidirectional = Object.assign({ majorAxis: [handle0, handle1], minorAxis: [handle2, handle3], maxMajor,
91
+ maxMinor }, sliceContour);
92
+ return bidirectional;
93
+ }
94
+ //# sourceMappingURL=findLargestBidirectional.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"findLargestBidirectional.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/findLargestBidirectional.ts"],"names":[],"mappings":"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"}
@@ -9,4 +9,8 @@ import floodFill from './floodFill';
9
9
  import { getBrushSizeForToolGroup, setBrushSizeForToolGroup } from './brushSizeForToolGroup';
10
10
  import { getBrushThresholdForToolGroup, setBrushThresholdForToolGroup } from './brushThresholdForToolGroup';
11
11
  import thresholdSegmentationByRange from './thresholdSegmentationByRange';
12
- export { thresholdVolumeByRange, createMergedLabelmapForIndex, isValidRepresentationConfig, getDefaultRepresentationConfig, createLabelmapVolumeForViewport, rectangleROIThresholdVolumeByRange, triggerSegmentationRender, floodFill, getBrushSizeForToolGroup, setBrushSizeForToolGroup, getBrushThresholdForToolGroup, setBrushThresholdForToolGroup, thresholdSegmentationByRange, };
12
+ import { createImageIdReferenceMap } from './createImageIdReferenceMap';
13
+ import contourAndFindLargestBidirectional from './contourAndFindLargestBidirectional';
14
+ import createBidirectionalToolData from './createBidirectionalToolData';
15
+ import segmentContourAction from './segmentContourAction';
16
+ export { thresholdVolumeByRange, createMergedLabelmapForIndex, isValidRepresentationConfig, getDefaultRepresentationConfig, createLabelmapVolumeForViewport, rectangleROIThresholdVolumeByRange, triggerSegmentationRender, floodFill, getBrushSizeForToolGroup, setBrushSizeForToolGroup, getBrushThresholdForToolGroup, setBrushThresholdForToolGroup, thresholdSegmentationByRange, createImageIdReferenceMap, contourAndFindLargestBidirectional, createBidirectionalToolData, segmentContourAction, };
@@ -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.thresholdSegmentationByRange = exports.setBrushThresholdForToolGroup = exports.getBrushThresholdForToolGroup = exports.setBrushSizeForToolGroup = exports.getBrushSizeForToolGroup = exports.floodFill = exports.triggerSegmentationRender = exports.rectangleROIThresholdVolumeByRange = exports.createLabelmapVolumeForViewport = exports.getDefaultRepresentationConfig = exports.isValidRepresentationConfig = exports.createMergedLabelmapForIndex = exports.thresholdVolumeByRange = void 0;
6
+ exports.segmentContourAction = exports.createBidirectionalToolData = exports.contourAndFindLargestBidirectional = exports.createImageIdReferenceMap = exports.thresholdSegmentationByRange = exports.setBrushThresholdForToolGroup = exports.getBrushThresholdForToolGroup = exports.setBrushSizeForToolGroup = exports.getBrushSizeForToolGroup = exports.floodFill = exports.triggerSegmentationRender = exports.rectangleROIThresholdVolumeByRange = exports.createLabelmapVolumeForViewport = exports.getDefaultRepresentationConfig = exports.isValidRepresentationConfig = exports.createMergedLabelmapForIndex = exports.thresholdVolumeByRange = void 0;
7
7
  const thresholdVolumeByRange_1 = __importDefault(require("./thresholdVolumeByRange"));
8
8
  exports.thresholdVolumeByRange = thresholdVolumeByRange_1.default;
9
9
  const rectangleROIThresholdVolumeByRange_1 = __importDefault(require("./rectangleROIThresholdVolumeByRange"));
@@ -28,4 +28,12 @@ Object.defineProperty(exports, "getBrushThresholdForToolGroup", { enumerable: tr
28
28
  Object.defineProperty(exports, "setBrushThresholdForToolGroup", { enumerable: true, get: function () { return brushThresholdForToolGroup_1.setBrushThresholdForToolGroup; } });
29
29
  const thresholdSegmentationByRange_1 = __importDefault(require("./thresholdSegmentationByRange"));
30
30
  exports.thresholdSegmentationByRange = thresholdSegmentationByRange_1.default;
31
+ const createImageIdReferenceMap_1 = require("./createImageIdReferenceMap");
32
+ Object.defineProperty(exports, "createImageIdReferenceMap", { enumerable: true, get: function () { return createImageIdReferenceMap_1.createImageIdReferenceMap; } });
33
+ const contourAndFindLargestBidirectional_1 = __importDefault(require("./contourAndFindLargestBidirectional"));
34
+ exports.contourAndFindLargestBidirectional = contourAndFindLargestBidirectional_1.default;
35
+ const createBidirectionalToolData_1 = __importDefault(require("./createBidirectionalToolData"));
36
+ exports.createBidirectionalToolData = createBidirectionalToolData_1.default;
37
+ const segmentContourAction_1 = __importDefault(require("./segmentContourAction"));
38
+ exports.segmentContourAction = segmentContourAction_1.default;
31
39
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/index.ts"],"names":[],"mappings":";;;;;;AAAA,sFAA8D;AAmB5D,iCAnBK,gCAAsB,CAmBL;AAlBxB,8GAAsF;AAuBpF,6CAvBK,4CAAkC,CAuBL;AAtBpC,kGAA0E;AAkBxE,uCAlBK,sCAA4B,CAkBL;AAjB9B,gGAAwE;AAkBtE,sCAlBK,qCAA2B,CAkBL;AAjB7B,sGAA8E;AAkB5E,yCAlBK,wCAA8B,CAkBL;AAjBhC,wGAAgF;AAkB9E,0CAlBK,yCAA+B,CAkBL;AAjBjC,2EAAwE;AAmBtE,0GAnBO,qDAAyB,OAmBP;AAlB3B,4DAAoC;AAmBlC,oBAnBK,mBAAS,CAmBL;AAlBX,mEAGiC;AAgB/B,yGAlBA,gDAAwB,OAkBA;AACxB,yGAlBA,gDAAwB,OAkBA;AAhB1B,6EAGsC;AAcpC,8GAhBA,0DAA6B,OAgBA;AAC7B,8GAhBA,0DAA6B,OAgBA;AAd/B,kGAA0E;AAexE,uCAfK,sCAA4B,CAeL"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/index.ts"],"names":[],"mappings":";;;;;;AAAA,sFAA8D;AAuB5D,iCAvBK,gCAAsB,CAuBL;AAtBxB,8GAAsF;AA2BpF,6CA3BK,4CAAkC,CA2BL;AA1BpC,kGAA0E;AAsBxE,uCAtBK,sCAA4B,CAsBL;AArB9B,gGAAwE;AAsBtE,sCAtBK,qCAA2B,CAsBL;AArB7B,sGAA8E;AAsB5E,yCAtBK,wCAA8B,CAsBL;AArBhC,wGAAgF;AAsB9E,0CAtBK,yCAA+B,CAsBL;AArBjC,2EAAwE;AAuBtE,0GAvBO,qDAAyB,OAuBP;AAtB3B,4DAAoC;AAuBlC,oBAvBK,mBAAS,CAuBL;AAtBX,mEAGiC;AAoB/B,yGAtBA,gDAAwB,OAsBA;AACxB,yGAtBA,gDAAwB,OAsBA;AApB1B,6EAGsC;AAkBpC,8GApBA,0DAA6B,OAoBA;AAC7B,8GApBA,0DAA6B,OAoBA;AAlB/B,kGAA0E;AAmBxE,uCAnBK,sCAA4B,CAmBL;AAlB9B,2EAAwE;AAmBtE,0GAnBO,qDAAyB,OAmBP;AAlB3B,8GAAsF;AAmBpF,6CAnBK,4CAAkC,CAmBL;AAlBpC,gGAAwE;AAmBtE,sCAnBK,qCAA2B,CAmBL;AAlB7B,kFAA0D;AAmBxD,+BAnBK,8BAAoB,CAmBL"}
@@ -0,0 +1,9 @@
1
+ import type { Types } from '@cornerstonejs/core';
2
+ import { vec3 } from 'gl-matrix';
3
+ export default function isLineInSegment(point1: Types.Point3, point2: Types.Point3, isInSegment: any): boolean;
4
+ declare function createIsInSegment(segVolumeId: string, segmentIndex: number, containedSegmentIndices?: Set<number>): {
5
+ testCenter: (point1: any, point2: any) => boolean;
6
+ toIJK: (point: any) => vec3;
7
+ testIJK: (ijk: any) => boolean;
8
+ };
9
+ export { createIsInSegment, isLineInSegment };
@@ -0,0 +1,55 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.isLineInSegment = exports.createIsInSegment = void 0;
4
+ const core_1 = require("@cornerstonejs/core");
5
+ const gl_matrix_1 = require("gl-matrix");
6
+ function isLineInSegment(point1, point2, isInSegment) {
7
+ const ijk1 = isInSegment.toIJK(point1);
8
+ const ijk2 = isInSegment.toIJK(point2);
9
+ const testPoint = gl_matrix_1.vec3.create();
10
+ const { testIJK } = isInSegment;
11
+ const delta = gl_matrix_1.vec3.sub(gl_matrix_1.vec3.create(), ijk1, ijk2);
12
+ const testSize = Math.round(Math.max(...delta.map(Math.abs)));
13
+ if (testSize < 2) {
14
+ return true;
15
+ }
16
+ const unitDelta = gl_matrix_1.vec3.scale(gl_matrix_1.vec3.create(), delta, 1 / testSize);
17
+ for (let i = 1; i < testSize; i++) {
18
+ gl_matrix_1.vec3.scaleAndAdd(testPoint, ijk2, unitDelta, i);
19
+ if (!testIJK(testPoint)) {
20
+ return false;
21
+ }
22
+ }
23
+ return true;
24
+ }
25
+ exports.default = isLineInSegment;
26
+ exports.isLineInSegment = isLineInSegment;
27
+ function createIsInSegment(segVolumeId, segmentIndex, containedSegmentIndices) {
28
+ const vol = core_1.cache.getVolume(segVolumeId);
29
+ if (!vol) {
30
+ console.warn(`No volume found for ${segVolumeId}`);
31
+ return;
32
+ }
33
+ const segData = vol.imageData.getPointData().getScalars().getData();
34
+ const width = vol.dimensions[0];
35
+ const pixelsPerSlice = width * vol.dimensions[1];
36
+ return {
37
+ testCenter: (point1, point2) => {
38
+ const point = gl_matrix_1.vec3.add(gl_matrix_1.vec3.create(), point1, point2).map((it) => it / 2);
39
+ const ijk = vol.imageData.worldToIndex(point).map(Math.round);
40
+ const [i, j, k] = ijk;
41
+ const index = i + j * width + k * pixelsPerSlice;
42
+ const value = segData[index];
43
+ return value === segmentIndex || (containedSegmentIndices === null || containedSegmentIndices === void 0 ? void 0 : containedSegmentIndices.has(value));
44
+ },
45
+ toIJK: (point) => vol.imageData.worldToIndex(point),
46
+ testIJK: (ijk) => {
47
+ const [i, j, k] = ijk;
48
+ const index = Math.round(i) + Math.round(j) * width + Math.round(k) * pixelsPerSlice;
49
+ const value = segData[index];
50
+ return value === segmentIndex || (containedSegmentIndices === null || containedSegmentIndices === void 0 ? void 0 : containedSegmentIndices.has(value));
51
+ },
52
+ };
53
+ }
54
+ exports.createIsInSegment = createIsInSegment;
55
+ //# sourceMappingURL=isLineInSegment.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"isLineInSegment.js","sourceRoot":"","sources":["../../../../src/utilities/segmentation/isLineInSegment.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,17 @@
1
+ import { type Types } from '@cornerstonejs/core';
2
+ export declare type Segment = {
3
+ segmentationId: string;
4
+ segmentIndex: number;
5
+ label: string;
6
+ style?: any;
7
+ containedSegmentIndices?: (number: any) => boolean;
8
+ };
9
+ export declare type SegmentContourActionConfiguration = {
10
+ getSegment?: (enabledElement: Types.IEnabledElement, configuration: SegmentContourActionConfiguration) => Segment;
11
+ segmentationId?: string;
12
+ segmentIndex?: number;
13
+ segmentData?: Map<number, Segment>;
14
+ toolGroupId?: string;
15
+ };
16
+ export default function segmentContourAction(element: HTMLDivElement, configuration: any): any;
17
+ export declare function defaultGetSegment(enabledElement: Types.IEnabledElement, configuration: SegmentContourActionConfiguration): Segment;