@cornerstonejs/core 1.42.0 → 1.43.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.js +3 -0
- package/dist/cjs/RenderingEngine/BaseVolumeViewport.js.map +1 -1
- package/dist/cjs/RenderingEngine/StackViewport.js +2 -1
- package/dist/cjs/RenderingEngine/StackViewport.js.map +1 -1
- package/dist/cjs/RenderingEngine/Viewport.d.ts +1 -0
- package/dist/cjs/RenderingEngine/Viewport.js +3 -0
- package/dist/cjs/RenderingEngine/Viewport.js.map +1 -1
- package/dist/cjs/RenderingEngine/helpers/createVolumeActor.js +2 -1
- package/dist/cjs/RenderingEngine/helpers/createVolumeActor.js.map +1 -1
- package/dist/cjs/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.js +1 -1
- package/dist/cjs/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.js.map +1 -1
- package/dist/cjs/cache/cache.d.ts +6 -3
- package/dist/cjs/cache/cache.js +43 -6
- package/dist/cjs/cache/cache.js.map +1 -1
- package/dist/cjs/cache/classes/ImageVolume.d.ts +25 -5
- package/dist/cjs/cache/classes/ImageVolume.js +302 -13
- package/dist/cjs/cache/classes/ImageVolume.js.map +1 -1
- package/dist/cjs/eventTarget.d.ts +1 -0
- package/dist/cjs/eventTarget.js +13 -1
- package/dist/cjs/eventTarget.js.map +1 -1
- package/dist/cjs/init.js +2 -0
- package/dist/cjs/init.js.map +1 -1
- package/dist/cjs/loaders/imageLoader.d.ts +6 -1
- package/dist/cjs/loaders/imageLoader.js +26 -12
- package/dist/cjs/loaders/imageLoader.js.map +1 -1
- package/dist/cjs/loaders/volumeLoader.d.ts +13 -9
- package/dist/cjs/loaders/volumeLoader.js +58 -5
- package/dist/cjs/loaders/volumeLoader.js.map +1 -1
- package/dist/cjs/types/BoundsLPS.d.ts +3 -0
- package/dist/cjs/types/BoundsLPS.js +3 -0
- package/dist/cjs/types/BoundsLPS.js.map +1 -0
- package/dist/cjs/types/Cornerstone3DConfig.d.ts +1 -0
- package/dist/cjs/types/IDynamicImageVolume.d.ts +2 -2
- package/dist/cjs/types/IImage.d.ts +5 -0
- package/dist/cjs/types/IImageVolume.d.ts +7 -2
- package/dist/cjs/types/ILoadObject.d.ts +2 -2
- package/dist/cjs/types/IViewport.d.ts +1 -0
- package/dist/cjs/types/IVolume.d.ts +3 -26
- package/dist/cjs/types/ImageVolumeProps.d.ts +6 -0
- package/dist/cjs/types/ImageVolumeProps.js +3 -0
- package/dist/cjs/types/ImageVolumeProps.js.map +1 -0
- package/dist/cjs/types/VolumeProps.d.ts +27 -0
- package/dist/cjs/types/VolumeProps.js +3 -0
- package/dist/cjs/types/VolumeProps.js.map +1 -0
- package/dist/cjs/types/index.d.ts +5 -2
- package/dist/cjs/utilities/VoxelManager.d.ts +2 -2
- package/dist/cjs/utilities/VoxelManager.js +13 -4
- package/dist/cjs/utilities/VoxelManager.js.map +1 -1
- package/dist/cjs/utilities/cacheUtils.d.ts +2 -0
- package/dist/cjs/utilities/cacheUtils.js +96 -0
- package/dist/cjs/utilities/cacheUtils.js.map +1 -0
- package/dist/cjs/utilities/convertStackToVolumeViewport.d.ts +12 -0
- package/dist/cjs/utilities/convertStackToVolumeViewport.js +61 -0
- package/dist/cjs/utilities/convertStackToVolumeViewport.js.map +1 -0
- package/dist/cjs/utilities/convertVolumeToStackViewport.d.ts +9 -0
- package/dist/cjs/utilities/convertVolumeToStackViewport.js +95 -0
- package/dist/cjs/utilities/convertVolumeToStackViewport.js.map +1 -0
- package/dist/cjs/utilities/generateVolumePropsFromImageIds.d.ts +3 -0
- package/dist/cjs/utilities/generateVolumePropsFromImageIds.js +124 -0
- package/dist/cjs/utilities/generateVolumePropsFromImageIds.js.map +1 -0
- package/dist/cjs/utilities/index.d.ts +6 -1
- package/dist/cjs/utilities/index.js +12 -1
- package/dist/cjs/utilities/index.js.map +1 -1
- package/dist/cjs/utilities/planar.d.ts +1 -1
- package/dist/cjs/utilities/planar.js +5 -1
- package/dist/cjs/utilities/planar.js.map +1 -1
- package/dist/cjs/utilities/roundNumber.d.ts +4 -0
- package/dist/cjs/utilities/roundNumber.js +36 -0
- package/dist/cjs/utilities/roundNumber.js.map +1 -0
- package/dist/esm/RenderingEngine/BaseVolumeViewport.js +3 -0
- package/dist/esm/RenderingEngine/BaseVolumeViewport.js.map +1 -1
- package/dist/esm/RenderingEngine/StackViewport.js +2 -1
- package/dist/esm/RenderingEngine/StackViewport.js.map +1 -1
- package/dist/esm/RenderingEngine/Viewport.js +3 -0
- package/dist/esm/RenderingEngine/Viewport.js.map +1 -1
- package/dist/esm/RenderingEngine/helpers/createVolumeActor.js +1 -1
- package/dist/esm/RenderingEngine/helpers/createVolumeActor.js.map +1 -1
- package/dist/esm/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.js +1 -1
- package/dist/esm/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.js.map +1 -1
- package/dist/esm/cache/cache.js +43 -6
- package/dist/esm/cache/cache.js.map +1 -1
- package/dist/esm/cache/classes/ImageVolume.js +279 -14
- package/dist/esm/cache/classes/ImageVolume.js.map +1 -1
- package/dist/esm/eventTarget.js +13 -1
- package/dist/esm/eventTarget.js.map +1 -1
- package/dist/esm/init.js +2 -0
- package/dist/esm/init.js.map +1 -1
- package/dist/esm/loaders/imageLoader.js +23 -9
- package/dist/esm/loaders/imageLoader.js.map +1 -1
- package/dist/esm/loaders/volumeLoader.js +58 -5
- package/dist/esm/loaders/volumeLoader.js.map +1 -1
- package/dist/esm/types/BoundsLPS.js +2 -0
- package/dist/esm/types/BoundsLPS.js.map +1 -0
- package/dist/esm/types/ImageVolumeProps.js +2 -0
- package/dist/esm/types/ImageVolumeProps.js.map +1 -0
- package/dist/esm/types/VolumeProps.js +2 -0
- package/dist/esm/types/VolumeProps.js.map +1 -0
- package/dist/esm/utilities/VoxelManager.js +13 -4
- package/dist/esm/utilities/VoxelManager.js.map +1 -1
- package/dist/esm/utilities/cacheUtils.js +65 -0
- package/dist/esm/utilities/cacheUtils.js.map +1 -0
- package/dist/esm/utilities/convertStackToVolumeViewport.js +49 -0
- package/dist/esm/utilities/convertStackToVolumeViewport.js.map +1 -0
- package/dist/esm/utilities/convertVolumeToStackViewport.js +58 -0
- package/dist/esm/utilities/convertVolumeToStackViewport.js.map +1 -0
- package/dist/esm/utilities/generateVolumePropsFromImageIds.js +118 -0
- package/dist/esm/utilities/generateVolumePropsFromImageIds.js.map +1 -0
- package/dist/esm/utilities/index.js +6 -1
- package/dist/esm/utilities/index.js.map +1 -1
- package/dist/esm/utilities/planar.js +5 -1
- package/dist/esm/utilities/planar.js.map +1 -1
- package/dist/esm/utilities/roundNumber.js +33 -0
- package/dist/esm/utilities/roundNumber.js.map +1 -0
- package/dist/types/RenderingEngine/BaseVolumeViewport.d.ts.map +1 -1
- package/dist/types/RenderingEngine/StackViewport.d.ts.map +1 -1
- package/dist/types/RenderingEngine/Viewport.d.ts +1 -0
- package/dist/types/RenderingEngine/Viewport.d.ts.map +1 -1
- package/dist/types/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.d.ts.map +1 -1
- package/dist/types/cache/cache.d.ts +6 -3
- package/dist/types/cache/cache.d.ts.map +1 -1
- package/dist/types/cache/classes/ImageVolume.d.ts +25 -5
- package/dist/types/cache/classes/ImageVolume.d.ts.map +1 -1
- package/dist/types/eventTarget.d.ts +1 -0
- package/dist/types/eventTarget.d.ts.map +1 -1
- package/dist/types/loaders/imageLoader.d.ts +6 -1
- package/dist/types/loaders/imageLoader.d.ts.map +1 -1
- package/dist/types/loaders/volumeLoader.d.ts +13 -9
- package/dist/types/loaders/volumeLoader.d.ts.map +1 -1
- package/dist/types/types/BoundsLPS.d.ts +4 -0
- package/dist/types/types/BoundsLPS.d.ts.map +1 -0
- package/dist/types/types/Cornerstone3DConfig.d.ts +1 -0
- package/dist/types/types/Cornerstone3DConfig.d.ts.map +1 -1
- package/dist/types/types/IDynamicImageVolume.d.ts +2 -2
- package/dist/types/types/IDynamicImageVolume.d.ts.map +1 -1
- package/dist/types/types/IImage.d.ts +5 -0
- package/dist/types/types/IImage.d.ts.map +1 -1
- package/dist/types/types/IImageVolume.d.ts +7 -2
- package/dist/types/types/IImageVolume.d.ts.map +1 -1
- package/dist/types/types/ILoadObject.d.ts +2 -2
- package/dist/types/types/ILoadObject.d.ts.map +1 -1
- package/dist/types/types/IViewport.d.ts +1 -0
- package/dist/types/types/IViewport.d.ts.map +1 -1
- package/dist/types/types/IVolume.d.ts +3 -26
- package/dist/types/types/IVolume.d.ts.map +1 -1
- package/dist/types/types/ImageVolumeProps.d.ts +7 -0
- package/dist/types/types/ImageVolumeProps.d.ts.map +1 -0
- package/dist/types/types/VolumeProps.d.ts +28 -0
- package/dist/types/types/VolumeProps.d.ts.map +1 -0
- package/dist/types/types/index.d.ts +5 -2
- package/dist/types/types/index.d.ts.map +1 -1
- package/dist/types/utilities/VoxelManager.d.ts +2 -2
- package/dist/types/utilities/VoxelManager.d.ts.map +1 -1
- package/dist/types/utilities/cacheUtils.d.ts +3 -0
- package/dist/types/utilities/cacheUtils.d.ts.map +1 -0
- package/dist/types/utilities/convertStackToVolumeViewport.d.ts +13 -0
- package/dist/types/utilities/convertStackToVolumeViewport.d.ts.map +1 -0
- package/dist/types/utilities/convertVolumeToStackViewport.d.ts +10 -0
- package/dist/types/utilities/convertVolumeToStackViewport.d.ts.map +1 -0
- package/dist/types/utilities/generateVolumePropsFromImageIds.d.ts +4 -0
- package/dist/types/utilities/generateVolumePropsFromImageIds.d.ts.map +1 -0
- package/dist/types/utilities/index.d.ts +6 -1
- package/dist/types/utilities/index.d.ts.map +1 -1
- package/dist/types/utilities/planar.d.ts +1 -1
- package/dist/types/utilities/planar.d.ts.map +1 -1
- package/dist/types/utilities/roundNumber.d.ts +5 -0
- package/dist/types/utilities/roundNumber.d.ts.map +1 -0
- package/dist/umd/index.js +1 -1
- package/dist/umd/index.js.map +1 -1
- package/package.json +3 -3
- package/src/RenderingEngine/BaseVolumeViewport.ts +4 -1
- package/src/RenderingEngine/StackViewport.ts +3 -1
- package/src/RenderingEngine/Viewport.ts +9 -1
- package/src/RenderingEngine/helpers/createVolumeActor.ts +1 -1
- package/src/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.js +3 -26
- package/src/cache/cache.ts +91 -7
- package/src/cache/classes/ImageVolume.ts +535 -21
- package/src/eventTarget.ts +19 -1
- package/src/init.ts +2 -2
- package/src/loaders/imageLoader.ts +58 -10
- package/src/loaders/volumeLoader.ts +139 -23
- package/src/types/BoundsLPS.ts +5 -0
- package/src/types/Cornerstone3DConfig.ts +12 -0
- package/src/types/IDynamicImageVolume.ts +2 -2
- package/src/types/IImage.ts +6 -0
- package/src/types/IImageVolume.ts +14 -2
- package/src/types/ILoadObject.ts +2 -2
- package/src/types/IViewport.ts +2 -1
- package/src/types/IVolume.ts +4 -41
- package/src/types/ImageVolumeProps.ts +15 -0
- package/src/types/VolumeProps.ts +57 -0
- package/src/types/index.ts +7 -2
- package/src/utilities/VoxelManager.ts +17 -6
- package/src/utilities/cacheUtils.ts +121 -0
- package/src/utilities/convertStackToVolumeViewport.ts +115 -0
- package/src/utilities/convertVolumeToStackViewport.ts +125 -0
- package/src/utilities/generateVolumePropsFromImageIds.ts +183 -0
- package/src/utilities/index.ts +11 -0
- package/src/utilities/planar.ts +12 -1
- package/src/utilities/roundNumber.ts +56 -0
|
@@ -10,7 +10,6 @@ const Constants_1 = require("@kitware/vtk.js/Rendering/OpenGL/Texture/Constants"
|
|
|
10
10
|
const Constants_2 = require("@kitware/vtk.js/Common/Core/DataArray/Constants");
|
|
11
11
|
const DataArray_1 = __importDefault(require("@kitware/vtk.js/Common/Core/DataArray"));
|
|
12
12
|
const Constants_3 = require("@kitware/vtk.js/Rendering/Core/Property/Constants");
|
|
13
|
-
const { vtkWarningMacro } = macros_1.default;
|
|
14
13
|
function vtkStreamingOpenGLVolumeMapper(publicAPI, model) {
|
|
15
14
|
model.classHierarchy.push('vtkStreamingOpenGLVolumeMapper');
|
|
16
15
|
publicAPI.buildBufferObjects = (ren, actor) => {
|
|
@@ -91,6 +90,7 @@ function vtkStreamingOpenGLVolumeMapper(publicAPI, model) {
|
|
|
91
90
|
model.colorTexture.create2DFromRaw(cWidth, 2 * numIComps, 3, Constants_2.VtkDataTypes.UNSIGNED_CHAR, cTable);
|
|
92
91
|
model.colorTextureString = toString;
|
|
93
92
|
}
|
|
93
|
+
publicAPI.updateLabelOutlineThicknessTexture(actor);
|
|
94
94
|
toString = `${image.getMTime()}`;
|
|
95
95
|
if (model.scalarTextureString !== toString) {
|
|
96
96
|
const dims = image.getDimensions();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"vtkStreamingOpenGLVolumeMapper.js","sourceRoot":"","sources":["../../../../src/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.js"],"names":[],"mappings":";;;;;;
|
|
1
|
+
{"version":3,"file":"vtkStreamingOpenGLVolumeMapper.js","sourceRoot":"","sources":["../../../../src/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.js"],"names":[],"mappings":"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"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { ICache, IImage,
|
|
1
|
+
import { ICache, IImage, IGeometry, IImageLoadObject, IVolumeLoadObject, IGeometryLoadObject, ICachedImage, IImageVolume } from '../types';
|
|
2
2
|
declare class Cache implements ICache {
|
|
3
3
|
private readonly _imageCache;
|
|
4
4
|
private readonly _volumeCache;
|
|
@@ -35,8 +35,11 @@ declare class Cache implements ICache {
|
|
|
35
35
|
removeImageLoadObject: (imageId: string) => void;
|
|
36
36
|
removeVolumeLoadObject: (volumeId: string) => void;
|
|
37
37
|
putGeometryLoadObject: (geometryId: string, geometryLoadObject: IGeometryLoadObject) => Promise<void>;
|
|
38
|
-
|
|
39
|
-
|
|
38
|
+
incrementImageCacheSize: (increment: number) => void;
|
|
39
|
+
incrementVolumeCacheSize: (increment: number) => void;
|
|
40
|
+
decrementImageCacheSize: (decrement: number) => void;
|
|
41
|
+
decrementVolumeCacheSize: (decrement: number) => void;
|
|
42
|
+
private _restoreImagesFromBuffer;
|
|
40
43
|
}
|
|
41
44
|
declare const cache: Cache;
|
|
42
45
|
export default cache;
|
package/dist/cjs/cache/cache.js
CHANGED
|
@@ -7,6 +7,7 @@ exports.Cache = void 0;
|
|
|
7
7
|
const utilities_1 = require("../utilities");
|
|
8
8
|
const eventTarget_1 = __importDefault(require("../eventTarget"));
|
|
9
9
|
const Events_1 = __importDefault(require("../enums/Events"));
|
|
10
|
+
const ImageVolume_1 = require("./classes/ImageVolume");
|
|
10
11
|
const ONE_GB = 1073741824;
|
|
11
12
|
class Cache {
|
|
12
13
|
constructor() {
|
|
@@ -54,6 +55,7 @@ class Cache {
|
|
|
54
55
|
if (volume.imageData) {
|
|
55
56
|
volume.imageData.delete();
|
|
56
57
|
}
|
|
58
|
+
this._restoreImagesFromBuffer(volume);
|
|
57
59
|
if (volumeLoadObject.cancelFn) {
|
|
58
60
|
volumeLoadObject.cancelFn();
|
|
59
61
|
}
|
|
@@ -139,7 +141,7 @@ class Cache {
|
|
|
139
141
|
if (cachedImage === undefined) {
|
|
140
142
|
throw new Error('removeImageLoadObject: imageId was not present in imageCache');
|
|
141
143
|
}
|
|
142
|
-
this.
|
|
144
|
+
this.incrementImageCacheSize(-cachedImage.sizeInBytes);
|
|
143
145
|
const eventDetails = {
|
|
144
146
|
imageId,
|
|
145
147
|
};
|
|
@@ -154,7 +156,7 @@ class Cache {
|
|
|
154
156
|
if (cachedVolume === undefined) {
|
|
155
157
|
throw new Error('removeVolumeLoadObject: volumeId was not present in volumeCache');
|
|
156
158
|
}
|
|
157
|
-
this.
|
|
159
|
+
this.incrementVolumeCacheSize(-cachedVolume.sizeInBytes);
|
|
158
160
|
const eventDetails = {
|
|
159
161
|
volume: cachedVolume,
|
|
160
162
|
volumeId,
|
|
@@ -201,12 +203,18 @@ class Cache {
|
|
|
201
203
|
throw error;
|
|
202
204
|
});
|
|
203
205
|
};
|
|
204
|
-
this.
|
|
206
|
+
this.incrementImageCacheSize = (increment) => {
|
|
205
207
|
this._imageCacheSize += increment;
|
|
206
208
|
};
|
|
207
|
-
this.
|
|
209
|
+
this.incrementVolumeCacheSize = (increment) => {
|
|
208
210
|
this._volumeCacheSize += increment;
|
|
209
211
|
};
|
|
212
|
+
this.decrementImageCacheSize = (decrement) => {
|
|
213
|
+
this._imageCacheSize -= decrement;
|
|
214
|
+
};
|
|
215
|
+
this.decrementVolumeCacheSize = (decrement) => {
|
|
216
|
+
this._volumeCacheSize -= decrement;
|
|
217
|
+
};
|
|
210
218
|
this._geometryCache = new Map();
|
|
211
219
|
}
|
|
212
220
|
getBytesAvailable() {
|
|
@@ -295,7 +303,7 @@ class Cache {
|
|
|
295
303
|
cachedImage.loaded = true;
|
|
296
304
|
cachedImage.image = image;
|
|
297
305
|
cachedImage.sizeInBytes = image.sizeInBytes;
|
|
298
|
-
this.
|
|
306
|
+
this.incrementImageCacheSize(cachedImage.sizeInBytes);
|
|
299
307
|
const eventDetails = {
|
|
300
308
|
image: cachedImage,
|
|
301
309
|
};
|
|
@@ -389,7 +397,7 @@ class Cache {
|
|
|
389
397
|
this.decacheIfNecessaryUntilBytesAvailable(volume.sizeInBytes, volume.imageIds);
|
|
390
398
|
cachedVolume.volume = volume;
|
|
391
399
|
cachedVolume.sizeInBytes = volume.sizeInBytes;
|
|
392
|
-
this.
|
|
400
|
+
this.incrementVolumeCacheSize(cachedVolume.sizeInBytes);
|
|
393
401
|
const eventDetails = {
|
|
394
402
|
volume: cachedVolume,
|
|
395
403
|
};
|
|
@@ -400,6 +408,35 @@ class Cache {
|
|
|
400
408
|
throw error;
|
|
401
409
|
});
|
|
402
410
|
}
|
|
411
|
+
_restoreImagesFromBuffer(volume) {
|
|
412
|
+
if (!(volume instanceof ImageVolume_1.ImageVolume)) {
|
|
413
|
+
console.warn('Volume is not an ImageVolume. Cannot restore images from buffer.');
|
|
414
|
+
return;
|
|
415
|
+
}
|
|
416
|
+
const scalarData = volume.getScalarData();
|
|
417
|
+
const imageCacheOffsetMap = volume.imageCacheOffsetMap;
|
|
418
|
+
if (imageCacheOffsetMap.size === 0) {
|
|
419
|
+
console.warn('No cached images to restore for this volume.');
|
|
420
|
+
return;
|
|
421
|
+
}
|
|
422
|
+
for (const [imageId, { offset }] of imageCacheOffsetMap) {
|
|
423
|
+
const image = this.getImage(imageId);
|
|
424
|
+
if (!image) {
|
|
425
|
+
console.warn(`Image with id ${imageId} not found in cache.`);
|
|
426
|
+
continue;
|
|
427
|
+
}
|
|
428
|
+
const viewPixelData = image.getPixelData();
|
|
429
|
+
const length = viewPixelData.length;
|
|
430
|
+
const pixelData = new viewPixelData.constructor(scalarData.buffer, offset, length);
|
|
431
|
+
image.getPixelData = () => pixelData;
|
|
432
|
+
if (image.imageFrame) {
|
|
433
|
+
image.imageFrame.pixelData = pixelData;
|
|
434
|
+
}
|
|
435
|
+
delete image.bufferView;
|
|
436
|
+
this.incrementImageCacheSize(image.sizeInBytes);
|
|
437
|
+
}
|
|
438
|
+
console.log(`Images restored from buffer for volume ${volume.volumeId}.`);
|
|
439
|
+
}
|
|
403
440
|
}
|
|
404
441
|
exports.Cache = Cache;
|
|
405
442
|
const cache = new Cache();
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../../src/cache/cache.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"cache.js","sourceRoot":"","sources":["../../../src/cache/cache.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,11 +1,15 @@
|
|
|
1
|
-
import
|
|
2
|
-
import {
|
|
1
|
+
import vtkImageData from '@kitware/vtk.js/Common/DataModel/ImageData';
|
|
2
|
+
import { Metadata, Point3, IImageVolume, Mat3, PixelDataTypedArray, ImageVolumeProps, IImage, IImageLoadObject } from '../../types';
|
|
3
3
|
export declare class ImageVolume implements IImageVolume {
|
|
4
4
|
private _imageIds;
|
|
5
5
|
private _imageIdsIndexMap;
|
|
6
6
|
private _imageURIsIndexMap;
|
|
7
|
-
protected scalarData:
|
|
7
|
+
protected scalarData: PixelDataTypedArray | Array<PixelDataTypedArray>;
|
|
8
|
+
protected numFrames: number;
|
|
9
|
+
protected totalNumFrames: number;
|
|
10
|
+
protected cornerstoneImageMetaData: any;
|
|
8
11
|
readonly volumeId: string;
|
|
12
|
+
imageCacheOffsetMap: Map<any, any>;
|
|
9
13
|
isPreScaled: boolean;
|
|
10
14
|
dimensions: Point3;
|
|
11
15
|
direction: Mat3;
|
|
@@ -26,16 +30,32 @@ export declare class ImageVolume implements IImageVolume {
|
|
|
26
30
|
vtkOpenGLTexture: any;
|
|
27
31
|
loadStatus?: Record<string, any>;
|
|
28
32
|
referencedVolumeId?: string;
|
|
33
|
+
referencedImageIds?: Array<string>;
|
|
29
34
|
hasPixelSpacing: boolean;
|
|
30
|
-
|
|
35
|
+
additionalDetails?: Record<string, any>;
|
|
36
|
+
constructor(props: ImageVolumeProps);
|
|
31
37
|
get imageIds(): Array<string>;
|
|
32
38
|
set imageIds(newImageIds: Array<string>);
|
|
33
39
|
private _reprocessImageIds;
|
|
34
40
|
cancelLoading: () => void;
|
|
35
41
|
isDynamicVolume(): boolean;
|
|
36
|
-
getScalarData():
|
|
42
|
+
getScalarData(): PixelDataTypedArray;
|
|
37
43
|
getImageIdIndex(imageId: string): number;
|
|
38
44
|
getImageURIIndex(imageURI: string): number;
|
|
39
45
|
destroy(): void;
|
|
46
|
+
getScalarDataArrays(): PixelDataTypedArray[];
|
|
47
|
+
decache(completelyRemove?: boolean): void | Array<string>;
|
|
48
|
+
removeFromCache(): void;
|
|
49
|
+
getScalarDataLength(): number;
|
|
50
|
+
private _getNumFrames;
|
|
51
|
+
private _getScalarDataLength;
|
|
52
|
+
private _createCornerstoneImageMetaData;
|
|
53
|
+
protected getScalarDataByImageIdIndex(imageIdIndex: number): PixelDataTypedArray;
|
|
54
|
+
getCornerstoneImage(imageId: string, imageIdIndex: number): IImage;
|
|
55
|
+
protected imageIdIndexToFrameIndex(imageIdIndex: number): number;
|
|
56
|
+
convertToCornerstoneImage(imageId: string, imageIdIndex: number): IImageLoadObject;
|
|
57
|
+
getCornerstoneImageLoadObject(imageId: string, imageIdIndex: number): IImageLoadObject;
|
|
58
|
+
getCornerstoneImages(): IImage[];
|
|
59
|
+
convertToImageSlicesAndCache(): string[];
|
|
40
60
|
}
|
|
41
61
|
export default ImageVolume;
|
|
@@ -1,34 +1,90 @@
|
|
|
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
|
+
};
|
|
2
25
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
26
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
27
|
};
|
|
5
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
29
|
exports.ImageVolume = void 0;
|
|
30
|
+
const ImageData_1 = __importDefault(require("@kitware/vtk.js/Common/DataModel/ImageData"));
|
|
31
|
+
const DataArray_1 = __importDefault(require("@kitware/vtk.js/Common/Core/DataArray"));
|
|
7
32
|
const isTypedArray_1 = __importDefault(require("../../utilities/isTypedArray"));
|
|
8
33
|
const utilities_1 = require("../../utilities");
|
|
9
34
|
const vtkClasses_1 = require("../../RenderingEngine/vtkClasses");
|
|
35
|
+
const cache_1 = __importDefault(require("../cache"));
|
|
36
|
+
const metaData = __importStar(require("../../metaData"));
|
|
10
37
|
class ImageVolume {
|
|
11
38
|
constructor(props) {
|
|
12
39
|
this._imageIdsIndexMap = new Map();
|
|
13
40
|
this._imageURIsIndexMap = new Map();
|
|
41
|
+
this.cornerstoneImageMetaData = null;
|
|
42
|
+
this.imageCacheOffsetMap = new Map();
|
|
14
43
|
this.isPreScaled = false;
|
|
15
|
-
|
|
16
|
-
this.
|
|
17
|
-
this.
|
|
18
|
-
this.
|
|
19
|
-
this.
|
|
20
|
-
this.
|
|
21
|
-
this.
|
|
22
|
-
this.
|
|
23
|
-
this.
|
|
44
|
+
const { imageIds, scalarData, scaling, dimensions, spacing, origin, direction, volumeId, referencedVolumeId, sizeInBytes, imageData, metadata, referencedImageIds, additionalDetails, } = props;
|
|
45
|
+
this.imageIds = imageIds;
|
|
46
|
+
this.volumeId = volumeId;
|
|
47
|
+
this.metadata = metadata;
|
|
48
|
+
this.dimensions = dimensions;
|
|
49
|
+
this.spacing = spacing;
|
|
50
|
+
this.origin = origin;
|
|
51
|
+
this.direction = direction;
|
|
52
|
+
this.scalarData = scalarData;
|
|
53
|
+
this.sizeInBytes = sizeInBytes;
|
|
24
54
|
this.vtkOpenGLTexture = vtkClasses_1.vtkStreamingOpenGLTexture.newInstance();
|
|
25
55
|
this.numVoxels =
|
|
26
56
|
this.dimensions[0] * this.dimensions[1] * this.dimensions[2];
|
|
27
|
-
if (
|
|
28
|
-
this.
|
|
57
|
+
if (imageData) {
|
|
58
|
+
this.imageData = imageData;
|
|
59
|
+
}
|
|
60
|
+
else {
|
|
61
|
+
const imageData = ImageData_1.default.newInstance();
|
|
62
|
+
const scalarArray = DataArray_1.default.newInstance({
|
|
63
|
+
name: 'Pixels',
|
|
64
|
+
numberOfComponents: 1,
|
|
65
|
+
values: scalarData,
|
|
66
|
+
});
|
|
67
|
+
imageData.setDimensions(dimensions);
|
|
68
|
+
imageData.setSpacing(spacing);
|
|
69
|
+
imageData.setDirection(direction);
|
|
70
|
+
imageData.setOrigin(origin);
|
|
71
|
+
imageData.getPointData().setScalars(scalarArray);
|
|
72
|
+
this.imageData = imageData;
|
|
73
|
+
}
|
|
74
|
+
this.numFrames = this._getNumFrames();
|
|
75
|
+
this._reprocessImageIds();
|
|
76
|
+
this._createCornerstoneImageMetaData();
|
|
77
|
+
if (scaling) {
|
|
78
|
+
this.scaling = scaling;
|
|
79
|
+
}
|
|
80
|
+
if (referencedVolumeId) {
|
|
81
|
+
this.referencedVolumeId = referencedVolumeId;
|
|
29
82
|
}
|
|
30
|
-
if (
|
|
31
|
-
this.
|
|
83
|
+
if (referencedImageIds) {
|
|
84
|
+
this.referencedImageIds = referencedImageIds;
|
|
85
|
+
}
|
|
86
|
+
if (additionalDetails) {
|
|
87
|
+
this.additionalDetails = additionalDetails;
|
|
32
88
|
}
|
|
33
89
|
}
|
|
34
90
|
get imageIds() {
|
|
@@ -69,6 +125,239 @@ class ImageVolume {
|
|
|
69
125
|
this.vtkOpenGLTexture.releaseGraphicsResources();
|
|
70
126
|
this.vtkOpenGLTexture.delete();
|
|
71
127
|
}
|
|
128
|
+
getScalarDataArrays() {
|
|
129
|
+
return this.isDynamicVolume()
|
|
130
|
+
? this.scalarData
|
|
131
|
+
: [this.scalarData];
|
|
132
|
+
}
|
|
133
|
+
decache(completelyRemove = false) {
|
|
134
|
+
if (completelyRemove) {
|
|
135
|
+
this.removeFromCache();
|
|
136
|
+
}
|
|
137
|
+
else {
|
|
138
|
+
this.convertToImageSlicesAndCache();
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
removeFromCache() {
|
|
142
|
+
cache_1.default.removeVolumeLoadObject(this.volumeId);
|
|
143
|
+
}
|
|
144
|
+
getScalarDataLength() {
|
|
145
|
+
const { scalarData } = this;
|
|
146
|
+
return this.isDynamicVolume()
|
|
147
|
+
? scalarData[0].length
|
|
148
|
+
: scalarData.length;
|
|
149
|
+
}
|
|
150
|
+
_getNumFrames() {
|
|
151
|
+
const { imageIds, scalarData } = this;
|
|
152
|
+
const scalarDataCount = this.isDynamicVolume() ? scalarData.length : 1;
|
|
153
|
+
return imageIds.length / scalarDataCount;
|
|
154
|
+
}
|
|
155
|
+
_getScalarDataLength() {
|
|
156
|
+
const { scalarData } = this;
|
|
157
|
+
return this.isDynamicVolume()
|
|
158
|
+
? scalarData[0].length
|
|
159
|
+
: scalarData.length;
|
|
160
|
+
}
|
|
161
|
+
_createCornerstoneImageMetaData() {
|
|
162
|
+
const { numFrames } = this;
|
|
163
|
+
if (numFrames === 0) {
|
|
164
|
+
return;
|
|
165
|
+
}
|
|
166
|
+
const bytesPerImage = this.sizeInBytes / numFrames;
|
|
167
|
+
const scalarDataLength = this._getScalarDataLength();
|
|
168
|
+
const numComponents = scalarDataLength / this.numVoxels;
|
|
169
|
+
const pixelsPerImage = this.dimensions[0] * this.dimensions[1] * numComponents;
|
|
170
|
+
const { PhotometricInterpretation, voiLut, VOILUTFunction } = this.metadata;
|
|
171
|
+
let windowCenter = [];
|
|
172
|
+
let windowWidth = [];
|
|
173
|
+
if (voiLut && voiLut.length) {
|
|
174
|
+
windowCenter = voiLut.map((voi) => {
|
|
175
|
+
return voi.windowCenter;
|
|
176
|
+
});
|
|
177
|
+
windowWidth = voiLut.map((voi) => {
|
|
178
|
+
return voi.windowWidth;
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
const color = numComponents > 1 ? true : false;
|
|
182
|
+
this.cornerstoneImageMetaData = {
|
|
183
|
+
bytesPerImage,
|
|
184
|
+
numComponents,
|
|
185
|
+
pixelsPerImage,
|
|
186
|
+
windowCenter,
|
|
187
|
+
windowWidth,
|
|
188
|
+
color,
|
|
189
|
+
rgba: false,
|
|
190
|
+
spacing: this.spacing,
|
|
191
|
+
dimensions: this.dimensions,
|
|
192
|
+
photometricInterpretation: PhotometricInterpretation,
|
|
193
|
+
voiLUTFunction: VOILUTFunction,
|
|
194
|
+
invert: PhotometricInterpretation === 'MONOCHROME1',
|
|
195
|
+
};
|
|
196
|
+
}
|
|
197
|
+
getScalarDataByImageIdIndex(imageIdIndex) {
|
|
198
|
+
if (imageIdIndex < 0 || imageIdIndex >= this.imageIds.length) {
|
|
199
|
+
throw new Error('imageIdIndex out of range');
|
|
200
|
+
}
|
|
201
|
+
const scalarDataArrays = this.getScalarDataArrays();
|
|
202
|
+
const scalarDataIndex = Math.floor(imageIdIndex / this.numFrames);
|
|
203
|
+
return scalarDataArrays[scalarDataIndex];
|
|
204
|
+
}
|
|
205
|
+
getCornerstoneImage(imageId, imageIdIndex) {
|
|
206
|
+
const { imageIds } = this;
|
|
207
|
+
const frameIndex = this.imageIdIndexToFrameIndex(imageIdIndex);
|
|
208
|
+
const { bytesPerImage, pixelsPerImage, windowCenter, windowWidth, numComponents, color, dimensions, spacing, invert, voiLUTFunction, photometricInterpretation, } = this.cornerstoneImageMetaData;
|
|
209
|
+
const scalarData = this.getScalarDataByImageIdIndex(imageIdIndex);
|
|
210
|
+
const volumeBuffer = scalarData.buffer;
|
|
211
|
+
const TypedArray = scalarData.constructor;
|
|
212
|
+
const bytePerPixel = bytesPerImage / pixelsPerImage;
|
|
213
|
+
let byteOffset = bytesPerImage * frameIndex;
|
|
214
|
+
if (scalarData.BYTES_PER_ELEMENT !== bytePerPixel) {
|
|
215
|
+
byteOffset *= scalarData.BYTES_PER_ELEMENT / bytePerPixel;
|
|
216
|
+
}
|
|
217
|
+
const imageScalarData = new TypedArray(pixelsPerImage);
|
|
218
|
+
const volumeBufferView = new TypedArray(volumeBuffer, byteOffset, pixelsPerImage);
|
|
219
|
+
imageScalarData.set(volumeBufferView);
|
|
220
|
+
const volumeImageId = imageIds[imageIdIndex];
|
|
221
|
+
const modalityLutModule = metaData.get('modalityLutModule', volumeImageId) || {};
|
|
222
|
+
const minMax = (0, utilities_1.getMinMax)(imageScalarData);
|
|
223
|
+
const intercept = modalityLutModule.rescaleIntercept
|
|
224
|
+
? modalityLutModule.rescaleIntercept
|
|
225
|
+
: 0;
|
|
226
|
+
return {
|
|
227
|
+
imageId,
|
|
228
|
+
intercept,
|
|
229
|
+
windowCenter,
|
|
230
|
+
windowWidth,
|
|
231
|
+
voiLUTFunction,
|
|
232
|
+
color,
|
|
233
|
+
rgba: false,
|
|
234
|
+
numComps: numComponents,
|
|
235
|
+
rows: dimensions[1],
|
|
236
|
+
columns: dimensions[0],
|
|
237
|
+
sizeInBytes: imageScalarData.byteLength,
|
|
238
|
+
getPixelData: () => imageScalarData,
|
|
239
|
+
minPixelValue: minMax.min,
|
|
240
|
+
maxPixelValue: minMax.max,
|
|
241
|
+
slope: modalityLutModule.rescaleSlope
|
|
242
|
+
? modalityLutModule.rescaleSlope
|
|
243
|
+
: 1,
|
|
244
|
+
getCanvas: undefined,
|
|
245
|
+
height: dimensions[0],
|
|
246
|
+
width: dimensions[1],
|
|
247
|
+
columnPixelSpacing: spacing[0],
|
|
248
|
+
rowPixelSpacing: spacing[1],
|
|
249
|
+
invert,
|
|
250
|
+
photometricInterpretation,
|
|
251
|
+
};
|
|
252
|
+
}
|
|
253
|
+
imageIdIndexToFrameIndex(imageIdIndex) {
|
|
254
|
+
return imageIdIndex % this.numFrames;
|
|
255
|
+
}
|
|
256
|
+
convertToCornerstoneImage(imageId, imageIdIndex) {
|
|
257
|
+
return this.getCornerstoneImageLoadObject(imageId, imageIdIndex);
|
|
258
|
+
}
|
|
259
|
+
getCornerstoneImageLoadObject(imageId, imageIdIndex) {
|
|
260
|
+
const image = this.getCornerstoneImage(imageId, imageIdIndex);
|
|
261
|
+
const imageLoadObject = {
|
|
262
|
+
promise: Promise.resolve(image),
|
|
263
|
+
};
|
|
264
|
+
return imageLoadObject;
|
|
265
|
+
}
|
|
266
|
+
getCornerstoneImages() {
|
|
267
|
+
const { imageIds } = this;
|
|
268
|
+
return imageIds.map((imageId, imageIdIndex) => {
|
|
269
|
+
return this.getCornerstoneImage(imageId, imageIdIndex);
|
|
270
|
+
});
|
|
271
|
+
}
|
|
272
|
+
convertToImageSlicesAndCache() {
|
|
273
|
+
var _a, _b;
|
|
274
|
+
const byteLength = this.sizeInBytes;
|
|
275
|
+
if (!((_a = this.imageIds) === null || _a === void 0 ? void 0 : _a.length)) {
|
|
276
|
+
const referencedVolumeId = this.referencedVolumeId;
|
|
277
|
+
const referencedVolume = cache_1.default.getVolume(referencedVolumeId);
|
|
278
|
+
const numSlices = ((_b = referencedVolume === null || referencedVolume === void 0 ? void 0 : referencedVolume.imageIds) === null || _b === void 0 ? void 0 : _b.length) || this.dimensions[2];
|
|
279
|
+
this.imageIds = Array.from({ length: numSlices }, (_, i) => {
|
|
280
|
+
return `generated:${this.volumeId}:${i}`;
|
|
281
|
+
});
|
|
282
|
+
this._reprocessImageIds();
|
|
283
|
+
this.numFrames = this._getNumFrames();
|
|
284
|
+
this._createCornerstoneImageMetaData();
|
|
285
|
+
}
|
|
286
|
+
const numImages = this.imageIds.length;
|
|
287
|
+
const { bytesPerImage } = this.cornerstoneImageMetaData;
|
|
288
|
+
let bytesRemaining = cache_1.default.decacheIfNecessaryUntilBytesAvailable(byteLength, this.imageIds);
|
|
289
|
+
for (let imageIdIndex = 0; imageIdIndex < numImages; imageIdIndex++) {
|
|
290
|
+
const imageId = this.imageIds[imageIdIndex];
|
|
291
|
+
bytesRemaining = bytesRemaining - bytesPerImage;
|
|
292
|
+
const image = this.getCornerstoneImage(imageId, imageIdIndex);
|
|
293
|
+
const imageLoadObject = {
|
|
294
|
+
promise: Promise.resolve(image),
|
|
295
|
+
};
|
|
296
|
+
if (!cache_1.default.getImageLoadObject(imageId)) {
|
|
297
|
+
cache_1.default.putImageLoadObject(imageId, imageLoadObject).catch((err) => {
|
|
298
|
+
console.error(err);
|
|
299
|
+
});
|
|
300
|
+
}
|
|
301
|
+
if (bytesRemaining <= bytesPerImage) {
|
|
302
|
+
break;
|
|
303
|
+
}
|
|
304
|
+
const imageOrientationPatient = [
|
|
305
|
+
this.direction[0],
|
|
306
|
+
this.direction[1],
|
|
307
|
+
this.direction[2],
|
|
308
|
+
this.direction[3],
|
|
309
|
+
this.direction[4],
|
|
310
|
+
this.direction[5],
|
|
311
|
+
];
|
|
312
|
+
const precision = 6;
|
|
313
|
+
const imagePositionPatient = [
|
|
314
|
+
parseFloat((this.origin[0] +
|
|
315
|
+
imageIdIndex * this.direction[6] * this.spacing[0]).toFixed(precision)),
|
|
316
|
+
parseFloat((this.origin[1] +
|
|
317
|
+
imageIdIndex * this.direction[7] * this.spacing[1]).toFixed(precision)),
|
|
318
|
+
parseFloat((this.origin[2] +
|
|
319
|
+
imageIdIndex * this.direction[8] * this.spacing[2]).toFixed(precision)),
|
|
320
|
+
];
|
|
321
|
+
const pixelData = image.getPixelData();
|
|
322
|
+
const bitsAllocated = pixelData.BYTES_PER_ELEMENT * 8;
|
|
323
|
+
const imagePixelModule = {
|
|
324
|
+
bitsAllocated,
|
|
325
|
+
photometricInterpretation: image.photometricInterpretation,
|
|
326
|
+
windowWidth: image.windowWidth,
|
|
327
|
+
windowCenter: image.windowCenter,
|
|
328
|
+
voiLUTFunction: image.voiLUTFunction,
|
|
329
|
+
};
|
|
330
|
+
const imagePlaneModule = {
|
|
331
|
+
rowCosines: [this.direction[0], this.direction[1], this.direction[2]],
|
|
332
|
+
columnCosines: [
|
|
333
|
+
this.direction[3],
|
|
334
|
+
this.direction[4],
|
|
335
|
+
this.direction[5],
|
|
336
|
+
],
|
|
337
|
+
pixelSpacing: [this.spacing[0], this.spacing[1]],
|
|
338
|
+
imageOrientationPatient: imageOrientationPatient,
|
|
339
|
+
imagePositionPatient: imagePositionPatient,
|
|
340
|
+
columnPixelSpacing: image.columnPixelSpacing,
|
|
341
|
+
rowPixelSpacing: image.rowPixelSpacing,
|
|
342
|
+
columns: image.columns,
|
|
343
|
+
rows: image.rows,
|
|
344
|
+
};
|
|
345
|
+
const generalSeriesModule = {};
|
|
346
|
+
const metadata = {
|
|
347
|
+
imagePixelModule,
|
|
348
|
+
imagePlaneModule,
|
|
349
|
+
generalSeriesModule,
|
|
350
|
+
};
|
|
351
|
+
['imagePixelModule', 'imagePlaneModule', 'generalSeriesModule'].forEach((type) => {
|
|
352
|
+
utilities_1.genericMetadataProvider.add(imageId, {
|
|
353
|
+
type,
|
|
354
|
+
metadata: metadata[type],
|
|
355
|
+
});
|
|
356
|
+
});
|
|
357
|
+
}
|
|
358
|
+
this.removeFromCache();
|
|
359
|
+
return this.imageIds;
|
|
360
|
+
}
|
|
72
361
|
}
|
|
73
362
|
exports.ImageVolume = ImageVolume;
|
|
74
363
|
exports.default = ImageVolume;
|