@cornerstonejs/tools 0.10.0 → 0.12.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 (243) hide show
  1. package/dist/cjs/drawingSvg/_getHash.d.ts +1 -1
  2. package/dist/cjs/drawingSvg/_getHash.js +2 -2
  3. package/dist/cjs/drawingSvg/_getHash.js.map +1 -1
  4. package/dist/cjs/drawingSvg/drawArrow.d.ts +2 -0
  5. package/dist/cjs/drawingSvg/drawArrow.js +53 -0
  6. package/dist/cjs/drawingSvg/drawArrow.js.map +1 -0
  7. package/dist/cjs/drawingSvg/drawCircle.d.ts +1 -1
  8. package/dist/cjs/drawingSvg/drawCircle.js +2 -2
  9. package/dist/cjs/drawingSvg/drawCircle.js.map +1 -1
  10. package/dist/cjs/drawingSvg/drawEllipse.d.ts +1 -1
  11. package/dist/cjs/drawingSvg/drawEllipse.js +2 -2
  12. package/dist/cjs/drawingSvg/drawEllipse.js.map +1 -1
  13. package/dist/cjs/drawingSvg/drawHandles.d.ts +1 -1
  14. package/dist/cjs/drawingSvg/drawHandles.js +2 -2
  15. package/dist/cjs/drawingSvg/drawHandles.js.map +1 -1
  16. package/dist/cjs/drawingSvg/drawLine.d.ts +1 -1
  17. package/dist/cjs/drawingSvg/drawLine.js +2 -2
  18. package/dist/cjs/drawingSvg/drawLine.js.map +1 -1
  19. package/dist/cjs/drawingSvg/drawLink.d.ts +1 -1
  20. package/dist/cjs/drawingSvg/drawLink.js +2 -2
  21. package/dist/cjs/drawingSvg/drawLink.js.map +1 -1
  22. package/dist/cjs/drawingSvg/drawLinkedTextBox.d.ts +1 -1
  23. package/dist/cjs/drawingSvg/drawLinkedTextBox.js +3 -3
  24. package/dist/cjs/drawingSvg/drawLinkedTextBox.js.map +1 -1
  25. package/dist/cjs/drawingSvg/drawPolyline.d.ts +8 -0
  26. package/dist/cjs/drawingSvg/drawPolyline.js +50 -0
  27. package/dist/cjs/drawingSvg/drawPolyline.js.map +1 -0
  28. package/dist/cjs/drawingSvg/drawRect.d.ts +1 -1
  29. package/dist/cjs/drawingSvg/drawRect.js +2 -2
  30. package/dist/cjs/drawingSvg/drawRect.js.map +1 -1
  31. package/dist/cjs/drawingSvg/drawTextBox.d.ts +1 -1
  32. package/dist/cjs/drawingSvg/drawTextBox.js +4 -4
  33. package/dist/cjs/drawingSvg/drawTextBox.js.map +1 -1
  34. package/dist/cjs/drawingSvg/index.d.ts +3 -1
  35. package/dist/cjs/drawingSvg/index.js +5 -1
  36. package/dist/cjs/drawingSvg/index.js.map +1 -1
  37. package/dist/cjs/index.d.ts +2 -2
  38. package/dist/cjs/index.js +3 -1
  39. package/dist/cjs/index.js.map +1 -1
  40. package/dist/cjs/stateManagement/annotation/config/annotationStyle.js +1 -1
  41. package/dist/cjs/tools/CrosshairsTool.js +12 -12
  42. package/dist/cjs/tools/CrosshairsTool.js.map +1 -1
  43. package/dist/cjs/tools/annotation/ArrowTool.d.ts +36 -0
  44. package/dist/cjs/tools/annotation/ArrowTool.js +403 -0
  45. package/dist/cjs/tools/annotation/ArrowTool.js.map +1 -0
  46. package/dist/cjs/tools/annotation/BidirectionalTool.js +4 -4
  47. package/dist/cjs/tools/annotation/BidirectionalTool.js.map +1 -1
  48. package/dist/cjs/tools/annotation/EllipticalROITool.js +3 -3
  49. package/dist/cjs/tools/annotation/EllipticalROITool.js.map +1 -1
  50. package/dist/cjs/tools/annotation/LengthTool.js +4 -3
  51. package/dist/cjs/tools/annotation/LengthTool.js.map +1 -1
  52. package/dist/cjs/tools/annotation/PlanarFreehandROITool.d.ts +32 -0
  53. package/dist/cjs/tools/annotation/PlanarFreehandROITool.js +192 -0
  54. package/dist/cjs/tools/annotation/PlanarFreehandROITool.js.map +1 -0
  55. package/dist/cjs/tools/annotation/ProbeTool.js +2 -2
  56. package/dist/cjs/tools/annotation/ProbeTool.js.map +1 -1
  57. package/dist/cjs/tools/annotation/RectangleROITool.js +3 -3
  58. package/dist/cjs/tools/annotation/RectangleROITool.js.map +1 -1
  59. package/dist/cjs/tools/annotation/planarFreehandROITool/closedContourEditLoop.d.ts +2 -0
  60. package/dist/cjs/tools/annotation/planarFreehandROITool/closedContourEditLoop.js +216 -0
  61. package/dist/cjs/tools/annotation/planarFreehandROITool/closedContourEditLoop.js.map +1 -0
  62. package/dist/cjs/tools/annotation/planarFreehandROITool/drawLoop.d.ts +2 -0
  63. package/dist/cjs/tools/annotation/planarFreehandROITool/drawLoop.js +182 -0
  64. package/dist/cjs/tools/annotation/planarFreehandROITool/drawLoop.js.map +1 -0
  65. package/dist/cjs/tools/annotation/planarFreehandROITool/editLoopCommon.d.ts +2 -0
  66. package/dist/cjs/tools/annotation/planarFreehandROITool/editLoopCommon.js +127 -0
  67. package/dist/cjs/tools/annotation/planarFreehandROITool/editLoopCommon.js.map +1 -0
  68. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEditLoop.d.ts +2 -0
  69. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEditLoop.js +289 -0
  70. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEditLoop.js.map +1 -0
  71. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEndEditLoop.d.ts +2 -0
  72. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js +43 -0
  73. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js.map +1 -0
  74. package/dist/cjs/tools/annotation/planarFreehandROITool/renderMethods.d.ts +2 -0
  75. package/dist/cjs/tools/annotation/planarFreehandROITool/renderMethods.js +99 -0
  76. package/dist/cjs/tools/annotation/planarFreehandROITool/renderMethods.js.map +1 -0
  77. package/dist/cjs/tools/index.d.ts +3 -1
  78. package/dist/cjs/tools/index.js +5 -1
  79. package/dist/cjs/tools/index.js.map +1 -1
  80. package/dist/cjs/tools/segmentation/BrushTool.js +1 -1
  81. package/dist/cjs/tools/segmentation/BrushTool.js.map +1 -1
  82. package/dist/cjs/tools/segmentation/CircleScissorsTool.js +1 -1
  83. package/dist/cjs/tools/segmentation/CircleScissorsTool.js.map +1 -1
  84. package/dist/cjs/tools/segmentation/RectangleROIStartEndThresholdTool.js +2 -2
  85. package/dist/cjs/tools/segmentation/RectangleROIStartEndThresholdTool.js.map +1 -1
  86. package/dist/cjs/tools/segmentation/RectangleROIThresholdTool.js +2 -2
  87. package/dist/cjs/tools/segmentation/RectangleROIThresholdTool.js.map +1 -1
  88. package/dist/cjs/tools/segmentation/RectangleScissorsTool.js +1 -1
  89. package/dist/cjs/tools/segmentation/RectangleScissorsTool.js.map +1 -1
  90. package/dist/cjs/tools/segmentation/SphereScissorsTool.js +1 -1
  91. package/dist/cjs/tools/segmentation/SphereScissorsTool.js.map +1 -1
  92. package/dist/cjs/types/AnnotationTypes.d.ts +1 -0
  93. package/dist/cjs/types/ToolSpecificAnnotationTypes.d.ts +50 -0
  94. package/dist/cjs/utilities/math/index.d.ts +2 -1
  95. package/dist/cjs/utilities/math/index.js +3 -1
  96. package/dist/cjs/utilities/math/index.js.map +1 -1
  97. package/dist/cjs/utilities/math/polyline/addCanvasPointsToArray.d.ts +4 -0
  98. package/dist/cjs/utilities/math/polyline/addCanvasPointsToArray.js +36 -0
  99. package/dist/cjs/utilities/math/polyline/addCanvasPointsToArray.js.map +1 -0
  100. package/dist/cjs/utilities/math/polyline/calculateAreaOfPoints.d.ts +2 -0
  101. package/dist/cjs/utilities/math/polyline/calculateAreaOfPoints.js +14 -0
  102. package/dist/cjs/utilities/math/polyline/calculateAreaOfPoints.js.map +1 -0
  103. package/dist/cjs/utilities/math/polyline/getIntersectionWithPolyline.d.ts +7 -0
  104. package/dist/cjs/utilities/math/polyline/getIntersectionWithPolyline.js +110 -0
  105. package/dist/cjs/utilities/math/polyline/getIntersectionWithPolyline.js.map +1 -0
  106. package/dist/cjs/utilities/math/polyline/getSubPixelSpacingAndXYDirections.d.ts +7 -0
  107. package/dist/cjs/utilities/math/polyline/getSubPixelSpacingAndXYDirections.js +67 -0
  108. package/dist/cjs/utilities/math/polyline/getSubPixelSpacingAndXYDirections.js.map +1 -0
  109. package/dist/cjs/utilities/math/polyline/index.d.ts +7 -0
  110. package/dist/cjs/utilities/math/polyline/index.js +20 -0
  111. package/dist/cjs/utilities/math/polyline/index.js.map +1 -0
  112. package/dist/cjs/utilities/math/polyline/planarFreehandROIInternalTypes.d.ts +22 -0
  113. package/dist/cjs/utilities/math/polyline/planarFreehandROIInternalTypes.js +3 -0
  114. package/dist/cjs/utilities/math/polyline/planarFreehandROIInternalTypes.js.map +1 -0
  115. package/dist/cjs/utilities/math/polyline/pointCanProjectOnLine.d.ts +3 -0
  116. package/dist/cjs/utilities/math/polyline/pointCanProjectOnLine.js +35 -0
  117. package/dist/cjs/utilities/math/polyline/pointCanProjectOnLine.js.map +1 -0
  118. package/dist/cjs/utilities/math/polyline/pointsAreWithinCloseContourProximity.d.ts +3 -0
  119. package/dist/cjs/utilities/math/polyline/pointsAreWithinCloseContourProximity.js +8 -0
  120. package/dist/cjs/utilities/math/polyline/pointsAreWithinCloseContourProximity.js.map +1 -0
  121. package/dist/esm/drawingSvg/_getHash.d.ts +1 -1
  122. package/dist/esm/drawingSvg/_getHash.js +2 -2
  123. package/dist/esm/drawingSvg/_getHash.js.map +1 -1
  124. package/dist/esm/drawingSvg/drawArrow.d.ts +2 -0
  125. package/dist/esm/drawingSvg/drawArrow.js +47 -0
  126. package/dist/esm/drawingSvg/drawArrow.js.map +1 -0
  127. package/dist/esm/drawingSvg/drawCircle.d.ts +1 -1
  128. package/dist/esm/drawingSvg/drawCircle.js +2 -2
  129. package/dist/esm/drawingSvg/drawCircle.js.map +1 -1
  130. package/dist/esm/drawingSvg/drawEllipse.d.ts +1 -1
  131. package/dist/esm/drawingSvg/drawEllipse.js +2 -2
  132. package/dist/esm/drawingSvg/drawEllipse.js.map +1 -1
  133. package/dist/esm/drawingSvg/drawHandles.d.ts +1 -1
  134. package/dist/esm/drawingSvg/drawHandles.js +2 -2
  135. package/dist/esm/drawingSvg/drawHandles.js.map +1 -1
  136. package/dist/esm/drawingSvg/drawLine.d.ts +1 -1
  137. package/dist/esm/drawingSvg/drawLine.js +2 -2
  138. package/dist/esm/drawingSvg/drawLine.js.map +1 -1
  139. package/dist/esm/drawingSvg/drawLink.d.ts +1 -1
  140. package/dist/esm/drawingSvg/drawLink.js +2 -2
  141. package/dist/esm/drawingSvg/drawLink.js.map +1 -1
  142. package/dist/esm/drawingSvg/drawLinkedTextBox.d.ts +1 -1
  143. package/dist/esm/drawingSvg/drawLinkedTextBox.js +3 -3
  144. package/dist/esm/drawingSvg/drawLinkedTextBox.js.map +1 -1
  145. package/dist/esm/drawingSvg/drawPolyline.d.ts +8 -0
  146. package/dist/esm/drawingSvg/drawPolyline.js +44 -0
  147. package/dist/esm/drawingSvg/drawPolyline.js.map +1 -0
  148. package/dist/esm/drawingSvg/drawRect.d.ts +1 -1
  149. package/dist/esm/drawingSvg/drawRect.js +2 -2
  150. package/dist/esm/drawingSvg/drawRect.js.map +1 -1
  151. package/dist/esm/drawingSvg/drawTextBox.d.ts +1 -1
  152. package/dist/esm/drawingSvg/drawTextBox.js +4 -4
  153. package/dist/esm/drawingSvg/drawTextBox.js.map +1 -1
  154. package/dist/esm/drawingSvg/index.d.ts +3 -1
  155. package/dist/esm/drawingSvg/index.js +3 -1
  156. package/dist/esm/drawingSvg/index.js.map +1 -1
  157. package/dist/esm/index.d.ts +2 -2
  158. package/dist/esm/index.js +2 -2
  159. package/dist/esm/index.js.map +1 -1
  160. package/dist/esm/stateManagement/annotation/config/annotationStyle.js +1 -1
  161. package/dist/esm/tools/CrosshairsTool.js +12 -12
  162. package/dist/esm/tools/CrosshairsTool.js.map +1 -1
  163. package/dist/esm/tools/annotation/ArrowTool.d.ts +36 -0
  164. package/dist/esm/tools/annotation/ArrowTool.js +379 -0
  165. package/dist/esm/tools/annotation/ArrowTool.js.map +1 -0
  166. package/dist/esm/tools/annotation/BidirectionalTool.js +4 -4
  167. package/dist/esm/tools/annotation/BidirectionalTool.js.map +1 -1
  168. package/dist/esm/tools/annotation/EllipticalROITool.js +3 -3
  169. package/dist/esm/tools/annotation/EllipticalROITool.js.map +1 -1
  170. package/dist/esm/tools/annotation/LengthTool.js +4 -3
  171. package/dist/esm/tools/annotation/LengthTool.js.map +1 -1
  172. package/dist/esm/tools/annotation/PlanarFreehandROITool.d.ts +32 -0
  173. package/dist/esm/tools/annotation/PlanarFreehandROITool.js +187 -0
  174. package/dist/esm/tools/annotation/PlanarFreehandROITool.js.map +1 -0
  175. package/dist/esm/tools/annotation/ProbeTool.js +2 -2
  176. package/dist/esm/tools/annotation/ProbeTool.js.map +1 -1
  177. package/dist/esm/tools/annotation/RectangleROITool.js +3 -3
  178. package/dist/esm/tools/annotation/RectangleROITool.js.map +1 -1
  179. package/dist/esm/tools/annotation/planarFreehandROITool/closedContourEditLoop.d.ts +2 -0
  180. package/dist/esm/tools/annotation/planarFreehandROITool/closedContourEditLoop.js +211 -0
  181. package/dist/esm/tools/annotation/planarFreehandROITool/closedContourEditLoop.js.map +1 -0
  182. package/dist/esm/tools/annotation/planarFreehandROITool/drawLoop.d.ts +2 -0
  183. package/dist/esm/tools/annotation/planarFreehandROITool/drawLoop.js +177 -0
  184. package/dist/esm/tools/annotation/planarFreehandROITool/drawLoop.js.map +1 -0
  185. package/dist/esm/tools/annotation/planarFreehandROITool/editLoopCommon.d.ts +2 -0
  186. package/dist/esm/tools/annotation/planarFreehandROITool/editLoopCommon.js +125 -0
  187. package/dist/esm/tools/annotation/planarFreehandROITool/editLoopCommon.js.map +1 -0
  188. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEditLoop.d.ts +2 -0
  189. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEditLoop.js +284 -0
  190. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEditLoop.js.map +1 -0
  191. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEndEditLoop.d.ts +2 -0
  192. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js +41 -0
  193. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js.map +1 -0
  194. package/dist/esm/tools/annotation/planarFreehandROITool/renderMethods.d.ts +2 -0
  195. package/dist/esm/tools/annotation/planarFreehandROITool/renderMethods.js +97 -0
  196. package/dist/esm/tools/annotation/planarFreehandROITool/renderMethods.js.map +1 -0
  197. package/dist/esm/tools/index.d.ts +3 -1
  198. package/dist/esm/tools/index.js +3 -1
  199. package/dist/esm/tools/index.js.map +1 -1
  200. package/dist/esm/tools/segmentation/BrushTool.js +1 -1
  201. package/dist/esm/tools/segmentation/BrushTool.js.map +1 -1
  202. package/dist/esm/tools/segmentation/CircleScissorsTool.js +1 -1
  203. package/dist/esm/tools/segmentation/CircleScissorsTool.js.map +1 -1
  204. package/dist/esm/tools/segmentation/RectangleROIStartEndThresholdTool.js +2 -2
  205. package/dist/esm/tools/segmentation/RectangleROIStartEndThresholdTool.js.map +1 -1
  206. package/dist/esm/tools/segmentation/RectangleROIThresholdTool.js +2 -2
  207. package/dist/esm/tools/segmentation/RectangleROIThresholdTool.js.map +1 -1
  208. package/dist/esm/tools/segmentation/RectangleScissorsTool.js +1 -1
  209. package/dist/esm/tools/segmentation/RectangleScissorsTool.js.map +1 -1
  210. package/dist/esm/tools/segmentation/SphereScissorsTool.js +1 -1
  211. package/dist/esm/tools/segmentation/SphereScissorsTool.js.map +1 -1
  212. package/dist/esm/types/AnnotationTypes.d.ts +1 -0
  213. package/dist/esm/types/ToolSpecificAnnotationTypes.d.ts +50 -0
  214. package/dist/esm/utilities/math/index.d.ts +2 -1
  215. package/dist/esm/utilities/math/index.js +2 -1
  216. package/dist/esm/utilities/math/index.js.map +1 -1
  217. package/dist/esm/utilities/math/polyline/addCanvasPointsToArray.d.ts +4 -0
  218. package/dist/esm/utilities/math/polyline/addCanvasPointsToArray.js +34 -0
  219. package/dist/esm/utilities/math/polyline/addCanvasPointsToArray.js.map +1 -0
  220. package/dist/esm/utilities/math/polyline/calculateAreaOfPoints.d.ts +2 -0
  221. package/dist/esm/utilities/math/polyline/calculateAreaOfPoints.js +11 -0
  222. package/dist/esm/utilities/math/polyline/calculateAreaOfPoints.js.map +1 -0
  223. package/dist/esm/utilities/math/polyline/getIntersectionWithPolyline.d.ts +7 -0
  224. package/dist/esm/utilities/math/polyline/getIntersectionWithPolyline.js +106 -0
  225. package/dist/esm/utilities/math/polyline/getIntersectionWithPolyline.js.map +1 -0
  226. package/dist/esm/utilities/math/polyline/getSubPixelSpacingAndXYDirections.d.ts +7 -0
  227. package/dist/esm/utilities/math/polyline/getSubPixelSpacingAndXYDirections.js +65 -0
  228. package/dist/esm/utilities/math/polyline/getSubPixelSpacingAndXYDirections.js.map +1 -0
  229. package/dist/esm/utilities/math/polyline/index.d.ts +7 -0
  230. package/dist/esm/utilities/math/polyline/index.js +8 -0
  231. package/dist/esm/utilities/math/polyline/index.js.map +1 -0
  232. package/dist/esm/utilities/math/polyline/planarFreehandROIInternalTypes.d.ts +22 -0
  233. package/dist/esm/utilities/math/polyline/planarFreehandROIInternalTypes.js +2 -0
  234. package/dist/esm/utilities/math/polyline/planarFreehandROIInternalTypes.js.map +1 -0
  235. package/dist/esm/utilities/math/polyline/pointCanProjectOnLine.d.ts +3 -0
  236. package/dist/esm/utilities/math/polyline/pointCanProjectOnLine.js +33 -0
  237. package/dist/esm/utilities/math/polyline/pointCanProjectOnLine.js.map +1 -0
  238. package/dist/esm/utilities/math/polyline/pointsAreWithinCloseContourProximity.d.ts +3 -0
  239. package/dist/esm/utilities/math/polyline/pointsAreWithinCloseContourProximity.js +6 -0
  240. package/dist/esm/utilities/math/polyline/pointsAreWithinCloseContourProximity.js.map +1 -0
  241. package/dist/umd/index.js +1 -1
  242. package/dist/umd/index.js.map +1 -1
  243. package/package.json +4 -4
