@cornerstonejs/tools 0.11.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 (129) hide show
  1. package/dist/cjs/drawingSvg/drawPolyline.d.ts +8 -0
  2. package/dist/cjs/drawingSvg/drawPolyline.js +50 -0
  3. package/dist/cjs/drawingSvg/drawPolyline.js.map +1 -0
  4. package/dist/cjs/drawingSvg/index.d.ts +2 -1
  5. package/dist/cjs/drawingSvg/index.js +3 -1
  6. package/dist/cjs/drawingSvg/index.js.map +1 -1
  7. package/dist/cjs/index.d.ts +2 -2
  8. package/dist/cjs/index.js +2 -1
  9. package/dist/cjs/index.js.map +1 -1
  10. package/dist/cjs/stateManagement/annotation/config/annotationStyle.js +1 -1
  11. package/dist/cjs/tools/annotation/PlanarFreehandROITool.d.ts +32 -0
  12. package/dist/cjs/tools/annotation/PlanarFreehandROITool.js +192 -0
  13. package/dist/cjs/tools/annotation/PlanarFreehandROITool.js.map +1 -0
  14. package/dist/cjs/tools/annotation/planarFreehandROITool/closedContourEditLoop.d.ts +2 -0
  15. package/dist/cjs/tools/annotation/planarFreehandROITool/closedContourEditLoop.js +216 -0
  16. package/dist/cjs/tools/annotation/planarFreehandROITool/closedContourEditLoop.js.map +1 -0
  17. package/dist/cjs/tools/annotation/planarFreehandROITool/drawLoop.d.ts +2 -0
  18. package/dist/cjs/tools/annotation/planarFreehandROITool/drawLoop.js +182 -0
  19. package/dist/cjs/tools/annotation/planarFreehandROITool/drawLoop.js.map +1 -0
  20. package/dist/cjs/tools/annotation/planarFreehandROITool/editLoopCommon.d.ts +2 -0
  21. package/dist/cjs/tools/annotation/planarFreehandROITool/editLoopCommon.js +127 -0
  22. package/dist/cjs/tools/annotation/planarFreehandROITool/editLoopCommon.js.map +1 -0
  23. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEditLoop.d.ts +2 -0
  24. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEditLoop.js +289 -0
  25. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEditLoop.js.map +1 -0
  26. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEndEditLoop.d.ts +2 -0
  27. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js +43 -0
  28. package/dist/cjs/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js.map +1 -0
  29. package/dist/cjs/tools/annotation/planarFreehandROITool/renderMethods.d.ts +2 -0
  30. package/dist/cjs/tools/annotation/planarFreehandROITool/renderMethods.js +99 -0
  31. package/dist/cjs/tools/annotation/planarFreehandROITool/renderMethods.js.map +1 -0
  32. package/dist/cjs/tools/index.d.ts +2 -1
  33. package/dist/cjs/tools/index.js +3 -1
  34. package/dist/cjs/tools/index.js.map +1 -1
  35. package/dist/cjs/types/AnnotationTypes.d.ts +1 -0
  36. package/dist/cjs/types/ToolSpecificAnnotationTypes.d.ts +31 -0
  37. package/dist/cjs/utilities/math/index.d.ts +2 -1
  38. package/dist/cjs/utilities/math/index.js +3 -1
  39. package/dist/cjs/utilities/math/index.js.map +1 -1
  40. package/dist/cjs/utilities/math/polyline/addCanvasPointsToArray.d.ts +4 -0
  41. package/dist/cjs/utilities/math/polyline/addCanvasPointsToArray.js +36 -0
  42. package/dist/cjs/utilities/math/polyline/addCanvasPointsToArray.js.map +1 -0
  43. package/dist/cjs/utilities/math/polyline/calculateAreaOfPoints.d.ts +2 -0
  44. package/dist/cjs/utilities/math/polyline/calculateAreaOfPoints.js +14 -0
  45. package/dist/cjs/utilities/math/polyline/calculateAreaOfPoints.js.map +1 -0
  46. package/dist/cjs/utilities/math/polyline/getIntersectionWithPolyline.d.ts +7 -0
  47. package/dist/cjs/utilities/math/polyline/getIntersectionWithPolyline.js +110 -0
  48. package/dist/cjs/utilities/math/polyline/getIntersectionWithPolyline.js.map +1 -0
  49. package/dist/cjs/utilities/math/polyline/getSubPixelSpacingAndXYDirections.d.ts +7 -0
  50. package/dist/cjs/utilities/math/polyline/getSubPixelSpacingAndXYDirections.js +67 -0
  51. package/dist/cjs/utilities/math/polyline/getSubPixelSpacingAndXYDirections.js.map +1 -0
  52. package/dist/cjs/utilities/math/polyline/index.d.ts +7 -0
  53. package/dist/cjs/utilities/math/polyline/index.js +20 -0
  54. package/dist/cjs/utilities/math/polyline/index.js.map +1 -0
  55. package/dist/cjs/utilities/math/polyline/planarFreehandROIInternalTypes.d.ts +22 -0
  56. package/dist/cjs/utilities/math/polyline/planarFreehandROIInternalTypes.js +3 -0
  57. package/dist/cjs/utilities/math/polyline/planarFreehandROIInternalTypes.js.map +1 -0
  58. package/dist/cjs/utilities/math/polyline/pointCanProjectOnLine.d.ts +3 -0
  59. package/dist/cjs/utilities/math/polyline/pointCanProjectOnLine.js +35 -0
  60. package/dist/cjs/utilities/math/polyline/pointCanProjectOnLine.js.map +1 -0
  61. package/dist/cjs/utilities/math/polyline/pointsAreWithinCloseContourProximity.d.ts +3 -0
  62. package/dist/cjs/utilities/math/polyline/pointsAreWithinCloseContourProximity.js +8 -0
  63. package/dist/cjs/utilities/math/polyline/pointsAreWithinCloseContourProximity.js.map +1 -0
  64. package/dist/esm/drawingSvg/drawPolyline.d.ts +8 -0
  65. package/dist/esm/drawingSvg/drawPolyline.js +44 -0
  66. package/dist/esm/drawingSvg/drawPolyline.js.map +1 -0
  67. package/dist/esm/drawingSvg/index.d.ts +2 -1
  68. package/dist/esm/drawingSvg/index.js +2 -1
  69. package/dist/esm/drawingSvg/index.js.map +1 -1
  70. package/dist/esm/index.d.ts +2 -2
  71. package/dist/esm/index.js +2 -2
  72. package/dist/esm/index.js.map +1 -1
  73. package/dist/esm/stateManagement/annotation/config/annotationStyle.js +1 -1
  74. package/dist/esm/tools/annotation/PlanarFreehandROITool.d.ts +32 -0
  75. package/dist/esm/tools/annotation/PlanarFreehandROITool.js +187 -0
  76. package/dist/esm/tools/annotation/PlanarFreehandROITool.js.map +1 -0
  77. package/dist/esm/tools/annotation/planarFreehandROITool/closedContourEditLoop.d.ts +2 -0
  78. package/dist/esm/tools/annotation/planarFreehandROITool/closedContourEditLoop.js +211 -0
  79. package/dist/esm/tools/annotation/planarFreehandROITool/closedContourEditLoop.js.map +1 -0
  80. package/dist/esm/tools/annotation/planarFreehandROITool/drawLoop.d.ts +2 -0
  81. package/dist/esm/tools/annotation/planarFreehandROITool/drawLoop.js +177 -0
  82. package/dist/esm/tools/annotation/planarFreehandROITool/drawLoop.js.map +1 -0
  83. package/dist/esm/tools/annotation/planarFreehandROITool/editLoopCommon.d.ts +2 -0
  84. package/dist/esm/tools/annotation/planarFreehandROITool/editLoopCommon.js +125 -0
  85. package/dist/esm/tools/annotation/planarFreehandROITool/editLoopCommon.js.map +1 -0
  86. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEditLoop.d.ts +2 -0
  87. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEditLoop.js +284 -0
  88. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEditLoop.js.map +1 -0
  89. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEndEditLoop.d.ts +2 -0
  90. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js +41 -0
  91. package/dist/esm/tools/annotation/planarFreehandROITool/openContourEndEditLoop.js.map +1 -0
  92. package/dist/esm/tools/annotation/planarFreehandROITool/renderMethods.d.ts +2 -0
  93. package/dist/esm/tools/annotation/planarFreehandROITool/renderMethods.js +97 -0
  94. package/dist/esm/tools/annotation/planarFreehandROITool/renderMethods.js.map +1 -0
  95. package/dist/esm/tools/index.d.ts +2 -1
  96. package/dist/esm/tools/index.js +2 -1
  97. package/dist/esm/tools/index.js.map +1 -1
  98. package/dist/esm/types/AnnotationTypes.d.ts +1 -0
  99. package/dist/esm/types/ToolSpecificAnnotationTypes.d.ts +31 -0
  100. package/dist/esm/utilities/math/index.d.ts +2 -1
  101. package/dist/esm/utilities/math/index.js +2 -1
  102. package/dist/esm/utilities/math/index.js.map +1 -1
  103. package/dist/esm/utilities/math/polyline/addCanvasPointsToArray.d.ts +4 -0
  104. package/dist/esm/utilities/math/polyline/addCanvasPointsToArray.js +34 -0
  105. package/dist/esm/utilities/math/polyline/addCanvasPointsToArray.js.map +1 -0
  106. package/dist/esm/utilities/math/polyline/calculateAreaOfPoints.d.ts +2 -0
  107. package/dist/esm/utilities/math/polyline/calculateAreaOfPoints.js +11 -0
  108. package/dist/esm/utilities/math/polyline/calculateAreaOfPoints.js.map +1 -0
  109. package/dist/esm/utilities/math/polyline/getIntersectionWithPolyline.d.ts +7 -0
  110. package/dist/esm/utilities/math/polyline/getIntersectionWithPolyline.js +106 -0
  111. package/dist/esm/utilities/math/polyline/getIntersectionWithPolyline.js.map +1 -0
  112. package/dist/esm/utilities/math/polyline/getSubPixelSpacingAndXYDirections.d.ts +7 -0
  113. package/dist/esm/utilities/math/polyline/getSubPixelSpacingAndXYDirections.js +65 -0
  114. package/dist/esm/utilities/math/polyline/getSubPixelSpacingAndXYDirections.js.map +1 -0
  115. package/dist/esm/utilities/math/polyline/index.d.ts +7 -0
  116. package/dist/esm/utilities/math/polyline/index.js +8 -0
  117. package/dist/esm/utilities/math/polyline/index.js.map +1 -0
  118. package/dist/esm/utilities/math/polyline/planarFreehandROIInternalTypes.d.ts +22 -0
  119. package/dist/esm/utilities/math/polyline/planarFreehandROIInternalTypes.js +2 -0
  120. package/dist/esm/utilities/math/polyline/planarFreehandROIInternalTypes.js.map +1 -0
  121. package/dist/esm/utilities/math/polyline/pointCanProjectOnLine.d.ts +3 -0
  122. package/dist/esm/utilities/math/polyline/pointCanProjectOnLine.js +33 -0
  123. package/dist/esm/utilities/math/polyline/pointCanProjectOnLine.js.map +1 -0
  124. package/dist/esm/utilities/math/polyline/pointsAreWithinCloseContourProximity.d.ts +3 -0
  125. package/dist/esm/utilities/math/polyline/pointsAreWithinCloseContourProximity.js +6 -0
  126. package/dist/esm/utilities/math/polyline/pointsAreWithinCloseContourProximity.js.map +1 -0
  127. package/dist/umd/index.js +1 -1
  128. package/dist/umd/index.js.map +1 -1
  129. package/package.json +2 -2
