@cornerstonejs/core 0.22.2 → 0.23.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/RenderingEngine/BaseVolumeViewport.d.ts +35 -0
- package/dist/cjs/RenderingEngine/BaseVolumeViewport.js +346 -0
- package/dist/cjs/RenderingEngine/BaseVolumeViewport.js.map +1 -0
- package/dist/cjs/RenderingEngine/RenderingEngine.js +6 -1
- package/dist/cjs/RenderingEngine/RenderingEngine.js.map +1 -1
- package/dist/cjs/RenderingEngine/VolumeViewport.d.ts +4 -21
- package/dist/cjs/RenderingEngine/VolumeViewport.js +26 -296
- package/dist/cjs/RenderingEngine/VolumeViewport.js.map +1 -1
- package/dist/cjs/RenderingEngine/VolumeViewport3D.d.ts +5 -0
- package/dist/cjs/RenderingEngine/VolumeViewport3D.js +22 -0
- package/dist/cjs/RenderingEngine/VolumeViewport3D.js.map +1 -0
- package/dist/cjs/RenderingEngine/helpers/addVolumesToViewports.js +6 -3
- package/dist/cjs/RenderingEngine/helpers/addVolumesToViewports.js.map +1 -1
- package/dist/cjs/RenderingEngine/helpers/setVolumesForViewports.js +6 -3
- package/dist/cjs/RenderingEngine/helpers/setVolumesForViewports.js.map +1 -1
- package/dist/cjs/RenderingEngine/helpers/viewportTypeToViewportClass.d.ts +2 -0
- package/dist/cjs/RenderingEngine/helpers/viewportTypeToViewportClass.js +2 -0
- package/dist/cjs/RenderingEngine/helpers/viewportTypeToViewportClass.js.map +1 -1
- package/dist/cjs/RenderingEngine/helpers/volumeNewImageEventDispatcher.js +3 -3
- package/dist/cjs/RenderingEngine/helpers/volumeNewImageEventDispatcher.js.map +1 -1
- package/dist/cjs/RenderingEngine/index.d.ts +2 -1
- package/dist/cjs/RenderingEngine/index.js +3 -1
- package/dist/cjs/RenderingEngine/index.js.map +1 -1
- package/dist/cjs/constants/index.d.ts +2 -1
- package/dist/cjs/constants/index.js +3 -1
- package/dist/cjs/constants/index.js.map +1 -1
- package/dist/cjs/constants/viewportPresets.d.ts +3 -0
- package/dist/cjs/constants/viewportPresets.js +318 -0
- package/dist/cjs/constants/viewportPresets.js.map +1 -0
- package/dist/cjs/enums/ViewportType.d.ts +2 -1
- package/dist/cjs/enums/ViewportType.js +1 -0
- package/dist/cjs/enums/ViewportType.js.map +1 -1
- package/dist/cjs/index.d.ts +2 -1
- package/dist/cjs/index.js +3 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/types/ViewportPreset.d.ts +13 -0
- package/dist/cjs/types/ViewportPreset.js +3 -0
- package/dist/cjs/types/ViewportPreset.js.map +1 -0
- package/dist/cjs/types/index.d.ts +2 -1
- package/dist/cjs/utilities/applyPreset.d.ts +3 -0
- package/dist/cjs/utilities/applyPreset.js +94 -0
- package/dist/cjs/utilities/applyPreset.js.map +1 -0
- package/dist/cjs/utilities/index.d.ts +2 -1
- package/dist/cjs/utilities/index.js +3 -1
- package/dist/cjs/utilities/index.js.map +1 -1
- package/dist/esm/RenderingEngine/BaseVolumeViewport.d.ts +35 -0
- package/dist/esm/RenderingEngine/BaseVolumeViewport.js +302 -0
- package/dist/esm/RenderingEngine/BaseVolumeViewport.js.map +1 -0
- package/dist/esm/RenderingEngine/RenderingEngine.js +6 -1
- package/dist/esm/RenderingEngine/RenderingEngine.js.map +1 -1
- package/dist/esm/RenderingEngine/VolumeViewport.d.ts +4 -21
- package/dist/esm/RenderingEngine/VolumeViewport.js +21 -271
- package/dist/esm/RenderingEngine/VolumeViewport.js.map +1 -1
- package/dist/esm/RenderingEngine/VolumeViewport3D.d.ts +5 -0
- package/dist/esm/RenderingEngine/VolumeViewport3D.js +17 -0
- package/dist/esm/RenderingEngine/VolumeViewport3D.js.map +1 -0
- package/dist/esm/RenderingEngine/helpers/addVolumesToViewports.js +3 -3
- package/dist/esm/RenderingEngine/helpers/addVolumesToViewports.js.map +1 -1
- package/dist/esm/RenderingEngine/helpers/setVolumesForViewports.js +3 -3
- package/dist/esm/RenderingEngine/helpers/setVolumesForViewports.js.map +1 -1
- package/dist/esm/RenderingEngine/helpers/viewportTypeToViewportClass.d.ts +2 -0
- package/dist/esm/RenderingEngine/helpers/viewportTypeToViewportClass.js +2 -0
- package/dist/esm/RenderingEngine/helpers/viewportTypeToViewportClass.js.map +1 -1
- package/dist/esm/RenderingEngine/helpers/volumeNewImageEventDispatcher.js +3 -3
- package/dist/esm/RenderingEngine/helpers/volumeNewImageEventDispatcher.js.map +1 -1
- package/dist/esm/RenderingEngine/index.d.ts +2 -1
- package/dist/esm/RenderingEngine/index.js +2 -1
- package/dist/esm/RenderingEngine/index.js.map +1 -1
- package/dist/esm/constants/index.d.ts +2 -1
- package/dist/esm/constants/index.js +2 -1
- package/dist/esm/constants/index.js.map +1 -1
- package/dist/esm/constants/viewportPresets.d.ts +3 -0
- package/dist/esm/constants/viewportPresets.js +316 -0
- package/dist/esm/constants/viewportPresets.js.map +1 -0
- package/dist/esm/enums/ViewportType.d.ts +2 -1
- package/dist/esm/enums/ViewportType.js +1 -0
- package/dist/esm/enums/ViewportType.js.map +1 -1
- package/dist/esm/index.d.ts +2 -1
- package/dist/esm/index.js +2 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/types/ViewportPreset.d.ts +13 -0
- package/dist/esm/types/ViewportPreset.js +2 -0
- package/dist/esm/types/ViewportPreset.js.map +1 -0
- package/dist/esm/types/index.d.ts +2 -1
- package/dist/esm/utilities/applyPreset.d.ts +3 -0
- package/dist/esm/utilities/applyPreset.js +88 -0
- package/dist/esm/utilities/applyPreset.js.map +1 -0
- package/dist/esm/utilities/index.d.ts +2 -1
- package/dist/esm/utilities/index.js +2 -1
- package/dist/esm/utilities/index.js.map +1 -1
- package/dist/umd/index.js +1 -1
- package/dist/umd/index.js.map +1 -1
- package/package.json +2 -2
|
@@ -1,27 +1,4 @@
|
|
|
1
1
|
"use strict";
|
|
2
|
-
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
-
if (k2 === undefined) k2 = k;
|
|
4
|
-
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
-
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
-
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
-
}
|
|
8
|
-
Object.defineProperty(o, k2, desc);
|
|
9
|
-
}) : (function(o, m, k, k2) {
|
|
10
|
-
if (k2 === undefined) k2 = k;
|
|
11
|
-
o[k2] = m[k];
|
|
12
|
-
}));
|
|
13
|
-
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
-
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
-
}) : function(o, v) {
|
|
16
|
-
o["default"] = v;
|
|
17
|
-
});
|
|
18
|
-
var __importStar = (this && this.__importStar) || function (mod) {
|
|
19
|
-
if (mod && mod.__esModule) return mod;
|
|
20
|
-
var result = {};
|
|
21
|
-
if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
|
|
22
|
-
__setModuleDefault(result, mod);
|
|
23
|
-
return result;
|
|
24
|
-
};
|
|
25
2
|
var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
|
|
26
3
|
function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
|
|
27
4
|
return new (P || (P = Promise))(function (resolve, reject) {
|
|
@@ -38,82 +15,17 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
38
15
|
const gl_matrix_1 = require("gl-matrix");
|
|
39
16
|
const Plane_1 = __importDefault(require("@kitware/vtk.js/Common/DataModel/Plane"));
|
|
40
17
|
const cache_1 = __importDefault(require("../cache"));
|
|
41
|
-
const ViewportType_1 = __importDefault(require("../enums/ViewportType"));
|
|
42
|
-
const Viewport_1 = __importDefault(require("./Viewport"));
|
|
43
|
-
const helpers_1 = require("./helpers");
|
|
44
|
-
const volumeNewImageEventDispatcher_1 = __importStar(require("./helpers/volumeNewImageEventDispatcher"));
|
|
45
|
-
const volumeLoader_1 = require("../volumeLoader");
|
|
46
|
-
const vtkSlabCamera_1 = __importDefault(require("./vtkClasses/vtkSlabCamera"));
|
|
47
|
-
const init_1 = require("../init");
|
|
48
18
|
const transformWorldToIndex_1 = __importDefault(require("../utilities/transformWorldToIndex"));
|
|
49
19
|
const constants_1 = require("../constants");
|
|
50
20
|
const enums_1 = require("../enums");
|
|
51
|
-
const
|
|
52
|
-
|
|
53
|
-
class VolumeViewport extends Viewport_1.default {
|
|
21
|
+
const BaseVolumeViewport_1 = __importDefault(require("./BaseVolumeViewport"));
|
|
22
|
+
class VolumeViewport extends BaseVolumeViewport_1.default {
|
|
54
23
|
constructor(props) {
|
|
55
24
|
super(props);
|
|
56
|
-
this.useCPURendering = false;
|
|
57
25
|
this._useAcquisitionPlaneForViewPlane = false;
|
|
58
|
-
this.getFrameOfReferenceUID = () => {
|
|
59
|
-
return this._FrameOfReferenceUID;
|
|
60
|
-
};
|
|
61
|
-
this.canvasToWorld = (canvasPos) => {
|
|
62
|
-
const vtkCamera = this.getVtkActiveCamera();
|
|
63
|
-
vtkCamera.setIsPerformingCoordinateTransformation(true);
|
|
64
|
-
const renderer = this.getRenderer();
|
|
65
|
-
const offscreenMultiRenderWindow = this.getRenderingEngine().offscreenMultiRenderWindow;
|
|
66
|
-
const openGLRenderWindow = offscreenMultiRenderWindow.getOpenGLRenderWindow();
|
|
67
|
-
const size = openGLRenderWindow.getSize();
|
|
68
|
-
const devicePixelRatio = window.devicePixelRatio || 1;
|
|
69
|
-
const canvasPosWithDPR = [
|
|
70
|
-
canvasPos[0] * devicePixelRatio,
|
|
71
|
-
canvasPos[1] * devicePixelRatio,
|
|
72
|
-
];
|
|
73
|
-
const displayCoord = [
|
|
74
|
-
canvasPosWithDPR[0] + this.sx,
|
|
75
|
-
canvasPosWithDPR[1] + this.sy,
|
|
76
|
-
];
|
|
77
|
-
displayCoord[1] = size[1] - displayCoord[1];
|
|
78
|
-
const worldCoord = openGLRenderWindow.displayToWorld(displayCoord[0], displayCoord[1], 0, renderer);
|
|
79
|
-
vtkCamera.setIsPerformingCoordinateTransformation(false);
|
|
80
|
-
return [worldCoord[0], worldCoord[1], worldCoord[2]];
|
|
81
|
-
};
|
|
82
|
-
this.worldToCanvas = (worldPos) => {
|
|
83
|
-
const vtkCamera = this.getVtkActiveCamera();
|
|
84
|
-
vtkCamera.setIsPerformingCoordinateTransformation(true);
|
|
85
|
-
const renderer = this.getRenderer();
|
|
86
|
-
const offscreenMultiRenderWindow = this.getRenderingEngine().offscreenMultiRenderWindow;
|
|
87
|
-
const openGLRenderWindow = offscreenMultiRenderWindow.getOpenGLRenderWindow();
|
|
88
|
-
const size = openGLRenderWindow.getSize();
|
|
89
|
-
const displayCoord = openGLRenderWindow.worldToDisplay(...worldPos, renderer);
|
|
90
|
-
displayCoord[1] = size[1] - displayCoord[1];
|
|
91
|
-
const canvasCoord = [
|
|
92
|
-
displayCoord[0] - this.sx,
|
|
93
|
-
displayCoord[1] - this.sy,
|
|
94
|
-
];
|
|
95
|
-
const devicePixelRatio = window.devicePixelRatio || 1;
|
|
96
|
-
const canvasCoordWithDPR = [
|
|
97
|
-
canvasCoord[0] / devicePixelRatio,
|
|
98
|
-
canvasCoord[1] / devicePixelRatio,
|
|
99
|
-
];
|
|
100
|
-
vtkCamera.setIsPerformingCoordinateTransformation(false);
|
|
101
|
-
return canvasCoordWithDPR;
|
|
102
|
-
};
|
|
103
26
|
this.getCurrentImageIdIndex = () => {
|
|
104
27
|
return this._getImageIdIndex();
|
|
105
28
|
};
|
|
106
|
-
this.hasImageURI = (imageURI) => {
|
|
107
|
-
const volumeActors = this.getActors().filter(({ actor }) => actor.isA('vtkVolume'));
|
|
108
|
-
return volumeActors.some(({ uid }) => {
|
|
109
|
-
const volume = cache_1.default.getVolume(uid);
|
|
110
|
-
if (!volume || !volume.imageIds) {
|
|
111
|
-
return false;
|
|
112
|
-
}
|
|
113
|
-
const volumeImageURIs = volume.imageIds.map(utilities_1.imageIdToURI);
|
|
114
|
-
return volumeImageURIs.includes(imageURI);
|
|
115
|
-
});
|
|
116
|
-
};
|
|
117
29
|
this.getCurrentImageId = () => {
|
|
118
30
|
const index = this._getImageIdIndex();
|
|
119
31
|
if (isNaN(index)) {
|
|
@@ -146,27 +58,10 @@ class VolumeViewport extends Viewport_1.default {
|
|
|
146
58
|
const distance = gl_matrix_1.vec3.dot(sub, viewPlaneNormal);
|
|
147
59
|
return Math.round(Math.abs(distance) / spacingInNormal);
|
|
148
60
|
};
|
|
149
|
-
this.useCPURendering = (0, init_1.getShouldUseCPURendering)();
|
|
150
|
-
if (this.useCPURendering) {
|
|
151
|
-
throw new Error('VolumeViewports cannot be used whilst CPU Fallback Rendering is enabled.');
|
|
152
|
-
}
|
|
153
|
-
const renderer = this.getRenderer();
|
|
154
|
-
const camera = vtkSlabCamera_1.default.newInstance();
|
|
155
|
-
renderer.setActiveCamera(camera);
|
|
156
|
-
switch (this.type) {
|
|
157
|
-
case ViewportType_1.default.ORTHOGRAPHIC:
|
|
158
|
-
camera.setParallelProjection(true);
|
|
159
|
-
break;
|
|
160
|
-
case ViewportType_1.default.PERSPECTIVE:
|
|
161
|
-
camera.setParallelProjection(false);
|
|
162
|
-
break;
|
|
163
|
-
default:
|
|
164
|
-
throw new Error(`Unrecognized viewport type: ${this.type}`);
|
|
165
|
-
}
|
|
166
|
-
this.initializeVolumeNewImageEventDispatcher();
|
|
167
61
|
const { orientation } = this.options;
|
|
168
62
|
if (orientation && orientation !== enums_1.OrientationAxis.ACQUISITION) {
|
|
169
63
|
const { viewPlaneNormal, viewUp } = this._getOrientationVectors(orientation);
|
|
64
|
+
const camera = this.getVtkActiveCamera();
|
|
170
65
|
camera.setDirectionOfProjection(-viewPlaneNormal[0], -viewPlaneNormal[1], -viewPlaneNormal[2]);
|
|
171
66
|
camera.setViewUpFrom(viewUp);
|
|
172
67
|
this.resetCamera();
|
|
@@ -174,70 +69,10 @@ class VolumeViewport extends Viewport_1.default {
|
|
|
174
69
|
}
|
|
175
70
|
this._useAcquisitionPlaneForViewPlane = true;
|
|
176
71
|
}
|
|
177
|
-
static get useCustomRenderingPipeline() {
|
|
178
|
-
return false;
|
|
179
|
-
}
|
|
180
|
-
initializeVolumeNewImageEventDispatcher() {
|
|
181
|
-
const volumeNewImageHandlerBound = volumeNewImageHandler.bind(this);
|
|
182
|
-
const volumeNewImageCleanUpBound = volumeNewImageCleanUp.bind(this);
|
|
183
|
-
function volumeNewImageHandler(cameraEvent) {
|
|
184
|
-
const { viewportId } = cameraEvent.detail;
|
|
185
|
-
if (viewportId !== this.id || this.isDisabled) {
|
|
186
|
-
return;
|
|
187
|
-
}
|
|
188
|
-
const viewportImageData = this.getImageData();
|
|
189
|
-
if (!viewportImageData) {
|
|
190
|
-
return;
|
|
191
|
-
}
|
|
192
|
-
(0, volumeNewImageEventDispatcher_1.default)(cameraEvent);
|
|
193
|
-
}
|
|
194
|
-
function volumeNewImageCleanUp(evt) {
|
|
195
|
-
const { viewportId } = evt.detail;
|
|
196
|
-
if (viewportId !== this.id) {
|
|
197
|
-
return;
|
|
198
|
-
}
|
|
199
|
-
this.element.removeEventListener(enums_1.Events.CAMERA_MODIFIED, volumeNewImageHandlerBound);
|
|
200
|
-
eventTarget_1.default.removeEventListener(enums_1.Events.ELEMENT_DISABLED, volumeNewImageCleanUpBound);
|
|
201
|
-
(0, volumeNewImageEventDispatcher_1.resetVolumeNewImageState)(viewportId);
|
|
202
|
-
}
|
|
203
|
-
this.element.removeEventListener(enums_1.Events.CAMERA_MODIFIED, volumeNewImageHandlerBound);
|
|
204
|
-
this.element.addEventListener(enums_1.Events.CAMERA_MODIFIED, volumeNewImageHandlerBound);
|
|
205
|
-
eventTarget_1.default.addEventListener(enums_1.Events.ELEMENT_DISABLED, volumeNewImageCleanUpBound);
|
|
206
|
-
}
|
|
207
|
-
setProperties({ voiRange } = {}, volumeId, suppressEvents = false) {
|
|
208
|
-
if (volumeId !== undefined && !this.getActor(volumeId)) {
|
|
209
|
-
return;
|
|
210
|
-
}
|
|
211
|
-
const actorEntries = this.getActors();
|
|
212
|
-
if (!actorEntries.length) {
|
|
213
|
-
return;
|
|
214
|
-
}
|
|
215
|
-
let volumeActor;
|
|
216
|
-
if (volumeId) {
|
|
217
|
-
const actorEntry = actorEntries.find((entry) => {
|
|
218
|
-
return entry.uid === volumeId;
|
|
219
|
-
});
|
|
220
|
-
volumeActor = actorEntry === null || actorEntry === void 0 ? void 0 : actorEntry.actor;
|
|
221
|
-
}
|
|
222
|
-
if (!volumeActor) {
|
|
223
|
-
volumeActor = actorEntries[0].actor;
|
|
224
|
-
volumeId = actorEntries[0].uid;
|
|
225
|
-
}
|
|
226
|
-
if (!voiRange) {
|
|
227
|
-
return;
|
|
228
|
-
}
|
|
229
|
-
const { lower, upper } = voiRange;
|
|
230
|
-
volumeActor.getProperty().getRGBTransferFunction(0).setRange(lower, upper);
|
|
231
|
-
if (!suppressEvents) {
|
|
232
|
-
const eventDetail = {
|
|
233
|
-
viewportId: this.id,
|
|
234
|
-
range: voiRange,
|
|
235
|
-
volumeId: volumeId,
|
|
236
|
-
};
|
|
237
|
-
(0, utilities_1.triggerEvent)(this.element, enums_1.Events.VOI_MODIFIED, eventDetail);
|
|
238
|
-
}
|
|
239
|
-
}
|
|
240
72
|
setVolumes(volumeInputArray, immediate = false, suppressEvents = false) {
|
|
73
|
+
const _super = Object.create(null, {
|
|
74
|
+
setVolumes: { get: () => super.setVolumes }
|
|
75
|
+
});
|
|
241
76
|
return __awaiter(this, void 0, void 0, function* () {
|
|
242
77
|
const firstImageVolume = cache_1.default.getVolume(volumeInputArray[0].volumeId);
|
|
243
78
|
if (!firstImageVolume) {
|
|
@@ -247,32 +82,13 @@ class VolumeViewport extends Viewport_1.default {
|
|
|
247
82
|
this._setViewPlaneToAcquisitionPlane(firstImageVolume);
|
|
248
83
|
this._useAcquisitionPlaneForViewPlane = false;
|
|
249
84
|
}
|
|
250
|
-
|
|
251
|
-
yield this._isValidVolumeInputArray(volumeInputArray, FrameOfReferenceUID);
|
|
252
|
-
this._FrameOfReferenceUID = FrameOfReferenceUID;
|
|
253
|
-
const volumeActors = [];
|
|
254
|
-
for (let i = 0; i < volumeInputArray.length; i++) {
|
|
255
|
-
const { volumeId, actorUID, slabThickness } = volumeInputArray[i];
|
|
256
|
-
const actor = yield (0, helpers_1.createVolumeActor)(volumeInputArray[i], this.element, this.id, suppressEvents);
|
|
257
|
-
const uid = actorUID || volumeId;
|
|
258
|
-
volumeActors.push({
|
|
259
|
-
uid,
|
|
260
|
-
actor,
|
|
261
|
-
slabThickness,
|
|
262
|
-
referenceId: volumeId,
|
|
263
|
-
});
|
|
264
|
-
}
|
|
265
|
-
this._setVolumeActors(volumeActors);
|
|
266
|
-
(0, utilities_1.triggerEvent)(this.element, enums_1.Events.VOLUME_VIEWPORT_NEW_VOLUME, {
|
|
267
|
-
viewportId: this.id,
|
|
268
|
-
volumeActors,
|
|
269
|
-
});
|
|
270
|
-
if (immediate) {
|
|
271
|
-
this.render();
|
|
272
|
-
}
|
|
85
|
+
return _super.setVolumes.call(this, volumeInputArray, immediate, suppressEvents);
|
|
273
86
|
});
|
|
274
87
|
}
|
|
275
88
|
addVolumes(volumeInputArray, immediate = false, suppressEvents = false) {
|
|
89
|
+
const _super = Object.create(null, {
|
|
90
|
+
addVolumes: { get: () => super.addVolumes }
|
|
91
|
+
});
|
|
276
92
|
return __awaiter(this, void 0, void 0, function* () {
|
|
277
93
|
const firstImageVolume = cache_1.default.getVolume(volumeInputArray[0].volumeId);
|
|
278
94
|
if (!firstImageVolume) {
|
|
@@ -282,34 +98,9 @@ class VolumeViewport extends Viewport_1.default {
|
|
|
282
98
|
this._setViewPlaneToAcquisitionPlane(firstImageVolume);
|
|
283
99
|
this._useAcquisitionPlaneForViewPlane = false;
|
|
284
100
|
}
|
|
285
|
-
|
|
286
|
-
yield this._isValidVolumeInputArray(volumeInputArray, this._FrameOfReferenceUID);
|
|
287
|
-
for (let i = 0; i < volumeInputArray.length; i++) {
|
|
288
|
-
const { volumeId, visibility, actorUID, slabThickness } = volumeInputArray[i];
|
|
289
|
-
const actor = yield (0, helpers_1.createVolumeActor)(volumeInputArray[i], this.element, this.id, suppressEvents);
|
|
290
|
-
if (visibility === false) {
|
|
291
|
-
actor.setVisibility(false);
|
|
292
|
-
}
|
|
293
|
-
const uid = actorUID || volumeId;
|
|
294
|
-
volumeActors.push({
|
|
295
|
-
uid,
|
|
296
|
-
actor,
|
|
297
|
-
slabThickness,
|
|
298
|
-
referenceId: volumeId,
|
|
299
|
-
});
|
|
300
|
-
}
|
|
301
|
-
this.addActors(volumeActors);
|
|
302
|
-
if (immediate) {
|
|
303
|
-
this.render();
|
|
304
|
-
}
|
|
101
|
+
return _super.addVolumes.call(this, volumeInputArray, immediate, suppressEvents);
|
|
305
102
|
});
|
|
306
103
|
}
|
|
307
|
-
removeVolumeActors(actorUIDs, immediate = false) {
|
|
308
|
-
this.removeActors(actorUIDs);
|
|
309
|
-
if (immediate) {
|
|
310
|
-
this.render();
|
|
311
|
-
}
|
|
312
|
-
}
|
|
313
104
|
setOrientation(orientation, immediate = true) {
|
|
314
105
|
let viewPlaneNormal, viewUp;
|
|
315
106
|
if (constants_1.MPR_CAMERA_VALUES[orientation]) {
|
|
@@ -381,22 +172,6 @@ class VolumeViewport extends Viewport_1.default {
|
|
|
381
172
|
});
|
|
382
173
|
this.resetCamera();
|
|
383
174
|
}
|
|
384
|
-
_isValidVolumeInputArray(volumeInputArray, FrameOfReferenceUID) {
|
|
385
|
-
return __awaiter(this, void 0, void 0, function* () {
|
|
386
|
-
const numVolumes = volumeInputArray.length;
|
|
387
|
-
for (let i = 1; i < numVolumes; i++) {
|
|
388
|
-
const volumeInput = volumeInputArray[i];
|
|
389
|
-
const imageVolume = yield (0, volumeLoader_1.loadVolume)(volumeInput.volumeId);
|
|
390
|
-
if (!imageVolume) {
|
|
391
|
-
throw new Error(`imageVolume with id: ${imageVolume.volumeId} does not exist`);
|
|
392
|
-
}
|
|
393
|
-
if (FrameOfReferenceUID !== imageVolume.metadata.FrameOfReferenceUID) {
|
|
394
|
-
throw new Error(`Volumes being added to viewport ${this.id} do not share the same FrameOfReferenceUID. This is not yet supported`);
|
|
395
|
-
}
|
|
396
|
-
}
|
|
397
|
-
return true;
|
|
398
|
-
});
|
|
399
|
-
}
|
|
400
175
|
getIntensityFromWorld(point) {
|
|
401
176
|
const { actor, uid } = this.getDefaultActor();
|
|
402
177
|
if (!actor.isA('vtkVolume')) {
|
|
@@ -411,13 +186,21 @@ class VolumeViewport extends Viewport_1.default {
|
|
|
411
186
|
index[0];
|
|
412
187
|
return volume.scalarData[voxelIndex];
|
|
413
188
|
}
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
419
|
-
|
|
420
|
-
|
|
189
|
+
setBlendMode(blendMode, filterActorUIDs = [], immediate = false) {
|
|
190
|
+
let actorEntries = this.getActors();
|
|
191
|
+
if (filterActorUIDs && filterActorUIDs.length > 0) {
|
|
192
|
+
actorEntries = actorEntries.filter((actorEntry) => {
|
|
193
|
+
return filterActorUIDs.includes(actorEntry.uid);
|
|
194
|
+
});
|
|
195
|
+
}
|
|
196
|
+
actorEntries.forEach((actorEntry) => {
|
|
197
|
+
const { actor } = actorEntry;
|
|
198
|
+
const mapper = actor.getMapper();
|
|
199
|
+
mapper.setBlendMode(blendMode);
|
|
200
|
+
});
|
|
201
|
+
if (immediate) {
|
|
202
|
+
this.render();
|
|
203
|
+
}
|
|
421
204
|
}
|
|
422
205
|
resetCamera(resetPan = true, resetZoom = true, resetToCenter = true) {
|
|
423
206
|
super.resetCamera(resetPan, resetZoom, resetToCenter);
|
|
@@ -452,22 +235,6 @@ class VolumeViewport extends Viewport_1.default {
|
|
|
452
235
|
});
|
|
453
236
|
return true;
|
|
454
237
|
}
|
|
455
|
-
setBlendMode(blendMode, filterActorUIDs = [], immediate = false) {
|
|
456
|
-
let actorEntries = this.getActors();
|
|
457
|
-
if (filterActorUIDs && filterActorUIDs.length > 0) {
|
|
458
|
-
actorEntries = actorEntries.filter((actorEntry) => {
|
|
459
|
-
return filterActorUIDs.includes(actorEntry.uid);
|
|
460
|
-
});
|
|
461
|
-
}
|
|
462
|
-
actorEntries.forEach((actorEntry) => {
|
|
463
|
-
const { actor } = actorEntry;
|
|
464
|
-
const mapper = actor.getMapper();
|
|
465
|
-
mapper.setBlendMode(blendMode);
|
|
466
|
-
});
|
|
467
|
-
if (immediate) {
|
|
468
|
-
this.render();
|
|
469
|
-
}
|
|
470
|
-
}
|
|
471
238
|
setSlabThickness(slabThickness, filterActorUIDs = []) {
|
|
472
239
|
let actorEntries = this.getActors();
|
|
473
240
|
if (filterActorUIDs && filterActorUIDs.length > 0) {
|
|
@@ -495,43 +262,6 @@ class VolumeViewport extends Viewport_1.default {
|
|
|
495
262
|
});
|
|
496
263
|
return slabThickness;
|
|
497
264
|
}
|
|
498
|
-
hasVolumeId(volumeId) {
|
|
499
|
-
const actorEntries = this.getActors();
|
|
500
|
-
return actorEntries.some((actorEntry) => {
|
|
501
|
-
return actorEntry.uid === volumeId;
|
|
502
|
-
});
|
|
503
|
-
}
|
|
504
|
-
getImageData(volumeId) {
|
|
505
|
-
var _a;
|
|
506
|
-
const defaultActor = this.getDefaultActor();
|
|
507
|
-
if (!defaultActor) {
|
|
508
|
-
return;
|
|
509
|
-
}
|
|
510
|
-
const { uid: defaultActorUID } = defaultActor;
|
|
511
|
-
volumeId = volumeId !== null && volumeId !== void 0 ? volumeId : defaultActorUID;
|
|
512
|
-
const { actor } = this.getActor(volumeId);
|
|
513
|
-
if (!actor.isA('vtkVolume')) {
|
|
514
|
-
return;
|
|
515
|
-
}
|
|
516
|
-
const volume = cache_1.default.getVolume(volumeId);
|
|
517
|
-
const vtkImageData = actor.getMapper().getInputData();
|
|
518
|
-
return {
|
|
519
|
-
dimensions: vtkImageData.getDimensions(),
|
|
520
|
-
spacing: vtkImageData.getSpacing(),
|
|
521
|
-
origin: vtkImageData.getOrigin(),
|
|
522
|
-
direction: vtkImageData.getDirection(),
|
|
523
|
-
scalarData: vtkImageData.getPointData().getScalars().getData(),
|
|
524
|
-
imageData: actor.getMapper().getInputData(),
|
|
525
|
-
metadata: {
|
|
526
|
-
Modality: (_a = volume === null || volume === void 0 ? void 0 : volume.metadata) === null || _a === void 0 ? void 0 : _a.Modality,
|
|
527
|
-
},
|
|
528
|
-
scaling: volume.scaling,
|
|
529
|
-
hasPixelSpacing: true,
|
|
530
|
-
};
|
|
531
|
-
}
|
|
532
|
-
_setVolumeActors(volumeActorEntries) {
|
|
533
|
-
this.setActors(volumeActorEntries);
|
|
534
|
-
}
|
|
535
265
|
}
|
|
536
266
|
exports.default = VolumeViewport;
|
|
537
267
|
//# sourceMappingURL=VolumeViewport.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"VolumeViewport.js","sourceRoot":"","sources":["../../../src/RenderingEngine/VolumeViewport.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"VolumeViewport.js","sourceRoot":"","sources":["../../../src/RenderingEngine/VolumeViewport.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
+
};
|
|
5
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
+
const BaseVolumeViewport_1 = __importDefault(require("./BaseVolumeViewport"));
|
|
7
|
+
const constants_1 = require("../constants");
|
|
8
|
+
class VolumeViewport3D extends BaseVolumeViewport_1.default {
|
|
9
|
+
resetCamera(resetPan = true, resetZoom = true, resetToCenter = true) {
|
|
10
|
+
super.resetCamera(resetPan, resetZoom, resetToCenter);
|
|
11
|
+
const activeCamera = this.getVtkActiveCamera();
|
|
12
|
+
if (activeCamera.getParallelProjection()) {
|
|
13
|
+
activeCamera.setClippingRange(-constants_1.RENDERING_DEFAULTS.MAXIMUM_RAY_DISTANCE, constants_1.RENDERING_DEFAULTS.MAXIMUM_RAY_DISTANCE);
|
|
14
|
+
}
|
|
15
|
+
else {
|
|
16
|
+
activeCamera.setClippingRange(constants_1.RENDERING_DEFAULTS.MINIMUM_SLAB_THICKNESS, constants_1.RENDERING_DEFAULTS.MAXIMUM_RAY_DISTANCE);
|
|
17
|
+
}
|
|
18
|
+
return;
|
|
19
|
+
}
|
|
20
|
+
}
|
|
21
|
+
exports.default = VolumeViewport3D;
|
|
22
|
+
//# sourceMappingURL=VolumeViewport3D.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"VolumeViewport3D.js","sourceRoot":"","sources":["../../../src/RenderingEngine/VolumeViewport3D.ts"],"names":[],"mappings":";;;;;AAAA,8EAAsD;AACtD,4CAAkD;AASlD,MAAM,gBAAiB,SAAQ,4BAAkB;IACxC,WAAW,CAChB,QAAQ,GAAG,IAAI,EACf,SAAS,GAAG,IAAI,EAChB,aAAa,GAAG,IAAI;QAEpB,KAAK,CAAC,WAAW,CAAC,QAAQ,EAAE,SAAS,EAAE,aAAa,CAAC,CAAC;QACtD,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAE/C,IAAI,YAAY,CAAC,qBAAqB,EAAE,EAAE;YACxC,YAAY,CAAC,gBAAgB,CAC3B,CAAC,8BAAkB,CAAC,oBAAoB,EACxC,8BAAkB,CAAC,oBAAoB,CACxC,CAAC;SACH;aAAM;YACL,YAAY,CAAC,gBAAgB,CAC3B,8BAAkB,CAAC,sBAAsB,EACzC,8BAAkB,CAAC,oBAAoB,CACxC,CAAC;SACH;QAED,OAAO;IACT,CAAC;CACF;AAED,kBAAe,gBAAgB,CAAC"}
|
|
@@ -8,8 +8,11 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
8
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
9
|
});
|
|
10
10
|
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
11
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
const
|
|
15
|
+
const BaseVolumeViewport_1 = __importDefault(require("../BaseVolumeViewport"));
|
|
13
16
|
function addVolumesToViewports(renderingEngine, volumeInputs, viewportIds, immediateRender = false, suppressEvents = false) {
|
|
14
17
|
return __awaiter(this, void 0, void 0, function* () {
|
|
15
18
|
for (const viewportId of viewportIds) {
|
|
@@ -17,8 +20,8 @@ function addVolumesToViewports(renderingEngine, volumeInputs, viewportIds, immed
|
|
|
17
20
|
if (!viewport) {
|
|
18
21
|
throw new Error(`Viewport with Id ${viewportId} does not exist`);
|
|
19
22
|
}
|
|
20
|
-
if (!(viewport instanceof
|
|
21
|
-
console.warn(`Viewport with Id ${viewportId} is not a
|
|
23
|
+
if (!(viewport instanceof BaseVolumeViewport_1.default)) {
|
|
24
|
+
console.warn(`Viewport with Id ${viewportId} is not a BaseVolumeViewport. Cannot add volume to this viewport.`);
|
|
22
25
|
return;
|
|
23
26
|
}
|
|
24
27
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"addVolumesToViewports.js","sourceRoot":"","sources":["../../../../src/RenderingEngine/helpers/addVolumesToViewports.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"addVolumesToViewports.js","sourceRoot":"","sources":["../../../../src/RenderingEngine/helpers/addVolumesToViewports.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AACA,+EAAuD;AAevD,SAAe,qBAAqB,CAClC,eAAiC,EACjC,YAAiC,EACjC,WAA0B,EAC1B,eAAe,GAAG,KAAK,EACvB,cAAc,GAAG,KAAK;;QAGtB,KAAK,MAAM,UAAU,IAAI,WAAW,EAAE;YACpC,MAAM,QAAQ,GAAG,eAAe,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;YAEzD,IAAI,CAAC,QAAQ,EAAE;gBACb,MAAM,IAAI,KAAK,CAAC,oBAAoB,UAAU,iBAAiB,CAAC,CAAC;aAClE;YAGD,IAAI,CAAC,CAAC,QAAQ,YAAY,4BAAkB,CAAC,EAAE;gBAC7C,OAAO,CAAC,IAAI,CACV,oBAAoB,UAAU,mEAAmE,CAClG,CAAC;gBAEF,OAAO;aACR;SACF;QAED,MAAM,iBAAiB,GAAG,WAAW,CAAC,GAAG,CAAC,CAAO,UAAU,EAAE,EAAE;YAC7D,MAAM,QAAQ,GAAG,eAAe,CAAC,WAAW,CAAC,UAAU,CAAmB,CAAC;YAE3E,MAAM,QAAQ,CAAC,UAAU,CAAC,YAAY,EAAE,eAAe,EAAE,cAAc,CAAC,CAAC;QAC3E,CAAC,CAAA,CAAC,CAAC;QAEH,MAAM,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;QACrC,OAAO;IACT,CAAC;CAAA;AAED,kBAAe,qBAAqB,CAAC"}
|
|
@@ -8,8 +8,11 @@ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, ge
|
|
|
8
8
|
step((generator = generator.apply(thisArg, _arguments || [])).next());
|
|
9
9
|
});
|
|
10
10
|
};
|
|
11
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
12
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
13
|
+
};
|
|
11
14
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
12
|
-
const
|
|
15
|
+
const BaseVolumeViewport_1 = __importDefault(require("../BaseVolumeViewport"));
|
|
13
16
|
function setVolumesForViewports(renderingEngine, volumeInputs, viewportIds, immediateRender = false, suppressEvents = false) {
|
|
14
17
|
return __awaiter(this, void 0, void 0, function* () {
|
|
15
18
|
viewportIds.forEach((viewportId) => {
|
|
@@ -17,8 +20,8 @@ function setVolumesForViewports(renderingEngine, volumeInputs, viewportIds, imme
|
|
|
17
20
|
if (!viewport) {
|
|
18
21
|
throw new Error(`Viewport with Id ${viewportId} does not exist`);
|
|
19
22
|
}
|
|
20
|
-
if (!(viewport instanceof
|
|
21
|
-
throw new Error('setVolumesForViewports only supports VolumeViewport');
|
|
23
|
+
if (!(viewport instanceof BaseVolumeViewport_1.default)) {
|
|
24
|
+
throw new Error('setVolumesForViewports only supports VolumeViewport and VolumeViewport3D');
|
|
22
25
|
}
|
|
23
26
|
});
|
|
24
27
|
const setVolumePromises = viewportIds.map((viewportId) => __awaiter(this, void 0, void 0, function* () {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"setVolumesForViewports.js","sourceRoot":"","sources":["../../../../src/RenderingEngine/helpers/setVolumesForViewports.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"setVolumesForViewports.js","sourceRoot":"","sources":["../../../../src/RenderingEngine/helpers/setVolumesForViewports.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAAA,+EAAuD;AAmBvD,SAAe,sBAAsB,CACnC,eAAiC,EACjC,YAAiC,EACjC,WAA0B,EAC1B,eAAe,GAAG,KAAK,EACvB,cAAc,GAAG,KAAK;;QAGtB,WAAW,CAAC,OAAO,CAAC,CAAC,UAAU,EAAE,EAAE;YACjC,MAAM,QAAQ,GAAG,eAAe,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;YAEzD,IAAI,CAAC,QAAQ,EAAE;gBACb,MAAM,IAAI,KAAK,CAAC,oBAAoB,UAAU,iBAAiB,CAAC,CAAC;aAClE;YAGD,IAAI,CAAC,CAAC,QAAQ,YAAY,4BAAkB,CAAC,EAAE;gBAC7C,MAAM,IAAI,KAAK,CAAC,0EAA0E,CAAC,CAAC;aAC7F;QACH,CAAC,CAAC,CAAC;QAEH,MAAM,iBAAiB,GAAG,WAAW,CAAC,GAAG,CAAC,CAAO,UAAU,EAAE,EAAE;YAC7D,MAAM,QAAQ,GAAG,eAAe,CAAC,WAAW,CAAC,UAAU,CAAoB,CAAC;YAE5E,MAAM,QAAQ,CAAC,UAAU,CAAC,YAAY,EAAE,eAAe,EAAE,cAAc,CAAC,CAAC;QAC3E,CAAC,CAAA,CAAC,CAAC;QAEH,MAAM,OAAO,CAAC,GAAG,CAAC,iBAAiB,CAAC,CAAC;QAErC,OAAO;IACT,CAAC;CAAA;AAED,kBAAe,sBAAsB,CAAC"}
|
|
@@ -1,8 +1,10 @@
|
|
|
1
1
|
import StackViewport from '../StackViewport';
|
|
2
2
|
import VolumeViewport from '../VolumeViewport';
|
|
3
|
+
import VolumeViewport3D from '../VolumeViewport3D';
|
|
3
4
|
declare const viewportTypeToViewportClass: {
|
|
4
5
|
orthographic: typeof VolumeViewport;
|
|
5
6
|
perspective: typeof VolumeViewport;
|
|
6
7
|
stack: typeof StackViewport;
|
|
8
|
+
volume3d: typeof VolumeViewport3D;
|
|
7
9
|
};
|
|
8
10
|
export default viewportTypeToViewportClass;
|
|
@@ -6,10 +6,12 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
const StackViewport_1 = __importDefault(require("../StackViewport"));
|
|
7
7
|
const VolumeViewport_1 = __importDefault(require("../VolumeViewport"));
|
|
8
8
|
const ViewportType_1 = __importDefault(require("../../enums/ViewportType"));
|
|
9
|
+
const VolumeViewport3D_1 = __importDefault(require("../VolumeViewport3D"));
|
|
9
10
|
const viewportTypeToViewportClass = {
|
|
10
11
|
[ViewportType_1.default.ORTHOGRAPHIC]: VolumeViewport_1.default,
|
|
11
12
|
[ViewportType_1.default.PERSPECTIVE]: VolumeViewport_1.default,
|
|
12
13
|
[ViewportType_1.default.STACK]: StackViewport_1.default,
|
|
14
|
+
[ViewportType_1.default.VOLUME_3D]: VolumeViewport3D_1.default,
|
|
13
15
|
};
|
|
14
16
|
exports.default = viewportTypeToViewportClass;
|
|
15
17
|
//# sourceMappingURL=viewportTypeToViewportClass.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"viewportTypeToViewportClass.js","sourceRoot":"","sources":["../../../../src/RenderingEngine/helpers/viewportTypeToViewportClass.ts"],"names":[],"mappings":";;;;;AACA,qEAA6C;AAC7C,uEAA+C;AAC/C,4EAAoD;
|
|
1
|
+
{"version":3,"file":"viewportTypeToViewportClass.js","sourceRoot":"","sources":["../../../../src/RenderingEngine/helpers/viewportTypeToViewportClass.ts"],"names":[],"mappings":";;;;;AACA,qEAA6C;AAC7C,uEAA+C;AAC/C,4EAAoD;AACpD,2EAAmD;AAEnD,MAAM,2BAA2B,GAAG;IAClC,CAAC,sBAAY,CAAC,YAAY,CAAC,EAAE,wBAAc;IAC3C,CAAC,sBAAY,CAAC,WAAW,CAAC,EAAE,wBAAc;IAC1C,CAAC,sBAAY,CAAC,KAAK,CAAC,EAAE,uBAAa;IACnC,CAAC,sBAAY,CAAC,SAAS,CAAC,EAAE,0BAAgB;CAC3C,CAAC;AAEF,kBAAe,2BAA2B,CAAC"}
|
|
@@ -7,7 +7,7 @@ exports.resetVolumeNewImageState = void 0;
|
|
|
7
7
|
const utilities_1 = require("../../utilities");
|
|
8
8
|
const enums_1 = require("../../enums");
|
|
9
9
|
const getRenderingEngine_1 = require("../getRenderingEngine");
|
|
10
|
-
const
|
|
10
|
+
const BaseVolumeViewport_1 = __importDefault(require("../BaseVolumeViewport"));
|
|
11
11
|
const state = {};
|
|
12
12
|
function resetVolumeNewImageState(viewportId) {
|
|
13
13
|
if (state[viewportId] !== undefined) {
|
|
@@ -19,8 +19,8 @@ function volumeNewImageEventDispatcher(cameraEvent) {
|
|
|
19
19
|
const { renderingEngineId, viewportId } = cameraEvent.detail;
|
|
20
20
|
const renderingEngine = (0, getRenderingEngine_1.getRenderingEngine)(renderingEngineId);
|
|
21
21
|
const viewport = renderingEngine.getViewport(viewportId);
|
|
22
|
-
if (!(viewport instanceof
|
|
23
|
-
throw new Error(`volumeNewImageEventDispatcher: viewport is not a
|
|
22
|
+
if (!(viewport instanceof BaseVolumeViewport_1.default)) {
|
|
23
|
+
throw new Error(`volumeNewImageEventDispatcher: viewport is not a BaseVolumeViewport`);
|
|
24
24
|
}
|
|
25
25
|
if (state[viewport.id] === undefined) {
|
|
26
26
|
state[viewport.id] = 0;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"volumeNewImageEventDispatcher.js","sourceRoot":"","sources":["../../../../src/RenderingEngine/helpers/volumeNewImageEventDispatcher.ts"],"names":[],"mappings":";;;;;;AAAA,+CAGyB;AAEzB,uCAAqC;AACrC,8DAA2D;AAC3D
|
|
1
|
+
{"version":3,"file":"volumeNewImageEventDispatcher.js","sourceRoot":"","sources":["../../../../src/RenderingEngine/helpers/volumeNewImageEventDispatcher.ts"],"names":[],"mappings":";;;;;;AAAA,+CAGyB;AAEzB,uCAAqC;AACrC,8DAA2D;AAC3D,+EAAuD;AAKvD,MAAM,KAAK,GAAqB,EAAE,CAAC;AAEnC,SAAgB,wBAAwB,CAAC,UAAkB;IACzD,IAAI,KAAK,CAAC,UAAU,CAAC,KAAK,SAAS,EAAE;QACnC,OAAO,KAAK,CAAC,UAAU,CAAC,CAAC;KAC1B;AACH,CAAC;AAJD,4DAIC;AAYD,SAAS,6BAA6B,CACpC,WAA2C;IAE3C,MAAM,EAAE,iBAAiB,EAAE,UAAU,EAAE,GAAG,WAAW,CAAC,MAAM,CAAC;IAC7D,MAAM,eAAe,GAAG,IAAA,uCAAkB,EAAC,iBAAiB,CAAC,CAAC;IAC9D,MAAM,QAAQ,GAAG,eAAe,CAAC,WAAW,CAAC,UAAU,CAAC,CAAC;IAEzD,IAAI,CAAC,CAAC,QAAQ,YAAY,4BAAkB,CAAC,EAAE;QAC7C,MAAM,IAAI,KAAK,CACb,qEAAqE,CACtE,CAAC;KACH;IAED,IAAI,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,KAAK,SAAS,EAAE;QACpC,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC;KACxB;IAED,MAAM,EAAE,cAAc,EAAE,UAAU,EAAE,GAClC,IAAA,8CAAkC,EAAC,QAAQ,CAAC,CAAC;IAE/C,IAAI,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,KAAK,UAAU,EAAE;QACrC,OAAO;KACR;IAED,KAAK,CAAC,QAAQ,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC;IAEhC,MAAM,WAAW,GAAyC;QACxD,UAAU;QACV,UAAU;QACV,iBAAiB;QACjB,cAAc;KACf,CAAC;IAEF,IAAA,wBAAY,EAAC,QAAQ,CAAC,OAAO,EAAE,cAAM,CAAC,gBAAgB,EAAE,WAAW,CAAC,CAAC;AACvE,CAAC;AAED,kBAAe,6BAA6B,CAAC"}
|
|
@@ -2,6 +2,7 @@ import RenderingEngine from './RenderingEngine';
|
|
|
2
2
|
import getRenderingEngine from './getRenderingEngine';
|
|
3
3
|
import VolumeViewport from './VolumeViewport';
|
|
4
4
|
import StackViewport from './StackViewport';
|
|
5
|
+
import VolumeViewport3D from './VolumeViewport3D';
|
|
5
6
|
import { createVolumeActor, createVolumeMapper, getOrCreateCanvas } from './helpers';
|
|
6
|
-
export { getRenderingEngine, RenderingEngine, VolumeViewport, createVolumeActor, createVolumeMapper, getOrCreateCanvas, StackViewport, };
|
|
7
|
+
export { getRenderingEngine, RenderingEngine, VolumeViewport, VolumeViewport3D, createVolumeActor, createVolumeMapper, getOrCreateCanvas, StackViewport, };
|
|
7
8
|
export default RenderingEngine;
|