@@ -0,0 +1,127 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const gl_matrix_1 = require("gl-matrix");
4
+ const math_1 = require("../../../utilities/math");
5
+ const { addCanvasPointsToArray, getFirstIntersectionWithPolyline } = math_1.polyline;
6
+ function checkForFirstCrossing(evt, isClosedContour) {
7
+ const eventDetail = evt.detail;
8
+ const { element, currentPoints, lastPoints } = eventDetail;
9
+ const canvasPos = currentPoints.canvas;
10
+ const lastCanvasPoint = lastPoints.canvas;
11
+ const { editCanvasPoints, prevCanvasPoints } = this.editData;
12
+ const crossedLineSegment = getFirstIntersectionWithPolyline(prevCanvasPoints, canvasPos, lastCanvasPoint, isClosedContour);
13
+ if (crossedLineSegment) {
14
+ this.editData.startCrossingIndex = crossedLineSegment[0];
15
+ this.removePointsUpUntilFirstCrossing(isClosedContour);
16
+ }
17
+ else if (editCanvasPoints.length >
18
+ this.configuration.checkCanvasEditFallbackProximity) {
19
+ const firstEditCanvasPoint = editCanvasPoints[0];
20
+ const distanceIndexPairs = [];
21
+ for (let i = 0; i < prevCanvasPoints.length; i++) {
22
+ const prevCanvasPoint = prevCanvasPoints[i];
23
+ const distance = gl_matrix_1.vec2.distance(prevCanvasPoint, firstEditCanvasPoint);
24
+ distanceIndexPairs.push({ distance, index: i });
25
+ }
26
+ distanceIndexPairs.sort((a, b) => a.distance - b.distance);
27
+ const twoClosestDistanceIndexPairs = [
28
+ distanceIndexPairs[0],
29
+ distanceIndexPairs[1],
30
+ ];
31
+ const lowestIndex = Math.min(twoClosestDistanceIndexPairs[0].index, twoClosestDistanceIndexPairs[1].index);
32
+ this.editData.startCrossingIndex = lowestIndex;
33
+ }
34
+ else if (editCanvasPoints.length >= 2) {
35
+ const dir = gl_matrix_1.vec2.create();
36
+ gl_matrix_1.vec2.subtract(dir, editCanvasPoints[1], editCanvasPoints[0]);
37
+ gl_matrix_1.vec2.normalize(dir, dir);
38
+ const proximity = 6;
39
+ const extendedPoint = [
40
+ editCanvasPoints[0][0] - dir[0] * proximity,
41
+ editCanvasPoints[0][1] - dir[1] * proximity,
42
+ ];
43
+ const crossedLineSegmentFromExtendedPoint = getFirstIntersectionWithPolyline(prevCanvasPoints, extendedPoint, editCanvasPoints[0], isClosedContour);
44
+ if (crossedLineSegmentFromExtendedPoint) {
45
+ const pointsToPrepend = [extendedPoint];
46
+ addCanvasPointsToArray(element, pointsToPrepend, editCanvasPoints[0], this.commonData);
47
+ editCanvasPoints.unshift(...pointsToPrepend);
48
+ this.removePointsUpUntilFirstCrossing(isClosedContour);
49
+ this.editData.editIndex = editCanvasPoints.length - 1;
50
+ this.editData.startCrossingIndex = crossedLineSegmentFromExtendedPoint[0];
51
+ }
52
+ }
53
+ }
54
+ function removePointsUpUntilFirstCrossing(isClosedContour) {
55
+ const { editCanvasPoints, prevCanvasPoints } = this.editData;
56
+ let numPointsToRemove = 0;
57
+ for (let i = 0; i < editCanvasPoints.length - 1; i++) {
58
+ const firstLine = [editCanvasPoints[i], editCanvasPoints[i + 1]];
59
+ const didCrossLine = !!getFirstIntersectionWithPolyline(prevCanvasPoints, firstLine[0], firstLine[1], isClosedContour);
60
+ numPointsToRemove++;
61
+ if (didCrossLine) {
62
+ break;
63
+ }
64
+ }
65
+ editCanvasPoints.splice(0, numPointsToRemove);
66
+ this.editData.editIndex = editCanvasPoints.length - 1;
67
+ }
68
+ function checkForSecondCrossing(evt, isClosedContour) {
69
+ const eventDetail = evt.detail;
70
+ const { currentPoints, lastPoints } = eventDetail;
71
+ const canvasPos = currentPoints.canvas;
72
+ const lastCanvasPoint = lastPoints.canvas;
73
+ const { prevCanvasPoints } = this.editData;
74
+ const crossedLineSegment = getFirstIntersectionWithPolyline(prevCanvasPoints, canvasPos, lastCanvasPoint, isClosedContour);
75
+ if (!crossedLineSegment) {
76
+ return false;
77
+ }
78
+ return true;
79
+ }
80
+ function removePointsAfterSecondCrossing(isClosedContour) {
81
+ const { prevCanvasPoints, editCanvasPoints } = this.editData;
82
+ for (let i = editCanvasPoints.length - 1; i > 0; i--) {
83
+ const lastLine = [editCanvasPoints[i], editCanvasPoints[i - 1]];
84
+ const didCrossLine = !!getFirstIntersectionWithPolyline(prevCanvasPoints, lastLine[0], lastLine[1], isClosedContour);
85
+ editCanvasPoints.pop();
86
+ if (didCrossLine) {
87
+ break;
88
+ }
89
+ }
90
+ }
91
+ function findSnapIndex() {
92
+ const { editCanvasPoints, prevCanvasPoints, startCrossingIndex } = this.editData;
93
+ if (startCrossingIndex === undefined) {
94
+ return;
95
+ }
96
+ const lastEditCanvasPoint = editCanvasPoints[editCanvasPoints.length - 1];
97
+ const distanceIndexPairs = [];
98
+ for (let i = 0; i < prevCanvasPoints.length; i++) {
99
+ const prevCanvasPoint = prevCanvasPoints[i];
100
+ const distance = gl_matrix_1.vec2.distance(prevCanvasPoint, lastEditCanvasPoint);
101
+ distanceIndexPairs.push({ distance, index: i });
102
+ }
103
+ distanceIndexPairs.sort((a, b) => a.distance - b.distance);
104
+ const editCanvasPointsLessLastOne = editCanvasPoints.slice(0, -1);
105
+ for (let i = 0; i < distanceIndexPairs.length; i++) {
106
+ const { index } = distanceIndexPairs[i];
107
+ const snapCanvasPosition = prevCanvasPoints[index];
108
+ const lastEditCanvasPoint = editCanvasPoints[editCanvasPoints.length - 1];
109
+ const crossedLineSegment = getFirstIntersectionWithPolyline(editCanvasPointsLessLastOne, snapCanvasPosition, lastEditCanvasPoint, false);
110
+ if (!crossedLineSegment) {
111
+ return index;
112
+ }
113
+ }
114
+ return -1;
115
+ }
116
+ function registerEditLoopCommon(toolInstance) {
117
+ toolInstance.checkForFirstCrossing = checkForFirstCrossing.bind(toolInstance);
118
+ toolInstance.removePointsUpUntilFirstCrossing =
119
+ removePointsUpUntilFirstCrossing.bind(toolInstance);
120
+ toolInstance.checkForSecondCrossing =
121
+ checkForSecondCrossing.bind(toolInstance);
122
+ toolInstance.findSnapIndex = findSnapIndex.bind(toolInstance);
123
+ toolInstance.removePointsAfterSecondCrossing =
124
+ removePointsAfterSecondCrossing.bind(toolInstance);
125
+ }
126
+ exports.default = registerEditLoopCommon;
127
+ //# sourceMappingURL=editLoopCommon.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"editLoopCommon.js","sourceRoot":"","sources":["../../../../../src/tools/annotation/planarFreehandROITool/editLoopCommon.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ declare function registerOpenContourEditLoop(toolInstance: any): void;
2
+ export default registerOpenContourEditLoop;
@@ -0,0 +1,289 @@
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 core_1 = require("@cornerstonejs/core");
7
+ const store_1 = require("../../../store");
8
+ const enums_1 = require("../../../enums");
9
+ const elementCursor_1 = require("../../../cursors/elementCursor");
10
+ const gl_matrix_1 = require("gl-matrix");
11
+ const math_1 = require("../../../utilities/math");
12
+ const triggerAnnotationRenderForViewportIds_1 = __importDefault(require("../../../utilities/triggerAnnotationRenderForViewportIds"));
13
+ const { addCanvasPointsToArray, getSubPixelSpacingAndXYDirections } = math_1.polyline;
14
+ function activateOpenContourEdit(evt, annotation, viewportIdsToRender) {
15
+ this.isEditingOpen = true;
16
+ const eventDetail = evt.detail;
17
+ const { currentPoints, element } = eventDetail;
18
+ const canvasPos = currentPoints.canvas;
19
+ const enabledElement = (0, core_1.getEnabledElement)(element);
20
+ const { viewport } = enabledElement;
21
+ const prevCanvasPoints = annotation.data.polyline.map(viewport.worldToCanvas);
22
+ const { spacing, xDir, yDir } = getSubPixelSpacingAndXYDirections(viewport, this.configuration.subPixelResolution);
23
+ this.editData = {
24
+ prevCanvasPoints,
25
+ editCanvasPoints: [canvasPos],
26
+ startCrossingIndex: undefined,
27
+ editIndex: 0,
28
+ };
29
+ this.commonData = {
30
+ annotation,
31
+ viewportIdsToRender,
32
+ spacing,
33
+ xDir,
34
+ yDir,
35
+ };
36
+ store_1.state.isInteractingWithTool = true;
37
+ element.addEventListener(enums_1.Events.MOUSE_UP, this.mouseUpOpenContourEditCallback);
38
+ element.addEventListener(enums_1.Events.MOUSE_DRAG, this.mouseDragOpenContourEditCallback);
39
+ element.addEventListener(enums_1.Events.MOUSE_CLICK, this.mouseUpOpenContourEditCallback);
40
+ (0, elementCursor_1.hideElementCursor)(element);
41
+ }
42
+ function deactivateOpenContourEdit(element) {
43
+ store_1.state.isInteractingWithTool = false;
44
+ element.removeEventListener(enums_1.Events.MOUSE_UP, this.mouseUpOpenContourEditCallback);
45
+ element.removeEventListener(enums_1.Events.MOUSE_DRAG, this.mouseDragOpenContourEditCallback);
46
+ element.removeEventListener(enums_1.Events.MOUSE_CLICK, this.mouseUpOpenContourEditCallback);
47
+ (0, elementCursor_1.resetElementCursor)(element);
48
+ }
49
+ function mouseDragOpenContourEditCallback(evt) {
50
+ const eventDetail = evt.detail;
51
+ const { currentPoints, element } = eventDetail;
52
+ const worldPos = currentPoints.world;
53
+ const canvasPos = currentPoints.canvas;
54
+ const enabledElement = (0, core_1.getEnabledElement)(element);
55
+ const { renderingEngine, viewport } = enabledElement;
56
+ const { viewportIdsToRender, xDir, yDir, spacing } = this.commonData;
57
+ const { editIndex, editCanvasPoints, startCrossingIndex } = this.editData;
58
+ const lastCanvasPoint = editCanvasPoints[editCanvasPoints.length - 1];
59
+ const lastWorldPoint = viewport.canvasToWorld(lastCanvasPoint);
60
+ const worldPosDiff = gl_matrix_1.vec3.create();
61
+ gl_matrix_1.vec3.subtract(worldPosDiff, worldPos, lastWorldPoint);
62
+ const xDist = Math.abs(gl_matrix_1.vec3.dot(worldPosDiff, xDir));
63
+ const yDist = Math.abs(gl_matrix_1.vec3.dot(worldPosDiff, yDir));
64
+ if (xDist <= spacing[0] && yDist <= spacing[1]) {
65
+ return;
66
+ }
67
+ const numPointsAdded = addCanvasPointsToArray(element, editCanvasPoints, canvasPos, this.commonData);
68
+ const currentEditIndex = editIndex + numPointsAdded;
69
+ this.editData.editIndex = currentEditIndex;
70
+ if (startCrossingIndex === undefined && editCanvasPoints.length > 1) {
71
+ this.checkForFirstCrossing(evt, false);
72
+ }
73
+ this.editData.snapIndex = this.findSnapIndex();
74
+ this.editData.fusedCanvasPoints = this.fuseEditPointsWithOpenContour(evt);
75
+ if (startCrossingIndex !== undefined &&
76
+ this.checkForSecondCrossing(evt, false)) {
77
+ this.removePointsAfterSecondCrossing(false);
78
+ this.finishEditOpenOnSecondCrossing(evt);
79
+ }
80
+ else if (this.checkIfShouldOverwriteAnEnd(evt)) {
81
+ this.openContourEditOverwriteEnd(evt);
82
+ }
83
+ (0, triggerAnnotationRenderForViewportIds_1.default)(renderingEngine, viewportIdsToRender);
84
+ }
85
+ function openContourEditOverwriteEnd(evt) {
86
+ const eventDetail = evt.detail;
87
+ const { element } = eventDetail;
88
+ const enabledElement = (0, core_1.getEnabledElement)(element);
89
+ const { viewport } = enabledElement;
90
+ const { annotation, viewportIdsToRender } = this.commonData;
91
+ const fusedCanvasPoints = this.fuseEditPointsForOpenContourEndEdit();
92
+ const worldPoints = fusedCanvasPoints.map((canvasPoint) => viewport.canvasToWorld(canvasPoint));
93
+ annotation.data.polyline = worldPoints;
94
+ annotation.data.isOpenContour = true;
95
+ annotation.data.handles.points = [
96
+ worldPoints[0],
97
+ worldPoints[worldPoints.length - 1],
98
+ ];
99
+ annotation.data.handles.activeHandleIndex = 1;
100
+ this.triggerAnnotationModified(annotation, enabledElement);
101
+ this.isEditingOpen = false;
102
+ this.editData = undefined;
103
+ this.commonData = undefined;
104
+ this.deactivateOpenContourEdit(element);
105
+ this.activateOpenContourEndEdit(evt, annotation, viewportIdsToRender);
106
+ }
107
+ function checkIfShouldOverwriteAnEnd(evt) {
108
+ const eventDetail = evt.detail;
109
+ const { currentPoints, lastPoints } = eventDetail;
110
+ const canvasPos = currentPoints.canvas;
111
+ const lastCanvasPos = lastPoints.canvas;
112
+ const { snapIndex, prevCanvasPoints, startCrossingIndex } = this.editData;
113
+ if (startCrossingIndex === undefined || snapIndex === undefined) {
114
+ return false;
115
+ }
116
+ if (snapIndex === -1) {
117
+ return true;
118
+ }
119
+ if (snapIndex !== 0 && snapIndex !== prevCanvasPoints.length - 1) {
120
+ return false;
121
+ }
122
+ const p1 = canvasPos;
123
+ const p2 = lastCanvasPos;
124
+ const p3 = prevCanvasPoints[snapIndex];
125
+ const a = gl_matrix_1.vec2.create();
126
+ const b = gl_matrix_1.vec2.create();
127
+ gl_matrix_1.vec2.set(a, p1[0] - p2[0], p1[1] - p2[1]);
128
+ gl_matrix_1.vec2.set(b, p1[0] - p3[0], p1[1] - p3[1]);
129
+ const aDotb = gl_matrix_1.vec2.dot(a, b);
130
+ const magA = Math.sqrt(a[0] * a[0] + a[1] * a[1]);
131
+ const magB = Math.sqrt(b[0] * b[0] + b[1] * b[1]);
132
+ const theta = Math.acos(aDotb / (magA * magB));
133
+ if (theta < Math.PI / 2) {
134
+ return true;
135
+ }
136
+ return false;
137
+ }
138
+ function fuseEditPointsForOpenContourEndEdit() {
139
+ const { snapIndex, prevCanvasPoints, editCanvasPoints, startCrossingIndex } = this.editData;
140
+ const newCanvasPoints = [];
141
+ if (snapIndex === 0) {
142
+ for (let i = prevCanvasPoints.length - 1; i >= startCrossingIndex; i--) {
143
+ const canvasPoint = prevCanvasPoints[i];
144
+ newCanvasPoints.push([canvasPoint[0], canvasPoint[1]]);
145
+ }
146
+ }
147
+ else {
148
+ for (let i = 0; i < startCrossingIndex; i++) {
149
+ const canvasPoint = prevCanvasPoints[i];
150
+ newCanvasPoints.push([canvasPoint[0], canvasPoint[1]]);
151
+ }
152
+ }
153
+ const distanceBetweenCrossingIndexAndFirstPoint = gl_matrix_1.vec2.distance(prevCanvasPoints[startCrossingIndex], editCanvasPoints[0]);
154
+ const distanceBetweenCrossingIndexAndLastPoint = gl_matrix_1.vec2.distance(prevCanvasPoints[startCrossingIndex], editCanvasPoints[editCanvasPoints.length - 1]);
155
+ if (distanceBetweenCrossingIndexAndFirstPoint <
156
+ distanceBetweenCrossingIndexAndLastPoint) {
157
+ for (let i = 0; i < editCanvasPoints.length; i++) {
158
+ const canvasPoint = editCanvasPoints[i];
159
+ newCanvasPoints.push([canvasPoint[0], canvasPoint[1]]);
160
+ }
161
+ }
162
+ else {
163
+ for (let i = editCanvasPoints.length - 1; i >= 0; i--) {
164
+ const canvasPoint = editCanvasPoints[i];
165
+ newCanvasPoints.push([canvasPoint[0], canvasPoint[1]]);
166
+ }
167
+ }
168
+ return newCanvasPoints;
169
+ }
170
+ function fuseEditPointsWithOpenContour(evt) {
171
+ const { prevCanvasPoints, editCanvasPoints, startCrossingIndex, snapIndex } = this.editData;
172
+ if (startCrossingIndex === undefined || snapIndex === undefined) {
173
+ return undefined;
174
+ }
175
+ const eventDetail = evt.detail;
176
+ const { element } = eventDetail;
177
+ const augmentedEditCanvasPoints = [...editCanvasPoints];
178
+ addCanvasPointsToArray(element, augmentedEditCanvasPoints, prevCanvasPoints[snapIndex], this.commonData);
179
+ if (augmentedEditCanvasPoints.length > editCanvasPoints.length) {
180
+ augmentedEditCanvasPoints.pop();
181
+ }
182
+ let lowIndex;
183
+ let highIndex;
184
+ if (startCrossingIndex > snapIndex) {
185
+ lowIndex = snapIndex;
186
+ highIndex = startCrossingIndex;
187
+ }
188
+ else {
189
+ lowIndex = startCrossingIndex;
190
+ highIndex = snapIndex;
191
+ }
192
+ const distanceBetweenLowAndFirstPoint = gl_matrix_1.vec2.distance(prevCanvasPoints[lowIndex], augmentedEditCanvasPoints[0]);
193
+ const distanceBetweenLowAndLastPoint = gl_matrix_1.vec2.distance(prevCanvasPoints[lowIndex], augmentedEditCanvasPoints[augmentedEditCanvasPoints.length - 1]);
194
+ const distanceBetweenHighAndFirstPoint = gl_matrix_1.vec2.distance(prevCanvasPoints[highIndex], augmentedEditCanvasPoints[0]);
195
+ const distanceBetweenHighAndLastPoint = gl_matrix_1.vec2.distance(prevCanvasPoints[highIndex], augmentedEditCanvasPoints[augmentedEditCanvasPoints.length - 1]);
196
+ const pointsToRender = [];
197
+ for (let i = 0; i < lowIndex; i++) {
198
+ const canvasPoint = prevCanvasPoints[i];
199
+ pointsToRender.push([canvasPoint[0], canvasPoint[1]]);
200
+ }
201
+ const inPlaceDistance = distanceBetweenLowAndFirstPoint + distanceBetweenHighAndLastPoint;
202
+ const reverseDistance = distanceBetweenLowAndLastPoint + distanceBetweenHighAndFirstPoint;
203
+ if (inPlaceDistance < reverseDistance) {
204
+ for (let i = 0; i < augmentedEditCanvasPoints.length; i++) {
205
+ const canvasPoint = augmentedEditCanvasPoints[i];
206
+ pointsToRender.push([canvasPoint[0], canvasPoint[1]]);
207
+ }
208
+ }
209
+ else {
210
+ for (let i = augmentedEditCanvasPoints.length - 1; i >= 0; i--) {
211
+ const canvasPoint = augmentedEditCanvasPoints[i];
212
+ pointsToRender.push([canvasPoint[0], canvasPoint[1]]);
213
+ }
214
+ }
215
+ for (let i = highIndex; i < prevCanvasPoints.length; i++) {
216
+ const canvasPoint = prevCanvasPoints[i];
217
+ pointsToRender.push([canvasPoint[0], canvasPoint[1]]);
218
+ }
219
+ return pointsToRender;
220
+ }
221
+ function finishEditOpenOnSecondCrossing(evt) {
222
+ const eventDetail = evt.detail;
223
+ const { element } = eventDetail;
224
+ const enabledElement = (0, core_1.getEnabledElement)(element);
225
+ const { viewport, renderingEngine } = enabledElement;
226
+ const { annotation, viewportIdsToRender } = this.commonData;
227
+ const { fusedCanvasPoints, editCanvasPoints } = this.editData;
228
+ const worldPoints = fusedCanvasPoints.map((canvasPoint) => viewport.canvasToWorld(canvasPoint));
229
+ annotation.data.polyline = worldPoints;
230
+ annotation.data.isOpenContour = true;
231
+ annotation.data.handles.points = [
232
+ worldPoints[0],
233
+ worldPoints[worldPoints.length - 1],
234
+ ];
235
+ this.triggerAnnotationModified(annotation, enabledElement);
236
+ const lastEditCanvasPoint = editCanvasPoints.pop();
237
+ this.editData = {
238
+ prevCanvasPoints: fusedCanvasPoints,
239
+ editCanvasPoints: [lastEditCanvasPoint],
240
+ startCrossingIndex: undefined,
241
+ editIndex: 0,
242
+ };
243
+ (0, triggerAnnotationRenderForViewportIds_1.default)(renderingEngine, viewportIdsToRender);
244
+ }
245
+ function mouseUpOpenContourEditCallback(evt) {
246
+ const eventDetail = evt.detail;
247
+ const { element } = eventDetail;
248
+ const enabledElement = (0, core_1.getEnabledElement)(element);
249
+ const { viewport, renderingEngine } = enabledElement;
250
+ const { annotation, viewportIdsToRender } = this.commonData;
251
+ const { fusedCanvasPoints } = this.editData;
252
+ if (fusedCanvasPoints) {
253
+ const worldPoints = fusedCanvasPoints.map((canvasPoint) => viewport.canvasToWorld(canvasPoint));
254
+ annotation.data.polyline = worldPoints;
255
+ annotation.data.isOpenContour = true;
256
+ annotation.data.handles.points = [
257
+ worldPoints[0],
258
+ worldPoints[worldPoints.length - 1],
259
+ ];
260
+ this.triggerAnnotationModified(annotation, enabledElement);
261
+ }
262
+ this.isEditingOpen = false;
263
+ this.editData = undefined;
264
+ this.commonData = undefined;
265
+ (0, triggerAnnotationRenderForViewportIds_1.default)(renderingEngine, viewportIdsToRender);
266
+ this.deactivateOpenContourEdit(element);
267
+ }
268
+ function registerOpenContourEditLoop(toolInstance) {
269
+ toolInstance.activateOpenContourEdit =
270
+ activateOpenContourEdit.bind(toolInstance);
271
+ toolInstance.deactivateOpenContourEdit =
272
+ deactivateOpenContourEdit.bind(toolInstance);
273
+ toolInstance.mouseDragOpenContourEditCallback =
274
+ mouseDragOpenContourEditCallback.bind(toolInstance);
275
+ toolInstance.mouseUpOpenContourEditCallback =
276
+ mouseUpOpenContourEditCallback.bind(toolInstance);
277
+ toolInstance.fuseEditPointsWithOpenContour =
278
+ fuseEditPointsWithOpenContour.bind(toolInstance);
279
+ toolInstance.finishEditOpenOnSecondCrossing =
280
+ finishEditOpenOnSecondCrossing.bind(toolInstance);
281
+ toolInstance.checkIfShouldOverwriteAnEnd =
282
+ checkIfShouldOverwriteAnEnd.bind(toolInstance);
283
+ toolInstance.fuseEditPointsForOpenContourEndEdit =
284
+ fuseEditPointsForOpenContourEndEdit.bind(toolInstance);
285
+ toolInstance.openContourEditOverwriteEnd =
286
+ openContourEditOverwriteEnd.bind(toolInstance);
287
+ }
288
+ exports.default = registerOpenContourEditLoop;
289
+ //# sourceMappingURL=openContourEditLoop.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openContourEditLoop.js","sourceRoot":"","sources":["../../../../../src/tools/annotation/planarFreehandROITool/openContourEditLoop.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ declare function registerOpenContourEndEditLoop(toolInstance: any): void;
2
+ export default registerOpenContourEndEditLoop;
@@ -0,0 +1,43 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const core_1 = require("@cornerstonejs/core");
4
+ const store_1 = require("../../../store");
5
+ const enums_1 = require("../../../enums");
6
+ const elementCursor_1 = require("../../../cursors/elementCursor");
7
+ const math_1 = require("../../../utilities/math");
8
+ const { getSubPixelSpacingAndXYDirections } = math_1.polyline;
9
+ function activateOpenContourEndEdit(evt, annotation, viewportIdsToRender) {
10
+ this.isDrawing = true;
11
+ const eventDetail = evt.detail;
12
+ const { element } = eventDetail;
13
+ const enabledElement = (0, core_1.getEnabledElement)(element);
14
+ const { viewport } = enabledElement;
15
+ const { spacing, xDir, yDir } = getSubPixelSpacingAndXYDirections(viewport, this.configuration.subPixelResolution);
16
+ const canvasPoints = annotation.data.polyline.map(viewport.worldToCanvas);
17
+ const handleIndexGrabbed = annotation.data.handles.activeHandleIndex;
18
+ if (handleIndexGrabbed === 0) {
19
+ canvasPoints.reverse();
20
+ }
21
+ this.drawData = {
22
+ canvasPoints: canvasPoints,
23
+ polylineIndex: canvasPoints.length - 1,
24
+ };
25
+ this.commonData = {
26
+ annotation,
27
+ viewportIdsToRender,
28
+ spacing,
29
+ xDir,
30
+ yDir,
31
+ };
32
+ store_1.state.isInteractingWithTool = true;
33
+ element.addEventListener(enums_1.Events.MOUSE_UP, this.mouseUpDrawCallback);
34
+ element.addEventListener(enums_1.Events.MOUSE_DRAG, this.mouseDragDrawCallback);
35
+ element.addEventListener(enums_1.Events.MOUSE_CLICK, this.mouseUpDrawCallback);
36
+ (0, elementCursor_1.hideElementCursor)(element);
37
+ }
38
+ function registerOpenContourEndEditLoop(toolInstance) {
39
+ toolInstance.activateOpenContourEndEdit =
40
+ activateOpenContourEndEdit.bind(toolInstance);
41
+ }
42
+ exports.default = registerOpenContourEndEditLoop;
43
+ //# sourceMappingURL=openContourEndEditLoop.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openContourEndEditLoop.js","sourceRoot":"","sources":["../../../../../src/tools/annotation/planarFreehandROITool/openContourEndEditLoop.ts"],"names":[],"mappings":";;AAAA,8CAAwD;AACxD,0CAAuC;AACvC,0CAAwC;AACxC,kEAAmE;AAEnE,kDAAmD;AAEnD,MAAM,EAAE,iCAAiC,EAAE,GAAG,eAAQ,CAAC;AAMvD,SAAS,0BAA0B,CACjC,GAA0C,EAC1C,UAAsB,EACtB,mBAA6B;IAE7B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;IAEtB,MAAM,WAAW,GAAG,GAAG,CAAC,MAAM,CAAC;IAC/B,MAAM,EAAE,OAAO,EAAE,GAAG,WAAW,CAAC;IAChC,MAAM,cAAc,GAAG,IAAA,wBAAiB,EAAC,OAAO,CAAC,CAAC;IAClD,MAAM,EAAE,QAAQ,EAAE,GAAG,cAAc,CAAC;IAEpC,MAAM,EAAE,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,iCAAiC,CAC/D,QAAQ,EACR,IAAI,CAAC,aAAa,CAAC,kBAAkB,CACtC,CAAC;IAEF,MAAM,YAAY,GAAG,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,QAAQ,CAAC,aAAa,CAAC,CAAC;IAC1E,MAAM,kBAAkB,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC;IAIrE,IAAI,kBAAkB,KAAK,CAAC,EAAE;QAC5B,YAAY,CAAC,OAAO,EAAE,CAAC;KACxB;IAED,IAAI,CAAC,QAAQ,GAAG;QACd,YAAY,EAAE,YAAY;QAC1B,aAAa,EAAE,YAAY,CAAC,MAAM,GAAG,CAAC;KACvC,CAAC;IAEF,IAAI,CAAC,UAAU,GAAG;QAChB,UAAU;QACV,mBAAmB;QACnB,OAAO;QACP,IAAI;QACJ,IAAI;KACL,CAAC;IAEF,aAAK,CAAC,qBAAqB,GAAG,IAAI,CAAC;IAGnC,OAAO,CAAC,gBAAgB,CAAC,cAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACpE,OAAO,CAAC,gBAAgB,CAAC,cAAM,CAAC,UAAU,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;IACxE,OAAO,CAAC,gBAAgB,CAAC,cAAM,CAAC,WAAW,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IAEvE,IAAA,iCAAiB,EAAC,OAAO,CAAC,CAAC;AAC7B,CAAC;AAKD,SAAS,8BAA8B,CAAC,YAAY;IAClD,YAAY,CAAC,0BAA0B;QACrC,0BAA0B,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;AAClD,CAAC;AAED,kBAAe,8BAA8B,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare function registerRenderMethods(toolInstance: any): void;
2
+ export default registerRenderMethods;
@@ -0,0 +1,99 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const core_1 = require("@cornerstonejs/core");
4
+ const drawingSvg_1 = require("../../../drawingSvg");
5
+ const math_1 = require("../../../utilities/math");
6
+ const { pointsAreWithinCloseContourProximity } = math_1.polyline;
7
+ function _getRenderingOptions(annotation) {
8
+ const settings = core_1.Settings.getObjectSettings(annotation, this.getToolName());
9
+ const lineWidth = this.getStyle(settings, 'lineWidth', annotation);
10
+ const color = this.getStyle(settings, 'color', annotation);
11
+ const isOpenContour = annotation.data.isOpenContour;
12
+ const options = {
13
+ color: color === undefined ? undefined : color,
14
+ width: lineWidth === undefined ? undefined : lineWidth,
15
+ connectLastToFirst: !isOpenContour,
16
+ };
17
+ return options;
18
+ }
19
+ function renderContour(enabledElement, svgDrawingHelper, annotation) {
20
+ if (annotation.data.isOpenContour) {
21
+ this.renderOpenContour(enabledElement, svgDrawingHelper, annotation);
22
+ }
23
+ else {
24
+ this.renderClosedContour(enabledElement, svgDrawingHelper, annotation);
25
+ }
26
+ }
27
+ function renderClosedContour(enabledElement, svgDrawingHelper, annotation) {
28
+ const { viewport } = enabledElement;
29
+ const options = this._getRenderingOptions(annotation);
30
+ const canvasPoints = annotation.data.polyline.map((worldPos) => viewport.worldToCanvas(worldPos));
31
+ const polylineUID = '1';
32
+ (0, drawingSvg_1.drawPolyline)(svgDrawingHelper, annotation.annotationUID, polylineUID, canvasPoints, options);
33
+ }
34
+ function renderOpenContour(enabledElement, svgDrawingHelper, annotation) {
35
+ const { viewport } = enabledElement;
36
+ const options = this._getRenderingOptions(annotation);
37
+ const canvasPoints = annotation.data.polyline.map((worldPos) => viewport.worldToCanvas(worldPos));
38
+ const polylineUID = '1';
39
+ (0, drawingSvg_1.drawPolyline)(svgDrawingHelper, annotation.annotationUID, polylineUID, canvasPoints, options);
40
+ const activeHandleIndex = annotation.data.handles.activeHandleIndex;
41
+ if (activeHandleIndex !== null) {
42
+ const handleGroupUID = '0';
43
+ const indexOfCanvasPoints = activeHandleIndex === 0 ? 0 : canvasPoints.length - 1;
44
+ const handlePoint = canvasPoints[indexOfCanvasPoints];
45
+ (0, drawingSvg_1.drawHandles)(svgDrawingHelper, annotation.annotationUID, handleGroupUID, [handlePoint], { color: options.color });
46
+ }
47
+ }
48
+ function renderContourBeingDrawn(enabledElement, svgDrawingHelper, annotation) {
49
+ const options = this._getRenderingOptions(annotation);
50
+ const { allowOpenContours } = this.configuration;
51
+ const { canvasPoints } = this.drawData;
52
+ options.connectLastToFirst = false;
53
+ (0, drawingSvg_1.drawPolyline)(svgDrawingHelper, annotation.annotationUID, '1', canvasPoints, options);
54
+ if (allowOpenContours) {
55
+ const firstPoint = canvasPoints[0];
56
+ const lastPoint = canvasPoints[canvasPoints.length - 1];
57
+ if (pointsAreWithinCloseContourProximity(firstPoint, lastPoint, this.configuration.closeContourProximity)) {
58
+ (0, drawingSvg_1.drawPolyline)(svgDrawingHelper, annotation.annotationUID, '2', [lastPoint, firstPoint], options);
59
+ }
60
+ else {
61
+ const handleGroupUID = '0';
62
+ (0, drawingSvg_1.drawHandles)(svgDrawingHelper, annotation.annotationUID, handleGroupUID, [firstPoint], { color: options.color, handleRadius: 2 });
63
+ }
64
+ }
65
+ }
66
+ function renderClosedContourBeingEdited(enabledElement, svgDrawingHelper, annotation) {
67
+ const { fusedCanvasPoints } = this.editData;
68
+ if (fusedCanvasPoints === undefined) {
69
+ this.renderClosedContour(enabledElement, svgDrawingHelper, annotation);
70
+ return;
71
+ }
72
+ const options = this._getRenderingOptions(annotation);
73
+ const polylineUIDToRender = 'preview-1';
74
+ (0, drawingSvg_1.drawPolyline)(svgDrawingHelper, annotation.annotationUID, polylineUIDToRender, fusedCanvasPoints, options);
75
+ }
76
+ function renderOpenContourBeingEdited(enabledElement, svgDrawingHelper, annotation) {
77
+ const { fusedCanvasPoints } = this.editData;
78
+ if (fusedCanvasPoints === undefined) {
79
+ this.renderOpenContour(enabledElement, svgDrawingHelper, annotation);
80
+ return;
81
+ }
82
+ const options = this._getRenderingOptions(annotation);
83
+ const polylineUIDToRender = 'preview-1';
84
+ (0, drawingSvg_1.drawPolyline)(svgDrawingHelper, annotation.annotationUID, polylineUIDToRender, fusedCanvasPoints, options);
85
+ }
86
+ function registerRenderMethods(toolInstance) {
87
+ toolInstance.renderContour = renderContour.bind(toolInstance);
88
+ toolInstance.renderClosedContour = renderClosedContour.bind(toolInstance);
89
+ toolInstance.renderOpenContour = renderOpenContour.bind(toolInstance);
90
+ toolInstance.renderContourBeingDrawn =
91
+ renderContourBeingDrawn.bind(toolInstance);
92
+ toolInstance.renderClosedContourBeingEdited =
93
+ renderClosedContourBeingEdited.bind(toolInstance);
94
+ toolInstance.renderOpenContourBeingEdited =
95
+ renderOpenContourBeingEdited.bind(toolInstance);
96
+ toolInstance._getRenderingOptions = _getRenderingOptions.bind(toolInstance);
97
+ }
98
+ exports.default = registerRenderMethods;
99
+ //# sourceMappingURL=renderMethods.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"renderMethods.js","sourceRoot":"","sources":["../../../../../src/tools/annotation/planarFreehandROITool/renderMethods.ts"],"names":[],"mappings":"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"}
@@ -12,6 +12,8 @@ import LengthTool from './annotation/LengthTool';
12
12
  import ProbeTool from './annotation/ProbeTool';