@@ -0,0 +1,284 @@
1
+ import { getEnabledElement } from '@cornerstonejs/core';
2
+ import { state } from '../../../store';
3
+ import { Events } from '../../../enums';
4
+ import { resetElementCursor, hideElementCursor, } from '../../../cursors/elementCursor';
5
+ import { vec3, vec2 } from 'gl-matrix';
6
+ import { polyline } from '../../../utilities/math';
7
+ import triggerAnnotationRenderForViewportIds from '../../../utilities/triggerAnnotationRenderForViewportIds';
8
+ const { addCanvasPointsToArray, getSubPixelSpacingAndXYDirections } = polyline;
9
+ function activateOpenContourEdit(evt, annotation, viewportIdsToRender) {
10
+ this.isEditingOpen = true;
11
+ const eventDetail = evt.detail;
12
+ const { currentPoints, element } = eventDetail;
13
+ const canvasPos = currentPoints.canvas;
14
+ const enabledElement = getEnabledElement(element);
15
+ const { viewport } = enabledElement;
16
+ const prevCanvasPoints = annotation.data.polyline.map(viewport.worldToCanvas);
17
+ const { spacing, xDir, yDir } = getSubPixelSpacingAndXYDirections(viewport, this.configuration.subPixelResolution);
18
+ this.editData = {
19
+ prevCanvasPoints,
20
+ editCanvasPoints: [canvasPos],
21
+ startCrossingIndex: undefined,
22
+ editIndex: 0,
23
+ };
24
+ this.commonData = {
25
+ annotation,
26
+ viewportIdsToRender,
27
+ spacing,
28
+ xDir,
29
+ yDir,
30
+ };
31
+ state.isInteractingWithTool = true;
32
+ element.addEventListener(Events.MOUSE_UP, this.mouseUpOpenContourEditCallback);
33
+ element.addEventListener(Events.MOUSE_DRAG, this.mouseDragOpenContourEditCallback);
34
+ element.addEventListener(Events.MOUSE_CLICK, this.mouseUpOpenContourEditCallback);
35
+ hideElementCursor(element);
36
+ }
37
+ function deactivateOpenContourEdit(element) {
38
+ state.isInteractingWithTool = false;
39
+ element.removeEventListener(Events.MOUSE_UP, this.mouseUpOpenContourEditCallback);
40
+ element.removeEventListener(Events.MOUSE_DRAG, this.mouseDragOpenContourEditCallback);
41
+ element.removeEventListener(Events.MOUSE_CLICK, this.mouseUpOpenContourEditCallback);
42
+ resetElementCursor(element);
43
+ }
44
+ function mouseDragOpenContourEditCallback(evt) {
45
+ const eventDetail = evt.detail;
46
+ const { currentPoints, element } = eventDetail;
47
+ const worldPos = currentPoints.world;
48
+ const canvasPos = currentPoints.canvas;
49
+ const enabledElement = getEnabledElement(element);
50
+ const { renderingEngine, viewport } = enabledElement;
51
+ const { viewportIdsToRender, xDir, yDir, spacing } = this.commonData;
52
+ const { editIndex, editCanvasPoints, startCrossingIndex } = this.editData;
53
+ const lastCanvasPoint = editCanvasPoints[editCanvasPoints.length - 1];
54
+ const lastWorldPoint = viewport.canvasToWorld(lastCanvasPoint);
55
+ const worldPosDiff = vec3.create();
56
+ vec3.subtract(worldPosDiff, worldPos, lastWorldPoint);
57
+ const xDist = Math.abs(vec3.dot(worldPosDiff, xDir));
58
+ const yDist = Math.abs(vec3.dot(worldPosDiff, yDir));
59
+ if (xDist <= spacing[0] && yDist <= spacing[1]) {
60
+ return;
61
+ }
62
+ const numPointsAdded = addCanvasPointsToArray(element, editCanvasPoints, canvasPos, this.commonData);
63
+ const currentEditIndex = editIndex + numPointsAdded;
64
+ this.editData.editIndex = currentEditIndex;
65
+ if (startCrossingIndex === undefined && editCanvasPoints.length > 1) {
66
+ this.checkForFirstCrossing(evt, false);
67
+ }
68
+ this.editData.snapIndex = this.findSnapIndex();
69
+ this.editData.fusedCanvasPoints = this.fuseEditPointsWithOpenContour(evt);
70
+ if (startCrossingIndex !== undefined &&
71
+ this.checkForSecondCrossing(evt, false)) {
72
+ this.removePointsAfterSecondCrossing(false);
73
+ this.finishEditOpenOnSecondCrossing(evt);
74
+ }
75
+ else if (this.checkIfShouldOverwriteAnEnd(evt)) {
76
+ this.openContourEditOverwriteEnd(evt);
77
+ }
78
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
79
+ }
80
+ function openContourEditOverwriteEnd(evt) {
81
+ const eventDetail = evt.detail;
82
+ const { element } = eventDetail;
83
+ const enabledElement = getEnabledElement(element);
84
+ const { viewport } = enabledElement;
85
+ const { annotation, viewportIdsToRender } = this.commonData;
86
+ const fusedCanvasPoints = this.fuseEditPointsForOpenContourEndEdit();
87
+ const worldPoints = fusedCanvasPoints.map((canvasPoint) => viewport.canvasToWorld(canvasPoint));
88
+ annotation.data.polyline = worldPoints;
89
+ annotation.data.isOpenContour = true;
90
+ annotation.data.handles.points = [
91
+ worldPoints[0],
92
+ worldPoints[worldPoints.length - 1],
93
+ ];
94
+ annotation.data.handles.activeHandleIndex = 1;
95
+ this.triggerAnnotationModified(annotation, enabledElement);
96
+ this.isEditingOpen = false;
97
+ this.editData = undefined;
98
+ this.commonData = undefined;
99
+ this.deactivateOpenContourEdit(element);
100
+ this.activateOpenContourEndEdit(evt, annotation, viewportIdsToRender);
101
+ }
102
+ function checkIfShouldOverwriteAnEnd(evt) {
103
+ const eventDetail = evt.detail;
104
+ const { currentPoints, lastPoints } = eventDetail;
105
+ const canvasPos = currentPoints.canvas;
106
+ const lastCanvasPos = lastPoints.canvas;
107
+ const { snapIndex, prevCanvasPoints, startCrossingIndex } = this.editData;
108
+ if (startCrossingIndex === undefined || snapIndex === undefined) {
109
+ return false;
110
+ }
111
+ if (snapIndex === -1) {
112
+ return true;
113
+ }
114
+ if (snapIndex !== 0 && snapIndex !== prevCanvasPoints.length - 1) {
115
+ return false;
116
+ }
117
+ const p1 = canvasPos;
118
+ const p2 = lastCanvasPos;
119
+ const p3 = prevCanvasPoints[snapIndex];
120
+ const a = vec2.create();
121
+ const b = vec2.create();
122
+ vec2.set(a, p1[0] - p2[0], p1[1] - p2[1]);
123
+ vec2.set(b, p1[0] - p3[0], p1[1] - p3[1]);
124
+ const aDotb = vec2.dot(a, b);
125
+ const magA = Math.sqrt(a[0] * a[0] + a[1] * a[1]);
126
+ const magB = Math.sqrt(b[0] * b[0] + b[1] * b[1]);
127
+ const theta = Math.acos(aDotb / (magA * magB));
128
+ if (theta < Math.PI / 2) {
129
+ return true;
130
+ }
131
+ return false;
132
+ }
133
+ function fuseEditPointsForOpenContourEndEdit() {
134
+ const { snapIndex, prevCanvasPoints, editCanvasPoints, startCrossingIndex } = this.editData;
135
+ const newCanvasPoints = [];
136
+ if (snapIndex === 0) {
137
+ for (let i = prevCanvasPoints.length - 1; i >= startCrossingIndex; i--) {
138
+ const canvasPoint = prevCanvasPoints[i];
139
+ newCanvasPoints.push([canvasPoint[0], canvasPoint[1]]);
140
+ }
141
+ }
142
+ else {
143
+ for (let i = 0; i < startCrossingIndex; i++) {
144
+ const canvasPoint = prevCanvasPoints[i];
145
+ newCanvasPoints.push([canvasPoint[0], canvasPoint[1]]);
146
+ }
147
+ }
148
+ const distanceBetweenCrossingIndexAndFirstPoint = vec2.distance(prevCanvasPoints[startCrossingIndex], editCanvasPoints[0]);
149
+ const distanceBetweenCrossingIndexAndLastPoint = vec2.distance(prevCanvasPoints[startCrossingIndex], editCanvasPoints[editCanvasPoints.length - 1]);
150
+ if (distanceBetweenCrossingIndexAndFirstPoint <
151
+ distanceBetweenCrossingIndexAndLastPoint) {
152
+ for (let i = 0; i < editCanvasPoints.length; i++) {
153
+ const canvasPoint = editCanvasPoints[i];
154
+ newCanvasPoints.push([canvasPoint[0], canvasPoint[1]]);
155
+ }
156
+ }
157
+ else {
158
+ for (let i = editCanvasPoints.length - 1; i >= 0; i--) {
159
+ const canvasPoint = editCanvasPoints[i];
160
+ newCanvasPoints.push([canvasPoint[0], canvasPoint[1]]);
161
+ }
162
+ }
163
+ return newCanvasPoints;
164
+ }
165
+ function fuseEditPointsWithOpenContour(evt) {
166
+ const { prevCanvasPoints, editCanvasPoints, startCrossingIndex, snapIndex } = this.editData;
167
+ if (startCrossingIndex === undefined || snapIndex === undefined) {
168
+ return undefined;
169
+ }
170
+ const eventDetail = evt.detail;
171
+ const { element } = eventDetail;
172
+ const augmentedEditCanvasPoints = [...editCanvasPoints];
173
+ addCanvasPointsToArray(element, augmentedEditCanvasPoints, prevCanvasPoints[snapIndex], this.commonData);
174
+ if (augmentedEditCanvasPoints.length > editCanvasPoints.length) {
175
+ augmentedEditCanvasPoints.pop();
176
+ }
177
+ let lowIndex;
178
+ let highIndex;
179
+ if (startCrossingIndex > snapIndex) {
180
+ lowIndex = snapIndex;
181
+ highIndex = startCrossingIndex;
182
+ }
183
+ else {
184
+ lowIndex = startCrossingIndex;
185
+ highIndex = snapIndex;
186
+ }
187
+ const distanceBetweenLowAndFirstPoint = vec2.distance(prevCanvasPoints[lowIndex], augmentedEditCanvasPoints[0]);
188
+ const distanceBetweenLowAndLastPoint = vec2.distance(prevCanvasPoints[lowIndex], augmentedEditCanvasPoints[augmentedEditCanvasPoints.length - 1]);
189
+ const distanceBetweenHighAndFirstPoint = vec2.distance(prevCanvasPoints[highIndex], augmentedEditCanvasPoints[0]);
190
+ const distanceBetweenHighAndLastPoint = vec2.distance(prevCanvasPoints[highIndex], augmentedEditCanvasPoints[augmentedEditCanvasPoints.length - 1]);
191
+ const pointsToRender = [];
192
+ for (let i = 0; i < lowIndex; i++) {
193
+ const canvasPoint = prevCanvasPoints[i];
194
+ pointsToRender.push([canvasPoint[0], canvasPoint[1]]);
195
+ }
196
+ const inPlaceDistance = distanceBetweenLowAndFirstPoint + distanceBetweenHighAndLastPoint;
197
+ const reverseDistance = distanceBetweenLowAndLastPoint + distanceBetweenHighAndFirstPoint;
198
+ if (inPlaceDistance < reverseDistance) {
199
+ for (let i = 0; i < augmentedEditCanvasPoints.length; i++) {
200
+ const canvasPoint = augmentedEditCanvasPoints[i];
201
+ pointsToRender.push([canvasPoint[0], canvasPoint[1]]);
202
+ }
203
+ }
204
+ else {
205
+ for (let i = augmentedEditCanvasPoints.length - 1; i >= 0; i--) {
206
+ const canvasPoint = augmentedEditCanvasPoints[i];
207
+ pointsToRender.push([canvasPoint[0], canvasPoint[1]]);
208
+ }
209
+ }
210
+ for (let i = highIndex; i < prevCanvasPoints.length; i++) {
211
+ const canvasPoint = prevCanvasPoints[i];
212
+ pointsToRender.push([canvasPoint[0], canvasPoint[1]]);
213
+ }
214
+ return pointsToRender;
215
+ }
216
+ function finishEditOpenOnSecondCrossing(evt) {
217
+ const eventDetail = evt.detail;
218
+ const { element } = eventDetail;
219
+ const enabledElement = getEnabledElement(element);
220
+ const { viewport, renderingEngine } = enabledElement;
221
+ const { annotation, viewportIdsToRender } = this.commonData;
222
+ const { fusedCanvasPoints, editCanvasPoints } = this.editData;
223
+ const worldPoints = fusedCanvasPoints.map((canvasPoint) => viewport.canvasToWorld(canvasPoint));
224
+ annotation.data.polyline = worldPoints;
225
+ annotation.data.isOpenContour = true;
226
+ annotation.data.handles.points = [
227
+ worldPoints[0],
228
+ worldPoints[worldPoints.length - 1],
229
+ ];
230
+ this.triggerAnnotationModified(annotation, enabledElement);
231
+ const lastEditCanvasPoint = editCanvasPoints.pop();
232
+ this.editData = {
233
+ prevCanvasPoints: fusedCanvasPoints,
234
+ editCanvasPoints: [lastEditCanvasPoint],
235
+ startCrossingIndex: undefined,
236
+ editIndex: 0,
237
+ };
238
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
239
+ }
240
+ function mouseUpOpenContourEditCallback(evt) {
241
+ const eventDetail = evt.detail;
242
+ const { element } = eventDetail;
243
+ const enabledElement = getEnabledElement(element);
244
+ const { viewport, renderingEngine } = enabledElement;
245
+ const { annotation, viewportIdsToRender } = this.commonData;
246
+ const { fusedCanvasPoints } = this.editData;
247
+ if (fusedCanvasPoints) {
248
+ const worldPoints = fusedCanvasPoints.map((canvasPoint) => viewport.canvasToWorld(canvasPoint));
249
+ annotation.data.polyline = worldPoints;
250
+ annotation.data.isOpenContour = true;
251
+ annotation.data.handles.points = [
252
+ worldPoints[0],
253
+ worldPoints[worldPoints.length - 1],
254
+ ];
255
+ this.triggerAnnotationModified(annotation, enabledElement);
256
+ }
257
+ this.isEditingOpen = false;
258
+ this.editData = undefined;
259
+ this.commonData = undefined;
260
+ triggerAnnotationRenderForViewportIds(renderingEngine, viewportIdsToRender);
261
+ this.deactivateOpenContourEdit(element);
262
+ }
263
+ function registerOpenContourEditLoop(toolInstance) {
264
+ toolInstance.activateOpenContourEdit =
265
+ activateOpenContourEdit.bind(toolInstance);
266
+ toolInstance.deactivateOpenContourEdit =
267
+ deactivateOpenContourEdit.bind(toolInstance);
268
+ toolInstance.mouseDragOpenContourEditCallback =
269
+ mouseDragOpenContourEditCallback.bind(toolInstance);
270
+ toolInstance.mouseUpOpenContourEditCallback =
271
+ mouseUpOpenContourEditCallback.bind(toolInstance);
272
+ toolInstance.fuseEditPointsWithOpenContour =
273
+ fuseEditPointsWithOpenContour.bind(toolInstance);
274
+ toolInstance.finishEditOpenOnSecondCrossing =
275
+ finishEditOpenOnSecondCrossing.bind(toolInstance);
276
+ toolInstance.checkIfShouldOverwriteAnEnd =
277
+ checkIfShouldOverwriteAnEnd.bind(toolInstance);
278
+ toolInstance.fuseEditPointsForOpenContourEndEdit =
279
+ fuseEditPointsForOpenContourEndEdit.bind(toolInstance);
280
+ toolInstance.openContourEditOverwriteEnd =
281
+ openContourEditOverwriteEnd.bind(toolInstance);
282
+ }
283
+ export default registerOpenContourEditLoop;
284
+ //# 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,41 @@
1
+ import { getEnabledElement } from '@cornerstonejs/core';
2
+ import { state } from '../../../store';
3
+ import { Events } from '../../../enums';
4
+ import { hideElementCursor } from '../../../cursors/elementCursor';
5
+ import { polyline } from '../../../utilities/math';
6
+ const { getSubPixelSpacingAndXYDirections } = polyline;
7
+ function activateOpenContourEndEdit(evt, annotation, viewportIdsToRender) {
8
+ this.isDrawing = true;
9
+ const eventDetail = evt.detail;
10
+ const { element } = eventDetail;
11
+ const enabledElement = getEnabledElement(element);
12
+ const { viewport } = enabledElement;
13
+ const { spacing, xDir, yDir } = getSubPixelSpacingAndXYDirections(viewport, this.configuration.subPixelResolution);
14
+ const canvasPoints = annotation.data.polyline.map(viewport.worldToCanvas);
15
+ const handleIndexGrabbed = annotation.data.handles.activeHandleIndex;
16
+ if (handleIndexGrabbed === 0) {
17
+ canvasPoints.reverse();
18
+ }
19
+ this.drawData = {
20
+ canvasPoints: canvasPoints,
21
+ polylineIndex: canvasPoints.length - 1,
22
+ };
23
+ this.commonData = {
24
+ annotation,
25
+ viewportIdsToRender,
26
+ spacing,
27
+ xDir,
28
+ yDir,
29
+ };
30
+ state.isInteractingWithTool = true;
31
+ element.addEventListener(Events.MOUSE_UP, this.mouseUpDrawCallback);
32
+ element.addEventListener(Events.MOUSE_DRAG, this.mouseDragDrawCallback);
33
+ element.addEventListener(Events.MOUSE_CLICK, this.mouseUpDrawCallback);
34
+ hideElementCursor(element);
35
+ }
36
+ function registerOpenContourEndEditLoop(toolInstance) {
37
+ toolInstance.activateOpenContourEndEdit =
38
+ activateOpenContourEndEdit.bind(toolInstance);
39
+ }
40
+ export default registerOpenContourEndEditLoop;
41
+ //# sourceMappingURL=openContourEndEditLoop.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"openContourEndEditLoop.js","sourceRoot":"","sources":["../../../../../src/tools/annotation/planarFreehandROITool/openContourEndEditLoop.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AACxD,OAAO,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AACvC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AACxC,OAAO,EAAE,iBAAiB,EAAE,MAAM,gCAAgC,CAAC;AAEnE,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AAEnD,MAAM,EAAE,iCAAiC,EAAE,GAAG,QAAQ,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,iBAAiB,CAAC,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,KAAK,CAAC,qBAAqB,GAAG,IAAI,CAAC;IAGnC,OAAO,CAAC,gBAAgB,CAAC,MAAM,CAAC,QAAQ,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IACpE,OAAO,CAAC,gBAAgB,CAAC,MAAM,CAAC,UAAU,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC;IACxE,OAAO,CAAC,gBAAgB,CAAC,MAAM,CAAC,WAAW,EAAE,IAAI,CAAC,mBAAmB,CAAC,CAAC;IAEvE,iBAAiB,CAAC,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,eAAe,8BAA8B,CAAC"}
@@ -0,0 +1,2 @@
1
+ declare function registerRenderMethods(toolInstance: any): void;
2
+ export default registerRenderMethods;
@@ -0,0 +1,97 @@
1
+ import { Settings } from '@cornerstonejs/core';
2
+ import { drawHandles as drawHandlesSvg, drawPolyline as drawPolylineSvg, } from '../../../drawingSvg';
3
+ import { polyline } from '../../../utilities/math';
4
+ const { pointsAreWithinCloseContourProximity } = polyline;
5
+ function _getRenderingOptions(annotation) {
6
+ const settings = Settings.getObjectSettings(annotation, this.getToolName());
7
+ const lineWidth = this.getStyle(settings, 'lineWidth', annotation);
8
+ const color = this.getStyle(settings, 'color', annotation);
9
+ const isOpenContour = annotation.data.isOpenContour;
10
+ const options = {
11
+ color: color === undefined ? undefined : color,
12
+ width: lineWidth === undefined ? undefined : lineWidth,
13
+ connectLastToFirst: !isOpenContour,
14
+ };
15
+ return options;
16
+ }
17
+ function renderContour(enabledElement, svgDrawingHelper, annotation) {
18
+ if (annotation.data.isOpenContour) {
19
+ this.renderOpenContour(enabledElement, svgDrawingHelper, annotation);
20
+ }
21
+ else {
22
+ this.renderClosedContour(enabledElement, svgDrawingHelper, annotation);
23
+ }
24
+ }
25
+ function renderClosedContour(enabledElement, svgDrawingHelper, annotation) {
26
+ const { viewport } = enabledElement;
27
+ const options = this._getRenderingOptions(annotation);
28
+ const canvasPoints = annotation.data.polyline.map((worldPos) => viewport.worldToCanvas(worldPos));
29
+ const polylineUID = '1';
30
+ drawPolylineSvg(svgDrawingHelper, annotation.annotationUID, polylineUID, canvasPoints, options);
31
+ }
32
+ function renderOpenContour(enabledElement, svgDrawingHelper, annotation) {
33
+ const { viewport } = enabledElement;
34
+ const options = this._getRenderingOptions(annotation);
35
+ const canvasPoints = annotation.data.polyline.map((worldPos) => viewport.worldToCanvas(worldPos));
36
+ const polylineUID = '1';
37
+ drawPolylineSvg(svgDrawingHelper, annotation.annotationUID, polylineUID, canvasPoints, options);
38
+ const activeHandleIndex = annotation.data.handles.activeHandleIndex;
39
+ if (activeHandleIndex !== null) {
40
+ const handleGroupUID = '0';
41
+ const indexOfCanvasPoints = activeHandleIndex === 0 ? 0 : canvasPoints.length - 1;
42
+ const handlePoint = canvasPoints[indexOfCanvasPoints];
43
+ drawHandlesSvg(svgDrawingHelper, annotation.annotationUID, handleGroupUID, [handlePoint], { color: options.color });
44
+ }
45
+ }
46
+ function renderContourBeingDrawn(enabledElement, svgDrawingHelper, annotation) {
47
+ const options = this._getRenderingOptions(annotation);
48
+ const { allowOpenContours } = this.configuration;
49
+ const { canvasPoints } = this.drawData;
50
+ options.connectLastToFirst = false;
51
+ drawPolylineSvg(svgDrawingHelper, annotation.annotationUID, '1', canvasPoints, options);
52
+ if (allowOpenContours) {
53
+ const firstPoint = canvasPoints[0];
54
+ const lastPoint = canvasPoints[canvasPoints.length - 1];
55
+ if (pointsAreWithinCloseContourProximity(firstPoint, lastPoint, this.configuration.closeContourProximity)) {
56
+ drawPolylineSvg(svgDrawingHelper, annotation.annotationUID, '2', [lastPoint, firstPoint], options);
57
+ }
58
+ else {
59
+ const handleGroupUID = '0';
60
+ drawHandlesSvg(svgDrawingHelper, annotation.annotationUID, handleGroupUID, [firstPoint], { color: options.color, handleRadius: 2 });
61
+ }
62
+ }
63
+ }
64
+ function renderClosedContourBeingEdited(enabledElement, svgDrawingHelper, annotation) {
65
+ const { fusedCanvasPoints } = this.editData;
66
+ if (fusedCanvasPoints === undefined) {
67
+ this.renderClosedContour(enabledElement, svgDrawingHelper, annotation);
68
+ return;
69
+ }
70
+ const options = this._getRenderingOptions(annotation);
71
+ const polylineUIDToRender = 'preview-1';
72
+ drawPolylineSvg(svgDrawingHelper, annotation.annotationUID, polylineUIDToRender, fusedCanvasPoints, options);
73
+ }
74
+ function renderOpenContourBeingEdited(enabledElement, svgDrawingHelper, annotation) {
75
+ const { fusedCanvasPoints } = this.editData;
76
+ if (fusedCanvasPoints === undefined) {
77
+ this.renderOpenContour(enabledElement, svgDrawingHelper, annotation);
78
+ return;
79
+ }
80
+ const options = this._getRenderingOptions(annotation);
81
+ const polylineUIDToRender = 'preview-1';
82
+ drawPolylineSvg(svgDrawingHelper, annotation.annotationUID, polylineUIDToRender, fusedCanvasPoints, options);
83
+ }
84
+ function registerRenderMethods(toolInstance) {
85
+ toolInstance.renderContour = renderContour.bind(toolInstance);
86
+ toolInstance.renderClosedContour = renderClosedContour.bind(toolInstance);
87
+ toolInstance.renderOpenContour = renderOpenContour.bind(toolInstance);
88
+ toolInstance.renderContourBeingDrawn =
89
+ renderContourBeingDrawn.bind(toolInstance);
90
+ toolInstance.renderClosedContourBeingEdited =
91
+ renderClosedContourBeingEdited.bind(toolInstance);
92
+ toolInstance.renderOpenContourBeingEdited =
93
+ renderOpenContourBeingEdited.bind(toolInstance);
94
+ toolInstance._getRenderingOptions = _getRenderingOptions.bind(toolInstance);
95
+ }
96
+ export default registerRenderMethods;
97
+ //# sourceMappingURL=renderMethods.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"renderMethods.js","sourceRoot":"","sources":["../../../../../src/tools/annotation/planarFreehandROITool/renderMethods.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAE/C,OAAO,EACL,WAAW,IAAI,cAAc,EAC7B,YAAY,IAAI,eAAe,GAChC,MAAM,qBAAqB,CAAC;AAC7B,OAAO,EAAE,QAAQ,EAAE,MAAM,yBAAyB,CAAC;AAGnD,MAAM,EAAE,oCAAoC,EAAE,GAAG,QAAQ,CAAC;AAQ1D,SAAS,oBAAoB,CAC3B,UAAuC;IAEvC,MAAM,QAAQ,GAAG,QAAQ,CAAC,iBAAiB,CAAC,UAAU,EAAE,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;IAE5E,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,WAAW,EAAE,UAAU,CAAC,CAAC;IACnE,MAAM,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,OAAO,EAAE,UAAU,CAAC,CAAC;IAE3D,MAAM,aAAa,GAAG,UAAU,CAAC,IAAI,CAAC,aAAa,CAAC;IAEpD,MAAM,OAAO,GAAG;QACd,KAAK,EAAE,KAAK,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAS,KAAK;QACtD,KAAK,EAAE,SAAS,KAAK,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAS,SAAS;QAC9D,kBAAkB,EAAE,CAAC,aAAa;KACnC,CAAC;IAEF,OAAO,OAAO,CAAC;AACjB,CAAC;AAKD,SAAS,aAAa,CACpB,cAAqC,EACrC,gBAAqB,EACrB,UAAuC;IAEvC,IAAI,UAAU,CAAC,IAAI,CAAC,aAAa,EAAE;QACjC,IAAI,CAAC,iBAAiB,CAAC,cAAc,EAAE,gBAAgB,EAAE,UAAU,CAAC,CAAC;KACtE;SAAM;QACL,IAAI,CAAC,mBAAmB,CAAC,cAAc,EAAE,gBAAgB,EAAE,UAAU,CAAC,CAAC;KACxE;AACH,CAAC;AAKD,SAAS,mBAAmB,CAC1B,cAAqC,EACrC,gBAAqB,EACrB,UAAuC;IAEvC,MAAM,EAAE,QAAQ,EAAE,GAAG,cAAc,CAAC;IACpC,MAAM,OAAO,GAAG,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAOtD,MAAM,YAAY,GAAG,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAC7D,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CACjC,CAAC;IAEF,MAAM,WAAW,GAAG,GAAG,CAAC;IAExB,eAAe,CACb,gBAAgB,EAChB,UAAU,CAAC,aAAa,EACxB,WAAW,EACX,YAAY,EACZ,OAAO,CACR,CAAC;AACJ,CAAC;AAKD,SAAS,iBAAiB,CACxB,cAAqC,EACrC,gBAAqB,EACrB,UAAuC;IAEvC,MAAM,EAAE,QAAQ,EAAE,GAAG,cAAc,CAAC;IACpC,MAAM,OAAO,GAAG,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAEtD,MAAM,YAAY,GAAG,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAC7D,QAAQ,CAAC,aAAa,CAAC,QAAQ,CAAC,CACjC,CAAC;IAEF,MAAM,WAAW,GAAG,GAAG,CAAC;IAExB,eAAe,CACb,gBAAgB,EAChB,UAAU,CAAC,aAAa,EACxB,WAAW,EACX,YAAY,EACZ,OAAO,CACR,CAAC;IAEF,MAAM,iBAAiB,GAAG,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,iBAAiB,CAAC;IAEpE,IAAI,iBAAiB,KAAK,IAAI,EAAE;QAE9B,MAAM,cAAc,GAAG,GAAG,CAAC;QAI3B,MAAM,mBAAmB,GACvB,iBAAiB,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC;QAExD,MAAM,WAAW,GAAG,YAAY,CAAC,mBAAmB,CAAC,CAAC;QAEtD,cAAc,CACZ,gBAAgB,EAChB,UAAU,CAAC,aAAa,EACxB,cAAc,EACd,CAAC,WAAW,CAAC,EACb,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,CACzB,CAAC;KACH;AACH,CAAC;AAMD,SAAS,uBAAuB,CAC9B,cAAqC,EACrC,gBAAqB,EACrB,UAAuC;IAEvC,MAAM,OAAO,GAAG,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAEtD,MAAM,EAAE,iBAAiB,EAAE,GAAG,IAAI,CAAC,aAAa,CAAC;IACjD,MAAM,EAAE,YAAY,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC;IAIvC,OAAO,CAAC,kBAAkB,GAAG,KAAK,CAAC;IAEnC,eAAe,CACb,gBAAgB,EAChB,UAAU,CAAC,aAAa,EACxB,GAAG,EACH,YAAY,EACZ,OAAO,CACR,CAAC;IAEF,IAAI,iBAAiB,EAAE;QACrB,MAAM,UAAU,GAAG,YAAY,CAAC,CAAC,CAAC,CAAC;QACnC,MAAM,SAAS,GAAG,YAAY,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAGxD,IACE,oCAAoC,CAClC,UAAU,EACV,SAAS,EACT,IAAI,CAAC,aAAa,CAAC,qBAAqB,CACzC,EACD;YAEA,eAAe,CACb,gBAAgB,EAChB,UAAU,CAAC,aAAa,EACxB,GAAG,EACH,CAAC,SAAS,EAAE,UAAU,CAAC,EACvB,OAAO,CACR,CAAC;SACH;aAAM;YAEL,MAAM,cAAc,GAAG,GAAG,CAAC;YAE3B,cAAc,CACZ,gBAAgB,EAChB,UAAU,CAAC,aAAa,EACxB,cAAc,EACd,CAAC,UAAU,CAAC,EACZ,EAAE,KAAK,EAAE,OAAO,CAAC,KAAK,EAAE,YAAY,EAAE,CAAC,EAAE,CAC1C,CAAC;SACH;KACF;AACH,CAAC;AAKD,SAAS,8BAA8B,CACrC,cAAc,EACd,gBAAgB,EAChB,UAAU;IAEV,MAAM,EAAE,iBAAiB,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC;IAE5C,IAAI,iBAAiB,KAAK,SAAS,EAAE;QAEnC,IAAI,CAAC,mBAAmB,CAAC,cAAc,EAAE,gBAAgB,EAAE,UAAU,CAAC,CAAC;QAEvE,OAAO;KACR;IAED,MAAM,OAAO,GAAG,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAEtD,MAAM,mBAAmB,GAAG,WAAW,CAAC;IAExC,eAAe,CACb,gBAAgB,EAChB,UAAU,CAAC,aAAa,EACxB,mBAAmB,EACnB,iBAAiB,EACjB,OAAO,CACR,CAAC;AACJ,CAAC;AAKD,SAAS,4BAA4B,CACnC,cAAqC,EACrC,gBAAqB,EACrB,UAAuC;IAEvC,MAAM,EAAE,iBAAiB,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC;IAE5C,IAAI,iBAAiB,KAAK,SAAS,EAAE;QAEnC,IAAI,CAAC,iBAAiB,CAAC,cAAc,EAAE,gBAAgB,EAAE,UAAU,CAAC,CAAC;QAErE,OAAO;KACR;IAED,MAAM,OAAO,GAAG,IAAI,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC;IAEtD,MAAM,mBAAmB,GAAG,WAAW,CAAC;IAExC,eAAe,CACb,gBAAgB,EAChB,UAAU,CAAC,aAAa,EACxB,mBAAmB,EACnB,iBAAiB,EACjB,OAAO,CACR,CAAC;AACJ,CAAC;AAKD,SAAS,qBAAqB,CAAC,YAAY;IACzC,YAAY,CAAC,aAAa,GAAG,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC9D,YAAY,CAAC,mBAAmB,GAAG,mBAAmB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAC1E,YAAY,CAAC,iBAAiB,GAAG,iBAAiB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAEtE,YAAY,CAAC,uBAAuB;QAClC,uBAAuB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAE7C,YAAY,CAAC,8BAA8B;QACzC,8BAA8B,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IACpD,YAAY,CAAC,4BAA4B;QACvC,4BAA4B,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;IAClD,YAAY,CAAC,oBAAoB,GAAG,oBAAoB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;AAC9E,CAAC;AAED,eAAe,qBAAqB,CAAC"}
@@ -12,6 +12,7 @@ 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';
15
16
  import ArrowTool from './annotation/ArrowTool';
