@cornerstonejs/tools 1.20.3 → 1.21.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (112) hide show
  1. package/dist/cjs/drawingSvg/getSvgDrawingHelper.js +1 -1
  2. package/dist/cjs/drawingSvg/getSvgDrawingHelper.js.map +1 -1
  3. package/dist/cjs/enums/Events.d.ts +1 -0
  4. package/dist/cjs/enums/Events.js +1 -0
  5. package/dist/cjs/enums/Events.js.map +1 -1
  6. package/dist/cjs/eventDispatchers/mouseEventHandlers/mouseDown.js +5 -0
  7. package/dist/cjs/eventDispatchers/mouseEventHandlers/mouseDown.js.map +1 -1
  8. package/dist/cjs/eventDispatchers/mouseEventHandlers/mouseDownAnnotationAction.d.ts +2 -0
  9. package/dist/cjs/eventDispatchers/mouseEventHandlers/mouseDownAnnotationAction.js +41 -0
  10. package/dist/cjs/eventDispatchers/mouseEventHandlers/mouseDownAnnotationAction.js.map +1 -0
  11. package/dist/cjs/eventDispatchers/shared/getToolsWithActionsForMouseEvent.d.ts +3 -0
  12. package/dist/cjs/eventDispatchers/shared/getToolsWithActionsForMouseEvent.js +39 -0
  13. package/dist/cjs/eventDispatchers/shared/getToolsWithActionsForMouseEvent.js.map +1 -0
  14. package/dist/cjs/eventListeners/mouse/mouseDownListener.js +5 -1
  15. package/dist/cjs/eventListeners/mouse/mouseDownListener.js.map +1 -1
  16. package/dist/cjs/eventListeners/mouse/mouseMoveListener.js +5 -1
  17. package/dist/cjs/eventListeners/mouse/mouseMoveListener.js.map +1 -1
  18. package/dist/cjs/index.d.ts +2 -2
  19. package/dist/cjs/index.js +3 -2
  20. package/dist/cjs/index.js.map +1 -1
  21. package/dist/cjs/store/ToolGroupManager/ToolGroup.d.ts +2 -0
  22. package/dist/cjs/store/ToolGroupManager/ToolGroup.js +35 -0
  23. package/dist/cjs/store/ToolGroupManager/ToolGroup.js.map +1 -1
  24. package/dist/cjs/tools/AdvancedMagnifyTool.d.ts +36 -0
  25. package/dist/cjs/tools/AdvancedMagnifyTool.js +448 -0
  26. package/dist/cjs/tools/AdvancedMagnifyTool.js.map +1 -0
  27. package/dist/cjs/tools/AdvancedMagnifyViewport.d.ts +76 -0
  28. package/dist/cjs/tools/AdvancedMagnifyViewport.js +352 -0
  29. package/dist/cjs/tools/AdvancedMagnifyViewport.js.map +1 -0
  30. package/dist/cjs/tools/AdvancedMagnifyViewportManager.d.ts +36 -0
  31. package/dist/cjs/tools/AdvancedMagnifyViewportManager.js +133 -0
  32. package/dist/cjs/tools/AdvancedMagnifyViewportManager.js.map +1 -0
  33. package/dist/cjs/tools/annotation/EllipticalROITool.d.ts +1 -1
  34. package/dist/cjs/tools/annotation/EllipticalROITool.js +12 -8
  35. package/dist/cjs/tools/annotation/EllipticalROITool.js.map +1 -1
  36. package/dist/cjs/tools/index.d.ts +2 -1
  37. package/dist/cjs/tools/index.js +3 -1
  38. package/dist/cjs/tools/index.js.map +1 -1
  39. package/dist/cjs/types/EventTypes.d.ts +9 -1
  40. package/dist/cjs/types/IToolGroup.d.ts +3 -0
  41. package/dist/cjs/types/ToolAction.d.ts +8 -0
  42. package/dist/cjs/types/ToolAction.js +3 -0
  43. package/dist/cjs/types/ToolAction.js.map +1 -0
  44. package/dist/cjs/types/ToolSpecificAnnotationTypes.d.ts +11 -0
  45. package/dist/cjs/types/index.d.ts +2 -1
  46. package/dist/esm/drawingSvg/getSvgDrawingHelper.js +1 -1
  47. package/dist/esm/drawingSvg/getSvgDrawingHelper.js.map +1 -1
  48. package/dist/esm/enums/Events.d.ts +1 -0
  49. package/dist/esm/enums/Events.js +1 -0
  50. package/dist/esm/enums/Events.js.map +1 -1
  51. package/dist/esm/eventDispatchers/mouseEventHandlers/mouseDown.js +5 -0
  52. package/dist/esm/eventDispatchers/mouseEventHandlers/mouseDown.js.map +1 -1
  53. package/dist/esm/eventDispatchers/mouseEventHandlers/mouseDownAnnotationAction.d.ts +2 -0
  54. package/dist/esm/eventDispatchers/mouseEventHandlers/mouseDownAnnotationAction.js +35 -0
  55. package/dist/esm/eventDispatchers/mouseEventHandlers/mouseDownAnnotationAction.js.map +1 -0
  56. package/dist/esm/eventDispatchers/shared/getToolsWithActionsForMouseEvent.d.ts +3 -0
  57. package/dist/esm/eventDispatchers/shared/getToolsWithActionsForMouseEvent.js +32 -0
  58. package/dist/esm/eventDispatchers/shared/getToolsWithActionsForMouseEvent.js.map +1 -0
  59. package/dist/esm/eventListeners/mouse/mouseDownListener.js +5 -1
  60. package/dist/esm/eventListeners/mouse/mouseDownListener.js.map +1 -1
  61. package/dist/esm/eventListeners/mouse/mouseMoveListener.js +5 -1
  62. package/dist/esm/eventListeners/mouse/mouseMoveListener.js.map +1 -1
  63. package/dist/esm/index.d.ts +2 -2
  64. package/dist/esm/index.js +2 -2
  65. package/dist/esm/index.js.map +1 -1
  66. package/dist/esm/store/ToolGroupManager/ToolGroup.d.ts +2 -0
  67. package/dist/esm/store/ToolGroupManager/ToolGroup.js +35 -1
  68. package/dist/esm/store/ToolGroupManager/ToolGroup.js.map +1 -1
  69. package/dist/esm/tools/AdvancedMagnifyTool.d.ts +36 -0
  70. package/dist/esm/tools/AdvancedMagnifyTool.js +440 -0
  71. package/dist/esm/tools/AdvancedMagnifyTool.js.map +1 -0
  72. package/dist/esm/tools/AdvancedMagnifyViewport.d.ts +76 -0
  73. package/dist/esm/tools/AdvancedMagnifyViewport.js +346 -0
  74. package/dist/esm/tools/AdvancedMagnifyViewport.js.map +1 -0
  75. package/dist/esm/tools/AdvancedMagnifyViewportManager.d.ts +36 -0
  76. package/dist/esm/tools/AdvancedMagnifyViewportManager.js +128 -0
  77. package/dist/esm/tools/AdvancedMagnifyViewportManager.js.map +1 -0
  78. package/dist/esm/tools/annotation/EllipticalROITool.d.ts +1 -1
  79. package/dist/esm/tools/annotation/EllipticalROITool.js +12 -8
  80. package/dist/esm/tools/annotation/EllipticalROITool.js.map +1 -1
  81. package/dist/esm/tools/index.d.ts +2 -1
  82. package/dist/esm/tools/index.js +2 -1
  83. package/dist/esm/tools/index.js.map +1 -1
  84. package/dist/esm/types/EventTypes.d.ts +9 -1
  85. package/dist/esm/types/IToolGroup.d.ts +3 -0
  86. package/dist/esm/types/ToolAction.d.ts +8 -0
  87. package/dist/esm/types/ToolAction.js +2 -0
  88. package/dist/esm/types/ToolAction.js.map +1 -0
  89. package/dist/esm/types/ToolSpecificAnnotationTypes.d.ts +11 -0
  90. package/dist/esm/types/index.d.ts +2 -1
  91. package/dist/umd/index.js +1 -1
  92. package/dist/umd/index.js.map +1 -1
  93. package/package.json +3 -3
  94. package/src/drawingSvg/getSvgDrawingHelper.ts +4 -1
  95. package/src/enums/Events.ts +9 -0
  96. package/src/eventDispatchers/mouseEventHandlers/mouseDown.ts +10 -1
  97. package/src/eventDispatchers/mouseEventHandlers/mouseDownAnnotationAction.ts +72 -0
  98. package/src/eventDispatchers/shared/getToolsWithActionsForMouseEvent.ts +66 -0
  99. package/src/eventListeners/mouse/mouseDownListener.ts +7 -1
  100. package/src/eventListeners/mouse/mouseMoveListener.ts +7 -1
  101. package/src/index.ts +2 -0
  102. package/src/store/ToolGroupManager/ToolGroup.ts +79 -2
  103. package/src/tools/AdvancedMagnifyTool.ts +725 -0
  104. package/src/tools/AdvancedMagnifyViewport.ts +624 -0
  105. package/src/tools/AdvancedMagnifyViewportManager.ts +291 -0
  106. package/src/tools/annotation/EllipticalROITool.ts +14 -9
  107. package/src/tools/index.ts +2 -0
  108. package/src/types/EventTypes.ts +23 -0
  109. package/src/types/IToolGroup.ts +7 -0
  110. package/src/types/ToolAction.ts +54 -0
  111. package/src/types/ToolSpecificAnnotationTypes.ts +12 -0
  112. package/src/types/index.ts +2 -0
