@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.
@@ -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.colormap = exports.getScalarDataType = exports.getScalingParameters = exports.deepMerge = exports.applyPreset = exports.hasNaNValues = exports.getViewportImageCornersInWorld = exports.spatialRegistrationMetadataProvider = exports.calculateViewportsSpatialRegistration = exports.getClosestStackImageIndexForPoint = exports.getViewportsWithImageURI = exports.actorIsA = 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;
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":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4FAAkD;AAqDrC,oCArDN,mCAAO,CAqDwB;AApDtC,0GAAkF;AAqDhF,2CArDK,0CAAgC,CAqDL;AApDlC,kHAA0F;AAqDxF,+CArDK,8CAAoC,CAqDL;AApDtC,wGAAgF;AAqD9E,0CArDK,yCAA+B,CAqDL;AApDjC,0FAAkE;AAqDhE,mCArDK,kCAAwB,CAqDL;AApD1B,kEAA0C;AAqDxC,uBArDK,sBAAY,CAqDL;AApDd,sDAA8B;AAuD5B,iBAvDK,gBAAM,CAuDL;AAtDR,4DAAoC;AAwDlC,oBAxDK,mBAAS,CAwDL;AAvDX,kEAA0C;AAwDxC,uBAxDK,sBAAY,CAwDL;AAvDd,kEAA0C;AAkDxC,uBAlDK,sBAAY,CAkDL;AAjDd,sHAA8F;AAkD5F,iDAlDK,gDAAsC,CAkDL;AAjDxC,wDAAgC;AAsD9B,kBAtDK,iBAAO,CAsDL;AArDT,8DAAsC;AAsDpC,qBAtDK,oBAAU,CAsDL;AArDZ,sFAA8D;AAuD5D,iCAvDK,gCAAsB,CAuDL;AAtDxB,0FAAkE;AAqDhE,mCArDK,kCAAwB,CAqDL;AApD1B,wFAAgE;AAsD9D,kCAtDK,iCAAuB,CAsDL;AArDzB,sFAA8D;AAsD5D,iCAtDK,gCAAsB,CAsDL;AArDxB,4EAAoD;AAuDlD,4BAvDK,2BAAiB,CAuDL;AAtDnB,gGAAwE;AAuDtE,sCAvDK,qCAA2B,CAuDL;AAtD7B,kHAA0F;AAuDxF,+CAvDK,8CAAoC,CAuDL;AAtDtC,oFAA4D;AAuD1D,gCAvDK,+BAAqB,CAuDL;AAtDvB,oFAA4D;AAuD1D,gCAvDK,+BAAqB,CAuDL;AAtDvB,wHAAgG;AAuD9F,kDAvDK,iDAAuC,CAuDL;AAtDzC,0FAAkE;AAuDhE,mCAvDK,kCAAwB,CAuDL;AAtD1B,oFAA4D;AAuD1D,gCAvDK,+BAAqB,CAuDL;AAtDvB,4EAAoD;AAuDlD,4BAvDK,2BAAiB,CAuDL;AAtDnB,4EAAoD;AAuDlD,4BAvDK,2BAAiB,CAuDL;AAtDnB,4EAAoD;AAuDlD,4BAvDK,2BAAiB,CAuDL;AAtDnB,8EAAsD;AAuDpD,6BAvDK,4BAAkB,CAuDL;AAtDpB,8EAAsD;AAuDpD,6BAvDK,4BAAkB,CAuDL;AAtDpB,wFAAgE;AAuD9D,kCAvDK,iCAAuB,CAuDL;AAtDzB,gGAAwE;AAuDtE,sCAvDK,qCAA2B,CAuDL;AAtD7B,oEAA4C;AAuD1C,wBAvDK,uBAAa,CAuDL;AAtDf,oFAA4D;AAuD1D,gCAvDK,+BAAqB,CAuDL;AAtDvB,8GAAsF;AAuDpF,6CAvDK,4CAAkC,CAuDL;AAtDpC,6CAAsD;AAuDpD,6FAvDO,yBAAY,OAuDP;AACZ,yFAxDqB,qBAAQ,OAwDrB;AAvDV,0FAAkE;AAwDhE,mCAxDK,kCAAwB,CAwDL;AAvD1B,4GAAoF;AAwDlF,4CAxDK,2CAAiC,CAwDL;AAvDnC,oHAA4F;AAwD1F,gDAxDK,+CAAqC,CAwDL;AAvDvC,gHAAwF;AAwDtF,8CAxDK,6CAAmC,CAwDL;AAvDrC,sGAA8E;AAwD5E,yCAxDK,wCAA8B,CAwDL;AAvDhC,kEAA0C;AAwDxC,uBAxDK,sBAAY,CAwDL;AAvDd,gEAAwC;AAwDtC,sBAxDK,qBAAW,CAwDL;AAvDb,4DAAoC;AAwDlC,oBAxDK,mBAAS,CAwDL;AAvDX,kFAA0D;AAwDxD,+BAxDK,8BAAoB,CAwDL;AAvDtB,4EAAoD;AAwDlD,4BAxDK,2BAAiB,CAwDL;AArDnB,iDAAmC;AAcjC,wBAAM;AAbR,2DAA6C;AAsB3C,kCAAW;AArBb,qDAAuC;AAoDrC,4BAAQ"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utilities/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,4FAAkD;AAsDrC,oCAtDN,mCAAO,CAsDwB;AArDtC,0GAAkF;AAsDhF,2CAtDK,0CAAgC,CAsDL;AArDlC,kHAA0F;AAsDxF,+CAtDK,8CAAoC,CAsDL;AArDtC,wGAAgF;AAsD9E,0CAtDK,yCAA+B,CAsDL;AArDjC,0FAAkE;AAsDhE,mCAtDK,kCAAwB,CAsDL;AArD1B,kEAA0C;AAsDxC,uBAtDK,sBAAY,CAsDL;AArDd,sDAA8B;AAwD5B,iBAxDK,gBAAM,CAwDL;AAvDR,4DAAoC;AAyDlC,oBAzDK,mBAAS,CAyDL;AAxDX,kEAA0C;AAyDxC,uBAzDK,sBAAY,CAyDL;AAxDd,kEAA0C;AAmDxC,uBAnDK,sBAAY,CAmDL;AAlDd,sHAA8F;AAmD5F,iDAnDK,gDAAsC,CAmDL;AAlDxC,wDAAgC;AAuD9B,kBAvDK,iBAAO,CAuDL;AAtDT,8DAAsC;AAuDpC,qBAvDK,oBAAU,CAuDL;AAtDZ,sFAA8D;AAwD5D,iCAxDK,gCAAsB,CAwDL;AAvDxB,0FAAkE;AAsDhE,mCAtDK,kCAAwB,CAsDL;AArD1B,wFAAgE;AAuD9D,kCAvDK,iCAAuB,CAuDL;AAtDzB,sFAA8D;AAuD5D,iCAvDK,gCAAsB,CAuDL;AAtDxB,4EAAoD;AAwDlD,4BAxDK,2BAAiB,CAwDL;AAvDnB,gGAAwE;AAwDtE,sCAxDK,qCAA2B,CAwDL;AAvD7B,kHAA0F;AAwDxF,+CAxDK,8CAAoC,CAwDL;AAvDtC,oFAA4D;AAwD1D,gCAxDK,+BAAqB,CAwDL;AAvDvB,oFAA4D;AAwD1D,gCAxDK,+BAAqB,CAwDL;AAvDvB,wHAAgG;AAwD9F,kDAxDK,iDAAuC,CAwDL;AAvDzC,0FAAkE;AAwDhE,mCAxDK,kCAAwB,CAwDL;AAvD1B,oFAA4D;AAwD1D,gCAxDK,+BAAqB,CAwDL;AAvDvB,4EAAoD;AAwDlD,4BAxDK,2BAAiB,CAwDL;AAvDnB,4EAAoD;AAwDlD,4BAxDK,2BAAiB,CAwDL;AAvDnB,4EAAoD;AAwDlD,4BAxDK,2BAAiB,CAwDL;AAvDnB,8EAAsD;AAwDpD,6BAxDK,4BAAkB,CAwDL;AAvDpB,8EAAsD;AAwDpD,6BAxDK,4BAAkB,CAwDL;AAvDpB,wFAAgE;AAwD9D,kCAxDK,iCAAuB,CAwDL;AAvDzB,gGAAwE;AAwDtE,sCAxDK,qCAA2B,CAwDL;AAvD7B,oEAA4C;AAwD1C,wBAxDK,uBAAa,CAwDL;AAvDf,oFAA4D;AAwD1D,gCAxDK,+BAAqB,CAwDL;AAvDvB,8GAAsF;AAwDpF,6CAxDK,4CAAkC,CAwDL;AAvDpC,6CAAsD;AAwDpD,6FAxDO,yBAAY,OAwDP;AAEZ,yFA1DqB,qBAAQ,OA0DrB;AAzDV,0FAAkE;AA0DhE,mCA1DK,kCAAwB,CA0DL;AAzD1B,4GAAoF;AA0DlF,4CA1DK,2CAAiC,CA0DL;AAzDnC,oHAA4F;AA0D1F,gDA1DK,+CAAqC,CA0DL;AAzDvC,gHAAwF;AA0DtF,8CA1DK,6CAAmC,CA0DL;AAzDrC,sGAA8E;AA0D5E,yCA1DK,wCAA8B,CA0DL;AAzDhC,kEAA0C;AA0DxC,uBA1DK,sBAAY,CA0DL;AAzDd,gEAAwC;AA0DtC,sBA1DK,qBAAW,CA0DL;AAzDb,4DAAoC;AA0DlC,oBA1DK,mBAAS,CA0DL;AAzDX,kFAA0D;AA0DxD,+BA1DK,8BAAoB,CA0DL;AAzDtB,4EAAoD;AA0DlD,4BA1DK,2BAAiB,CA0DL;AAzDnB,kFAA0D;AA8CxD,+BA9CK,8BAAoB,CA8CL;AA3CtB,iDAAmC;AAcjC,wBAAM;AAbR,2DAA6C;AAsB3C,kCAAW;AArBb,qDAAuC;AAqDrC,4BAAQ"}
@@ -0,0 +1,3 @@
1
+ import { IImage } from '../types';
2
+ declare const isPTPrescaledWithSUV: (image: IImage) => number;
3
+ export default isPTPrescaledWithSUV;
@@ -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
- if (modality === 'PT' && !_isPTImagePreScaledWithSUV(image)) {
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":"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"}
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":"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"}
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,3 @@
1
+ import { IImage } from '../types';
2
+ declare const isPTPrescaledWithSUV: (image: IImage) => number;
3
+ export default isPTPrescaledWithSUV;
@@ -0,0 +1,5 @@
1
+ const isPTPrescaledWithSUV = (image) => {
2
+ return image.preScale?.scaled && image.preScale.scalingParameters?.suvbw;
3
+ };
4
+ export default isPTPrescaledWithSUV;
5
+ //# 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,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
- if (modality === 'PT' && !_isPTImagePreScaledWithSUV(image)) {
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":"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"}
1
+ {"version":3,"file":"renderToCanvasGPU.js","sourceRoot":"","sources":["../../../src/utilities/renderToCanvasGPU.ts"],"names":[],"mappings":"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"}