@cornerstonejs/tools 0.30.6 → 0.31.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 (105) hide show
  1. package/dist/cjs/drawingSvg/getSvgDrawingHelper.js +3 -1
  2. package/dist/cjs/drawingSvg/getSvgDrawingHelper.js.map +1 -1
  3. package/dist/cjs/index.d.ts +2 -2
  4. package/dist/cjs/index.js +2 -1
  5. package/dist/cjs/index.js.map +1 -1
  6. package/dist/cjs/store/ToolGroupManager/ToolGroup.d.ts +4 -1
  7. package/dist/cjs/store/ToolGroupManager/ToolGroup.js +90 -29
  8. package/dist/cjs/store/ToolGroupManager/ToolGroup.js.map +1 -1
  9. package/dist/cjs/store/state.d.ts +4 -6
  10. package/dist/cjs/tools/base/BaseTool.d.ts +1 -1
  11. package/dist/cjs/tools/index.d.ts +2 -1
  12. package/dist/cjs/tools/index.js +3 -1
  13. package/dist/cjs/tools/index.js.map +1 -1
  14. package/dist/cjs/tools/segmentation/BrushTool.d.ts +9 -5
  15. package/dist/cjs/tools/segmentation/BrushTool.js +95 -115
  16. package/dist/cjs/tools/segmentation/BrushTool.js.map +1 -1
  17. package/dist/cjs/tools/segmentation/PaintFillTool.d.ts +12 -0
  18. package/dist/cjs/tools/segmentation/PaintFillTool.js +213 -0
  19. package/dist/cjs/tools/segmentation/PaintFillTool.js.map +1 -0
  20. package/dist/cjs/tools/segmentation/strategies/eraseCircle.d.ts +15 -0
  21. package/dist/cjs/tools/segmentation/strategies/eraseCircle.js +10 -0
  22. package/dist/cjs/tools/segmentation/strategies/eraseCircle.js.map +1 -0
  23. package/dist/cjs/tools/segmentation/strategies/eraseSphere.d.ts +13 -0
  24. package/dist/cjs/tools/segmentation/strategies/eraseSphere.js +12 -0
  25. package/dist/cjs/tools/segmentation/strategies/eraseSphere.js.map +1 -0
  26. package/dist/cjs/tools/segmentation/strategies/fillCircle.d.ts +3 -0
  27. package/dist/cjs/tools/segmentation/strategies/fillCircle.js +41 -12
  28. package/dist/cjs/tools/segmentation/strategies/fillCircle.js.map +1 -1
  29. package/dist/cjs/types/FloodFillTypes.d.ts +15 -0
  30. package/dist/cjs/types/FloodFillTypes.js +3 -0
  31. package/dist/cjs/types/FloodFillTypes.js.map +1 -0
  32. package/dist/cjs/types/IToolClassReference.d.ts +3 -0
  33. package/dist/cjs/types/IToolClassReference.js +3 -0
  34. package/dist/cjs/types/IToolClassReference.js.map +1 -0
  35. package/dist/cjs/types/IToolGroup.d.ts +3 -0
  36. package/dist/cjs/types/index.d.ts +3 -1
  37. package/dist/cjs/utilities/segmentation/brushSizeForToolGroup.d.ts +2 -0
  38. package/dist/cjs/utilities/segmentation/brushSizeForToolGroup.js +49 -0
  39. package/dist/cjs/utilities/segmentation/brushSizeForToolGroup.js.map +1 -0
  40. package/dist/cjs/utilities/segmentation/brushThresholdForToolGroup.d.ts +3 -0
  41. package/dist/cjs/utilities/segmentation/brushThresholdForToolGroup.js +49 -0
  42. package/dist/cjs/utilities/segmentation/brushThresholdForToolGroup.js.map +1 -0
  43. package/dist/cjs/utilities/segmentation/floodFill.d.ts +3 -0
  44. package/dist/cjs/utilities/segmentation/floodFill.js +131 -0
  45. package/dist/cjs/utilities/segmentation/floodFill.js.map +1 -0
  46. package/dist/cjs/utilities/segmentation/index.d.ts +4 -1
  47. package/dist/cjs/utilities/segmentation/index.js +9 -1
  48. package/dist/cjs/utilities/segmentation/index.js.map +1 -1
  49. package/dist/cjs/utilities/segmentation/utilities.d.ts +2 -0
  50. package/dist/cjs/utilities/segmentation/utilities.js +21 -0
  51. package/dist/cjs/utilities/segmentation/utilities.js.map +1 -0
  52. package/dist/esm/drawingSvg/getSvgDrawingHelper.js +3 -1
  53. package/dist/esm/drawingSvg/getSvgDrawingHelper.js.map +1 -1
  54. package/dist/esm/index.d.ts +2 -2
  55. package/dist/esm/index.js +2 -2
  56. package/dist/esm/index.js.map +1 -1
  57. package/dist/esm/store/ToolGroupManager/ToolGroup.d.ts +4 -1
  58. package/dist/esm/store/ToolGroupManager/ToolGroup.js +90 -29
  59. package/dist/esm/store/ToolGroupManager/ToolGroup.js.map +1 -1
  60. package/dist/esm/store/state.d.ts +4 -6
  61. package/dist/esm/tools/base/BaseTool.d.ts +1 -1
  62. package/dist/esm/tools/index.d.ts +2 -1
  63. package/dist/esm/tools/index.js +2 -1
  64. package/dist/esm/tools/index.js.map +1 -1
  65. package/dist/esm/tools/segmentation/BrushTool.d.ts +9 -5
  66. package/dist/esm/tools/segmentation/BrushTool.js +98 -119
  67. package/dist/esm/tools/segmentation/BrushTool.js.map +1 -1
  68. package/dist/esm/tools/segmentation/PaintFillTool.d.ts +12 -0
  69. package/dist/esm/tools/segmentation/PaintFillTool.js +210 -0
  70. package/dist/esm/tools/segmentation/PaintFillTool.js.map +1 -0
  71. package/dist/esm/tools/segmentation/strategies/eraseCircle.d.ts +15 -0
  72. package/dist/esm/tools/segmentation/strategies/eraseCircle.js +9 -0
  73. package/dist/esm/tools/segmentation/strategies/eraseCircle.js.map +1 -0
  74. package/dist/esm/tools/segmentation/strategies/eraseSphere.d.ts +13 -0
  75. package/dist/esm/tools/segmentation/strategies/eraseSphere.js +8 -0
  76. package/dist/esm/tools/segmentation/strategies/eraseSphere.js.map +1 -0
  77. package/dist/esm/tools/segmentation/strategies/fillCircle.d.ts +3 -0
  78. package/dist/esm/tools/segmentation/strategies/fillCircle.js +38 -10
  79. package/dist/esm/tools/segmentation/strategies/fillCircle.js.map +1 -1
  80. package/dist/esm/types/FloodFillTypes.d.ts +15 -0
  81. package/dist/esm/types/FloodFillTypes.js +2 -0
  82. package/dist/esm/types/FloodFillTypes.js.map +1 -0
  83. package/dist/esm/types/IToolClassReference.d.ts +3 -0
  84. package/dist/esm/types/IToolClassReference.js +2 -0
  85. package/dist/esm/types/IToolClassReference.js.map +1 -0
  86. package/dist/esm/types/IToolGroup.d.ts +3 -0
  87. package/dist/esm/types/index.d.ts +3 -1
  88. package/dist/esm/utilities/segmentation/brushSizeForToolGroup.d.ts +2 -0
  89. package/dist/esm/utilities/segmentation/brushSizeForToolGroup.js +41 -0
  90. package/dist/esm/utilities/segmentation/brushSizeForToolGroup.js.map +1 -0
  91. package/dist/esm/utilities/segmentation/brushThresholdForToolGroup.d.ts +3 -0
  92. package/dist/esm/utilities/segmentation/brushThresholdForToolGroup.js +41 -0
  93. package/dist/esm/utilities/segmentation/brushThresholdForToolGroup.js.map +1 -0
  94. package/dist/esm/utilities/segmentation/floodFill.d.ts +3 -0
  95. package/dist/esm/utilities/segmentation/floodFill.js +128 -0
  96. package/dist/esm/utilities/segmentation/floodFill.js.map +1 -0
  97. package/dist/esm/utilities/segmentation/index.d.ts +4 -1
  98. package/dist/esm/utilities/segmentation/index.js +4 -1
  99. package/dist/esm/utilities/segmentation/index.js.map +1 -1
  100. package/dist/esm/utilities/segmentation/utilities.d.ts +2 -0
  101. package/dist/esm/utilities/segmentation/utilities.js +15 -0
  102. package/dist/esm/utilities/segmentation/utilities.js.map +1 -0
  103. package/dist/umd/index.js +1 -1
  104. package/dist/umd/index.js.map +1 -1
  105. package/package.json +2 -2
