@cornerstonejs/core 0.8.1 → 0.10.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (167) hide show
  1. package/dist/cjs/RenderingEngine/RenderingEngine.js +6 -2
  2. package/dist/cjs/RenderingEngine/RenderingEngine.js.map +1 -1
  3. package/dist/cjs/RenderingEngine/StackViewport.js +47 -38
  4. package/dist/cjs/RenderingEngine/StackViewport.js.map +1 -1
  5. package/dist/cjs/RenderingEngine/Viewport.d.ts +7 -1
  6. package/dist/cjs/RenderingEngine/Viewport.js +74 -53
  7. package/dist/cjs/RenderingEngine/Viewport.js.map +1 -1
  8. package/dist/cjs/RenderingEngine/VolumeViewport.d.ts +3 -1
  9. package/dist/cjs/RenderingEngine/VolumeViewport.js +151 -53
  10. package/dist/cjs/RenderingEngine/VolumeViewport.js.map +1 -1
  11. package/dist/cjs/RenderingEngine/helpers/cpuFallback/rendering/generateLut.js +19 -5
  12. package/dist/cjs/RenderingEngine/helpers/cpuFallback/rendering/generateLut.js.map +1 -1
  13. package/dist/cjs/RenderingEngine/helpers/cpuFallback/rendering/getDefaultViewport.js +2 -1
  14. package/dist/cjs/RenderingEngine/helpers/cpuFallback/rendering/getDefaultViewport.js.map +1 -1
  15. package/dist/cjs/RenderingEngine/helpers/createVolumeActor.d.ts +1 -1
  16. package/dist/cjs/RenderingEngine/helpers/createVolumeActor.js +31 -3
  17. package/dist/cjs/RenderingEngine/helpers/createVolumeActor.js.map +1 -1
  18. package/dist/cjs/RenderingEngine/helpers/index.d.ts +2 -1
  19. package/dist/cjs/RenderingEngine/helpers/index.js +3 -1
  20. package/dist/cjs/RenderingEngine/helpers/index.js.map +1 -1
  21. package/dist/cjs/RenderingEngine/helpers/setDefaultVolumeVOI.d.ts +3 -0
  22. package/dist/cjs/RenderingEngine/helpers/setDefaultVolumeVOI.js +163 -0
  23. package/dist/cjs/RenderingEngine/helpers/setDefaultVolumeVOI.js.map +1 -0
  24. package/dist/cjs/RenderingEngine/helpers/volumeNewImageEventDispatcher.d.ts +4 -0
  25. package/dist/cjs/RenderingEngine/helpers/volumeNewImageEventDispatcher.js +42 -0
  26. package/dist/cjs/RenderingEngine/helpers/volumeNewImageEventDispatcher.js.map +1 -0
  27. package/dist/cjs/RenderingEngine/vtkClasses/vtkSlabCamera.d.ts +12 -24
  28. package/dist/cjs/RenderingEngine/vtkClasses/vtkSlabCamera.js +7 -8
  29. package/dist/cjs/RenderingEngine/vtkClasses/vtkSlabCamera.js.map +1 -1
  30. package/dist/cjs/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.js +3 -14
  31. package/dist/cjs/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.js.map +1 -1
  32. package/dist/cjs/Settings.js +1 -0
  33. package/dist/cjs/Settings.js.map +1 -1
  34. package/dist/cjs/cache/classes/ImageVolume.d.ts +1 -0
  35. package/dist/cjs/cache/classes/ImageVolume.js +1 -0
  36. package/dist/cjs/cache/classes/ImageVolume.js.map +1 -1
  37. package/dist/cjs/constants/index.d.ts +2 -1
  38. package/dist/cjs/constants/index.js +3 -1
  39. package/dist/cjs/constants/index.js.map +1 -1
  40. package/dist/cjs/constants/rendering.d.ts +5 -0
  41. package/dist/cjs/constants/rendering.js +9 -0
  42. package/dist/cjs/constants/rendering.js.map +1 -0
  43. package/dist/cjs/enums/BlendModes.js +1 -1
  44. package/dist/cjs/enums/BlendModes.js.map +1 -1
  45. package/dist/cjs/enums/Events.d.ts +1 -0
  46. package/dist/cjs/enums/Events.js +1 -0
  47. package/dist/cjs/enums/Events.js.map +1 -1
  48. package/dist/cjs/types/ActorSliceRange.d.ts +11 -0
  49. package/dist/cjs/types/ActorSliceRange.js +3 -0
  50. package/dist/cjs/types/ActorSliceRange.js.map +1 -0
  51. package/dist/cjs/types/EventTypes.d.ts +10 -1
  52. package/dist/cjs/types/IActor.d.ts +5 -2
  53. package/dist/cjs/types/ICamera.d.ts +0 -3
  54. package/dist/cjs/types/IImageVolume.d.ts +1 -0
  55. package/dist/cjs/types/IViewport.d.ts +2 -0
  56. package/dist/cjs/types/IVolumeInput.d.ts +1 -0
  57. package/dist/cjs/types/IVolumeViewport.d.ts +2 -1
  58. package/dist/cjs/types/ImageSliceData.d.ts +5 -0
  59. package/dist/cjs/types/ImageSliceData.js +3 -0
  60. package/dist/cjs/types/ImageSliceData.js.map +1 -0
  61. package/dist/cjs/types/Metadata.d.ts +1 -0
  62. package/dist/cjs/types/index.d.ts +4 -2
  63. package/dist/cjs/utilities/getImageSliceDataForVolumeViewport.d.ts +3 -0
  64. package/dist/cjs/utilities/getImageSliceDataForVolumeViewport.js +37 -0
  65. package/dist/cjs/utilities/getImageSliceDataForVolumeViewport.js.map +1 -0
  66. package/dist/cjs/utilities/getScalingParameters.d.ts +2 -0
  67. package/dist/cjs/utilities/getScalingParameters.js +41 -0
  68. package/dist/cjs/utilities/getScalingParameters.js.map +1 -0
  69. package/dist/cjs/utilities/getSliceRange.d.ts +2 -0
  70. package/dist/cjs/utilities/getSliceRange.js +39 -0
  71. package/dist/cjs/utilities/getSliceRange.js.map +1 -0
  72. package/dist/cjs/utilities/getTargetVolumeAndSpacingInNormalDir.js +1 -1
  73. package/dist/cjs/utilities/getVolumeViewportsContainingVolumeId.js +2 -2
  74. package/dist/cjs/utilities/getVolumeViewportsContainingVolumeId.js.map +1 -1
  75. package/dist/cjs/utilities/index.d.ts +6 -2
  76. package/dist/cjs/utilities/index.js +9 -1
  77. package/dist/cjs/utilities/index.js.map +1 -1
  78. package/dist/cjs/utilities/loadImageToCanvas.js +2 -9
  79. package/dist/cjs/utilities/loadImageToCanvas.js.map +1 -1
  80. package/dist/cjs/utilities/snapFocalPointToSlice.d.ts +5 -0
  81. package/dist/cjs/utilities/snapFocalPointToSlice.js +41 -0
  82. package/dist/cjs/utilities/snapFocalPointToSlice.js.map +1 -0
  83. package/dist/esm/RenderingEngine/RenderingEngine.js +6 -2
  84. package/dist/esm/RenderingEngine/RenderingEngine.js.map +1 -1
  85. package/dist/esm/RenderingEngine/StackViewport.js +47 -38
  86. package/dist/esm/RenderingEngine/StackViewport.js.map +1 -1
  87. package/dist/esm/RenderingEngine/Viewport.d.ts +7 -1
  88. package/dist/esm/RenderingEngine/Viewport.js +74 -53
  89. package/dist/esm/RenderingEngine/Viewport.js.map +1 -1
  90. package/dist/esm/RenderingEngine/VolumeViewport.d.ts +3 -1
  91. package/dist/esm/RenderingEngine/VolumeViewport.js +132 -53
  92. package/dist/esm/RenderingEngine/VolumeViewport.js.map +1 -1
  93. package/dist/esm/RenderingEngine/helpers/cpuFallback/rendering/generateLut.js +19 -5
  94. package/dist/esm/RenderingEngine/helpers/cpuFallback/rendering/generateLut.js.map +1 -1
  95. package/dist/esm/RenderingEngine/helpers/cpuFallback/rendering/getDefaultViewport.js +2 -1
  96. package/dist/esm/RenderingEngine/helpers/cpuFallback/rendering/getDefaultViewport.js.map +1 -1
  97. package/dist/esm/RenderingEngine/helpers/createVolumeActor.d.ts +1 -1
  98. package/dist/esm/RenderingEngine/helpers/createVolumeActor.js +31 -3
  99. package/dist/esm/RenderingEngine/helpers/createVolumeActor.js.map +1 -1
  100. package/dist/esm/RenderingEngine/helpers/index.d.ts +2 -1
  101. package/dist/esm/RenderingEngine/helpers/index.js +2 -1
  102. package/dist/esm/RenderingEngine/helpers/index.js.map +1 -1
  103. package/dist/esm/RenderingEngine/helpers/setDefaultVolumeVOI.d.ts +3 -0
  104. package/dist/esm/RenderingEngine/helpers/setDefaultVolumeVOI.js +132 -0
  105. package/dist/esm/RenderingEngine/helpers/setDefaultVolumeVOI.js.map +1 -0
  106. package/dist/esm/RenderingEngine/helpers/volumeNewImageEventDispatcher.d.ts +4 -0
  107. package/dist/esm/RenderingEngine/helpers/volumeNewImageEventDispatcher.js +35 -0
  108. package/dist/esm/RenderingEngine/helpers/volumeNewImageEventDispatcher.js.map +1 -0
  109. package/dist/esm/RenderingEngine/vtkClasses/vtkSlabCamera.d.ts +12 -24
  110. package/dist/esm/RenderingEngine/vtkClasses/vtkSlabCamera.js +7 -8
  111. package/dist/esm/RenderingEngine/vtkClasses/vtkSlabCamera.js.map +1 -1
  112. package/dist/esm/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.js +3 -14
  113. package/dist/esm/RenderingEngine/vtkClasses/vtkStreamingOpenGLVolumeMapper.js.map +1 -1
  114. package/dist/esm/Settings.js +1 -0
  115. package/dist/esm/Settings.js.map +1 -1
  116. package/dist/esm/cache/classes/ImageVolume.d.ts +1 -0
  117. package/dist/esm/cache/classes/ImageVolume.js +1 -0
  118. package/dist/esm/cache/classes/ImageVolume.js.map +1 -1
  119. package/dist/esm/constants/index.d.ts +2 -1
  120. package/dist/esm/constants/index.js +2 -1
  121. package/dist/esm/constants/index.js.map +1 -1
  122. package/dist/esm/constants/rendering.d.ts +5 -0
  123. package/dist/esm/constants/rendering.js +7 -0
  124. package/dist/esm/constants/rendering.js.map +1 -0
  125. package/dist/esm/enums/BlendModes.js +1 -1
  126. package/dist/esm/enums/BlendModes.js.map +1 -1
  127. package/dist/esm/enums/Events.d.ts +1 -0
  128. package/dist/esm/enums/Events.js +1 -0
  129. package/dist/esm/enums/Events.js.map +1 -1
  130. package/dist/esm/types/ActorSliceRange.d.ts +11 -0
  131. package/dist/esm/types/ActorSliceRange.js +2 -0
  132. package/dist/esm/types/ActorSliceRange.js.map +1 -0
  133. package/dist/esm/types/EventTypes.d.ts +10 -1
  134. package/dist/esm/types/IActor.d.ts +5 -2
  135. package/dist/esm/types/ICamera.d.ts +0 -3
  136. package/dist/esm/types/IImageVolume.d.ts +1 -0
  137. package/dist/esm/types/IViewport.d.ts +2 -0
  138. package/dist/esm/types/IVolumeInput.d.ts +1 -0
  139. package/dist/esm/types/IVolumeViewport.d.ts +2 -1
  140. package/dist/esm/types/ImageSliceData.d.ts +5 -0
  141. package/dist/esm/types/ImageSliceData.js +2 -0
  142. package/dist/esm/types/ImageSliceData.js.map +1 -0
  143. package/dist/esm/types/Metadata.d.ts +1 -0
  144. package/dist/esm/types/index.d.ts +4 -2
  145. package/dist/esm/utilities/getImageSliceDataForVolumeViewport.d.ts +3 -0
  146. package/dist/esm/utilities/getImageSliceDataForVolumeViewport.js +32 -0
  147. package/dist/esm/utilities/getImageSliceDataForVolumeViewport.js.map +1 -0
  148. package/dist/esm/utilities/getScalingParameters.d.ts +2 -0
  149. package/dist/esm/utilities/getScalingParameters.js +22 -0
  150. package/dist/esm/utilities/getScalingParameters.js.map +1 -0
  151. package/dist/esm/utilities/getSliceRange.d.ts +2 -0
  152. package/dist/esm/utilities/getSliceRange.js +33 -0
  153. package/dist/esm/utilities/getSliceRange.js.map +1 -0
  154. package/dist/esm/utilities/getTargetVolumeAndSpacingInNormalDir.js +1 -1
  155. package/dist/esm/utilities/getVolumeViewportsContainingVolumeId.js +2 -2
  156. package/dist/esm/utilities/getVolumeViewportsContainingVolumeId.js.map +1 -1
  157. package/dist/esm/utilities/index.d.ts +6 -2
  158. package/dist/esm/utilities/index.js +6 -2
  159. package/dist/esm/utilities/index.js.map +1 -1
  160. package/dist/esm/utilities/loadImageToCanvas.js +2 -9
  161. package/dist/esm/utilities/loadImageToCanvas.js.map +1 -1
  162. package/dist/esm/utilities/snapFocalPointToSlice.d.ts +5 -0
  163. package/dist/esm/utilities/snapFocalPointToSlice.js +38 -0
  164. package/dist/esm/utilities/snapFocalPointToSlice.js.map +1 -0
  165. package/dist/umd/index.js +1 -1
  166. package/dist/umd/index.js.map +1 -1
  167. package/package.json +2 -2
