@cornerstonejs/tools 0.30.7 → 0.32.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.
- package/dist/cjs/index.d.ts +2 -2
- package/dist/cjs/index.js +2 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/store/ToolGroupManager/ToolGroup.d.ts +4 -1
- package/dist/cjs/store/ToolGroupManager/ToolGroup.js +90 -29
- package/dist/cjs/store/ToolGroupManager/ToolGroup.js.map +1 -1
- package/dist/cjs/store/state.d.ts +4 -6
- package/dist/cjs/tools/base/BaseTool.d.ts +1 -1
- package/dist/cjs/tools/index.d.ts +2 -1
- package/dist/cjs/tools/index.js +3 -1
- package/dist/cjs/tools/index.js.map +1 -1
- package/dist/cjs/tools/segmentation/BrushTool.d.ts +9 -5
- package/dist/cjs/tools/segmentation/BrushTool.js +95 -115
- package/dist/cjs/tools/segmentation/BrushTool.js.map +1 -1
- package/dist/cjs/tools/segmentation/PaintFillTool.d.ts +12 -0
- package/dist/cjs/tools/segmentation/PaintFillTool.js +213 -0
- package/dist/cjs/tools/segmentation/PaintFillTool.js.map +1 -0
- package/dist/cjs/tools/segmentation/strategies/eraseCircle.d.ts +15 -0
- package/dist/cjs/tools/segmentation/strategies/eraseCircle.js +10 -0
- package/dist/cjs/tools/segmentation/strategies/eraseCircle.js.map +1 -0
- package/dist/cjs/tools/segmentation/strategies/eraseSphere.d.ts +13 -0
- package/dist/cjs/tools/segmentation/strategies/eraseSphere.js +12 -0
- package/dist/cjs/tools/segmentation/strategies/eraseSphere.js.map +1 -0
- package/dist/cjs/tools/segmentation/strategies/fillCircle.d.ts +3 -0
- package/dist/cjs/tools/segmentation/strategies/fillCircle.js +41 -12
- package/dist/cjs/tools/segmentation/strategies/fillCircle.js.map +1 -1
- package/dist/cjs/types/FloodFillTypes.d.ts +15 -0
- package/dist/cjs/types/FloodFillTypes.js +3 -0
- package/dist/cjs/types/FloodFillTypes.js.map +1 -0
- package/dist/cjs/types/IToolClassReference.d.ts +3 -0
- package/dist/cjs/types/IToolClassReference.js +3 -0
- package/dist/cjs/types/IToolClassReference.js.map +1 -0
- package/dist/cjs/types/IToolGroup.d.ts +3 -0
- package/dist/cjs/types/index.d.ts +3 -1
- package/dist/cjs/utilities/segmentation/brushSizeForToolGroup.d.ts +2 -0
- package/dist/cjs/utilities/segmentation/brushSizeForToolGroup.js +49 -0
- package/dist/cjs/utilities/segmentation/brushSizeForToolGroup.js.map +1 -0
- package/dist/cjs/utilities/segmentation/brushThresholdForToolGroup.d.ts +3 -0
- package/dist/cjs/utilities/segmentation/brushThresholdForToolGroup.js +49 -0
- package/dist/cjs/utilities/segmentation/brushThresholdForToolGroup.js.map +1 -0
- package/dist/cjs/utilities/segmentation/createLabelmapVolumeForViewport.js +1 -1
- package/dist/cjs/utilities/segmentation/createLabelmapVolumeForViewport.js.map +1 -1
- package/dist/cjs/utilities/segmentation/floodFill.d.ts +3 -0
- package/dist/cjs/utilities/segmentation/floodFill.js +131 -0
- package/dist/cjs/utilities/segmentation/floodFill.js.map +1 -0
- package/dist/cjs/utilities/segmentation/index.d.ts +4 -1
- package/dist/cjs/utilities/segmentation/index.js +9 -1
- package/dist/cjs/utilities/segmentation/index.js.map +1 -1
- package/dist/cjs/utilities/segmentation/utilities.d.ts +2 -0
- package/dist/cjs/utilities/segmentation/utilities.js +21 -0
- package/dist/cjs/utilities/segmentation/utilities.js.map +1 -0
- package/dist/cjs/utilities/viewport/isViewportPreScaled.js +1 -1
- package/dist/cjs/utilities/viewport/isViewportPreScaled.js.map +1 -1
- package/dist/esm/index.d.ts +2 -2
- package/dist/esm/index.js +2 -2
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/store/ToolGroupManager/ToolGroup.d.ts +4 -1
- package/dist/esm/store/ToolGroupManager/ToolGroup.js +90 -29
- package/dist/esm/store/ToolGroupManager/ToolGroup.js.map +1 -1
- package/dist/esm/store/state.d.ts +4 -6
- package/dist/esm/tools/base/BaseTool.d.ts +1 -1
- package/dist/esm/tools/index.d.ts +2 -1
- package/dist/esm/tools/index.js +2 -1
- package/dist/esm/tools/index.js.map +1 -1
- package/dist/esm/tools/segmentation/BrushTool.d.ts +9 -5
- package/dist/esm/tools/segmentation/BrushTool.js +98 -119
- package/dist/esm/tools/segmentation/BrushTool.js.map +1 -1
- package/dist/esm/tools/segmentation/PaintFillTool.d.ts +12 -0
- package/dist/esm/tools/segmentation/PaintFillTool.js +210 -0
- package/dist/esm/tools/segmentation/PaintFillTool.js.map +1 -0
- package/dist/esm/tools/segmentation/strategies/eraseCircle.d.ts +15 -0
- package/dist/esm/tools/segmentation/strategies/eraseCircle.js +9 -0
- package/dist/esm/tools/segmentation/strategies/eraseCircle.js.map +1 -0
- package/dist/esm/tools/segmentation/strategies/eraseSphere.d.ts +13 -0
- package/dist/esm/tools/segmentation/strategies/eraseSphere.js +8 -0
- package/dist/esm/tools/segmentation/strategies/eraseSphere.js.map +1 -0
- package/dist/esm/tools/segmentation/strategies/fillCircle.d.ts +3 -0
- package/dist/esm/tools/segmentation/strategies/fillCircle.js +38 -10
- package/dist/esm/tools/segmentation/strategies/fillCircle.js.map +1 -1
- package/dist/esm/types/FloodFillTypes.d.ts +15 -0
- package/dist/esm/types/FloodFillTypes.js +2 -0
- package/dist/esm/types/FloodFillTypes.js.map +1 -0
- package/dist/esm/types/IToolClassReference.d.ts +3 -0
- package/dist/esm/types/IToolClassReference.js +2 -0
- package/dist/esm/types/IToolClassReference.js.map +1 -0
- package/dist/esm/types/IToolGroup.d.ts +3 -0
- package/dist/esm/types/index.d.ts +3 -1
- package/dist/esm/utilities/segmentation/brushSizeForToolGroup.d.ts +2 -0
- package/dist/esm/utilities/segmentation/brushSizeForToolGroup.js +41 -0
- package/dist/esm/utilities/segmentation/brushSizeForToolGroup.js.map +1 -0
- package/dist/esm/utilities/segmentation/brushThresholdForToolGroup.d.ts +3 -0
- package/dist/esm/utilities/segmentation/brushThresholdForToolGroup.js +41 -0
- package/dist/esm/utilities/segmentation/brushThresholdForToolGroup.js.map +1 -0
- package/dist/esm/utilities/segmentation/createLabelmapVolumeForViewport.js +1 -1
- package/dist/esm/utilities/segmentation/createLabelmapVolumeForViewport.js.map +1 -1
- package/dist/esm/utilities/segmentation/floodFill.d.ts +3 -0
- package/dist/esm/utilities/segmentation/floodFill.js +128 -0
- package/dist/esm/utilities/segmentation/floodFill.js.map +1 -0
- package/dist/esm/utilities/segmentation/index.d.ts +4 -1
- package/dist/esm/utilities/segmentation/index.js +4 -1
- package/dist/esm/utilities/segmentation/index.js.map +1 -1
- package/dist/esm/utilities/segmentation/utilities.d.ts +2 -0
- package/dist/esm/utilities/segmentation/utilities.js +15 -0
- package/dist/esm/utilities/segmentation/utilities.js.map +1 -0
- package/dist/esm/utilities/viewport/isViewportPreScaled.js +2 -2
- package/dist/esm/utilities/viewport/isViewportPreScaled.js.map +1 -1
- package/dist/umd/index.js +1 -1
- package/dist/umd/index.js.map +1 -1
- package/package.json +3 -3
|
@@ -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
|
-
|
|
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
|
-
|
|
22
|
-
|
|
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 {
|
|
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
|
-
|
|
35
|
-
|
|
36
|
-
|
|
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 {
|
|
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
|
|
51
|
-
const
|
|
52
|
-
const
|
|
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.
|
|
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
|
|
110
|
-
const {
|
|
111
|
-
|
|
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
|
|
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
|
|
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":";;;;;AAAA,8CAA8E;AAS9E,kCAAmC;
|
|
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":"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"}
|
|
@@ -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 {};
|