16
17
  import SegmentationDisplayTool from './displayTools/SegmentationDisplayTool';
17
18
  import RectangleScissorsTool from './segmentation/RectangleScissorsTool';
@@ -20,4 +21,4 @@ import SphereScissorsTool from './segmentation/SphereScissorsTool';
20
21
  import RectangleROIThresholdTool from './segmentation/RectangleROIThresholdTool';
21
22
  import RectangleROIStartEndThresholdTool from './segmentation/RectangleROIStartEndThresholdTool';
22
23
  import BrushTool from './segmentation/BrushTool';
23
- export { BaseTool, AnnotationTool, PanTool, WindowLevelTool, StackScrollTool, StackScrollMouseWheelTool, ZoomTool, VolumeRotateMouseWheelTool, MIPJumpToClickTool, CrosshairsTool, BidirectionalTool, LengthTool, ProbeTool, RectangleROITool, EllipticalROITool, ArrowTool, 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, };
@@ -12,6 +12,7 @@ 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';
15
16
  import ArrowTool from './annotation/ArrowTool';
16
17
  import SegmentationDisplayTool from './displayTools/SegmentationDisplayTool';
17
18
  import RectangleScissorsTool from './segmentation/RectangleScissorsTool';
@@ -20,5 +21,5 @@ import SphereScissorsTool from './segmentation/SphereScissorsTool';
20
21
  import RectangleROIThresholdTool from './segmentation/RectangleROIThresholdTool';