13
13
  import RectangleROITool from './annotation/RectangleROITool';
14
14
  import EllipticalROITool from './annotation/EllipticalROITool';
15
+ import PlanarFreehandROITool from './annotation/PlanarFreehandROITool';
16
+ import ArrowTool from './annotation/ArrowTool';
15
17
  import SegmentationDisplayTool from './displayTools/SegmentationDisplayTool';
16
18
  import RectangleScissorsTool from './segmentation/RectangleScissorsTool';
17
19
  import CircleScissorsTool from './segmentation/CircleScissorsTool';
@@ -19,4 +21,4 @@ import SphereScissorsTool from './segmentation/SphereScissorsTool';
19
21
  import RectangleROIThresholdTool from './segmentation/RectangleROIThresholdTool';
20
22
  import RectangleROIStartEndThresholdTool from './segmentation/RectangleROIStartEndThresholdTool';
21
23
  import BrushTool from './segmentation/BrushTool';
22
- export { BaseTool, AnnotationTool, PanTool, WindowLevelTool, StackScrollTool, StackScrollMouseWheelTool, ZoomTool, VolumeRotateMouseWheelTool, MIPJumpToClickTool, CrosshairsTool, BidirectionalTool, LengthTool, ProbeTool, RectangleROITool, EllipticalROITool, SegmentationDisplayTool, RectangleScissorsTool, CircleScissorsTool, SphereScissorsTool, RectangleROIThresholdTool, RectangleROIStartEndThresholdTool, BrushTool, };
24
+ export { BaseTool, AnnotationTool, PanTool, WindowLevelTool, StackScrollTool, StackScrollMouseWheelTool, ZoomTool, VolumeRotateMouseWheelTool, MIPJumpToClickTool, CrosshairsTool, BidirectionalTool, LengthTool, ProbeTool, RectangleROITool, EllipticalROITool, PlanarFreehandROITool, ArrowTool, SegmentationDisplayTool, RectangleScissorsTool, CircleScissorsTool, SphereScissorsTool, RectangleROIThresholdTool, RectangleROIStartEndThresholdTool, BrushTool, };