@@ -5,7 +5,10 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  const core_1 = require("@cornerstonejs/core");
7
7
  const base_1 = require("../base");
8
+ const fillSphere_1 = require("./strategies/fillSphere");
9
+ const eraseSphere_1 = require("./strategies/eraseSphere");
8
10
  const fillCircle_1 = require("./strategies/fillCircle");
11
+ const eraseCircle_1 = require("./strategies/eraseCircle");
9
12
  const enums_1 = require("../../enums");
10
13
  const drawingSvg_1 = require("../../drawingSvg");
11
14
  const elementCursor_1 = require("../../cursors/elementCursor");
@@ -16,77 +19,57 @@ class BrushTool extends base_1.BaseTool {
16
19
  supportedInteractionTypes: ['Mouse', 'Touch'],
17
20
  configuration: {
18
21
  strategies: {
19
- FILL_INSIDE: fillCircle_1.fillInsideCircle,
22
+ FILL_INSIDE_CIRCLE: fillCircle_1.fillInsideCircle,
23
+ THRESHOLD_INSIDE_CIRCLE: fillCircle_1.thresholdInsideCircle,
24
+ ERASE_INSIDE_CIRCLE: eraseCircle_1.eraseInsideCircle,
25
+ FILL_INSIDE_SPHERE: fillSphere_1.fillInsideSphere,
26
+ ERASE_INSIDE_SPHERE: eraseSphere_1.eraseInsideSphere,
20
27
  },
21
- defaultStrategy: 'FILL_INSIDE',
22
- activeStrategy: 'FILL_INSIDE',
28
+ strategySpecificConfiguration: {
29
+ THRESHOLD_INSIDE_CIRCLE: {
30
+ threshold: [-150, -70],
31
+ },
32
+ },
33
+ defaultStrategy: 'FILL_INSIDE_CIRCLE',
34
+ activeStrategy: 'FILL_INSIDE_CIRCLE',
23
35
  brushSize: 25,
24
36
  },
25
37
  }) {
26
38
  super(toolProps, defaultToolProps);
39
+ this.onSetToolPassive = () => {
40
+ this.disableCursor();
41
+ };
42
+ this.onSetToolEnabled = () => {
43
+ this.disableCursor();
44
+ };
45
+ this.onSetToolDisabled = () => {
46
+ this.disableCursor();
47
+ };
27
48
  this.preMouseDownCallback = (evt) => {
28
49
  const eventData = evt.detail;
29
- const { currentPoints, element } = eventData;
30
- const worldPos = currentPoints.world;
31
- const canvasPos = currentPoints.canvas;
50
+ const { element } = eventData;
32
51
  const enabledElement = (0, core_1.getEnabledElement)(element);
33
52
  const { viewport, renderingEngine } = enabledElement;
34
- const { canvasToWorld } = viewport;
35
- this._isDrawing = true;
36
- const camera = viewport.getCamera();
37
- const { viewPlaneNormal, viewUp } = camera;
53
+ if (viewport instanceof core_1.StackViewport) {
54
+ throw new Error('Not implemented yet');
55
+ }
38
56
  const toolGroupId = this.toolGroupId;
39
57
  const activeSegmentationRepresentation = segmentation_1.activeSegmentation.getActiveSegmentationRepresentation(toolGroupId);
40
58
  if (!activeSegmentationRepresentation) {
41
59
  throw new Error('No active segmentation detected, create one before using the brush tool');
42
60
  }
43
- const { segmentationRepresentationUID, segmentationId, type } = activeSegmentationRepresentation;
44
- const segmentIndex = segmentation_1.segmentIndex.getActiveSegmentIndex(segmentationId);
61
+ const { segmentationId, type } = activeSegmentationRepresentation;
45
62
  const segmentsLocked = segmentation_1.segmentLocking.getLockedSegments(segmentationId);
46
- const segmentColor = segmentation_1.config.color.getColorForSegmentIndex(toolGroupId, segmentationRepresentationUID, segmentIndex);
47
63
  const { representationData } = segmentation_1.state.getSegmentation(segmentationId);
48
64
  const { volumeId } = representationData[type];
49
65
  const segmentation = core_1.cache.getVolume(volumeId);
50
- const centerCanvas = canvasPos;
51
- const radius = this.configuration.brushSize;
52
- const bottomCanvas = [
53
- centerCanvas[0],
54
- centerCanvas[1] + radius,
55
- ];
56
- const topCanvas = [centerCanvas[0], centerCanvas[1] - radius];
57
- const leftCanvas = [
58
- centerCanvas[0] - radius,
59
- centerCanvas[1],
60
- ];
61
- const rightCanvas = [
62
- centerCanvas[0] + radius,
63
- centerCanvas[1],
64
- ];
65
- const brushCursor = {
66
- metadata: {
67
- viewPlaneNormal: [...viewPlaneNormal],
68
- viewUp: [...viewUp],
69
- FrameOfReferenceUID: viewport.getFrameOfReferenceUID(),
70
- referencedImageId: '',
71
- toolName: this.getToolName(),
72
- segmentColor,
73
- },
74
- data: {
75
- invalidated: true,
76
- handles: {
77
- points: [
78
- canvasToWorld(bottomCanvas),
79
- canvasToWorld(topCanvas),
80
- canvasToWorld(leftCanvas),
81
- canvasToWorld(rightCanvas),
82
- ],
83
- },
84
- cachedStats: {},
85
- },
86
- };
66
+ const actors = viewport.getActors();
67
+ const firstVolumeActorUID = actors[0].uid;
68
+ const imageVolume = core_1.cache.getVolume(firstVolumeActorUID);
87
69
  const viewportIdsToRender = [viewport.id];
88
70
  this._editData = {
89
71
  segmentation,
72
+ imageVolume,
90
73
  segmentsLocked,
91
74
  };
92
75
  this._activateDraw(element);
@@ -96,48 +79,25 @@ class BrushTool extends base_1.BaseTool {
96
79
  return true;
97
80
  };
98
81
  this.mouseMoveCallback = (evt) => {
99
- this.updateCursor(evt);
82
+ if (this.mode === enums_1.ToolModes.Active) {
83
+ this.updateCursor(evt);
84
+ }
100
85
  };
101
86
  this._mouseDragCallback = (evt) => {
102
- this._isDrawing = true;
103
- const brushSize = this.configuration.brushSize;
104
87
  const eventData = evt.detail;
105
88
  const { element } = eventData;
106
- const { currentPoints } = eventData;
107
- const currentCanvasPoints = currentPoints.canvas;
108
89
  const enabledElement = (0, core_1.getEnabledElement)(element);
109
- const { renderingEngine, viewport } = enabledElement;
110
- const { canvasToWorld } = viewport;
111
- const { segmentation, segmentsLocked } = this._editData;
90
+ const { renderingEngine } = enabledElement;
91
+ const { imageVolume, segmentation, segmentsLocked } = this._editData;
92
+ this.updateCursor(evt);
112
93
  const { segmentIndex, segmentationId, segmentationRepresentationUID, brushCursor, viewportIdsToRender, } = this._hoverData;
113
- const { viewPlaneNormal, viewUp } = brushCursor.metadata;
114
94
  const { data } = brushCursor;
115
- const centerCanvas = currentCanvasPoints;
116
- const radius = brushSize;
117
- const bottomCanvas = [
118
- centerCanvas[0],
119
- centerCanvas[1] + radius,
120
- ];
121
- const topCanvas = [centerCanvas[0], centerCanvas[1] - radius];
122
- const leftCanvas = [
123
- centerCanvas[0] - radius,
124
- centerCanvas[1],
125
- ];
126
- const rightCanvas = [
127
- centerCanvas[0] + radius,
128
- centerCanvas[1],
129
- ];
130
- data.handles.points = [
131
- canvasToWorld(bottomCanvas),
132
- canvasToWorld(topCanvas),
133
- canvasToWorld(leftCanvas),
134
- canvasToWorld(rightCanvas),
135
- ];
136
- data.invalidated = true;
95
+ const { viewPlaneNormal, viewUp } = brushCursor.metadata;
137
96
  (0, triggerAnnotationRenderForViewportIds_1.default)(renderingEngine, viewportIdsToRender);
138
97
  const operationData = {
139
98
  points: data.handles.points,
140
99
  volume: segmentation,
100
+ imageVolume,
141
101
  segmentIndex,
142
102
  segmentsLocked,
143
103
  viewPlaneNormal,
@@ -145,13 +105,14 @@ class BrushTool extends base_1.BaseTool {
145
105
  segmentationId,
146
106
  segmentationRepresentationUID,
147
107
  viewUp,
108
+ strategySpecificConfiguration: this.configuration.strategySpecificConfiguration,
148
109
  };
149
110
  this.applyActiveStrategy(enabledElement, operationData);
150
111
  };
151
112
  this._mouseUpCallback = (evt) => {
152
113
  const eventData = evt.detail;
153
114
  const { element } = eventData;
154
- const { segmentation, segmentsLocked } = this._editData;
115
+ const { imageVolume, segmentation, segmentsLocked } = this._editData;
155
116
  const { segmentIndex, segmentationId, segmentationRepresentationUID, brushCursor, } = this._hoverData;
156
117
  const { data } = brushCursor;
157
118
  const { viewPlaneNormal, viewUp } = brushCursor.metadata;
@@ -160,7 +121,6 @@ class BrushTool extends base_1.BaseTool {
160
121
  const enabledElement = (0, core_1.getEnabledElement)(element);
161
122
  const { viewport } = enabledElement;
162
123
  this._editData = null;
163
- this._isDrawing = false;
164
124
  this.updateCursor(evt);
165
125
  if (viewport instanceof core_1.StackViewport) {
166
126
  throw new Error('Not implemented yet');
@@ -168,6 +128,7 @@ class BrushTool extends base_1.BaseTool {
168
128
  const operationData = {
169
129
  points: data.handles.points,
170
130
  volume: segmentation,
131
+ imageVolume,
171
132
  segmentIndex,
172
133
  segmentsLocked,
173
134
  viewPlaneNormal,
@@ -175,6 +136,7 @@ class BrushTool extends base_1.BaseTool {
175
136
  segmentationId,
176
137
  segmentationRepresentationUID,
177
138
  viewUp,
139
+ strategySpecificConfiguration: this.configuration.strategySpecificConfiguration,
178
140
  };
179
141
  this.applyActiveStrategy(enabledElement, operationData);
180
142
  };
@@ -189,15 +151,16 @@ class BrushTool extends base_1.BaseTool {
189
151
  element.removeEventListener(enums_1.Events.MOUSE_CLICK, this._mouseUpCallback);
190
152
  };
191
153
  }
154
+ disableCursor() {
155
+ this._hoverData = undefined;
156
+ }
192
157
  updateCursor(evt) {
193
- const brushSize = this.configuration.brushSize;
194
158
  const eventData = evt.detail;
195
159
  const { element } = eventData;
196
160
  const { currentPoints } = eventData;
197
- const canvasPos = currentPoints.canvas;
161
+ const centerCanvas = currentPoints.canvas;
198
162
  const enabledElement = (0, core_1.getEnabledElement)(element);
199
163
  const { renderingEngine, viewport } = enabledElement;
200
- const { canvasToWorld } = viewport;
201
164
  const camera = viewport.getCamera();
202
165
  const { viewPlaneNormal, viewUp } = camera;
203
166
  const toolGroupId = this.toolGroupId;
@@ -208,24 +171,8 @@ class BrushTool extends base_1.BaseTool {
208
171
  }
209
172
  const { segmentationRepresentationUID, segmentationId } = activeSegmentationRepresentation;
210
173
  const segmentIndex = segmentation_1.segmentIndex.getActiveSegmentIndex(segmentationId);
211
- const segmentsLocked = segmentation_1.segmentLocking.getLockedSegments(segmentationId);
212
174
  const segmentColor = segmentation_1.config.color.getColorForSegmentIndex(toolGroupId, segmentationRepresentationUID, segmentIndex);
213
175
  const viewportIdsToRender = [viewport.id];
214
- const centerCanvas = canvasPos;
215
- const radius = brushSize;
216
- const bottomCanvas = [
217
- centerCanvas[0],
218
- centerCanvas[1] + radius,
219
- ];
220
- const topCanvas = [centerCanvas[0], centerCanvas[1] - radius];
221
- const leftCanvas = [
222
- centerCanvas[0] - radius,
223
- centerCanvas[1],
224
- ];
225
- const rightCanvas = [
226
- centerCanvas[0] + radius,
227
- centerCanvas[1],
228
- ];
229
176
  const brushCursor = {
230
177
  metadata: {
231
178
  viewPlaneNormal: [...viewPlaneNormal],
@@ -235,18 +182,7 @@ class BrushTool extends base_1.BaseTool {
235
182
  toolName: this.getToolName(),
236
183
  segmentColor,
237
184
  },
238
- data: {
239
- invalidated: true,
240
- handles: {
241
- points: [
242
- canvasToWorld(bottomCanvas),
243
- canvasToWorld(topCanvas),
244
- canvasToWorld(leftCanvas),
245
- canvasToWorld(rightCanvas),
246
- ],
247
- },
248
- cachedStats: {},
249
- },
185
+ data: {},
250
186
  };
251
187
  this._hoverData = {
252
188
  brushCursor,
@@ -257,8 +193,47 @@ class BrushTool extends base_1.BaseTool {
257
193
  segmentColor,
258
194
  viewportIdsToRender,
259
195
  };
196
+ this._calculateCursor(element, centerCanvas);
260
197
  (0, triggerAnnotationRenderForViewportIds_1.default)(renderingEngine, viewportIdsToRender);
261
198
  }
199
+ _calculateCursor(element, centerCanvas) {
200
+ const enabledElement = (0, core_1.getEnabledElement)(element);
201
+ const { viewport } = enabledElement;
202
+ const { canvasToWorld } = viewport;
203
+ const { brushSize } = this.configuration;
204
+ const radius = brushSize;
205
+ const bottomCanvas = [
206
+ centerCanvas[0],
207
+ centerCanvas[1] + radius,
208
+ ];
209
+ const topCanvas = [centerCanvas[0], centerCanvas[1] - radius];
210
+ const leftCanvas = [
211
+ centerCanvas[0] - radius,
212
+ centerCanvas[1],
213
+ ];
214
+ const rightCanvas = [
215
+ centerCanvas[0] + radius,
216
+ centerCanvas[1],
217
+ ];
218
+ const { brushCursor } = this._hoverData;
219
+ const { data } = brushCursor;
220
+ if (data.handles === undefined) {
221
+ data.handles = {};
222
+ }
223
+ data.handles.points = [
224
+ canvasToWorld(bottomCanvas),
225
+ canvasToWorld(topCanvas),
226
+ canvasToWorld(leftCanvas),
227
+ canvasToWorld(rightCanvas),
228
+ ];
229
+ data.invalidated = false;
230
+ }
231
+ invalidateBrushCursor() {
232
+ if (this._hoverData !== undefined) {
233
+ const { data } = this._hoverData.brushCursor;
234
+ data.invalidated = true;
235
+ }
236
+ }
262
237
  renderAnnotation(enabledElement, svgDrawingHelper) {
263
238
  if (!this._hoverData) {
264
239
  return;
@@ -269,6 +244,11 @@ class BrushTool extends base_1.BaseTool {
269
244
  return;
270
245
  }
271
246
  const brushCursor = this._hoverData.brushCursor;
247
+ if (brushCursor.data.invalidated === true) {
248
+ const { centerCanvas } = this._hoverData;
249
+ const { element } = viewport;
250
+ this._calculateCursor(element, centerCanvas);
251
+ }
272
252
  const toolMetadata = brushCursor.metadata;
273
253
  const annotationUID = toolMetadata.brushCursorUID;
274
254
  const data = brushCursor.data;
@@ -292,6 +272,6 @@ class BrushTool extends base_1.BaseTool {
292
272
  });
293
273
  }
294
274
  }
295
- BrushTool.toolName = 'Brush';
296
275
  exports.default = BrushTool;
276
+ BrushTool.toolName = 'Brush';
297
277
  //# sourceMappingURL=BrushTool.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"BrushTool.js","sourceRoot":"","sources":["../../../../src/tools/segmentation/BrushTool.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"BrushTool.js","sourceRoot":"","sources":["../../../../src/tools/segmentation/BrushTool.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,12 @@
1
+ import { BaseTool } from '../base';
2
+ import { PublicToolProps, ToolProps, EventTypes } from '../../types';
3
+ export default class PaintFillTool extends BaseTool {
4
+ static toolName: string;
5
+ constructor(toolProps?: PublicToolProps, defaultToolProps?: ToolProps);
6
+ preMouseDownCallback: (evt: EventTypes.MouseDownActivateEventType) => boolean;
7
+ private getFramesModified;
8
+ private generateHelpers;
9
+ private getFixedDimension;
10
+ private generateFloodFillGetter;
11
+ private generateGetScalarDataPositionFromPlane;
12
+ }
@@ -0,0 +1,213 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const core_1 = require("@cornerstonejs/core");
4
+ const base_1 = require("../base");
5
+ const triggerSegmentationEvents_1 = require("../../stateManagement/segmentation/triggerSegmentationEvents");
6
+ const segmentation_1 = require("../../stateManagement/segmentation");
7
+ const utilities_1 = require("../../utilities");
8
+ const segmentationState_1 = require("../../stateManagement/segmentation/segmentationState");
9
+ const { transformWorldToIndex, isEqual } = core_1.utilities;
10
+ const { floodFill } = utilities_1.segmentation;
11
+ class PaintFillTool extends base_1.BaseTool {
12
+ constructor(toolProps = {}, defaultToolProps = {
13
+ supportedInteractionTypes: ['Mouse', 'Touch'],
14
+ }) {
15
+ super(toolProps, defaultToolProps);
16
+ this.preMouseDownCallback = (evt) => {
17
+ const eventDetail = evt.detail;
18
+ const { currentPoints, element } = eventDetail;
19
+ const worldPos = currentPoints.world;
20
+ const enabledElement = (0, core_1.getEnabledElement)(element);
21
+ const { viewport } = enabledElement;
22
+ const camera = viewport.getCamera();
23
+ const { viewPlaneNormal } = camera;
24
+ const toolGroupId = this.toolGroupId;
25
+ const activeSegmentationRepresentation = segmentation_1.activeSegmentation.getActiveSegmentationRepresentation(toolGroupId);
26
+ if (!activeSegmentationRepresentation) {
27
+ throw new Error('No active segmentation detected, create one before using scissors tool');
28
+ }
29
+ const { segmentationId, type } = activeSegmentationRepresentation;
30
+ const segmentIndex = segmentation_1.segmentIndex.getActiveSegmentIndex(segmentationId);
31
+ const segmentsLocked = segmentation_1.segmentLocking.getLockedSegments(segmentationId);
32
+ const { representationData } = (0, segmentationState_1.getSegmentation)(segmentationId);
33
+ const { volumeId } = representationData[type];
34
+ const segmentation = core_1.cache.getVolume(volumeId);
35
+ const { scalarData, dimensions, direction } = segmentation;
36
+ const index = transformWorldToIndex(segmentation.imageData, worldPos);
37
+ const fixedDimension = this.getFixedDimension(viewPlaneNormal, direction);
38
+ if (fixedDimension === undefined) {
39
+ console.warn('Oblique paint fill not yet supported');
40
+ return;
41
+ }
42
+ const { floodFillGetter, getLabelValue, getScalarDataPositionFromPlane, inPlaneSeedPoint, fixedDimensionValue, } = this.generateHelpers(scalarData, dimensions, index, fixedDimension);
43
+ if (index[0] < 0 ||
44
+ index[0] >= dimensions[0] ||
45
+ index[1] < 0 ||
46
+ index[1] >= dimensions[1] ||
47
+ index[2] < 0 ||
48
+ index[2] >= dimensions[2]) {
49
+ return;
50
+ }
51
+ const clickedLabelValue = getLabelValue(index[0], index[1], index[2]);
52
+ if (segmentsLocked.includes(clickedLabelValue)) {
53
+ return;
54
+ }
55
+ const floodFillResult = floodFill(floodFillGetter, inPlaneSeedPoint);
56
+ const { flooded } = floodFillResult;
57
+ flooded.forEach((index) => {
58
+ const scalarDataPosition = getScalarDataPositionFromPlane(index[0], index[1]);
59
+ scalarData[scalarDataPosition] = segmentIndex;
60
+ });
61
+ const framesModified = this.getFramesModified(fixedDimension, fixedDimensionValue, floodFillResult);
62
+ (0, triggerSegmentationEvents_1.triggerSegmentationDataModified)(segmentationId, framesModified);
63
+ return true;
64
+ };
65
+ this.getFramesModified = (fixedDimension, fixedDimensionValue, floodFillResult) => {
66
+ const { boundaries } = floodFillResult;
67
+ if (fixedDimension === 2) {
68
+ return [fixedDimensionValue];
69
+ }
70
+ let minJ = Infinity;
71
+ let maxJ = -Infinity;
72
+ for (let b = 0; b < boundaries.length; b++) {
73
+ const j = boundaries[b][1];
74
+ if (j < minJ)
75
+ minJ = j;
76
+ if (j > maxJ)
77
+ maxJ = j;
78
+ }
79
+ const framesModified = [];
80
+ for (let frame = minJ; frame <= maxJ; frame++) {
81
+ framesModified.push(frame);
82
+ }
83
+ return framesModified;
84
+ };
85
+ this.generateHelpers = (scalarData, dimensions, seedIndex3D, fixedDimension = 2) => {
86
+ let fixedDimensionValue;
87
+ let inPlaneSeedPoint;
88
+ switch (fixedDimension) {
89
+ case 0:
90
+ fixedDimensionValue = seedIndex3D[0];
91
+ inPlaneSeedPoint = [seedIndex3D[1], seedIndex3D[2]];
92
+ break;
93
+ case 1:
94
+ fixedDimensionValue = seedIndex3D[1];
95
+ inPlaneSeedPoint = [seedIndex3D[0], seedIndex3D[2]];
96
+ break;
97
+ case 2:
98
+ fixedDimensionValue = seedIndex3D[2];
99
+ inPlaneSeedPoint = [seedIndex3D[0], seedIndex3D[1]];
100
+ break;
101
+ default:
102
+ throw new Error(`Invalid fixedDimension: ${fixedDimension}`);
103
+ }
104
+ const getScalarDataPosition = (x, y, z) => {
105
+ return z * dimensions[1] * dimensions[0] + y * dimensions[0] + x;
106
+ };
107
+ const getLabelValue = (x, y, z) => {
108
+ return scalarData[getScalarDataPosition(x, y, z)];
109
+ };
110
+ const floodFillGetter = this.generateFloodFillGetter(dimensions, fixedDimension, fixedDimensionValue, getLabelValue);
111
+ const getScalarDataPositionFromPlane = this.generateGetScalarDataPositionFromPlane(getScalarDataPosition, fixedDimension, fixedDimensionValue);
112
+ return {
113
+ getScalarDataPositionFromPlane,
114
+ getLabelValue,
115
+ floodFillGetter,
116
+ inPlaneSeedPoint,
117
+ fixedDimensionValue,
118
+ };
119
+ };
120
+ this.generateFloodFillGetter = (dimensions, fixedDimension, fixedDimensionValue, getLabelValue) => {
121
+ let floodFillGetter;
122
+ switch (fixedDimension) {
123
+ case 0:
124
+ floodFillGetter = (y, z) => {
125
+ if (y >= dimensions[1] || y < 0 || z >= dimensions[2] || z < 0) {
126
+ return;
127
+ }
128
+ return getLabelValue(fixedDimensionValue, y, z);
129
+ };
130
+ break;
131
+ case 1:
132
+ floodFillGetter = (x, z) => {
133
+ if (x >= dimensions[0] || x < 0 || z >= dimensions[2] || z < 0) {
134
+ return;
135
+ }
136
+ return getLabelValue(x, fixedDimensionValue, z);
137
+ };
138
+ break;
139
+ case 2:
140
+ floodFillGetter = (x, y) => {
141
+ if (x >= dimensions[0] || x < 0 || y >= dimensions[1] || y < 0) {
142
+ return;
143
+ }
144
+ return getLabelValue(x, y, fixedDimensionValue);
145
+ };
146
+ break;
147
+ default:
148
+ throw new Error(`Invalid fixedDimension: ${fixedDimension}`);
149
+ }
150
+ return floodFillGetter;
151
+ };
152
+ this.generateGetScalarDataPositionFromPlane = (getScalarDataPosition, fixedDimension, fixedDimensionValue) => {
153
+ let getScalarDataPositionFromPlane;
154
+ switch (fixedDimension) {
155
+ case 0:
156
+ getScalarDataPositionFromPlane = (y, z) => {
157
+ return getScalarDataPosition(fixedDimensionValue, y, z);
158
+ };
159
+ break;
160
+ case 1:
161
+ getScalarDataPositionFromPlane = (x, z) => {
162
+ return getScalarDataPosition(x, fixedDimensionValue, z);
163
+ };
164
+ break;
165
+ case 2:
166
+ getScalarDataPositionFromPlane = (x, y) => {
167
+ return getScalarDataPosition(x, y, fixedDimensionValue);
168
+ };
169
+ break;
170
+ default:
171
+ throw new Error(`Invalid fixedDimension: ${fixedDimension}`);
172
+ }
173
+ return getScalarDataPositionFromPlane;
174
+ };
175
+ }
176
+ getFixedDimension(viewPlaneNormal, direction) {
177
+ const xDirection = direction.slice(0, 3);
178
+ const yDirection = direction.slice(3, 6);
179
+ const zDirection = direction.slice(6, 9);
180
+ const absoluteOfViewPlaneNormal = [
181
+ Math.abs(viewPlaneNormal[0]),
182
+ Math.abs(viewPlaneNormal[1]),
183
+ Math.abs(viewPlaneNormal[2]),
184
+ ];
185
+ const absoluteOfXDirection = [
186
+ Math.abs(xDirection[0]),
187
+ Math.abs(xDirection[1]),
188
+ Math.abs(xDirection[2]),
189
+ ];
190
+ if (isEqual(absoluteOfViewPlaneNormal, absoluteOfXDirection)) {
191
+ return 0;
192
+ }
193
+ const absoluteOfYDirection = [
194
+ Math.abs(yDirection[0]),
195
+ Math.abs(yDirection[1]),
196
+ Math.abs(yDirection[2]),
197
+ ];
198
+ if (isEqual(absoluteOfViewPlaneNormal, absoluteOfYDirection)) {
199
+ return 1;
200
+ }
201
+ const absoluteOfZDirection = [
202
+ Math.abs(zDirection[0]),
203
+ Math.abs(zDirection[1]),
204
+ Math.abs(zDirection[2]),
205
+ ];
206
+ if (isEqual(absoluteOfViewPlaneNormal, absoluteOfZDirection)) {
207
+ return 2;
208
+ }
209
+ }
210
+ }
211
+ exports.default = PaintFillTool;
212
+ PaintFillTool.toolName = 'PaintFill';
213
+ //# sourceMappingURL=PaintFillTool.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PaintFillTool.js","sourceRoot":"","sources":["../../../../src/tools/segmentation/PaintFillTool.ts"],"names":[],"mappings":";;AAAA,8CAI6B;AAG7B,kCAAmC;AAGnC,4GAA+G;AAC/G,qEAI4C;AAC5C,+CAAoE;AACpE,4FAAuF;AAGvF,MAAM,EAAE,qBAAqB,EAAE,OAAO,EAAE,GAAG,gBAAO,CAAC;AACnD,MAAM,EAAE,SAAS,EAAE,GAAG,wBAAiB,CAAC;AAiBxC,MAAqB,aAAc,SAAQ,eAAQ;IAGjD,YACE,YAA6B,EAAE,EAC/B,mBAA8B;QAC5B,yBAAyB,EAAE,CAAC,OAAO,EAAE,OAAO,CAAC;KAC9C;QAED,KAAK,CAAC,SAAS,EAAE,gBAAgB,CAAC,CAAC;QAWrC,yBAAoB,GAAG,CACrB,GAA0C,EACjC,EAAE;YACX,MAAM,WAAW,GAAG,GAAG,CAAC,MAAM,CAAC;YAC/B,MAAM,EAAE,aAAa,EAAE,OAAO,EAAE,GAAG,WAAW,CAAC;YAC/C,MAAM,QAAQ,GAAG,aAAa,CAAC,KAAK,CAAC;YAErC,MAAM,cAAc,GAAG,IAAA,wBAAiB,EAAC,OAAO,CAAC,CAAC;YAClD,MAAM,EAAE,QAAQ,EAAE,GAAG,cAAc,CAAC;YAEpC,MAAM,MAAM,GAAG,QAAQ,CAAC,SAAS,EAAE,CAAC;YACpC,MAAM,EAAE,eAAe,EAAE,GAAG,MAAM,CAAC;YACnC,MAAM,WAAW,GAAG,IAAI,CAAC,WAAW,CAAC;YAErC,MAAM,gCAAgC,GACpC,iCAAkB,CAAC,mCAAmC,CAAC,WAAW,CAAC,CAAC;YACtE,IAAI,CAAC,gCAAgC,EAAE;gBACrC,MAAM,IAAI,KAAK,CACb,wEAAwE,CACzE,CAAC;aACH;YAED,MAAM,EAAE,cAAc,EAAE,IAAI,EAAE,GAAG,gCAAgC,CAAC;YAClE,MAAM,YAAY,GAChB,2BAAsB,CAAC,qBAAqB,CAAC,cAAc,CAAC,CAAC;YAC/D,MAAM,cAAc,GAClB,6BAAc,CAAC,iBAAiB,CAAC,cAAc,CAAC,CAAC;YACnD,MAAM,EAAE,kBAAkB,EAAE,GAAG,IAAA,mCAAe,EAAC,cAAc,CAAC,CAAC;YAE/D,MAAM,EAAE,QAAQ,EAAE,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAC;YAC9C,MAAM,YAAY,GAAG,YAAK,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC;YAC/C,MAAM,EAAE,UAAU,EAAE,UAAU,EAAE,SAAS,EAAE,GAAG,YAAY,CAAC;YAE3D,MAAM,KAAK,GAAG,qBAAqB,CAAC,YAAY,CAAC,SAAS,EAAE,QAAQ,CAAC,CAAC;YAEtE,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAAC,eAAe,EAAE,SAAS,CAAC,CAAC;YAE1E,IAAI,cAAc,KAAK,SAAS,EAAE;gBAChC,OAAO,CAAC,IAAI,CAAC,sCAAsC,CAAC,CAAC;gBACrD,OAAO;aACR;YAED,MAAM,EACJ,eAAe,EACf,aAAa,EACb,8BAA8B,EAC9B,gBAAgB,EAChB,mBAAmB,GACpB,GAAG,IAAI,CAAC,eAAe,CAAC,UAAU,EAAE,UAAU,EAAE,KAAK,EAAE,cAAc,CAAC,CAAC;YAGxE,IACE,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC;gBACZ,KAAK,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC;gBACzB,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC;gBACZ,KAAK,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC;gBACzB,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC;gBACZ,KAAK,CAAC,CAAC,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,EACzB;gBAEA,OAAO;aACR;YAED,MAAM,iBAAiB,GAAG,aAAa,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,CAAC;YAEtE,IAAI,cAAc,CAAC,QAAQ,CAAC,iBAAiB,CAAC,EAAE;gBAE9C,OAAO;aACR;YAED,MAAM,eAAe,GAAG,SAAS,CAAC,eAAe,EAAE,gBAAgB,CAAC,CAAC;YAErE,MAAM,EAAE,OAAO,EAAE,GAAG,eAAe,CAAC;YAEpC,OAAO,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;gBACxB,MAAM,kBAAkB,GAAG,8BAA8B,CACvD,KAAK,CAAC,CAAC,CAAC,EACR,KAAK,CAAC,CAAC,CAAC,CACT,CAAC;gBAEF,UAAU,CAAC,kBAAkB,CAAC,GAAG,YAAY,CAAC;YAChD,CAAC,CAAC,CAAC;YAEH,MAAM,cAAc,GAAG,IAAI,CAAC,iBAAiB,CAC3C,cAAc,EACd,mBAAmB,EACnB,eAAe,CAChB,CAAC;YAEF,IAAA,2DAA+B,EAAC,cAAc,EAAE,cAAc,CAAC,CAAC;YAEhE,OAAO,IAAI,CAAC;QACd,CAAC,CAAC;QAEM,sBAAiB,GAAG,CAC1B,cAAsB,EACtB,mBAA2B,EAC3B,eAAgC,EACtB,EAAE;YACZ,MAAM,EAAE,UAAU,EAAE,GAAG,eAAe,CAAC;YAEvC,IAAI,cAAc,KAAK,CAAC,EAAE;gBACxB,OAAO,CAAC,mBAAmB,CAAC,CAAC;aAC9B;YAKD,IAAI,IAAI,GAAG,QAAQ,CAAC;YACpB,IAAI,IAAI,GAAG,CAAC,QAAQ,CAAC;YAErB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;gBAC1C,MAAM,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;gBAE3B,IAAI,CAAC,GAAG,IAAI;oBAAE,IAAI,GAAG,CAAC,CAAC;gBACvB,IAAI,CAAC,GAAG,IAAI;oBAAE,IAAI,GAAG,CAAC,CAAC;aACxB;YAED,MAAM,cAAc,GAAG,EAAE,CAAC;YAE1B,KAAK,IAAI,KAAK,GAAG,IAAI,EAAE,KAAK,IAAI,IAAI,EAAE,KAAK,EAAE,EAAE;gBAC7C,cAAc,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;aAC5B;YAED,OAAO,cAAc,CAAC;QACxB,CAAC,CAAC;QAEM,oBAAe,GAAG,CACxB,UAAqC,EACrC,UAAwB,EACxB,WAAyB,EACzB,cAAc,GAAG,CAAC,EACI,EAAE;YACxB,IAAI,mBAA2B,CAAC;YAChC,IAAI,gBAA8B,CAAC;YAEnC,QAAQ,cAAc,EAAE;gBACtB,KAAK,CAAC;oBACJ,mBAAmB,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;oBACrC,gBAAgB,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;oBACpD,MAAM;gBACR,KAAK,CAAC;oBACJ,mBAAmB,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;oBACrC,gBAAgB,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;oBACpD,MAAM;gBACR,KAAK,CAAC;oBACJ,mBAAmB,GAAG,WAAW,CAAC,CAAC,CAAC,CAAC;oBACrC,gBAAgB,GAAG,CAAC,WAAW,CAAC,CAAC,CAAC,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC,CAAC;oBACpD,MAAM;gBACR;oBACE,MAAM,IAAI,KAAK,CAAC,2BAA2B,cAAc,EAAE,CAAC,CAAC;aAChE;YAED,MAAM,qBAAqB,GAAG,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS,EAAU,EAAE;gBACxE,OAAO,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,GAAG,UAAU,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;YACnE,CAAC,CAAC;YAEF,MAAM,aAAa,GAAG,CAAC,CAAS,EAAE,CAAS,EAAE,CAAS,EAAU,EAAE;gBAChE,OAAO,UAAU,CAAC,qBAAqB,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;YACpD,CAAC,CAAC;YAEF,MAAM,eAAe,GAAG,IAAI,CAAC,uBAAuB,CAClD,UAAU,EACV,cAAc,EACd,mBAAmB,EACnB,aAAa,CACd,CAAC;YAEF,MAAM,8BAA8B,GAClC,IAAI,CAAC,sCAAsC,CACzC,qBAAqB,EACrB,cAAc,EACd,mBAAmB,CACpB,CAAC;YAEJ,OAAO;gBACL,8BAA8B;gBAC9B,aAAa;gBACb,eAAe;gBACf,gBAAgB;gBAChB,mBAAmB;aACpB,CAAC;QACJ,CAAC,CAAC;QAgDM,4BAAuB,GAAG,CAChC,UAAwB,EACxB,cAAsB,EACtB,mBAA2B,EAC3B,aAAoD,EACnC,EAAE;YACnB,IAAI,eAAe,CAAC;YAOpB,QAAQ,cAAc,EAAE;gBACtB,KAAK,CAAC;oBACJ,eAAe,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;wBACzB,IAAI,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;4BAC9D,OAAO;yBACR;wBAED,OAAO,aAAa,CAAC,mBAAmB,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;oBAClD,CAAC,CAAC;oBACF,MAAM;gBAER,KAAK,CAAC;oBACJ,eAAe,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;wBACzB,IAAI,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;4BAC9D,OAAO;yBACR;wBAED,OAAO,aAAa,CAAC,CAAC,EAAE,mBAAmB,EAAE,CAAC,CAAC,CAAC;oBAClD,CAAC,CAAC;oBACF,MAAM;gBAER,KAAK,CAAC;oBACJ,eAAe,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;wBACzB,IAAI,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,IAAI,UAAU,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE;4BAC9D,OAAO;yBACR;wBAED,OAAO,aAAa,CAAC,CAAC,EAAE,CAAC,EAAE,mBAAmB,CAAC,CAAC;oBAClD,CAAC,CAAC;oBACF,MAAM;gBACR;oBACE,MAAM,IAAI,KAAK,CAAC,2BAA2B,cAAc,EAAE,CAAC,CAAC;aAChE;YAED,OAAO,eAAe,CAAC;QACzB,CAAC,CAAC;QAEM,2CAAsC,GAAG,CAC/C,qBAAkE,EAClE,cAAsB,EACtB,mBAA2B,EAC6B,EAAE;YAC1D,IAAI,8BAA8B,CAAC;YAEnC,QAAQ,cAAc,EAAE;gBACtB,KAAK,CAAC;oBACJ,8BAA8B,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;wBACxC,OAAO,qBAAqB,CAAC,mBAAmB,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC;oBAC1D,CAAC,CAAC;oBACF,MAAM;gBACR,KAAK,CAAC;oBACJ,8BAA8B,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;wBACxC,OAAO,qBAAqB,CAAC,CAAC,EAAE,mBAAmB,EAAE,CAAC,CAAC,CAAC;oBAC1D,CAAC,CAAC;oBACF,MAAM;gBACR,KAAK,CAAC;oBACJ,8BAA8B,GAAG,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;wBACxC,OAAO,qBAAqB,CAAC,CAAC,EAAE,CAAC,EAAE,mBAAmB,CAAC,CAAC;oBAC1D,CAAC,CAAC;oBACF,MAAM;gBACR;oBACE,MAAM,IAAI,KAAK,CAAC,2BAA2B,cAAc,EAAE,CAAC,CAAC;aAChE;YAED,OAAO,8BAA8B,CAAC;QACxC,CAAC,CAAC;IA9TF,CAAC;IAkMO,iBAAiB,CACvB,eAA6B,EAC7B,SAAmB;QAEnB,MAAM,UAAU,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACzC,MAAM,UAAU,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QACzC,MAAM,UAAU,GAAG,SAAS,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC;QAEzC,MAAM,yBAAyB,GAAG;YAChC,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;YAC5B,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;YAC5B,IAAI,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC;SAC7B,CAAC;QAEF,MAAM,oBAAoB,GAAG;YAC3B,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;SACxB,CAAC;QAEF,IAAI,OAAO,CAAC,yBAAyB,EAAE,oBAAoB,CAAC,EAAE;YAC5D,OAAO,CAAC,CAAC;SACV;QAED,MAAM,oBAAoB,GAAG;YAC3B,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;SACxB,CAAC;QAEF,IAAI,OAAO,CAAC,yBAAyB,EAAE,oBAAoB,CAAC,EAAE;YAC5D,OAAO,CAAC,CAAC;SACV;QAED,MAAM,oBAAoB,GAAG;YAC3B,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;YACvB,IAAI,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC;SACxB,CAAC;QAEF,IAAI,OAAO,CAAC,yBAAyB,EAAE,oBAAoB,CAAC,EAAE;YAC5D,OAAO,CAAC,CAAC;SACV;IACH,CAAC;;AAvPH,gCAyUC;AAxUQ,sBAAQ,GAAG,WAAW,CAAC"}
@@ -0,0 +1,15 @@
1
+ import type { Types } from '@cornerstonejs/core';
2
+ declare type OperationData = {
3
+ segmentationId: string;
4
+ imageVolume: Types.IImageVolume;
5
+ points: any;
6
+ volume: Types.IImageVolume;
7
+ segmentIndex: number;
8
+ segmentsLocked: number[];
9
+ viewPlaneNormal: number[];
10
+ viewUp: number[];
11
+ strategySpecificConfiguration: any;
12
+ constraintFn: () => boolean;
13
+ };
14
+ export declare function eraseInsideCircle(enabledElement: Types.IEnabledElement, operationData: OperationData): void;
15
+ export {};