21
22
  import RectangleROIStartEndThresholdTool from './segmentation/RectangleROIStartEndThresholdTool';
22
23
  import BrushTool from './segmentation/BrushTool';
23
- export { BaseTool, AnnotationTool, PanTool, WindowLevelTool, StackScrollTool, StackScrollMouseWheelTool, ZoomTool, VolumeRotateMouseWheelTool, MIPJumpToClickTool, CrosshairsTool, BidirectionalTool, LengthTool, ProbeTool, RectangleROITool, EllipticalROITool, ArrowTool, 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, };
24
25
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tools/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AAClD,OAAO,OAAO,MAAM,WAAW,CAAC;AAChC,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,yBAAyB,MAAM,iCAAiC,CAAC;AACxE,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,0BAA0B,MAAM,8BAA8B,CAAC;AACtE,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAE9C,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,UAAU,MAAM,yBAAyB,CAAC;AACjD,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAC/C,OAAO,gBAAgB,MAAM,+BAA+B,CAAC;AAC7D,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAG/C,OAAO,uBAAuB,MAAM,wCAAwC,CAAC;AAG7E,OAAO,qBAAqB,MAAM,sCAAsC,CAAC;AACzE,OAAO,kBAAkB,MAAM,mCAAmC,CAAC;AACnE,OAAO,kBAAkB,MAAM,mCAAmC,CAAC;AACnE,OAAO,yBAAyB,MAAM,0CAA0C,CAAC;AACjF,OAAO,iCAAiC,MAAM,kDAAkD,CAAC;AACjG,OAAO,SAAS,MAAM,0BAA0B,CAAC;AAEjD,OAAO,EAEL,QAAQ,EACR,cAAc,EAEd,OAAO,EACP,eAAe,EACf,eAAe,EACf,yBAAyB,EACzB,QAAQ,EACR,0BAA0B,EAC1B,kBAAkB,EAElB,cAAc,EACd,iBAAiB,EACjB,UAAU,EACV,SAAS,EACT,gBAAgB,EAChB,iBAAiB,EACjB,SAAS,EAET,uBAAuB,EAEvB,qBAAqB,EACrB,kBAAkB,EAClB,kBAAkB,EAClB,yBAAyB,EACzB,iCAAiC,EACjC,SAAS,GACV,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/tools/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,cAAc,EAAE,MAAM,QAAQ,CAAC;AAClD,OAAO,OAAO,MAAM,WAAW,CAAC;AAChC,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,eAAe,MAAM,mBAAmB,CAAC;AAChD,OAAO,yBAAyB,MAAM,iCAAiC,CAAC;AACxE,OAAO,QAAQ,MAAM,YAAY,CAAC;AAClC,OAAO,0BAA0B,MAAM,8BAA8B,CAAC;AACtE,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAE9C,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,UAAU,MAAM,yBAAyB,CAAC;AACjD,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAC/C,OAAO,gBAAgB,MAAM,+BAA+B,CAAC;AAC7D,OAAO,iBAAiB,MAAM,gCAAgC,CAAC;AAC/D,OAAO,qBAAqB,MAAM,oCAAoC,CAAC;AACvE,OAAO,SAAS,MAAM,wBAAwB,CAAC;AAG/C,OAAO,uBAAuB,MAAM,wCAAwC,CAAC;AAG7E,OAAO,qBAAqB,MAAM,sCAAsC,CAAC;AACzE,OAAO,kBAAkB,MAAM,mCAAmC,CAAC;AACnE,OAAO,kBAAkB,MAAM,mCAAmC,CAAC;AACnE,OAAO,yBAAyB,MAAM,0CAA0C,CAAC;AACjF,OAAO,iCAAiC,MAAM,kDAAkD,CAAC;AACjG,OAAO,SAAS,MAAM,0BAA0B,CAAC;AAEjD,OAAO,EAEL,QAAQ,EACR,cAAc,EAEd,OAAO,EACP,eAAe,EACf,eAAe,EACf,yBAAyB,EACzB,QAAQ,EACR,0BAA0B,EAC1B,kBAAkB,EAElB,cAAc,EACd,iBAAiB,EACjB,UAAU,EACV,SAAS,EACT,gBAAgB,EAChB,iBAAiB,EACjB,qBAAqB,EACrB,SAAS,EAET,uBAAuB,EAEvB,qBAAqB,EACrB,kBAAkB,EAClB,kBAAkB,EAClB,yBAAyB,EACzB,iCAAiC,EACjC,SAAS,GACV,CAAC"}
@@ -30,6 +30,7 @@ declare type Annotation = {
30
30
  };
