@cornerstonejs/core 0.46.0 → 0.46.2
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/utilities/index.d.ts +2 -1
- package/dist/cjs/utilities/index.js +4 -1
- package/dist/cjs/utilities/index.js.map +1 -1
- package/dist/cjs/utilities/isPTPrescaledWithSUV.d.ts +3 -0
- package/dist/cjs/utilities/isPTPrescaledWithSUV.js +8 -0
- package/dist/cjs/utilities/isPTPrescaledWithSUV.js.map +1 -0
- package/dist/cjs/utilities/renderToCanvasGPU.js +11 -5
- package/dist/cjs/utilities/renderToCanvasGPU.js.map +1 -1
- 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/esm/utilities/isPTPrescaledWithSUV.d.ts +3 -0
- package/dist/esm/utilities/isPTPrescaledWithSUV.js +5 -0
- package/dist/esm/utilities/isPTPrescaledWithSUV.js.map +1 -0
- package/dist/esm/utilities/renderToCanvasGPU.js +11 -5
- package/dist/esm/utilities/renderToCanvasGPU.js.map +1 -1
- package/dist/umd/index.js +1 -1
- package/dist/umd/index.js.map +1 -1
- package/package.json +2 -2
- package/src/utilities/index.ts +2 -0
- package/src/utilities/isPTPrescaledWithSUV.ts +7 -0
- package/src/utilities/renderToCanvasGPU.ts +28 -6
|
@@ -44,7 +44,8 @@ import applyPreset from './applyPreset';
|
|
|
44
44
|
import deepMerge from './deepMerge';
|
|
45
45
|
import getScalingParameters from './getScalingParameters';
|
|
46
46
|
import getScalarDataType from './getScalarDataType';
|
|
47
|
+
import isPTPrescaledWithSUV from './isPTPrescaledWithSUV';
|
|
47
48
|
import * as planar from './planar';
|
|
48
49
|
import * as windowLevel from './windowLevel';
|
|
49
50
|
import * as colormap from './colormap';
|
|
50
|
-
export { csUtils as invertRgbTransferFunction, createSigmoidRGBTransferFunction, getVoiFromSigmoidRGBTransferFunction, createLinearRGBTransferFunction, scaleRgbTransferFunction, triggerEvent, imageIdToURI, calibratedPixelSpacingMetadataProvider, uuidv4, planar, getMinMax, getRuntimeId, isEqual, isOpposite, createFloat32SharedArray, createUint8SharedArray, createUint16SharedArray, createInt16SharedArray, windowLevel, getClosestImageId, getSpacingInNormalDirection, getTargetVolumeAndSpacingInNormalDir, getVolumeActorCorners, indexWithinDimensions, getVolumeViewportsContainingSameVolumes, getViewportsWithVolumeId, transformWorldToIndex, loadImageToCanvas, renderToCanvasCPU, renderToCanvasGPU, worldToImageCoords, imageToWorldCoords, getVolumeSliceRangeInfo, getVolumeViewportScrollInfo, getSliceRange, snapFocalPointToSlice, getImageSliceDataForVolumeViewport, isImageActor, actorIsA, getViewportsWithImageURI, getClosestStackImageIndexForPoint, calculateViewportsSpatialRegistration, spatialRegistrationMetadataProvider, getViewportImageCornersInWorld, hasNaNValues, applyPreset, deepMerge, getScalingParameters, getScalarDataType, colormap, };
|
|
51
|
+
export { csUtils as invertRgbTransferFunction, createSigmoidRGBTransferFunction, getVoiFromSigmoidRGBTransferFunction, createLinearRGBTransferFunction, scaleRgbTransferFunction, triggerEvent, imageIdToURI, calibratedPixelSpacingMetadataProvider, uuidv4, planar, getMinMax, getRuntimeId, isEqual, isOpposite, createFloat32SharedArray, createUint8SharedArray, createUint16SharedArray, createInt16SharedArray, windowLevel, getClosestImageId, getSpacingInNormalDirection, getTargetVolumeAndSpacingInNormalDir, getVolumeActorCorners, indexWithinDimensions, getVolumeViewportsContainingSameVolumes, getViewportsWithVolumeId, transformWorldToIndex, loadImageToCanvas, renderToCanvasCPU, renderToCanvasGPU, worldToImageCoords, imageToWorldCoords, getVolumeSliceRangeInfo, getVolumeViewportScrollInfo, getSliceRange, snapFocalPointToSlice, getImageSliceDataForVolumeViewport, isImageActor, isPTPrescaledWithSUV, actorIsA, getViewportsWithImageURI, getClosestStackImageIndexForPoint, calculateViewportsSpatialRegistration, spatialRegistrationMetadataProvider, getViewportImageCornersInWorld, hasNaNValues, applyPreset, deepMerge, getScalingParameters, getScalarDataType, colormap, };
|
|
@@ -26,7 +26,8 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
|
26
26
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
27
27
|
};
|
|
28
28
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
29
|
-
exports.
|
|
29
|
+
exports.getScalarDataType = exports.getScalingParameters = exports.deepMerge = exports.applyPreset = exports.hasNaNValues = exports.getViewportImageCornersInWorld = exports.spatialRegistrationMetadataProvider = exports.calculateViewportsSpatialRegistration = exports.getClosestStackImageIndexForPoint = exports.getViewportsWithImageURI = exports.actorIsA = exports.isPTPrescaledWithSUV = exports.isImageActor = exports.getImageSliceDataForVolumeViewport = exports.snapFocalPointToSlice = exports.getSliceRange = exports.getVolumeViewportScrollInfo = exports.getVolumeSliceRangeInfo = exports.imageToWorldCoords = exports.worldToImageCoords = exports.renderToCanvasGPU = exports.renderToCanvasCPU = exports.loadImageToCanvas = exports.transformWorldToIndex = exports.getViewportsWithVolumeId = exports.getVolumeViewportsContainingSameVolumes = exports.indexWithinDimensions = exports.getVolumeActorCorners = exports.getTargetVolumeAndSpacingInNormalDir = exports.getSpacingInNormalDirection = exports.getClosestImageId = exports.windowLevel = exports.createInt16SharedArray = exports.createUint16SharedArray = exports.createUint8SharedArray = exports.createFloat32SharedArray = exports.isOpposite = exports.isEqual = exports.getRuntimeId = exports.getMinMax = exports.planar = exports.uuidv4 = exports.calibratedPixelSpacingMetadataProvider = exports.imageIdToURI = exports.triggerEvent = exports.scaleRgbTransferFunction = exports.createLinearRGBTransferFunction = exports.getVoiFromSigmoidRGBTransferFunction = exports.createSigmoidRGBTransferFunction = exports.invertRgbTransferFunction = void 0;
|
|
30
|
+
exports.colormap = void 0;
|
|
30
31
|
const invertRgbTransferFunction_1 = __importDefault(require("./invertRgbTransferFunction"));
|
|
31
32
|
exports.invertRgbTransferFunction = invertRgbTransferFunction_1.default;
|
|
32
33
|
const createSigmoidRGBTransferFunction_1 = __importDefault(require("./createSigmoidRGBTransferFunction"));
|
|
@@ -120,6 +121,8 @@ const getScalingParameters_1 = __importDefault(require("./getScalingParameters")
|
|
|
120
121
|
exports.getScalingParameters = getScalingParameters_1.default;
|
|
121
122
|
const getScalarDataType_1 = __importDefault(require("./getScalarDataType"));
|
|
122
123
|
exports.getScalarDataType = getScalarDataType_1.default;
|
|
124
|
+
const isPTPrescaledWithSUV_1 = __importDefault(require("./isPTPrescaledWithSUV"));
|
|
125
|
+
exports.isPTPrescaledWithSUV = isPTPrescaledWithSUV_1.default;
|
|
123
126
|
const planar = __importStar(require("./planar"));
|
|
124
127
|
exports.planar = planar;
|
|
125
128
|
const windowLevel = __importStar(require("./windowLevel"));
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utilities/index.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utilities/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
const isPTPrescaledWithSUV = (image) => {
|
|
4
|
+
var _a, _b;
|
|
5
|
+
return ((_a = image.preScale) === null || _a === void 0 ? void 0 : _a.scaled) && ((_b = image.preScale.scalingParameters) === null || _b === void 0 ? void 0 : _b.suvbw);
|
|
6
|
+
};
|
|
7
|
+
exports.default = isPTPrescaledWithSUV;
|
|
8
|
+
//# sourceMappingURL=isPTPrescaledWithSUV.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isPTPrescaledWithSUV.js","sourceRoot":"","sources":["../../../src/utilities/isPTPrescaledWithSUV.ts"],"names":[],"mappings":";;AAEA,MAAM,oBAAoB,GAAG,CAAC,KAAa,EAAE,EAAE;;IAC7C,OAAO,CAAA,MAAA,KAAK,CAAC,QAAQ,0CAAE,MAAM,MAAI,MAAA,KAAK,CAAC,QAAQ,CAAC,iBAAiB,0CAAE,KAAK,CAAA,CAAC;AAC3E,CAAC,CAAC;AAEF,kBAAe,oBAAoB,CAAC"}
|
|
@@ -7,6 +7,7 @@ const getOrCreateCanvas_1 = __importDefault(require("../RenderingEngine/helpers/
|
|
|
7
7
|
const enums_1 = require("../enums");
|
|
8
8
|
const getRenderingEngine_1 = require("../RenderingEngine/getRenderingEngine");
|
|
9
9
|
const RenderingEngine_1 = __importDefault(require("../RenderingEngine"));
|
|
10
|
+
const isPTPrescaledWithSUV_1 = __importDefault(require("./isPTPrescaledWithSUV"));
|
|
10
11
|
function renderToCanvasGPU(canvas, image, modality = undefined, renderingEngineId = '_thumbnails') {
|
|
11
12
|
if (!canvas || !(canvas instanceof HTMLCanvasElement)) {
|
|
12
13
|
throw new Error('canvas element is required');
|
|
@@ -19,6 +20,13 @@ function renderToCanvasGPU(canvas, image, modality = undefined, renderingEngineI
|
|
|
19
20
|
element.style.height = `${canvas.height}px`;
|
|
20
21
|
element.style.visibility = 'hidden';
|
|
21
22
|
element.style.position = 'absolute';
|
|
23
|
+
const devicePixelRatio = window.devicePixelRatio || 1;
|
|
24
|
+
const originalWidth = canvas.width;
|
|
25
|
+
const originalHeight = canvas.height;
|
|
26
|
+
canvas.width = originalWidth * devicePixelRatio;
|
|
27
|
+
canvas.height = originalHeight * devicePixelRatio;
|
|
28
|
+
canvas.style.width = `${originalWidth}px`;
|
|
29
|
+
canvas.style.height = `${originalHeight}px`;
|
|
22
30
|
document.body.appendChild(element);
|
|
23
31
|
const uniqueId = viewportId.split(':').join('-');
|
|
24
32
|
element.setAttribute('viewport-id-for-remove', uniqueId);
|
|
@@ -45,7 +53,7 @@ function renderToCanvasGPU(canvas, image, modality = undefined, renderingEngineI
|
|
|
45
53
|
}
|
|
46
54
|
const temporaryCanvas = (0, getOrCreateCanvas_1.default)(element);
|
|
47
55
|
const context = canvas.getContext('2d');
|
|
48
|
-
context.drawImage(temporaryCanvas, 0, 0);
|
|
56
|
+
context.drawImage(temporaryCanvas, 0, 0, temporaryCanvas.width, temporaryCanvas.height, 0, 0, canvas.width, canvas.height);
|
|
49
57
|
elementRendered = true;
|
|
50
58
|
element.removeEventListener(enums_1.Events.IMAGE_RENDERED, onImageRendered);
|
|
51
59
|
setTimeout(() => {
|
|
@@ -59,7 +67,8 @@ function renderToCanvasGPU(canvas, image, modality = undefined, renderingEngineI
|
|
|
59
67
|
};
|
|
60
68
|
element.addEventListener(enums_1.Events.IMAGE_RENDERED, onImageRendered);
|
|
61
69
|
viewport.renderImageObject(image);
|
|
62
|
-
|
|
70
|
+
viewport.resetCamera();
|
|
71
|
+
if (modality === 'PT' && !(0, isPTPrescaledWithSUV_1.default)(image)) {
|
|
63
72
|
viewport.setProperties({
|
|
64
73
|
voiRange: {
|
|
65
74
|
lower: image.minPixelValue,
|
|
@@ -71,7 +80,4 @@ function renderToCanvasGPU(canvas, image, modality = undefined, renderingEngineI
|
|
|
71
80
|
});
|
|
72
81
|
}
|
|
73
82
|
exports.default = renderToCanvasGPU;
|
|
74
|
-
const _isPTImagePreScaledWithSUV = (image) => {
|
|
75
|
-
return image.preScale.scaled && image.preScale.scalingParameters.suvbw;
|
|
76
|
-
};
|
|
77
83
|
//# sourceMappingURL=renderToCanvasGPU.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"renderToCanvasGPU.js","sourceRoot":"","sources":["../../../src/utilities/renderToCanvasGPU.ts"],"names":[],"mappings":";;;;;AAAA,qGAA6E;AAC7E,oCAAgD;AAGhD,8EAA2E;AAC3E,yEAAiD;
|
|
1
|
+
{"version":3,"file":"renderToCanvasGPU.js","sourceRoot":"","sources":["../../../src/utilities/renderToCanvasGPU.ts"],"names":[],"mappings":";;;;;AAAA,qGAA6E;AAC7E,oCAAgD;AAGhD,8EAA2E;AAC3E,yEAAiD;AACjD,kFAA0D;AAqB1D,SAAwB,iBAAiB,CACvC,MAAyB,EACzB,KAAa,EACb,QAAQ,GAAG,SAAS,EACpB,iBAAiB,GAAG,aAAa;IAEjC,IAAI,CAAC,MAAM,IAAI,CAAC,CAAC,MAAM,YAAY,iBAAiB,CAAC,EAAE;QACrD,MAAM,IAAI,KAAK,CAAC,4BAA4B,CAAC,CAAC;KAC/C;IAED,MAAM,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC;IACrC,MAAM,UAAU,GAAG,qBAAqB,cAAc,EAAE,CAAC;IACzD,MAAM,OAAO,GAAG,KAAK,CAAC,OAAO,CAAC;IAC9B,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;IAC9C,OAAO,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,MAAM,CAAC,KAAK,IAAI,CAAC;IAC1C,OAAO,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,MAAM,CAAC,MAAM,IAAI,CAAC;IAC5C,OAAO,CAAC,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC;IACpC,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC;IAKpC,MAAM,gBAAgB,GAAG,MAAM,CAAC,gBAAgB,IAAI,CAAC,CAAC;IACtD,MAAM,aAAa,GAAG,MAAM,CAAC,KAAK,CAAC;IACnC,MAAM,cAAc,GAAG,MAAM,CAAC,MAAM,CAAC;IACrC,MAAM,CAAC,KAAK,GAAG,aAAa,GAAG,gBAAgB,CAAC;IAChD,MAAM,CAAC,MAAM,GAAG,cAAc,GAAG,gBAAgB,CAAC;IAClD,MAAM,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,aAAa,IAAI,CAAC;IAC1C,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,cAAc,IAAI,CAAC;IAE5C,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;IAGnC,MAAM,QAAQ,GAAG,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACjD,OAAO,CAAC,YAAY,CAAC,wBAAwB,EAAE,QAAQ,CAAC,CAAC;IAEzD,MAAM,eAAe,GAClB,IAAA,uCAAkB,EAAC,iBAAiB,CAAqB;QAC1D,IAAI,yBAAe,CAAC,iBAAiB,CAAC,CAAC;IAEzC,IAAI,QAAQ,GAAG,eAAe,CAAC,WAAW,CAAC,UAAU,CAAkB,CAAC;IAExE,IAAI,CAAC,QAAQ,EAAE;QACb,MAAM,kBAAkB,GAAG;YACzB,UAAU;YACV,IAAI,EAAE,oBAAY,CAAC,KAAK;YACxB,OAAO;YACP,cAAc,EAAE;gBACd,cAAc,EAAE,IAAI;aACrB;SACF,CAAC;QACF,eAAe,CAAC,aAAa,CAAC,kBAAkB,CAAC,CAAC;QAClD,QAAQ,GAAG,eAAe,CAAC,WAAW,CAAC,UAAU,CAAkB,CAAC;KACrE;IAED,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAG7B,IAAI,eAAe,GAAG,KAAK,CAAC;QAG5B,MAAM,eAAe,GAAG,CAAC,WAAW,EAAE,EAAE;YACtC,IAAI,eAAe,EAAE;gBACnB,OAAO;aACR;YAGD,MAAM,eAAe,GAAG,IAAA,2BAAiB,EAAC,OAAO,CAAC,CAAC;YAGnD,MAAM,OAAO,GAAG,MAAM,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC;YACxC,OAAO,CAAC,SAAS,CACf,eAAe,EACf,CAAC,EACD,CAAC,EACD,eAAe,CAAC,KAAK,EACrB,eAAe,CAAC,MAAM,EACtB,CAAC,EACD,CAAC,EACD,MAAM,CAAC,KAAK,EACZ,MAAM,CAAC,MAAM,CACd,CAAC;YAEF,eAAe,GAAG,IAAI,CAAC;YAGvB,OAAO,CAAC,mBAAmB,CAAC,cAAM,CAAC,cAAc,EAAE,eAAe,CAAC,CAAC;YAOpE,UAAU,CAAC,GAAG,EAAE;gBACd,eAAe,CAAC,cAAc,CAAC,UAAU,CAAC,CAAC;gBAG3C,MAAM,QAAQ,GAAG,QAAQ,CAAC,gBAAgB,CACxC,4BAA4B,QAAQ,IAAI,CACzC,CAAC;gBACF,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;oBAC3B,OAAO,CAAC,MAAM,EAAE,CAAC;gBACnB,CAAC,CAAC,CAAC;YACL,CAAC,EAAE,CAAC,CAAC,CAAC;YACN,OAAO,CAAC,OAAO,CAAC,CAAC;QACnB,CAAC,CAAC;QAEF,OAAO,CAAC,gBAAgB,CAAC,cAAM,CAAC,cAAc,EAAE,eAAe,CAAC,CAAC;QACjE,QAAQ,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;QAGlC,QAAQ,CAAC,WAAW,EAAE,CAAC;QAEvB,IAAI,QAAQ,KAAK,IAAI,IAAI,CAAC,IAAA,8BAAoB,EAAC,KAAK,CAAC,EAAE;YACrD,QAAQ,CAAC,aAAa,CAAC;gBACrB,QAAQ,EAAE;oBACR,KAAK,EAAE,KAAK,CAAC,aAAa;oBAC1B,KAAK,EAAE,KAAK,CAAC,aAAa;iBAC3B;aACF,CAAC,CAAC;SACJ;QAED,QAAQ,CAAC,MAAM,EAAE,CAAC;IACpB,CAAC,CAAC,CAAC;AACL,CAAC;AA5HD,oCA4HC"}
|
|
@@ -44,7 +44,8 @@ import applyPreset from './applyPreset';
|
|
|
44
44
|
import deepMerge from './deepMerge';
|
|
45
45
|
import getScalingParameters from './getScalingParameters';
|
|
46
46
|
import getScalarDataType from './getScalarDataType';
|
|
47
|
+
import isPTPrescaledWithSUV from './isPTPrescaledWithSUV';
|
|
47
48
|
import * as planar from './planar';
|
|
48
49
|
import * as windowLevel from './windowLevel';
|
|
49
50
|
import * as colormap from './colormap';
|
|
50
|
-
export { csUtils as invertRgbTransferFunction, createSigmoidRGBTransferFunction, getVoiFromSigmoidRGBTransferFunction, createLinearRGBTransferFunction, scaleRgbTransferFunction, triggerEvent, imageIdToURI, calibratedPixelSpacingMetadataProvider, uuidv4, planar, getMinMax, getRuntimeId, isEqual, isOpposite, createFloat32SharedArray, createUint8SharedArray, createUint16SharedArray, createInt16SharedArray, windowLevel, getClosestImageId, getSpacingInNormalDirection, getTargetVolumeAndSpacingInNormalDir, getVolumeActorCorners, indexWithinDimensions, getVolumeViewportsContainingSameVolumes, getViewportsWithVolumeId, transformWorldToIndex, loadImageToCanvas, renderToCanvasCPU, renderToCanvasGPU, worldToImageCoords, imageToWorldCoords, getVolumeSliceRangeInfo, getVolumeViewportScrollInfo, getSliceRange, snapFocalPointToSlice, getImageSliceDataForVolumeViewport, isImageActor, actorIsA, getViewportsWithImageURI, getClosestStackImageIndexForPoint, calculateViewportsSpatialRegistration, spatialRegistrationMetadataProvider, getViewportImageCornersInWorld, hasNaNValues, applyPreset, deepMerge, getScalingParameters, getScalarDataType, colormap, };
|
|
51
|
+
export { csUtils as invertRgbTransferFunction, createSigmoidRGBTransferFunction, getVoiFromSigmoidRGBTransferFunction, createLinearRGBTransferFunction, scaleRgbTransferFunction, triggerEvent, imageIdToURI, calibratedPixelSpacingMetadataProvider, uuidv4, planar, getMinMax, getRuntimeId, isEqual, isOpposite, createFloat32SharedArray, createUint8SharedArray, createUint16SharedArray, createInt16SharedArray, windowLevel, getClosestImageId, getSpacingInNormalDirection, getTargetVolumeAndSpacingInNormalDir, getVolumeActorCorners, indexWithinDimensions, getVolumeViewportsContainingSameVolumes, getViewportsWithVolumeId, transformWorldToIndex, loadImageToCanvas, renderToCanvasCPU, renderToCanvasGPU, worldToImageCoords, imageToWorldCoords, getVolumeSliceRangeInfo, getVolumeViewportScrollInfo, getSliceRange, snapFocalPointToSlice, getImageSliceDataForVolumeViewport, isImageActor, isPTPrescaledWithSUV, actorIsA, getViewportsWithImageURI, getClosestStackImageIndexForPoint, calculateViewportsSpatialRegistration, spatialRegistrationMetadataProvider, getViewportImageCornersInWorld, hasNaNValues, applyPreset, deepMerge, getScalingParameters, getScalarDataType, colormap, };
|
|
@@ -44,8 +44,9 @@ import applyPreset from './applyPreset';
|
|
|
44
44
|
import deepMerge from './deepMerge';
|
|
45
45
|
import getScalingParameters from './getScalingParameters';
|
|
46
46
|
import getScalarDataType from './getScalarDataType';
|
|
47
|
+
import isPTPrescaledWithSUV from './isPTPrescaledWithSUV';
|
|
47
48
|
import * as planar from './planar';
|
|
48
49
|
import * as windowLevel from './windowLevel';
|
|
49
50
|
import * as colormap from './colormap';
|
|
50
|
-
export { csUtils as invertRgbTransferFunction, createSigmoidRGBTransferFunction, getVoiFromSigmoidRGBTransferFunction, createLinearRGBTransferFunction, scaleRgbTransferFunction, triggerEvent, imageIdToURI, calibratedPixelSpacingMetadataProvider, uuidv4, planar, getMinMax, getRuntimeId, isEqual, isOpposite, createFloat32SharedArray, createUint8SharedArray, createUint16SharedArray, createInt16SharedArray, windowLevel, getClosestImageId, getSpacingInNormalDirection, getTargetVolumeAndSpacingInNormalDir, getVolumeActorCorners, indexWithinDimensions, getVolumeViewportsContainingSameVolumes, getViewportsWithVolumeId, transformWorldToIndex, loadImageToCanvas, renderToCanvasCPU, renderToCanvasGPU, worldToImageCoords, imageToWorldCoords, getVolumeSliceRangeInfo, getVolumeViewportScrollInfo, getSliceRange, snapFocalPointToSlice, getImageSliceDataForVolumeViewport, isImageActor, actorIsA, getViewportsWithImageURI, getClosestStackImageIndexForPoint, calculateViewportsSpatialRegistration, spatialRegistrationMetadataProvider, getViewportImageCornersInWorld, hasNaNValues, applyPreset, deepMerge, getScalingParameters, getScalarDataType, colormap, };
|
|
51
|
+
export { csUtils as invertRgbTransferFunction, createSigmoidRGBTransferFunction, getVoiFromSigmoidRGBTransferFunction, createLinearRGBTransferFunction, scaleRgbTransferFunction, triggerEvent, imageIdToURI, calibratedPixelSpacingMetadataProvider, uuidv4, planar, getMinMax, getRuntimeId, isEqual, isOpposite, createFloat32SharedArray, createUint8SharedArray, createUint16SharedArray, createInt16SharedArray, windowLevel, getClosestImageId, getSpacingInNormalDirection, getTargetVolumeAndSpacingInNormalDir, getVolumeActorCorners, indexWithinDimensions, getVolumeViewportsContainingSameVolumes, getViewportsWithVolumeId, transformWorldToIndex, loadImageToCanvas, renderToCanvasCPU, renderToCanvasGPU, worldToImageCoords, imageToWorldCoords, getVolumeSliceRangeInfo, getVolumeViewportScrollInfo, getSliceRange, snapFocalPointToSlice, getImageSliceDataForVolumeViewport, isImageActor, isPTPrescaledWithSUV, actorIsA, getViewportsWithImageURI, getClosestStackImageIndexForPoint, calculateViewportsSpatialRegistration, spatialRegistrationMetadataProvider, getViewportImageCornersInWorld, hasNaNValues, applyPreset, deepMerge, getScalingParameters, getScalarDataType, colormap, };
|
|
51
52
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utilities/index.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,6BAA6B,CAAC;AAClD,OAAO,gCAAgC,MAAM,oCAAoC,CAAC;AAClF,OAAO,oCAAoC,MAAM,wCAAwC,CAAC;AAC1F,OAAO,+BAA+B,MAAM,mCAAmC,CAAC;AAChF,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,MAAM,MAAM,UAAU,CAAC;AAC9B,OAAO,SAAS,MAAM,aAAa,CAAC;AACpC,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,sCAAsC,MAAM,0CAA0C,CAAC;AAC9F,OAAO,OAAO,MAAM,WAAW,CAAC;AAChC,OAAO,UAAU,MAAM,cAAc,CAAC;AACtC,OAAO,sBAAsB,MAAM,0BAA0B,CAAC;AAC9D,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,uBAAuB,MAAM,2BAA2B,CAAC;AAChE,OAAO,sBAAsB,MAAM,0BAA0B,CAAC;AAC9D,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,2BAA2B,MAAM,+BAA+B,CAAC;AACxE,OAAO,oCAAoC,MAAM,wCAAwC,CAAC;AAC1F,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,uCAAuC,MAAM,2CAA2C,CAAC;AAChG,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,uBAAuB,MAAM,2BAA2B,CAAC;AAChE,OAAO,2BAA2B,MAAM,+BAA+B,CAAC;AACxE,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,kCAAkC,MAAM,sCAAsC,CAAC;AACtF,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,iCAAiC,MAAM,qCAAqC,CAAC;AACpF,OAAO,qCAAqC,MAAM,yCAAyC,CAAC;AAC5F,OAAO,mCAAmC,MAAM,uCAAuC,CAAC;AACxF,OAAO,8BAA8B,MAAM,kCAAkC,CAAC;AAC9E,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,SAAS,MAAM,aAAa,CAAC;AACpC,OAAO,oBAAoB,MAAM,wBAAwB,CAAC;AAC1D,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utilities/index.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,6BAA6B,CAAC;AAClD,OAAO,gCAAgC,MAAM,oCAAoC,CAAC;AAClF,OAAO,oCAAoC,MAAM,wCAAwC,CAAC;AAC1F,OAAO,+BAA+B,MAAM,mCAAmC,CAAC;AAChF,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,MAAM,MAAM,UAAU,CAAC;AAC9B,OAAO,SAAS,MAAM,aAAa,CAAC;AACpC,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,sCAAsC,MAAM,0CAA0C,CAAC;AAC9F,OAAO,OAAO,MAAM,WAAW,CAAC;AAChC,OAAO,UAAU,MAAM,cAAc,CAAC;AACtC,OAAO,sBAAsB,MAAM,0BAA0B,CAAC;AAC9D,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,uBAAuB,MAAM,2BAA2B,CAAC;AAChE,OAAO,sBAAsB,MAAM,0BAA0B,CAAC;AAC9D,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,2BAA2B,MAAM,+BAA+B,CAAC;AACxE,OAAO,oCAAoC,MAAM,wCAAwC,CAAC;AAC1F,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,uCAAuC,MAAM,2CAA2C,CAAC;AAChG,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,uBAAuB,MAAM,2BAA2B,CAAC;AAChE,OAAO,2BAA2B,MAAM,+BAA+B,CAAC;AACxE,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,kCAAkC,MAAM,sCAAsC,CAAC;AACtF,OAAO,EAAE,YAAY,EAAE,QAAQ,EAAE,MAAM,cAAc,CAAC;AACtD,OAAO,wBAAwB,MAAM,4BAA4B,CAAC;AAClE,OAAO,iCAAiC,MAAM,qCAAqC,CAAC;AACpF,OAAO,qCAAqC,MAAM,yCAAyC,CAAC;AAC5F,OAAO,mCAAmC,MAAM,uCAAuC,CAAC;AACxF,OAAO,8BAA8B,MAAM,kCAAkC,CAAC;AAC9E,OAAO,YAAY,MAAM,gBAAgB,CAAC;AAC1C,OAAO,WAAW,MAAM,eAAe,CAAC;AACxC,OAAO,SAAS,MAAM,aAAa,CAAC;AACpC,OAAO,oBAAoB,MAAM,wBAAwB,CAAC;AAC1D,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,oBAAoB,MAAM,wBAAwB,CAAC;AAG1D,OAAO,KAAK,MAAM,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAC7C,OAAO,KAAK,QAAQ,MAAM,YAAY,CAAC;AAEvC,OAAO,EACL,OAAO,IAAI,yBAAyB,EACpC,gCAAgC,EAChC,oCAAoC,EACpC,+BAA+B,EAC/B,wBAAwB,EACxB,YAAY,EACZ,YAAY,EACZ,sCAAsC,EACtC,MAAM,EACN,MAAM,EACN,SAAS,EACT,YAAY,EACZ,OAAO,EACP,UAAU,EACV,wBAAwB,EACxB,sBAAsB,EACtB,uBAAuB,EACvB,sBAAsB,EACtB,WAAW,EACX,iBAAiB,EACjB,2BAA2B,EAC3B,oCAAoC,EACpC,qBAAqB,EACrB,qBAAqB,EACrB,uCAAuC,EACvC,wBAAwB,EACxB,qBAAqB,EACrB,iBAAiB,EACjB,iBAAiB,EACjB,iBAAiB,EACjB,kBAAkB,EAClB,kBAAkB,EAClB,uBAAuB,EACvB,2BAA2B,EAC3B,aAAa,EACb,qBAAqB,EACrB,kCAAkC,EAClC,YAAY,EACZ,oBAAoB,EACpB,QAAQ,EACR,wBAAwB,EACxB,iCAAiC,EACjC,qCAAqC,EACrC,mCAAmC,EACnC,8BAA8B,EAC9B,YAAY,EACZ,WAAW,EACX,SAAS,EACT,oBAAoB,EACpB,iBAAiB,EACjB,QAAQ,GACT,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"isPTPrescaledWithSUV.js","sourceRoot":"","sources":["../../../src/utilities/isPTPrescaledWithSUV.ts"],"names":[],"mappings":"AAEA,MAAM,oBAAoB,GAAG,CAAC,KAAa,EAAE,EAAE;IAC7C,OAAO,KAAK,CAAC,QAAQ,EAAE,MAAM,IAAI,KAAK,CAAC,QAAQ,CAAC,iBAAiB,EAAE,KAAK,CAAC;AAC3E,CAAC,CAAC;AAEF,eAAe,oBAAoB,CAAC"}
|
|
@@ -2,6 +2,7 @@ import getOrCreateCanvas from '../RenderingEngine/helpers/getOrCreateCanvas';
|
|
|
2
2
|
import { ViewportType, Events } from '../enums';
|
|
3
3
|
import { getRenderingEngine } from '../RenderingEngine/getRenderingEngine';
|
|
4
4
|
import RenderingEngine from '../RenderingEngine';
|
|
5
|
+
import isPTPrescaledWithSUV from './isPTPrescaledWithSUV';
|
|
5
6
|
export default function renderToCanvasGPU(canvas, image, modality = undefined, renderingEngineId = '_thumbnails') {
|
|
6
7
|
if (!canvas || !(canvas instanceof HTMLCanvasElement)) {
|
|
7
8
|
throw new Error('canvas element is required');
|
|
@@ -14,6 +15,13 @@ export default function renderToCanvasGPU(canvas, image, modality = undefined, r
|
|
|
14
15
|
element.style.height = `${canvas.height}px`;
|
|
15
16
|
element.style.visibility = 'hidden';
|
|
16
17
|
element.style.position = 'absolute';
|
|
18
|
+
const devicePixelRatio = window.devicePixelRatio || 1;
|
|
19
|
+
const originalWidth = canvas.width;
|
|
20
|
+
const originalHeight = canvas.height;
|
|
21
|
+
canvas.width = originalWidth * devicePixelRatio;
|
|
22
|
+
canvas.height = originalHeight * devicePixelRatio;
|
|
23
|
+
canvas.style.width = `${originalWidth}px`;
|
|
24
|
+
canvas.style.height = `${originalHeight}px`;
|
|
17
25
|
document.body.appendChild(element);
|
|
18
26
|
const uniqueId = viewportId.split(':').join('-');
|
|
19
27
|
element.setAttribute('viewport-id-for-remove', uniqueId);
|
|
@@ -40,7 +48,7 @@ export default function renderToCanvasGPU(canvas, image, modality = undefined, r
|
|
|
40
48
|
}
|
|
41
49
|
const temporaryCanvas = getOrCreateCanvas(element);
|
|
42
50
|
const context = canvas.getContext('2d');
|
|
43
|
-
context.drawImage(temporaryCanvas, 0, 0);
|
|
51
|
+
context.drawImage(temporaryCanvas, 0, 0, temporaryCanvas.width, temporaryCanvas.height, 0, 0, canvas.width, canvas.height);
|
|
44
52
|
elementRendered = true;
|
|
45
53
|
element.removeEventListener(Events.IMAGE_RENDERED, onImageRendered);
|
|
46
54
|
setTimeout(() => {
|
|
@@ -54,7 +62,8 @@ export default function renderToCanvasGPU(canvas, image, modality = undefined, r
|
|
|
54
62
|
};
|
|
55
63
|
element.addEventListener(Events.IMAGE_RENDERED, onImageRendered);
|
|
56
64
|
viewport.renderImageObject(image);
|
|
57
|
-
|
|
65
|
+
viewport.resetCamera();
|
|
66
|
+
if (modality === 'PT' && !isPTPrescaledWithSUV(image)) {
|
|
58
67
|
viewport.setProperties({
|
|
59
68
|
voiRange: {
|
|
60
69
|
lower: image.minPixelValue,
|
|
@@ -65,7 +74,4 @@ export default function renderToCanvasGPU(canvas, image, modality = undefined, r
|
|
|
65
74
|
viewport.render();
|
|
66
75
|
});
|
|
67
76
|
}
|
|
68
|
-
const _isPTImagePreScaledWithSUV = (image) => {
|
|
69
|
-
return image.preScale.scaled && image.preScale.scalingParameters.suvbw;
|
|
70
|
-
};
|
|
71
77
|
//# sourceMappingURL=renderToCanvasGPU.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"renderToCanvasGPU.js","sourceRoot":"","sources":["../../../src/utilities/renderToCanvasGPU.ts"],"names":[],"mappings":"AAAA,OAAO,iBAAiB,MAAM,8CAA8C,CAAC;AAC7E,OAAO,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAGhD,OAAO,EAAE,kBAAkB,EAAE,MAAM,uCAAuC,CAAC;AAC3E,OAAO,eAAe,MAAM,oBAAoB,CAAC;
|
|
1
|
+
{"version":3,"file":"renderToCanvasGPU.js","sourceRoot":"","sources":["../../../src/utilities/renderToCanvasGPU.ts"],"names":[],"mappings":"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"}
|