@@ -0,0 +1,352 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AdvancedMagnifyViewport = exports.default = void 0;
4
+ const gl_matrix_1 = require("gl-matrix");
5
+ const core_1 = require("@cornerstonejs/core");
6
+ const enums_1 = require("../enums");
7
+ const store_1 = require("../store");
8
+ const utilities_1 = require("../utilities");
9
+ const __1 = require("..");
10
+ const _1 = require("./");
11
+ const point_1 = require("../utilities/math/point");
12
+ const MAGNIFY_CLASSNAME = 'advancedMagnifyTool';
13
+ const MAGNIFY_VIEWPORT_INITIAL_RADIUS = 125;
14
+ const isSegmentation = (actor) => actor.uid !== actor.referenceId;
15
+ class AdvancedMagnifyViewport {
16
+ constructor({ magnifyViewportId, sourceEnabledElement, radius = MAGNIFY_VIEWPORT_INITIAL_RADIUS, position = [0, 0], zoomFactor, autoPan, }) {
17
+ this._enabledElement = null;
18
+ this._sourceToolGroup = null;
19
+ this._magnifyToolGroup = null;
20
+ this._isViewportReady = false;
21
+ this._radius = 0;
22
+ this._resized = false;
23
+ this._canAutoPan = false;
24
+ this._viewportId = magnifyViewportId !== null && magnifyViewportId !== void 0 ? magnifyViewportId : core_1.utilities.uuidv4();
25
+ this._sourceEnabledElement = sourceEnabledElement;
26
+ this._autoPan = autoPan;
27
+ this.radius = radius;
28
+ this.position = position;
29
+ this.zoomFactor = zoomFactor;
30
+ this.visible = true;
31
+ this._browserMouseDownCallback = this._browserMouseDownCallback.bind(this);
32
+ this._browserMouseUpCallback = this._browserMouseUpCallback.bind(this);
33
+ this._handleToolModeChanged = this._handleToolModeChanged.bind(this);
34
+ this._mouseDragCallback = this._mouseDragCallback.bind(this);
35
+ this._resizeViewportAsync = ((0, utilities_1.debounce)(this._resizeViewport.bind(this), 1));
36
+ this._initialize();
37
+ }
38
+ get sourceEnabledElement() {
39
+ return this._sourceEnabledElement;
40
+ }
41
+ get viewportId() {
42
+ return this._viewportId;
43
+ }
44
+ get radius() {
45
+ return this._radius;
46
+ }
47
+ set radius(radius) {
48
+ if (Math.abs(this._radius - radius) > 0.00001) {
49
+ this._radius = radius;
50
+ this._resized = true;
51
+ }
52
+ }
53
+ update() {
54
+ const { radius, position, visible } = this;
55
+ const { viewport } = this._enabledElement;
56
+ const { element } = viewport;
57
+ const size = 2 * radius;
58
+ const [x, y] = position;
59
+ if (this._resized) {
60
+ this._resizeViewportAsync();
61
+ this._resized = false;
62
+ }
63
+ Object.assign(element.style, {
64
+ display: visible ? 'block' : 'hidden',
65
+ width: `${size}px`,
66
+ height: `${size}px`,
67
+ left: `${-radius}px`,
68
+ top: `${-radius}px`,
69
+ transform: `translate(${x}px, ${y}px)`,
70
+ });
71
+ if (this._isViewportReady) {
72
+ this._syncViewports();
73
+ viewport.render();
74
+ }
75
+ }
76
+ dispose() {
77
+ const { viewport } = this._enabledElement;
78
+ const { element } = viewport;
79
+ const renderingEngine = viewport.getRenderingEngine();
80
+ this._removeEventListeners(element);
81
+ renderingEngine.disableElement(viewport.id);
82
+ if (element.parentNode) {
83
+ element.parentNode.removeChild(element);
84
+ }
85
+ }
86
+ _handleToolModeChanged(evt) {
87
+ var _a;
88
+ const { _magnifyToolGroup: magnifyToolGroup } = this;
89
+ const { toolGroupId, toolName, mode, toolBindingsOptions } = evt.detail;
90
+ if (((_a = this._sourceToolGroup) === null || _a === void 0 ? void 0 : _a.id) !== toolGroupId) {
91
+ return;
92
+ }
93
+ switch (mode) {
94
+ case enums_1.ToolModes.Active:
95
+ magnifyToolGroup.setToolActive(toolName, toolBindingsOptions);
96
+ break;
97
+ case enums_1.ToolModes.Passive:
98
+ magnifyToolGroup.setToolPassive(toolName);
99
+ break;
100
+ case enums_1.ToolModes.Enabled:
101
+ magnifyToolGroup.setToolEnabled(toolName);
102
+ break;
103
+ case enums_1.ToolModes.Disabled:
104
+ magnifyToolGroup.setToolDisabled(toolName);
105
+ break;
106
+ default:
107
+ throw new Error(`Unknow tool mode (${mode})`);
108
+ }
109
+ }
110
+ _inheritBorderRadius(magnifyElement) {
111
+ const viewport = magnifyElement.querySelector('.viewport-element');
112
+ const canvas = magnifyElement.querySelector('.cornerstone-canvas');
113
+ viewport.style.borderRadius = 'inherit';
114
+ canvas.style.borderRadius = 'inherit';
115
+ }
116
+ _createViewportNode() {
117
+ const magnifyElement = document.createElement('div');
118
+ const { radius } = this;
119
+ const size = radius * 2;
120
+ magnifyElement.classList.add(MAGNIFY_CLASSNAME);
121
+ Object.assign(magnifyElement.style, {
122
+ display: 'block',
123
+ width: `${size}px`,
124
+ height: `${size}px`,
125
+ position: 'absolute',
126
+ overflow: 'hidden',
127
+ borderRadius: '50%',
128
+ boxSizing: 'border-box',
129
+ left: `${-radius}px`,
130
+ top: `${-radius}px`,
131
+ transform: `translate(-1000px, -1000px)`,
132
+ });
133
+ return magnifyElement;
134
+ }
135
+ _convertZoomFactorToParalellScale(viewport, magnifyViewport, zoomFactor) {
136
+ const { parallelScale } = viewport.getCamera();
137
+ const canvasRatio = magnifyViewport.canvas.offsetWidth / viewport.canvas.offsetWidth;
138
+ return parallelScale * (1 / zoomFactor) * canvasRatio;
139
+ }
140
+ _isStackViewport(viewport) {
141
+ return 'setStack' in viewport;
142
+ }
143
+ _isVolumeViewport(viewport) {
144
+ return 'addVolumes' in viewport;
145
+ }
146
+ _cloneToolGroups(sourceViewport, magnifyViewport) {
147
+ const sourceActors = sourceViewport.getActors();
148
+ const magnifyToolGroupId = `${magnifyViewport.id}-toolGroup`;
149
+ const sourceToolGroup = store_1.ToolGroupManager.getToolGroupForViewport(sourceViewport.id, sourceViewport.renderingEngineId);
150
+ const magnifyToolGroup = sourceToolGroup.clone(magnifyToolGroupId, (toolName) => {
151
+ const toolInstance = sourceToolGroup.getToolInstance(toolName);
152
+ const isAnnotationTool = toolInstance instanceof _1.AnnotationTool &&
153
+ !(toolInstance instanceof _1.AdvancedMagnifyTool);
154
+ return (isAnnotationTool || toolName === _1.SegmentationDisplayTool.toolName);
155
+ });
156
+ magnifyToolGroup.addViewport(magnifyViewport.id, magnifyViewport.renderingEngineId);
157
+ sourceActors.filter(isSegmentation).forEach((actor) => {
158
+ __1.segmentation.addSegmentationRepresentations(magnifyToolGroupId, [
159
+ {
160
+ segmentationId: actor.referenceId,
161
+ type: enums_1.SegmentationRepresentations.Labelmap,
162
+ },
163
+ ]);
164
+ });
165
+ return { sourceToolGroup, magnifyToolGroup };
166
+ }
167
+ _cloneStack(sourceViewport, magnifyViewport) {
168
+ const imageIds = sourceViewport.getImageIds();
169
+ magnifyViewport.setStack(imageIds).then(() => {
170
+ this._isViewportReady = true;
171
+ this.update();
172
+ });
173
+ }
174
+ _cloneVolumes(sourceViewport, magnifyViewport) {
175
+ const actors = sourceViewport.getActors();
176
+ const volumeInputArray = actors
177
+ .filter((actor) => !isSegmentation(actor))
178
+ .map((actor) => ({ volumeId: actor.uid }));
179
+ magnifyViewport.setVolumes(volumeInputArray).then(() => {
180
+ this._isViewportReady = true;
181
+ this.update();
182
+ });
183
+ return magnifyViewport;
184
+ }
185
+ _cloneViewport(sourceViewport, magnifyElement) {
186
+ const { viewportId: magnifyViewportId } = this;
187
+ const renderingEngine = sourceViewport.getRenderingEngine();
188
+ const { options: sourceViewportOptions } = sourceViewport;
189
+ const viewportInput = {
190
+ element: magnifyElement,
191
+ viewportId: magnifyViewportId,
192
+ type: sourceViewport.type,
193
+ defaultOptions: Object.assign({}, sourceViewportOptions),
194
+ };
195
+ renderingEngine.enableElement(viewportInput);
196
+ const magnifyViewport = (renderingEngine.getViewport(magnifyViewportId));
197
+ if (this._isStackViewport(sourceViewport)) {
198
+ this._cloneStack(sourceViewport, magnifyViewport);
199
+ }
200
+ else if (this._isVolumeViewport(sourceViewport)) {
201
+ this._cloneVolumes(sourceViewport, magnifyViewport);
202
+ }
203
+ this._inheritBorderRadius(magnifyElement);
204
+ const toolGroups = this._cloneToolGroups(sourceViewport, magnifyViewport);
205
+ this._sourceToolGroup = toolGroups.sourceToolGroup;
206
+ this._magnifyToolGroup = toolGroups.magnifyToolGroup;
207
+ }
208
+ _cancelMouseEventCallback(evt) {
209
+ evt.stopPropagation();
210
+ evt.preventDefault();
211
+ }
212
+ _browserMouseUpCallback(evt) {
213
+ const { element } = this._enabledElement.viewport;
214
+ document.removeEventListener('mouseup', this._browserMouseUpCallback);
215
+ element.addEventListener('mouseup', this._cancelMouseEventCallback);
216
+ element.addEventListener('mousemove', this._cancelMouseEventCallback);
217
+ }
218
+ _browserMouseDownCallback(evt) {
219
+ var _a;
220
+ const { element } = this._enabledElement.viewport;
221
+ this._canAutoPan = !!((_a = evt.target) === null || _a === void 0 ? void 0 : _a.closest('.advancedMagnifyTool'));
222
+ document.addEventListener('mouseup', this._browserMouseUpCallback);
223
+ element.removeEventListener('mouseup', this._cancelMouseEventCallback);
224
+ element.removeEventListener('mousemove', this._cancelMouseEventCallback);
225
+ }
226
+ _mouseDragCallback(evt) {
227
+ if (!store_1.state.isInteractingWithTool) {
228
+ return;
229
+ }
230
+ const { _autoPan: autoPan } = this;
231
+ if (!autoPan.enabled || !this._canAutoPan) {
232
+ return;
233
+ }
234
+ const { currentPoints } = evt.detail;
235
+ const { viewport } = this._enabledElement;
236
+ const { canvasToWorld } = viewport;
237
+ const { canvas: canvasCurrent } = currentPoints;
238
+ const { radius: magnifyRadius } = this;
239
+ const canvasCenter = [magnifyRadius, magnifyRadius];
240
+ const dist = (0, point_1.distanceToPoint)(canvasCenter, canvasCurrent);
241
+ const maxDist = magnifyRadius - autoPan.padding;
242
+ if (dist <= maxDist) {
243
+ return;
244
+ }
245
+ const panDist = dist - maxDist;
246
+ const canvasDeltaPos = gl_matrix_1.vec2.sub(gl_matrix_1.vec2.create(), canvasCurrent, canvasCenter);
247
+ gl_matrix_1.vec2.normalize(canvasDeltaPos, canvasDeltaPos);
248
+ gl_matrix_1.vec2.scale(canvasDeltaPos, canvasDeltaPos, panDist);
249
+ const newCanvasPosition = gl_matrix_1.vec2.add(gl_matrix_1.vec2.create(), this.position, canvasDeltaPos);
250
+ const currentWorldPos = canvasToWorld(this.position);
251
+ const newWorldPos = canvasToWorld(newCanvasPosition);
252
+ const worldDeltaPos = gl_matrix_1.vec3.sub(gl_matrix_1.vec3.create(), newWorldPos, currentWorldPos);
253
+ const autoPanCallbackData = {
254
+ points: {
255
+ currentPosition: {
256
+ canvas: this.position,
257
+ world: currentWorldPos,
258
+ },
259
+ newPosition: {
260
+ canvas: newCanvasPosition,
261
+ world: newWorldPos,
262
+ },
263
+ },
264
+ delta: {
265
+ canvas: canvasDeltaPos,
266
+ world: worldDeltaPos,
267
+ },
268
+ };
269
+ autoPan.callback(autoPanCallbackData);
270
+ }
271
+ _addBrowserEventListeners(element) {
272
+ document.addEventListener('mousedown', this._browserMouseDownCallback, true);
273
+ element.addEventListener('mousedown', this._cancelMouseEventCallback);
274
+ element.addEventListener('mouseup', this._cancelMouseEventCallback);
275
+ element.addEventListener('mousemove', this._cancelMouseEventCallback);
276
+ element.addEventListener('dblclick', this._cancelMouseEventCallback);
277
+ }
278
+ _removeBrowserEventListeners(element) {
279
+ document.removeEventListener('mousedown', this._browserMouseDownCallback, true);
280
+ document.removeEventListener('mouseup', this._browserMouseUpCallback);
281
+ element.removeEventListener('mousedown', this._cancelMouseEventCallback);
282
+ element.removeEventListener('mouseup', this._cancelMouseEventCallback);
283
+ element.removeEventListener('mousemove', this._cancelMouseEventCallback);
284
+ element.removeEventListener('dblclick', this._cancelMouseEventCallback);
285
+ }
286
+ _addEventListeners(element) {
287
+ core_1.eventTarget.addEventListener(enums_1.Events.TOOL_MODE_CHANGED, this._handleToolModeChanged);
288
+ element.addEventListener(enums_1.Events.MOUSE_MOVE, this._mouseDragCallback);
289
+ element.addEventListener(enums_1.Events.MOUSE_DRAG, this._mouseDragCallback);
290
+ this._addBrowserEventListeners(element);
291
+ }
292
+ _removeEventListeners(element) {
293
+ core_1.eventTarget.removeEventListener(enums_1.Events.TOOL_MODE_CHANGED, this._handleToolModeChanged);
294
+ element.addEventListener(enums_1.Events.MOUSE_MOVE, this._mouseDragCallback);
295
+ element.addEventListener(enums_1.Events.MOUSE_DRAG, this._mouseDragCallback);
296
+ this._removeBrowserEventListeners(element);
297
+ }
298
+ _initialize() {
299
+ const { _sourceEnabledElement: sourceEnabledElement } = this;
300
+ const { viewport: sourceViewport } = sourceEnabledElement;
301
+ const { canvas: sourceCanvas } = sourceViewport;
302
+ const magnifyElement = this._createViewportNode();
303
+ sourceCanvas.parentNode.appendChild(magnifyElement);
304
+ this._addEventListeners(magnifyElement);
305
+ this._cloneViewport(sourceViewport, magnifyElement);
306
+ this._enabledElement = (0, core_1.getEnabledElement)(magnifyElement);
307
+ }
308
+ _syncViewportsCameras(sourceViewport, magnifyViewport) {
309
+ const worldPos = sourceViewport.canvasToWorld(this.position);
310
+ const parallelScale = this._convertZoomFactorToParalellScale(sourceViewport, magnifyViewport, this.zoomFactor);
311
+ const { focalPoint, position, viewPlaneNormal } = magnifyViewport.getCamera();
312
+ const distance = Math.sqrt(Math.pow(focalPoint[0] - position[0], 2) +
313
+ Math.pow(focalPoint[1] - position[1], 2) +
314
+ Math.pow(focalPoint[2] - position[2], 2));
315
+ const updatedFocalPoint = [
316
+ worldPos[0],
317
+ worldPos[1],
318
+ worldPos[2],
319
+ ];
320
+ const updatedPosition = [
321
+ updatedFocalPoint[0] + distance * viewPlaneNormal[0],
322
+ updatedFocalPoint[1] + distance * viewPlaneNormal[1],
323
+ updatedFocalPoint[2] + distance * viewPlaneNormal[2],
324
+ ];
325
+ magnifyViewport.setCamera({
326
+ parallelScale,
327
+ focalPoint: updatedFocalPoint,
328
+ position: updatedPosition,
329
+ });
330
+ }
331
+ _syncStackViewports(sourceViewport, magnifyViewport) {
332
+ magnifyViewport.setImageIdIndex(sourceViewport.getCurrentImageIdIndex());
333
+ }
334
+ _syncViewports() {
335
+ const { viewport: sourceViewport } = this._sourceEnabledElement;
336
+ const { viewport: magnifyViewport } = this._enabledElement;
337
+ const sourceProperties = sourceViewport.getProperties();
338
+ magnifyViewport.setProperties(sourceProperties);
339
+ this._syncViewportsCameras(sourceViewport, magnifyViewport);
340
+ if (this._isStackViewport(sourceViewport)) {
341
+ this._syncStackViewports(sourceViewport, magnifyViewport);
342
+ }
343
+ }
344
+ _resizeViewport() {
345
+ const { viewport } = this._enabledElement;
346
+ const renderingEngine = viewport.getRenderingEngine();
347
+ renderingEngine.resize();
348
+ }
349
+ }
350
+ exports.default = AdvancedMagnifyViewport;
351
+ exports.AdvancedMagnifyViewport = AdvancedMagnifyViewport;
352
+ //# sourceMappingURL=AdvancedMagnifyViewport.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AdvancedMagnifyViewport.js","sourceRoot":"","sources":["../../../src/tools/AdvancedMagnifyViewport.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,36 @@
1
+ import type { Types } from '@cornerstonejs/core';
2
+ import { AdvancedMagnifyViewport, AutoPanCallback } from './AdvancedMagnifyViewport';
3
+ import { AdvancedMagnifyAnnotation } from '../types/ToolSpecificAnnotationTypes';
4
+ export declare type MagnifyViewportInfo = {
5
+ magnifyViewportId?: string;
6
+ sourceEnabledElement: Types.IEnabledElement;
7
+ position: Types.Point2;
8
+ radius: number;
9
+ zoomFactor: number;
10
+ autoPan: {
11
+ enabled: boolean;
12
+ padding: number;
13
+ callback: AutoPanCallback;
14
+ };
15
+ };
16
+ declare class AdvancedMagnifyViewportManager {
17
+ private static _singleton;
18
+ private _magnifyViewportsMap;
19
+ constructor();
20
+ static getInstance(): AdvancedMagnifyViewportManager;
21
+ createViewport: (annotation: AdvancedMagnifyAnnotation, viewportInfo: MagnifyViewportInfo) => AdvancedMagnifyViewport;
22
+ getViewport(magnifyViewportId: string): AdvancedMagnifyViewport;
23
+ dispose(): void;
24
+ private _destroyViewport;
25
+ private _destroyViewports;
26
+ private _annotationRemovedCallback;
27
+ private _getMagnifyViewportsMapEntriesBySourceViewportId;
28
+ private _newStackImageCallback;
29
+ private _newVolumeImageCallback;
30
+ private _addEventListeners;
31
+ private _removeEventListeners;
32
+ private _addSourceElementEventListener;
33
+ private _removeSourceElementEventListener;
34
+ private _initialize;
35
+ }
36
+ export { AdvancedMagnifyViewportManager as default, AdvancedMagnifyViewportManager, };
@@ -0,0 +1,133 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.AdvancedMagnifyViewportManager = exports.default = void 0;
4
+ const gl_matrix_1 = require("gl-matrix");
5
+ const core_1 = require("@cornerstonejs/core");
6
+ const enums_1 = require("../enums");
7
+ const AdvancedMagnifyViewport_1 = require("./AdvancedMagnifyViewport");
8
+ const ADVANCED_MAGNIFY_TOOL_NAME = 'AdvancedMagnify';
9
+ const PARALLEL_THRESHOLD = 1 - core_1.CONSTANTS.EPSILON;
10
+ const { Events } = core_1.Enums;
11
+ class AdvancedMagnifyViewportManager {
12
+ constructor() {
13
+ this.createViewport = (annotation, viewportInfo) => {
14
+ const { magnifyViewportId, sourceEnabledElement, position, radius, zoomFactor, autoPan, } = viewportInfo;
15
+ const { viewport: sourceViewport } = sourceEnabledElement;
16
+ const { element: sourceElement } = sourceViewport;
17
+ const magnifyViewport = new AdvancedMagnifyViewport_1.AdvancedMagnifyViewport({
18
+ magnifyViewportId,
19
+ sourceEnabledElement,
20
+ radius,
21
+ position,
22
+ zoomFactor,
23
+ autoPan,
24
+ });
25
+ this._addSourceElementEventListener(sourceElement);
26
+ this._magnifyViewportsMap.set(magnifyViewport.viewportId, {
27
+ annotation,
28
+ magnifyViewport,
29
+ });
30
+ return magnifyViewport;
31
+ };
32
+ this._annotationRemovedCallback = (evt) => {
33
+ const { annotation } = evt.detail;
34
+ if (annotation.metadata.toolName !== ADVANCED_MAGNIFY_TOOL_NAME) {
35
+ return;
36
+ }
37
+ this._destroyViewport(annotation.data.magnifyViewportId);
38
+ };
39
+ this._newStackImageCallback = (evt) => {
40
+ const { viewportId: sourceViewportId, imageId } = evt.detail;
41
+ const magnifyViewportsMapEntries = this._getMagnifyViewportsMapEntriesBySourceViewportId(sourceViewportId);
42
+ magnifyViewportsMapEntries.forEach(({ annotation }) => {
43
+ annotation.metadata.referencedImageId = imageId;
44
+ annotation.invalidated = true;
45
+ });
46
+ };
47
+ this._newVolumeImageCallback = (evt) => {
48
+ const { renderingEngineId, viewportId: sourceViewportId } = evt.detail;
49
+ const renderingEngine = (0, core_1.getRenderingEngine)(renderingEngineId);
50
+ const sourceViewport = renderingEngine.getViewport(sourceViewportId);
51
+ const { viewPlaneNormal: currentViewPlaneNormal } = sourceViewport.getCamera();
52
+ const magnifyViewportsMapEntries = this._getMagnifyViewportsMapEntriesBySourceViewportId(sourceViewportId);
53
+ magnifyViewportsMapEntries.forEach(({ annotation }) => {
54
+ const { viewPlaneNormal } = annotation.metadata;
55
+ const isParallel = Math.abs(gl_matrix_1.vec3.dot(viewPlaneNormal, currentViewPlaneNormal)) >
56
+ PARALLEL_THRESHOLD;
57
+ if (!isParallel) {
58
+ return;
59
+ }
60
+ const { handles } = annotation.data;
61
+ const worldImagePlanePoint = sourceViewport.canvasToWorld([0, 0]);
62
+ const vecHandleToImagePlane = gl_matrix_1.vec3.sub(gl_matrix_1.vec3.create(), worldImagePlanePoint, handles.points[0]);
63
+ const worldDist = gl_matrix_1.vec3.dot(vecHandleToImagePlane, currentViewPlaneNormal);
64
+ const worldDelta = gl_matrix_1.vec3.scale(gl_matrix_1.vec3.create(), currentViewPlaneNormal, worldDist);
65
+ for (let i = 0, len = handles.points.length; i < len; i++) {
66
+ const point = handles.points[i];
67
+ point[0] += worldDelta[0];
68
+ point[1] += worldDelta[1];
69
+ point[2] += worldDelta[2];
70
+ }
71
+ annotation.invalidated = true;
72
+ });
73
+ };
74
+ this._magnifyViewportsMap = new Map();
75
+ this._initialize();
76
+ }
77
+ static getInstance() {
78
+ var _a;
79
+ AdvancedMagnifyViewportManager._singleton =
80
+ (_a = AdvancedMagnifyViewportManager._singleton) !== null && _a !== void 0 ? _a : new AdvancedMagnifyViewportManager();
81
+ return AdvancedMagnifyViewportManager._singleton;
82
+ }
83
+ getViewport(magnifyViewportId) {
84
+ var _a;
85
+ return (_a = this._magnifyViewportsMap.get(magnifyViewportId)) === null || _a === void 0 ? void 0 : _a.magnifyViewport;
86
+ }
87
+ dispose() {
88
+ this._removeEventListeners();
89
+ this._destroyViewports();
90
+ }
91
+ _destroyViewport(magnifyViewportId) {
92
+ const magnifyViewportMapEntry = this._magnifyViewportsMap.get(magnifyViewportId);
93
+ if (magnifyViewportMapEntry) {
94
+ const { magnifyViewport } = magnifyViewportMapEntry;
95
+ const { viewport: sourceViewport } = magnifyViewport.sourceEnabledElement;
96
+ const { element: sourceElement } = sourceViewport;
97
+ this._removeSourceElementEventListener(sourceElement);
98
+ magnifyViewport.dispose();
99
+ this._magnifyViewportsMap.delete(magnifyViewportId);
100
+ }
101
+ }
102
+ _destroyViewports() {
103
+ const magnifyViewportIds = Array.from(this._magnifyViewportsMap.keys());
104
+ magnifyViewportIds.forEach((magnifyViewportId) => this._destroyViewport(magnifyViewportId));
105
+ }
106
+ _getMagnifyViewportsMapEntriesBySourceViewportId(sourceViewportId) {
107
+ const magnifyViewportsMapEntries = Array.from(this._magnifyViewportsMap.values());
108
+ return magnifyViewportsMapEntries.filter(({ magnifyViewport }) => {
109
+ const { viewport } = magnifyViewport.sourceEnabledElement;
110
+ return viewport.id === sourceViewportId;
111
+ });
112
+ }
113
+ _addEventListeners() {
114
+ core_1.eventTarget.addEventListener(enums_1.Events.ANNOTATION_REMOVED, this._annotationRemovedCallback);
115
+ }
116
+ _removeEventListeners() {
117
+ core_1.eventTarget.removeEventListener(enums_1.Events.ANNOTATION_REMOVED, this._annotationRemovedCallback);
118
+ }
119
+ _addSourceElementEventListener(element) {
120
+ element.addEventListener(Events.STACK_NEW_IMAGE, this._newStackImageCallback);
121
+ element.addEventListener(Events.VOLUME_NEW_IMAGE, this._newVolumeImageCallback);
122
+ }
123
+ _removeSourceElementEventListener(element) {
124
+ element.removeEventListener(Events.STACK_NEW_IMAGE, this._newStackImageCallback);
125
+ element.removeEventListener(Events.VOLUME_NEW_IMAGE, this._newVolumeImageCallback);
126
+ }
127
+ _initialize() {
128
+ this._addEventListeners();
129
+ }
130
+ }
131
+ exports.default = AdvancedMagnifyViewportManager;
132
+ exports.AdvancedMagnifyViewportManager = AdvancedMagnifyViewportManager;
133
+ //# sourceMappingURL=AdvancedMagnifyViewportManager.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"AdvancedMagnifyViewportManager.js","sourceRoot":"","sources":["../../../src/tools/AdvancedMagnifyViewportManager.ts"],"names":[],"mappings":"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"}
@@ -12,7 +12,7 @@ declare class EllipticalROITool extends AnnotationTool {
12
12
  viewportIdsToRender: Array<string>;
13
13
  handleIndex?: number;
14
14
  movingTextBox?: boolean;
15
- centerCanvas?: Array<number>;
15
+ centerWorld?: Array<number>;
16
16
  canvasWidth?: number;
17
17
  canvasHeight?: number;
18
18
  originalHandleCanvas?: Array<number>;
@@ -90,7 +90,7 @@ class EllipticalROITool extends base_1.AnnotationTool {
90
90
  this.editData = {
91
91
  annotation,
92
92
  viewportIdsToRender,
93
- centerCanvas: canvasPos,
93
+ centerWorld: worldPos,
94
94
  newAnnotation: true,
95
95
  hasMoved: false,
96
96
  };
@@ -152,6 +152,7 @@ class EllipticalROITool extends base_1.AnnotationTool {
152
152
  let movingTextBox = false;
153
153
  let handleIndex;
154
154
  let centerCanvas;
155
+ let centerWorld;
155
156
  let canvasWidth;
156
157
  let canvasHeight;
157
158
  let originalHandleCanvas;
@@ -160,8 +161,8 @@ class EllipticalROITool extends base_1.AnnotationTool {
160
161
  }
161
162
  else {
162
163
  const { points } = data.handles;
163
- const enabledElement = (0, core_1.getEnabledElement)(element);
164
- const { worldToCanvas } = enabledElement.viewport;
164
+ const { viewport } = (0, core_1.getEnabledElement)(element);
165
+ const { worldToCanvas, canvasToWorld } = viewport;
165
166
  handleIndex = points.findIndex((p) => p === handle);
166
167
  const pointsCanvas = points.map(worldToCanvas);
167
168
  originalHandleCanvas = pointsCanvas[handleIndex];
@@ -171,6 +172,7 @@ class EllipticalROITool extends base_1.AnnotationTool {
171
172
  (pointsCanvas[2][0] + pointsCanvas[3][0]) / 2,
172
173
  (pointsCanvas[0][1] + pointsCanvas[1][1]) / 2,
173
174
  ];
175
+ centerWorld = canvasToWorld(centerCanvas);
174
176
  }
175
177
  const viewportIdsToRender = (0, viewportFilters_1.getViewportIdsWithToolToRender)(element, this.getToolName());
176
178
  this.editData = {
@@ -179,7 +181,7 @@ class EllipticalROITool extends base_1.AnnotationTool {
179
181
  handleIndex,
180
182
  canvasWidth,
181
183
  canvasHeight,
182
- centerCanvas,
184
+ centerWorld,
183
185
  originalHandleCanvas,
184
186
  movingTextBox,
185
187
  };
@@ -229,7 +231,8 @@ class EllipticalROITool extends base_1.AnnotationTool {
229
231
  const enabledElement = (0, core_1.getEnabledElement)(element);
230
232
  const { renderingEngine, viewport } = enabledElement;
231
233
  const { canvasToWorld } = viewport;
232
- const { annotation, viewportIdsToRender, centerCanvas } = this.editData;
234
+ const { annotation, viewportIdsToRender, centerWorld } = this.editData;
235
+ const centerCanvas = viewport.worldToCanvas(centerWorld);
233
236
  const { data } = annotation;
234
237
  const dX = Math.abs(currentCanvasPoints[0] - centerCanvas[0]);
235
238
  const dY = Math.abs(currentCanvasPoints[1] - centerCanvas[1]);
@@ -285,9 +288,10 @@ class EllipticalROITool extends base_1.AnnotationTool {
285
288
  this._dragHandle = (evt) => {
286
289
  const eventDetail = evt.detail;
287
290
  const { element } = eventDetail;
288
- const enabledElement = (0, core_1.getEnabledElement)(element);
289
- const { canvasToWorld } = enabledElement.viewport;
290
- const { annotation, canvasWidth, canvasHeight, handleIndex, centerCanvas, originalHandleCanvas, } = this.editData;
291
+ const { viewport } = (0, core_1.getEnabledElement)(element);
292
+ const { canvasToWorld, worldToCanvas } = viewport;
293
+ const { annotation, canvasWidth, canvasHeight, handleIndex, centerWorld, originalHandleCanvas, } = this.editData;
294
+ const centerCanvas = viewport.worldToCanvas(centerWorld);
291
295
  const { data } = annotation;
292
296
  const { points } = data.handles;
293
297
  const { currentPoints } = eventDetail;