31
31
  [key: string]: any;
32
32
  };
33
+ [key: string]: any;
33
34
  cachedStats?: unknown;
34
35
  };
35
36
  };
@@ -165,6 +165,37 @@ export interface RectangleROIStartEndThresholdAnnotation extends Annotation {
165
165
  };
166
166
  };
167
167
  }
168
+ export interface PlanarFreehandROIAnnotation extends Annotation {
169
+ metadata: {
170
+ cameraPosition?: Types.Point3;
171
+ cameraFocalPoint?: Types.Point3;
172
+ viewPlaneNormal?: Types.Point3;
173
+ viewUp?: Types.Point3;
174
+ annotationUID?: string;
175
+ FrameOfReferenceUID: string;
176
+ referencedImageId?: string;
177
+ toolName: string;
178
+ };
179
+ data: {
180
+ polyline: Types.Point3[];
181
+ label?: string;
182
+ isOpenContour?: boolean;
183
+ handles: {
184
+ points: Types.Point3[];
185
+ activeHandleIndex: number | null;
186
+ textBox: {
187
+ hasMoved: boolean;
188
+ worldPosition: Types.Point3;
189
+ worldBoundingBox: {
190
+ topLeft: Types.Point3;
191
+ topRight: Types.Point3;
192
+ bottomLeft: Types.Point3;
193
+ bottomRight: Types.Point3;
194
+ };
195
+ };
196
+ };
197
+ };
198
+ }
168
199
  export interface ArrowAnnotation extends Annotation {
169
200
  data: {
170
201
  text: string;
@@ -2,4 +2,5 @@ import * as vec2 from './vec2';
2
2
  import * as ellipse from './ellipse';
3
3
  import * as lineSegment from './line';
4
4
  import * as rectangle from './rectangle';
5
- export { vec2, ellipse, lineSegment, rectangle };
5
+ import * as polyline from './polyline';
6
+ export { vec2, ellipse, lineSegment, rectangle, polyline };
@@ -2,5 +2,6 @@ import * as vec2 from './vec2';
2
2
  import * as ellipse from './ellipse';
3
3
  import * as lineSegment from './line';
4
4
  import * as rectangle from './rectangle';
5
- export { vec2, ellipse, lineSegment, rectangle };
5
+ import * as polyline from './polyline';
6
+ export { vec2, ellipse, lineSegment, rectangle, polyline };
6
7
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/math/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,IAAI,MAAM,QAAQ,CAAC;AAC/B,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,WAAW,MAAM,QAAQ,CAAC;AACtC,OAAO,KAAK,SAAS,MAAM,aAAa,CAAC;AAEzC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/utilities/math/index.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,IAAI,MAAM,QAAQ,CAAC;AAC/B,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC;AACrC,OAAO,KAAK,WAAW,MAAM,QAAQ,CAAC;AACtC,OAAO,KAAK,SAAS,MAAM,aAAa,CAAC;AACzC,OAAO,KAAK,QAAQ,MAAM,YAAY,CAAC;AAEvC,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,QAAQ,EAAE,CAAC"}
@@ -0,0 +1,4 @@
1
+ import type { Types } from '@cornerstonejs/core';
2
+ import { PlanarFreehandROICommonData } from './planarFreehandROIInternalTypes';
3
+ declare const addCanvasPointsToArray: (element: HTMLDivElement, canvasPoints: Types.Point2[], newCanvasPoint: Types.Point2, commonData: PlanarFreehandROICommonData) => number;
4
+ export default addCanvasPointsToArray;
@@ -0,0 +1,34 @@
1
+ import { getEnabledElement } from '@cornerstonejs/core';
2
+ import { vec2, vec3 } from 'gl-matrix';
3
+ const addCanvasPointsToArray = (element, canvasPoints, newCanvasPoint, commonData) => {
4
+ const { xDir, yDir, spacing } = commonData;
5
+ const enabledElement = getEnabledElement(element);
6
+ const { viewport } = enabledElement;
7
+ const lastWorldPos = viewport.canvasToWorld(canvasPoints[canvasPoints.length - 1]);
8
+ const newWorldPos = viewport.canvasToWorld(newCanvasPoint);
9
+ const worldPosDiff = vec3.create();
10
+ vec3.subtract(worldPosDiff, newWorldPos, lastWorldPos);
11
+ const xDist = Math.abs(vec3.dot(worldPosDiff, xDir));
12
+ const yDist = Math.abs(vec3.dot(worldPosDiff, yDir));
13
+ const numPointsToAdd = Math.max(Math.floor(xDist / spacing[0]), Math.floor(yDist / spacing[0]));
14
+ if (numPointsToAdd > 1) {
15
+ const lastCanvasPoint = canvasPoints[canvasPoints.length - 1];
16
+ const canvasDist = vec2.dist(lastCanvasPoint, newCanvasPoint);
17
+ const canvasDir = vec2.create();
18
+ vec2.subtract(canvasDir, newCanvasPoint, lastCanvasPoint);
19
+ vec2.set(canvasDir, canvasDir[0] / canvasDist, canvasDir[1] / canvasDist);
20
+ const distPerPoint = canvasDist / numPointsToAdd;
21
+ for (let i = 1; i <= numPointsToAdd; i++) {
22
+ canvasPoints.push([
23
+ lastCanvasPoint[0] + distPerPoint * canvasDir[0] * i,
24
+ lastCanvasPoint[1] + distPerPoint * canvasDir[1] * i,
25
+ ]);
26
+ }
27
+ }
28
+ else {
29
+ canvasPoints.push(newCanvasPoint);
30
+ }
31
+ return numPointsToAdd;
32
+ };
33
+ export default addCanvasPointsToArray;
34
+ //# sourceMappingURL=addCanvasPointsToArray.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"addCanvasPointsToArray.js","sourceRoot":"","sources":["../../../../../src/utilities/math/polyline/addCanvasPointsToArray.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC;AAExD,OAAO,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAMvC,MAAM,sBAAsB,GAAG,CAC7B,OAAuB,EACvB,YAA4B,EAC5B,cAA4B,EAC5B,UAAuC,EAC/B,EAAE;IACV,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC;IAC3C,MAAM,cAAc,GAAG,iBAAiB,CAAC,OAAO,CAAC,CAAC;IAClD,MAAM,EAAE,QAAQ,EAAE,GAAG,cAAc,CAAC;IAEpC,MAAM,YAAY,GAAG,QAAQ,CAAC,aAAa,CACzC,YAAY,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CACtC,CAAC;IACF,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,cAAc,CAAC,CAAC;IAE3D,MAAM,YAAY,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;IAEnC,IAAI,CAAC,QAAQ,CAAC,YAAY,EAAE,WAAW,EAAE,YAAY,CAAC,CAAC;IAEvD,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC,CAAC;IACrD,MAAM,KAAK,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,YAAY,EAAE,IAAI,CAAC,CAAC,CAAC;IAErD,MAAM,cAAc,GAAG,IAAI,CAAC,GAAG,CAC7B,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,EAC9B,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,CAC/B,CAAC;IAEF,IAAI,cAAc,GAAG,CAAC,EAAE;QACtB,MAAM,eAAe,GAAG,YAAY,CAAC,YAAY,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;QAE9D,MAAM,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,cAAc,CAAC,CAAC;QAE9D,MAAM,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;QAEhC,IAAI,CAAC,QAAQ,CAAC,SAAS,EAAE,cAAc,EAAE,eAAe,CAAC,CAAC;QAE1D,IAAI,CAAC,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC;QAE1E,MAAM,YAAY,GAAG,UAAU,GAAG,cAAc,CAAC;QAEjD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,cAAc,EAAE,CAAC,EAAE,EAAE;YACxC,YAAY,CAAC,IAAI,CAAC;gBAChB,eAAe,CAAC,CAAC,CAAC,GAAG,YAAY,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC;gBACpD,eAAe,CAAC,CAAC,CAAC,GAAG,YAAY,GAAG,SAAS,CAAC,CAAC,CAAC,GAAG,CAAC;aACrD,CAAC,CAAC;SACJ;KACF;SAAM;QACL,YAAY,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;KACnC;IAED,OAAO,cAAc,CAAC;AACxB,CAAC,CAAC;AAEF,eAAe,sBAAsB,CAAC"}
@@ -0,0 +1,2 @@
1
+ import type { Types } from '@cornerstonejs/core';
2
+ export default function calculateAreaOfPoints(points: Types.Point2[]): number;