@@ -10,7 +10,7 @@ import type IRegisterImageLoader from './IRegisterImageLoader';
10
10
  import type IStreamingVolumeProperties from './IStreamingVolumeProperties';
11
11
  import type CustomEventType from './CustomEventType';
12
12
  import type { IViewport, PublicViewportInput } from './IViewport';
13
- import type { VolumeActor, ActorEntry } from './IActor';
13
+ import type { VolumeActor, Actor, ActorEntry } from './IActor';
14
14
  import type { IImageLoadObject, IVolumeLoadObject } from './ILoadObject';
15
15
  import type Metadata from './Metadata';
16
16
  import type Orientation from './Orientation';
@@ -46,4 +46,6 @@ import type CPUFallbackRenderingTools from './CPUFallbackRenderingTools';
46
46
  import type { IVolumeInput, VolumeInputCallback } from './IVolumeInput';
47
47
  import type * as EventTypes from './EventTypes';
48
48
  import type IRenderingEngine from './IRenderingEngine';
49
- export type { ICamera, IStackViewport, IVolumeViewport, IEnabledElement, ICache, IVolume, IViewportId, IImageVolume, IRenderingEngine, ScalingParameters, PTScaling, Scaling, IStreamingImageVolume, IImage, IImageData, CPUIImageData, CPUImageData, EventTypes, ImageLoaderFn, VolumeLoaderFn, IRegisterImageLoader, IStreamingVolumeProperties, IViewport, StackViewportProperties, PublicViewportInput, VolumeActor, ActorEntry, IImageLoadObject, IVolumeLoadObject, IVolumeInput, VolumeInputCallback, Metadata, Orientation, Point2, Point3, Point4, Plane, ViewportInputOptions, VOIRange, VOI, FlipDirection, ICachedImage, ICachedVolume, CPUFallbackEnabledElement, CPUFallbackViewport, CPUFallbackTransform, CPUFallbackColormapData, CPUFallbackViewportDisplayedArea, CPUFallbackColormapsData, CPUFallbackColormap, TransformMatrix2D, CPUFallbackLookupTable, CPUFallbackLUT, CPUFallbackRenderingTools, CustomEventType, };
49
+ import type ActorSliceRange from './ActorSliceRange';
50
+ import type ImageSliceData from './ImageSliceData';
51
+ export type { ICamera, IStackViewport, IVolumeViewport, IEnabledElement, ICache, IVolume, IViewportId, IImageVolume, IRenderingEngine, ScalingParameters, PTScaling, Scaling, IStreamingImageVolume, IImage, IImageData, CPUIImageData, CPUImageData, EventTypes, ImageLoaderFn, VolumeLoaderFn, IRegisterImageLoader, IStreamingVolumeProperties, IViewport, StackViewportProperties, PublicViewportInput, VolumeActor, Actor, ActorEntry, IImageLoadObject, IVolumeLoadObject, IVolumeInput, VolumeInputCallback, Metadata, Orientation, Point2, Point3, Point4, Plane, ViewportInputOptions, VOIRange, VOI, FlipDirection, ICachedImage, ICachedVolume, CPUFallbackEnabledElement, CPUFallbackViewport, CPUFallbackTransform, CPUFallbackColormapData, CPUFallbackViewportDisplayedArea, CPUFallbackColormapsData, CPUFallbackColormap, TransformMatrix2D, CPUFallbackLookupTable, CPUFallbackLUT, CPUFallbackRenderingTools, CustomEventType, ActorSliceRange, ImageSliceData, };
@@ -0,0 +1,3 @@
1
+ import { ImageSliceData, IVolumeViewport } from '../types';
2
+ declare function getImageSliceDataForVolumeViewport(viewport: IVolumeViewport): ImageSliceData;
3
+ export default getImageSliceDataForVolumeViewport;
@@ -0,0 +1,32 @@
1
+ import getSliceRange from './getSliceRange';
2
+ import getTargetVolumeAndSpacingInNormalDir from './getTargetVolumeAndSpacingInNormalDir';
3
+ function getImageSliceDataForVolumeViewport(viewport) {
4
+ const camera = viewport.getCamera();
5
+ const { spacingInNormalDirection, imageVolume } = getTargetVolumeAndSpacingInNormalDir(viewport, camera);
6
+ if (!imageVolume) {
7
+ return;
8
+ }
9
+ const { viewPlaneNormal, focalPoint } = camera;
10
+ const actorEntry = viewport.getActor(imageVolume.volumeId);
11
+ if (!actorEntry) {
12
+ console.warn('No actor found for with actorUID of', imageVolume.volumeId);
13
+ }
14
+ const volumeActor = actorEntry.actor;
15
+ const sliceRange = getSliceRange(volumeActor, viewPlaneNormal, focalPoint);
16
+ const { min, max, current } = sliceRange;
17
+ const numberOfSlices = Math.round((max - min) / spacingInNormalDirection) + 1;
18
+ let imageIndex = ((current - min) / (max - min)) * numberOfSlices;
19
+ imageIndex = Math.floor(imageIndex);
20
+ if (imageIndex > numberOfSlices - 1) {
21
+ imageIndex = numberOfSlices - 1;
22
+ }
23
+ else if (imageIndex < 0) {
24
+ imageIndex = 0;
25
+ }
26
+ return {
27
+ numberOfSlices,
28
+ imageIndex,
29
+ };
30
+ }
31
+ export default getImageSliceDataForVolumeViewport;
32
+ //# sourceMappingURL=getImageSliceDataForVolumeViewport.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getImageSliceDataForVolumeViewport.js","sourceRoot":"","sources":["../../../src/utilities/getImageSliceDataForVolumeViewport.ts"],"names":[],"mappings":"AACA,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,oCAAoC,MAAM,wCAAwC,CAAC;AAQ1F,SAAS,kCAAkC,CACzC,QAAyB;IAEzB,MAAM,MAAM,GAAG,QAAQ,CAAC,SAAS,EAAE,CAAC;IAEpC,MAAM,EAAE,wBAAwB,EAAE,WAAW,EAAE,GAC7C,oCAAoC,CAAC,QAAQ,EAAE,MAAM,CAAC,CAAC;IAEzD,IAAI,CAAC,WAAW,EAAE;QAChB,OAAO;KACR;IAED,MAAM,EAAE,eAAe,EAAE,UAAU,EAAE,GAAG,MAAM,CAAC;IAC/C,MAAM,UAAU,GAAG,QAAQ,CAAC,QAAQ,CAAC,WAAW,CAAC,QAAQ,CAAC,CAAC;IAE3D,IAAI,CAAC,UAAU,EAAE;QACf,OAAO,CAAC,IAAI,CAAC,qCAAqC,EAAE,WAAW,CAAC,QAAQ,CAAC,CAAC;KAC3E;IAED,MAAM,WAAW,GAAG,UAAU,CAAC,KAAoB,CAAC;IACpD,MAAM,UAAU,GAAG,aAAa,CAAC,WAAW,EAAE,eAAe,EAAE,UAAU,CAAC,CAAC;IAE3E,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC;IAGzC,MAAM,cAAc,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,wBAAwB,CAAC,GAAG,CAAC,CAAC;IAG9E,IAAI,UAAU,GAAG,CAAC,CAAC,OAAO,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC,GAAG,cAAc,CAAC;IAClE,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,CAAC;IAGpC,IAAI,UAAU,GAAG,cAAc,GAAG,CAAC,EAAE;QACnC,UAAU,GAAG,cAAc,GAAG,CAAC,CAAC;KACjC;SAAM,IAAI,UAAU,GAAG,CAAC,EAAE;QACzB,UAAU,GAAG,CAAC,CAAC;KAChB;IAED,OAAO;QACL,cAAc;QACd,UAAU;KACX,CAAC;AACJ,CAAC;AAED,eAAe,kCAAkC,CAAC"}
@@ -0,0 +1,2 @@
1
+ import { ScalingParameters } from '../types';
2
+ export default function getScalingParameters(imageId: string): ScalingParameters | undefined;
@@ -0,0 +1,22 @@
1
+ import * as metaData from '../metaData';
2
+ export default function getScalingParameters(imageId) {
3
+ const modalityLutModule = metaData.get('modalityLutModule', imageId) || {};
4
+ const generalSeriesModule = metaData.get('generalSeriesModule', imageId) || {};
5
+ const { modality } = generalSeriesModule;
6
+ const scalingParameters = {
7
+ rescaleSlope: modalityLutModule.rescaleSlope,
8
+ rescaleIntercept: modalityLutModule.rescaleIntercept,
9
+ modality,
10
+ };
11
+ if (modality !== 'PT') {
12
+ return scalingParameters;
13
+ }
14
+ const suvFactor = metaData.get('scalingModule', imageId) || {};
15
+ if (modality === 'PT' && suvFactor.suvbw) {
16
+ return {
17
+ ...scalingParameters,
18
+ suvbw: suvFactor.suvbw,
19
+ };
20
+ }
21
+ }
22
+ //# sourceMappingURL=getScalingParameters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getScalingParameters.js","sourceRoot":"","sources":["../../../src/utilities/getScalingParameters.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,QAAQ,MAAM,aAAa,CAAC;AASxC,MAAM,CAAC,OAAO,UAAU,oBAAoB,CAC1C,OAAe;IAEf,MAAM,iBAAiB,GAAG,QAAQ,CAAC,GAAG,CAAC,mBAAmB,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;IAE3E,MAAM,mBAAmB,GACvB,QAAQ,CAAC,GAAG,CAAC,qBAAqB,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;IAErD,MAAM,EAAE,QAAQ,EAAE,GAAG,mBAAmB,CAAC;IAEzC,MAAM,iBAAiB,GAAsB;QAC3C,YAAY,EAAE,iBAAiB,CAAC,YAAY;QAC5C,gBAAgB,EAAE,iBAAiB,CAAC,gBAAgB;QACpD,QAAQ;KACT,CAAC;IAEF,IAAI,QAAQ,KAAK,IAAI,EAAE;QACrB,OAAO,iBAAiB,CAAC;KAC1B;IAED,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,eAAe,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;IAE/D,IAAI,QAAQ,KAAK,IAAI,IAAI,SAAS,CAAC,KAAK,EAAE;QACxC,OAAO;YACL,GAAG,iBAAiB;YACpB,KAAK,EAAE,SAAS,CAAC,KAAK;SACvB,CAAC;KACH;AACH,CAAC"}
@@ -0,0 +1,2 @@
1
+ import type { VolumeActor, Point3, ActorSliceRange } from '../types';
2
+ export default function getSliceRange(volumeActor: VolumeActor, viewPlaneNormal: Point3, focalPoint: Point3): ActorSliceRange;
@@ -0,0 +1,33 @@
1
+ import vtkMatrixBuilder from '@kitware/vtk.js/Common/Core/MatrixBuilder';
2
+ import getVolumeActorCorners from './getVolumeActorCorners';
3
+ export default function getSliceRange(volumeActor, viewPlaneNormal, focalPoint) {
4
+ const corners = getVolumeActorCorners(volumeActor);
5
+ const transform = vtkMatrixBuilder
6
+ .buildFromDegree()
7
+ .identity()
8
+ .rotateFromDirections(viewPlaneNormal, [1, 0, 0]);
9
+ corners.forEach((pt) => transform.apply(pt));
10
+ const transformedFocalPoint = [...focalPoint];
11
+ transform.apply(transformedFocalPoint);
12
+ const currentSlice = transformedFocalPoint[0];
13
+ let minX = Infinity;
14
+ let maxX = -Infinity;
15
+ for (let i = 0; i < 8; i++) {
16
+ const x = corners[i][0];
17
+ if (x > maxX) {
18
+ maxX = x;
19
+ }
20
+ if (x < minX) {
21
+ minX = x;
22
+ }
23
+ }
24
+ return {
25
+ min: minX,
26
+ max: maxX,
27
+ current: currentSlice,
28
+ actor: volumeActor,
29
+ viewPlaneNormal,
30
+ focalPoint,
31
+ };
32
+ }
33
+ //# sourceMappingURL=getSliceRange.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getSliceRange.js","sourceRoot":"","sources":["../../../src/utilities/getSliceRange.ts"],"names":[],"mappings":"AAAA,OAAO,gBAAgB,MAAM,2CAA2C,CAAC;AACzE,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAe5D,MAAM,CAAC,OAAO,UAAU,aAAa,CACnC,WAAwB,EACxB,eAAuB,EACvB,UAAkB;IAElB,MAAM,OAAO,GAAG,qBAAqB,CAAC,WAAW,CAAC,CAAC;IAGnD,MAAM,SAAS,GAAG,gBAAgB;SAC/B,eAAe,EAAE;SACjB,QAAQ,EAAE;SACV,oBAAoB,CAAC,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;IAEpD,OAAO,CAAC,OAAO,CAAC,CAAC,EAAE,EAAE,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC;IAE7C,MAAM,qBAAqB,GAAG,CAAC,GAAG,UAAU,CAAC,CAAC;IAE9C,SAAS,CAAC,KAAK,CAAC,qBAAqB,CAAC,CAAC;IAEvC,MAAM,YAAY,GAAG,qBAAqB,CAAC,CAAC,CAAC,CAAC;IAG9C,IAAI,IAAI,GAAG,QAAQ,CAAC;IACpB,IAAI,IAAI,GAAG,CAAC,QAAQ,CAAC;IACrB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE;QAC1B,MAAM,CAAC,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACxB,IAAI,CAAC,GAAG,IAAI,EAAE;YACZ,IAAI,GAAG,CAAC,CAAC;SACV;QACD,IAAI,CAAC,GAAG,IAAI,EAAE;YACZ,IAAI,GAAG,CAAC,CAAC;SACV;KACF;IAED,OAAO;QACL,GAAG,EAAE,IAAI;QACT,GAAG,EAAE,IAAI;QACT,OAAO,EAAE,YAAY;QACrB,KAAK,EAAE,WAAW;QAClB,eAAe;QACf,UAAU;KACX,CAAC;AACJ,CAAC"}
@@ -3,7 +3,7 @@ import getSpacingInNormalDirection from './getSpacingInNormalDirection';
3
3
  export default function getTargetVolumeAndSpacingInNormalDir(viewport, camera, targetVolumeId) {
4
4
  const { viewPlaneNormal } = camera;
5
5
  const volumeActors = viewport.getActors();
6
- if (!volumeActors && !volumeActors.length) {
6
+ if (!volumeActors || !volumeActors.length) {
7
7
  return { spacingInNormalDirection: null, imageVolume: null };
8
8
  }
9
9
  const numVolumeActors = volumeActors.length;
@@ -11,8 +11,8 @@ function getVolumeViewportsContainingVolumeId(volumeId, renderingEngineId) {
11
11
  renderingEngines.forEach((renderingEngine) => {
12
12
  const viewports = renderingEngine.getVolumeViewports();
13
13
  const filteredViewports = viewports.filter((vp) => {
14
- const actors = vp.getActors();
15
- return actors.some((actor) => actor.volumeActor && actor.uid === volumeId);
14
+ const actorEntries = vp.getActors();
15
+ return actorEntries.some((actorEntry) => actorEntry.actor && actorEntry.uid === volumeId);
16
16
  });
17
17
  sameVolumeViewports.push(...filteredViewports);
18
18
  });
@@ -1 +1 @@
1
- {"version":3,"file":"getVolumeViewportsContainingVolumeId.js","sourceRoot":"","sources":["../../../src/utilities/getVolumeViewportsContainingVolumeId.ts"],"names":[],"mappings":"AACA,OAAO,EACL,mBAAmB,EACnB,kBAAkB,GACnB,MAAM,uCAAuC,CAAC;AAQ/C,SAAS,oCAAoC,CAC3C,QAAgB,EAChB,iBAA0B;IAG1B,IAAI,gBAAgB,CAAC;IACrB,IAAI,iBAAiB,EAAE;QACrB,gBAAgB,GAAG,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC,CAAC;KAC5D;SAAM;QACL,gBAAgB,GAAG,mBAAmB,EAAE,CAAC;KAC1C;IAED,MAAM,mBAAmB,GAAG,EAAE,CAAC;IAE/B,gBAAgB,CAAC,OAAO,CAAC,CAAC,eAAe,EAAE,EAAE;QAC3C,MAAM,SAAS,GAAG,eAAe,CAAC,kBAAkB,EAAE,CAAC;QACvD,MAAM,iBAAiB,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE;YAChD,MAAM,MAAM,GAAG,EAAE,CAAC,SAAS,EAAE,CAAC;YAC9B,OAAO,MAAM,CAAC,IAAI,CAChB,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,CAAC,WAAW,IAAI,KAAK,CAAC,GAAG,KAAK,QAAQ,CACvD,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,mBAAmB,CAAC,IAAI,CAAC,GAAG,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,OAAO,mBAAmB,CAAC;AAC7B,CAAC;AAED,eAAe,oCAAoC,CAAC"}
1
+ {"version":3,"file":"getVolumeViewportsContainingVolumeId.js","sourceRoot":"","sources":["../../../src/utilities/getVolumeViewportsContainingVolumeId.ts"],"names":[],"mappings":"AACA,OAAO,EACL,mBAAmB,EACnB,kBAAkB,GACnB,MAAM,uCAAuC,CAAC;AAQ/C,SAAS,oCAAoC,CAC3C,QAAgB,EAChB,iBAA0B;IAG1B,IAAI,gBAAgB,CAAC;IACrB,IAAI,iBAAiB,EAAE;QACrB,gBAAgB,GAAG,CAAC,kBAAkB,CAAC,iBAAiB,CAAC,CAAC,CAAC;KAC5D;SAAM;QACL,gBAAgB,GAAG,mBAAmB,EAAE,CAAC;KAC1C;IAED,MAAM,mBAAmB,GAAG,EAAE,CAAC;IAE/B,gBAAgB,CAAC,OAAO,CAAC,CAAC,eAAe,EAAE,EAAE;QAC3C,MAAM,SAAS,GAAG,eAAe,CAAC,kBAAkB,EAAE,CAAC;QACvD,MAAM,iBAAiB,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,EAAE,EAAE,EAAE;YAChD,MAAM,YAAY,GAAG,EAAE,CAAC,SAAS,EAAE,CAAC;YACpC,OAAO,YAAY,CAAC,IAAI,CACtB,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,KAAK,IAAI,UAAU,CAAC,GAAG,KAAK,QAAQ,CAChE,CAAC;QACJ,CAAC,CAAC,CAAC;QACH,mBAAmB,CAAC,IAAI,CAAC,GAAG,iBAAiB,CAAC,CAAC;IACjD,CAAC,CAAC,CAAC;IAEH,OAAO,mBAAmB,CAAC;AAC7B,CAAC;AAED,eAAe,oCAAoC,CAAC"}
@@ -1,4 +1,4 @@
1
- import invertRgbTransferFunction from './invertRgbTransferFunction';
1
+ import csUtils from './invertRgbTransferFunction';
2
2
  import scaleRgbTransferFunction from './scaleRgbTransferFunction';
3
3
  import triggerEvent from './triggerEvent';
4
4
  import uuidv4 from './uuidv4';
@@ -23,6 +23,10 @@ import loadImageToCanvas from './loadImageToCanvas';
23
23
  import renderToCanvas from './renderToCanvas';
24
24
  import worldToImageCoords from './worldToImageCoords';
25
25
  import imageToWorldCoords from './imageToWorldCoords';
26
+ import getSliceRange from './getSliceRange';
27
+ import snapFocalPointToSlice from './snapFocalPointToSlice';
28
+ import getImageSliceDataForVolumeViewport from './getImageSliceDataForVolumeViewport';
29
+ import getScalingParameters from './getScalingParameters';
26
30
  import * as planar from './planar';
27
31
  import * as windowLevel from './windowLevel';
28
- export { invertRgbTransferFunction, scaleRgbTransferFunction, triggerEvent, imageIdToURI, calibratedPixelSpacingMetadataProvider, uuidv4, planar, getMinMax, getRuntimeId, isEqual, isOpposite, createFloat32SharedArray, createUint8SharedArray, windowLevel, getClosestImageId, getSpacingInNormalDirection, getTargetVolumeAndSpacingInNormalDir, getVolumeActorCorners, indexWithinDimensions, getVolumeViewportsContainingSameVolumes, getVolumeViewportsContainingVolumeId, transformWorldToIndex, prefetchStack, loadImageToCanvas, renderToCanvas, worldToImageCoords, imageToWorldCoords, };
32
+ export { csUtils as invertRgbTransferFunction, scaleRgbTransferFunction, triggerEvent, imageIdToURI, calibratedPixelSpacingMetadataProvider, uuidv4, planar, getMinMax, getRuntimeId, isEqual, isOpposite, createFloat32SharedArray, createUint8SharedArray, windowLevel, getClosestImageId, getSpacingInNormalDirection, getTargetVolumeAndSpacingInNormalDir, getVolumeActorCorners, indexWithinDimensions, getVolumeViewportsContainingSameVolumes, getVolumeViewportsContainingVolumeId, transformWorldToIndex, prefetchStack, loadImageToCanvas, renderToCanvas, worldToImageCoords, imageToWorldCoords, getSliceRange, snapFocalPointToSlice, getImageSliceDataForVolumeViewport, getScalingParameters, };
@@ -1,4 +1,4 @@
1
- import invertRgbTransferFunction from './invertRgbTransferFunction';
1
+ import csUtils from './invertRgbTransferFunction';
2
2
  import scaleRgbTransferFunction from './scaleRgbTransferFunction';
3
3
  import triggerEvent from './triggerEvent';
4
4
  import uuidv4 from './uuidv4';
@@ -23,7 +23,11 @@ import loadImageToCanvas from './loadImageToCanvas';
23
23
  import renderToCanvas from './renderToCanvas';
24
24
  import worldToImageCoords from './worldToImageCoords';
25
25
  import imageToWorldCoords from './imageToWorldCoords';
26
+ import getSliceRange from './getSliceRange';
27
+ import snapFocalPointToSlice from './snapFocalPointToSlice';
28
+ import getImageSliceDataForVolumeViewport from './getImageSliceDataForVolumeViewport';
29
+ import getScalingParameters from './getScalingParameters';
26
30
  import * as planar from './planar';
27
31
  import * as windowLevel from './windowLevel';
28
- export { invertRgbTransferFunction, scaleRgbTransferFunction, triggerEvent, imageIdToURI, calibratedPixelSpacingMetadataProvider, uuidv4, planar, getMinMax, getRuntimeId, isEqual, isOpposite, createFloat32SharedArray, createUint8SharedArray, windowLevel, getClosestImageId, getSpacingInNormalDirection, getTargetVolumeAndSpacingInNormalDir, getVolumeActorCorners, indexWithinDimensions, getVolumeViewportsContainingSameVolumes, getVolumeViewportsContainingVolumeId, transformWorldToIndex, prefetchStack, loadImageToCanvas, renderToCanvas, worldToImageCoords, imageToWorldCoords, };
32
+ export { csUtils as invertRgbTransferFunction, scaleRgbTransferFunction, triggerEvent, imageIdToURI, calibratedPixelSpacingMetadataProvider, uuidv4, planar, getMinMax, getRuntimeId, isEqual, isOpposite, createFloat32SharedArray, createUint8SharedArray, windowLevel, getClosestImageId, getSpacingInNormalDirection, getTargetVolumeAndSpacingInNormalDir, getVolumeActorCorners, indexWithinDimensions, getVolumeViewportsContainingSameVolumes, getVolumeViewportsContainingVolumeId, transformWorldToIndex, prefetchStack, loadImageToCanvas, renderToCanvas, worldToImageCoords, imageToWorldCoords, getSliceRange, snapFocalPointToSlice, getImageSliceDataForVolumeViewport, getScalingParameters, };
29
33
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utilities/index.ts"],"names":[],"mappings":"AAAA,OAAO,yBAAyB,MAAM,6BAA6B,CAAC;AACpE,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,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,oCAAoC,MAAM,wCAAwC,CAAC;AAC1F,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAC9C,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AAGtD,OAAO,KAAK,MAAM,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAE7C,OAAO,EACL,yBAAyB,EACzB,wBAAwB,EACxB,YAAY,EACZ,YAAY,EACZ,sCAAsC,EACtC,MAAM,EACN,MAAM,EACN,SAAS,EACT,YAAY,EACZ,OAAO,EACP,UAAU,EACV,wBAAwB,EACxB,sBAAsB,EACtB,WAAW,EACX,iBAAiB,EACjB,2BAA2B,EAC3B,oCAAoC,EACpC,qBAAqB,EACrB,qBAAqB,EACrB,uCAAuC,EACvC,oCAAoC,EACpC,qBAAqB,EACrB,aAAa,EACb,iBAAiB,EACjB,cAAc,EACd,kBAAkB,EAClB,kBAAkB,GACnB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/utilities/index.ts"],"names":[],"mappings":"AAAA,OAAO,OAAO,MAAM,6BAA6B,CAAC;AAClD,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,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,oCAAoC,MAAM,wCAAwC,CAAC;AAC1F,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,iBAAiB,MAAM,qBAAqB,CAAC;AACpD,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAC9C,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,kBAAkB,MAAM,sBAAsB,CAAC;AACtD,OAAO,aAAa,MAAM,iBAAiB,CAAC;AAC5C,OAAO,qBAAqB,MAAM,yBAAyB,CAAC;AAC5D,OAAO,kCAAkC,MAAM,sCAAsC,CAAC;AACtF,OAAO,oBAAoB,MAAM,wBAAwB,CAAC;AAG1D,OAAO,KAAK,MAAM,MAAM,UAAU,CAAC;AACnC,OAAO,KAAK,WAAW,MAAM,eAAe,CAAC;AAE7C,OAAO,EACL,OAAO,IAAI,yBAAyB,EACpC,wBAAwB,EACxB,YAAY,EACZ,YAAY,EACZ,sCAAsC,EACtC,MAAM,EACN,MAAM,EACN,SAAS,EACT,YAAY,EACZ,OAAO,EACP,UAAU,EACV,wBAAwB,EACxB,sBAAsB,EACtB,WAAW,EACX,iBAAiB,EACjB,2BAA2B,EAC3B,oCAAoC,EACpC,qBAAqB,EACrB,qBAAqB,EACrB,uCAAuC,EACvC,oCAAoC,EACpC,qBAAqB,EACrB,aAAa,EACb,iBAAiB,EACjB,cAAc,EACd,kBAAkB,EAClB,kBAAkB,EAClB,aAAa,EACb,qBAAqB,EACrB,kCAAkC,EAClC,oBAAoB,GACrB,CAAC"}
@@ -3,6 +3,7 @@ import * as metaData from '../metaData';
3
3
  import { RequestType } from '../enums';
4
4
  import imageLoadPoolManager from '../requestPool/imageLoadPoolManager';
5
5
  import renderToCanvas from './renderToCanvas';
6
+ import getScalingParameters from './getScalingParameters';
6
7
  export default function loadImageToCanvas(canvas, imageId, requestType = RequestType.Thumbnail, priority = -5) {
7
8
  return new Promise((resolve, reject) => {
8
9
  function successCallback(image, imageId) {
@@ -22,15 +23,7 @@ export default function loadImageToCanvas(canvas, imageId, requestType = Request
22
23
  errorCallback.call(this, error, imageId);
23
24
  });
24
25
  }
25
- const modalityLutModule = metaData.get('modalityLutModule', imageId) || {};
26
- const suvFactor = metaData.get('scalingModule', imageId) || {};
27
- const generalSeriesModule = metaData.get('generalSeriesModule', imageId) || {};
28
- const scalingParameters = {
29
- rescaleSlope: modalityLutModule.rescaleSlope,
30
- rescaleIntercept: modalityLutModule.rescaleIntercept,
31
- modality: generalSeriesModule.modality,
32
- suvbw: suvFactor.suvbw,
33
- };
26
+ const scalingParameters = getScalingParameters(imageId);
34
27
  const options = {
35
28
  targetBuffer: {
36
29
  type: 'Float32Array',
@@ -1 +1 @@
1
- {"version":3,"file":"loadImageToCanvas.js","sourceRoot":"","sources":["../../../src/utilities/loadImageToCanvas.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACnD,OAAO,KAAK,QAAQ,MAAM,aAAa,CAAC;AACxC,OAAO,EAAE,WAAW,EAAE,MAAM,UAAU,CAAC;AACvC,OAAO,oBAAoB,MAAM,qCAAqC,CAAC;AACvE,OAAO,cAAc,MAAM,kBAAkB,CAAC;AAoB9C,MAAM,CAAC,OAAO,UAAU,iBAAiB,CACvC,MAAyB,EACzB,OAAe,EACf,WAAW,GAAG,WAAW,CAAC,SAAS,EACnC,QAAQ,GAAG,CAAC,CAAC;IAEb,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QACrC,SAAS,eAAe,CAAC,KAAa,EAAE,OAAe;YACrD,MAAM,EAAE,QAAQ,EAAE,GAAG,QAAQ,CAAC,GAAG,CAAC,qBAAqB,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;YAExE,KAAK,CAAC,WAAW,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC;YAC5C,cAAc,CAAC,MAAM,EAAE,KAAK,EAAE,QAAQ,CAAC,CAAC;YACxC,OAAO,CAAC,OAAO,CAAC,CAAC;QACnB,CAAC;QAED,SAAS,aAAa,CAAC,KAAY,EAAE,OAAe;YAClD,OAAO,CAAC,KAAK,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;YAC9B,MAAM,CAAC,KAAK,CAAC,CAAC;QAChB,CAAC;QAED,SAAS,WAAW,CAAC,OAAO,EAAE,YAAY,EAAE,OAAO;YACjD,OAAO,iBAAiB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,IAAI,CAC7C,CAAC,KAAK,EAAE,EAAE;gBACR,eAAe,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,EAAE,YAAY,CAAC,CAAC;YAC3D,CAAC,EACD,CAAC,KAAK,EAAE,EAAE;gBACR,aAAa,CAAC,IAAI,CAAC,IAAI,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;YAC3C,CAAC,CACF,CAAC;QACJ,CAAC;QAED,MAAM,iBAAiB,GAAG,QAAQ,CAAC,GAAG,CAAC,mBAAmB,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;QAC3E,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,eAAe,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;QAE/D,MAAM,mBAAmB,GACvB,QAAQ,CAAC,GAAG,CAAC,qBAAqB,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;QAErD,MAAM,iBAAiB,GAAG;YACxB,YAAY,EAAE,iBAAiB,CAAC,YAAY;YAC5C,gBAAgB,EAAE,iBAAiB,CAAC,gBAAgB;YACpD,QAAQ,EAAE,mBAAmB,CAAC,QAAQ;YACtC,KAAK,EAAE,SAAS,CAAC,KAAK;SACvB,CAAC;QAIF,MAAM,OAAO,GAAG;YACd,YAAY,EAAE;gBACZ,IAAI,EAAE,cAAc;gBACpB,MAAM,EAAE,IAAI;gBACZ,MAAM,EAAE,IAAI;aACb;YACD,QAAQ,EAAE;gBACR,iBAAiB;aAClB;YACD,WAAW;SACZ,CAAC;QAEF,oBAAoB,CAAC,UAAU,CAC7B,WAAW,CAAC,IAAI,CAAC,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,CAAC,EAC9C,WAAW,EACX,EAAE,OAAO,EAAE,EACX,QAAQ,CACT,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC;AAMD,SAAS,gBAAgB,CAAC,KAAK;IAC7B,MAAM,EAAE,OAAO,EAAE,GAAG,KAAK,CAAC;IAE1B,MAAM,iBAAiB,GAAG,QAAQ,CAAC,GAAG,CAAC,mBAAmB,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;IAC3E,MAAM,SAAS,GAAG,QAAQ,CAAC,GAAG,CAAC,eAAe,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;IAE/D,MAAM,mBAAmB,GACvB,QAAQ,CAAC,GAAG,CAAC,qBAAqB,EAAE,OAAO,CAAC,IAAI,EAAE,CAAC;IAErD,IACE,iBAAiB,CAAC,YAAY,KAAK,SAAS;QAC5C,iBAAiB,CAAC,gBAAgB,KAAK,SAAS,EAChD;QACA,IAAI,mBAAmB,CAAC,QAAQ,KAAK,IAAI,EAAE;YACzC,OAAO,SAAS,CAAC,KAAK,KAAK,SAAS,CAAC;SACtC;QAED,OAAO,IAAI,CAAC;KACb;IAED,OAAO,KAAK,CAAC;AACf,CAAC"}
1
+ {"version":3,"file":"loadImageToCanvas.js","sourceRoot":"","sources":["../../../src/utilities/loadImageToCanvas.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,5 @@
1
+ import { ActorSliceRange, Point3 } from '../types';
2
+ export default function snapFocalPointToSlice(focalPoint: Point3, position: Point3, sliceRange: ActorSliceRange, viewPlaneNormal: Point3, spacingInNormalDirection: number, deltaFrames: number): {
3
+ newFocalPoint: Point3;
4
+ newPosition: Point3;
5
+ };
@@ -0,0 +1,38 @@
1
+ import { vec3 } from 'gl-matrix';
2
+ export default function snapFocalPointToSlice(focalPoint, position, sliceRange, viewPlaneNormal, spacingInNormalDirection, deltaFrames) {
3
+ const { min, max, current } = sliceRange;
4
+ const posDiffFromFocalPoint = vec3.create();
5
+ vec3.sub(posDiffFromFocalPoint, position, focalPoint);
6
+ const steps = Math.round((max - min) / spacingInNormalDirection);
7
+ const fraction = (current - min) / (max - min);
8
+ const floatingStepNumber = fraction * steps;
9
+ let frameIndex = Math.round(floatingStepNumber);
10
+ let newFocalPoint = [
11
+ focalPoint[0] -
12
+ viewPlaneNormal[0] * floatingStepNumber * spacingInNormalDirection,
13
+ focalPoint[1] -
14
+ viewPlaneNormal[1] * floatingStepNumber * spacingInNormalDirection,
15
+ focalPoint[2] -
16
+ viewPlaneNormal[2] * floatingStepNumber * spacingInNormalDirection,
17
+ ];
18
+ frameIndex += deltaFrames;
19
+ if (frameIndex > steps) {
20
+ frameIndex = steps;
21
+ }
22
+ else if (frameIndex < 0) {
23
+ frameIndex = 0;
24
+ }
25
+ const newSlicePosFromMin = frameIndex * spacingInNormalDirection;
26
+ newFocalPoint = [
27
+ newFocalPoint[0] + viewPlaneNormal[0] * newSlicePosFromMin,
28
+ newFocalPoint[1] + viewPlaneNormal[1] * newSlicePosFromMin,
29
+ newFocalPoint[2] + viewPlaneNormal[2] * newSlicePosFromMin,
30
+ ];
31
+ const newPosition = [
32
+ newFocalPoint[0] + posDiffFromFocalPoint[0],
33
+ newFocalPoint[1] + posDiffFromFocalPoint[1],
34
+ newFocalPoint[2] + posDiffFromFocalPoint[2],
35
+ ];
36
+ return { newFocalPoint, newPosition };
37
+ }
38
+ //# sourceMappingURL=snapFocalPointToSlice.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"snapFocalPointToSlice.js","sourceRoot":"","sources":["../../../src/utilities/snapFocalPointToSlice.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAkBjC,MAAM,CAAC,OAAO,UAAU,qBAAqB,CAC3C,UAAkB,EAClB,QAAgB,EAChB,UAA2B,EAC3B,eAAuB,EACvB,wBAAgC,EAChC,WAAmB;IAEnB,MAAM,EAAE,GAAG,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,UAAU,CAAC;IAGzC,MAAM,qBAAqB,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC;IAE5C,IAAI,CAAC,GAAG,CAAC,qBAAqB,EAAQ,QAAQ,EAAQ,UAAU,CAAC,CAAC;IAGlE,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,GAAG,GAAG,GAAG,CAAC,GAAG,wBAAwB,CAAC,CAAC;IAGjE,MAAM,QAAQ,GAAG,CAAC,OAAO,GAAG,GAAG,CAAC,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC,CAAC;IAC/C,MAAM,kBAAkB,GAAG,QAAQ,GAAG,KAAK,CAAC;IAC5C,IAAI,UAAU,GAAG,IAAI,CAAC,KAAK,CAAC,kBAAkB,CAAC,CAAC;IAGhD,IAAI,aAAa,GAAW;QAC1B,UAAU,CAAC,CAAC,CAAC;YACX,eAAe,CAAC,CAAC,CAAC,GAAG,kBAAkB,GAAG,wBAAwB;QACpE,UAAU,CAAC,CAAC,CAAC;YACX,eAAe,CAAC,CAAC,CAAC,GAAG,kBAAkB,GAAG,wBAAwB;QACpE,UAAU,CAAC,CAAC,CAAC;YACX,eAAe,CAAC,CAAC,CAAC,GAAG,kBAAkB,GAAG,wBAAwB;KACrE,CAAC;IAGF,UAAU,IAAI,WAAW,CAAC;IAG1B,IAAI,UAAU,GAAG,KAAK,EAAE;QACtB,UAAU,GAAG,KAAK,CAAC;KACpB;SAAM,IAAI,UAAU,GAAG,CAAC,EAAE;QACzB,UAAU,GAAG,CAAC,CAAC;KAChB;IAGD,MAAM,kBAAkB,GAAG,UAAU,GAAG,wBAAwB,CAAC;IAEjE,aAAa,GAAW;QACtB,aAAa,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC,GAAG,kBAAkB;QAC1D,aAAa,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC,GAAG,kBAAkB;QAC1D,aAAa,CAAC,CAAC,CAAC,GAAG,eAAe,CAAC,CAAC,CAAC,GAAG,kBAAkB;KAC3D,CAAC;IAEF,MAAM,WAAW,GAAW;QAC1B,aAAa,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC,CAAC,CAAC;QAC3C,aAAa,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC,CAAC,CAAC;QAC3C,aAAa,CAAC,CAAC,CAAC,GAAG,qBAAqB,CAAC,CAAC,CAAC;KAC5C,CAAC;IAEF,OAAO,EAAE,aAAa,EAAE,WAAW,EAAE,CAAC;AACxC,CAAC"}