@cornerstonejs/dicom-image-loader 1.78.1 → 2.0.0-beta.10

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 (478) hide show
  1. package/dist/744.bundle.min.js +3 -0
  2. package/dist/744.bundle.min.js.LICENSE.txt +5 -0
  3. package/dist/744.bundle.min.js.map +1 -0
  4. package/dist/cornerstoneDICOMImageLoader.bundle.min.js +1 -1
  5. package/dist/cornerstoneDICOMImageLoader.bundle.min.js.map +1 -1
  6. package/dist/dynamic-import/{945.min.worker.js → 584.min.js} +2 -2
  7. package/dist/dynamic-import/584.min.js.map +1 -0
  8. package/dist/dynamic-import/595.min.js +2 -0
  9. package/dist/dynamic-import/595.min.js.map +1 -0
  10. package/dist/dynamic-import/610.min.js +2 -0
  11. package/dist/dynamic-import/610.min.js.map +1 -0
  12. package/dist/dynamic-import/958.min.js +3 -0
  13. package/dist/dynamic-import/958.min.js.LICENSE.txt +5 -0
  14. package/dist/dynamic-import/958.min.js.map +1 -0
  15. package/dist/dynamic-import/cornerstoneDICOMImageLoader.min.js +1 -1
  16. package/dist/dynamic-import/cornerstoneDICOMImageLoader.min.js.map +1 -1
  17. package/dist/esm/codecs/jpeg.js +891 -0
  18. package/dist/esm/codecs/jpeg.js.map +1 -0
  19. package/dist/esm/codecs/jpegLossless.js +1220 -0
  20. package/dist/esm/codecs/jpegLossless.js.map +1 -0
  21. package/dist/esm/src/constants/transferSyntaxes.js +47 -0
  22. package/dist/esm/src/constants/transferSyntaxes.js.map +1 -0
  23. package/dist/esm/src/externalModules.js +45 -0
  24. package/dist/esm/src/externalModules.js.map +1 -0
  25. package/dist/esm/src/imageLoader/colorSpaceConverters/convertPALETTECOLOR.js +78 -0
  26. package/dist/esm/src/imageLoader/colorSpaceConverters/convertPALETTECOLOR.js.map +1 -0
  27. package/dist/esm/src/imageLoader/colorSpaceConverters/convertRGBColorByPixel.js +22 -0
  28. package/dist/esm/src/imageLoader/colorSpaceConverters/convertRGBColorByPixel.js.map +1 -0
  29. package/dist/esm/src/imageLoader/colorSpaceConverters/convertRGBColorByPlane.js +29 -0
  30. package/dist/esm/src/imageLoader/colorSpaceConverters/convertRGBColorByPlane.js.map +1 -0
  31. package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFull422ByPixel.js +45 -0
  32. package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFull422ByPixel.js.map +1 -0
  33. package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFullByPixel.js +34 -0
  34. package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFullByPixel.js.map +1 -0
  35. package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFullByPlane.js +36 -0
  36. package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFullByPlane.js.map +1 -0
  37. package/dist/esm/src/imageLoader/colorSpaceConverters/index.js +8 -0
  38. package/dist/esm/src/imageLoader/colorSpaceConverters/index.js.map +1 -0
  39. package/dist/esm/src/imageLoader/configure.js +12 -0
  40. package/dist/esm/src/imageLoader/configure.js.map +1 -0
  41. package/dist/esm/src/imageLoader/convertColorSpace.js +41 -0
  42. package/dist/esm/src/imageLoader/convertColorSpace.js.map +1 -0
  43. package/dist/esm/src/imageLoader/createImage.js +249 -0
  44. package/dist/esm/src/imageLoader/createImage.js.map +1 -0
  45. package/dist/esm/src/imageLoader/decodeImageFrame.js +66 -0
  46. package/dist/esm/src/imageLoader/decodeImageFrame.js.map +1 -0
  47. package/dist/esm/src/imageLoader/decodeJPEGBaseline8BitColor.js +65 -0
  48. package/dist/esm/src/imageLoader/decodeJPEGBaseline8BitColor.js.map +1 -0
  49. package/dist/esm/src/imageLoader/getImageFrame.js +27 -0
  50. package/dist/esm/src/imageLoader/getImageFrame.js.map +1 -0
  51. package/dist/esm/src/imageLoader/getInstanceModule.js +41 -0
  52. package/dist/esm/src/imageLoader/getInstanceModule.js.map +1 -0
  53. package/dist/esm/src/imageLoader/getMinMax.js +16 -0
  54. package/dist/esm/src/imageLoader/getMinMax.js.map +1 -0
  55. package/dist/esm/src/imageLoader/getScalingParameters.js +16 -0
  56. package/dist/esm/src/imageLoader/getScalingParameters.js.map +1 -0
  57. package/dist/esm/src/imageLoader/imageIdToURI.js +5 -0
  58. package/dist/esm/src/imageLoader/imageIdToURI.js.map +1 -0
  59. package/dist/esm/src/imageLoader/index.js +37 -0
  60. package/dist/esm/src/imageLoader/index.js.map +1 -0
  61. package/dist/esm/src/imageLoader/internal/index.js +9 -0
  62. package/dist/esm/src/imageLoader/internal/index.js.map +1 -0
  63. package/dist/esm/src/imageLoader/internal/options.js +24 -0
  64. package/dist/esm/src/imageLoader/internal/options.js.map +1 -0
  65. package/dist/esm/src/imageLoader/internal/rangeRequest.js +122 -0
  66. package/dist/esm/src/imageLoader/internal/rangeRequest.js.map +1 -0
  67. package/dist/esm/src/imageLoader/internal/streamRequest.js +93 -0
  68. package/dist/esm/src/imageLoader/internal/streamRequest.js.map +1 -0
  69. package/dist/esm/src/imageLoader/internal/xhrRequest.js +103 -0
  70. package/dist/esm/src/imageLoader/internal/xhrRequest.js.map +1 -0
  71. package/dist/esm/src/imageLoader/isColorConversionRequired.js +23 -0
  72. package/dist/esm/src/imageLoader/isColorConversionRequired.js.map +1 -0
  73. package/dist/esm/src/imageLoader/isJPEGBaseline8BitColor.js +10 -0
  74. package/dist/esm/src/imageLoader/isJPEGBaseline8BitColor.js.map +1 -0
  75. package/dist/esm/src/imageLoader/isNMReconstructable.js +4 -0
  76. package/dist/esm/src/imageLoader/isNMReconstructable.js.map +1 -0
  77. package/dist/esm/src/imageLoader/registerLoaders.js +8 -0
  78. package/dist/esm/src/imageLoader/registerLoaders.js.map +1 -0
  79. package/dist/esm/src/imageLoader/wadors/combineFrameInstance.js +45 -0
  80. package/dist/esm/src/imageLoader/wadors/combineFrameInstance.js.map +1 -0
  81. package/dist/esm/src/imageLoader/wadors/extractMultipart.js +74 -0
  82. package/dist/esm/src/imageLoader/wadors/extractMultipart.js.map +1 -0
  83. package/dist/esm/src/imageLoader/wadors/findIndexOfString.js +33 -0
  84. package/dist/esm/src/imageLoader/wadors/findIndexOfString.js.map +1 -0
  85. package/dist/esm/src/imageLoader/wadors/getImageQualityStatus.js +9 -0
  86. package/dist/esm/src/imageLoader/wadors/getImageQualityStatus.js.map +1 -0
  87. package/dist/esm/src/imageLoader/wadors/getPixelData.js +36 -0
  88. package/dist/esm/src/imageLoader/wadors/getPixelData.js.map +1 -0
  89. package/dist/esm/src/imageLoader/wadors/getTagValue.js +10 -0
  90. package/dist/esm/src/imageLoader/wadors/getTagValue.js.map +1 -0
  91. package/dist/esm/src/imageLoader/wadors/index.js +22 -0
  92. package/dist/esm/src/imageLoader/wadors/index.js.map +1 -0
  93. package/dist/esm/src/imageLoader/wadors/loadImage.js +126 -0
  94. package/dist/esm/src/imageLoader/wadors/loadImage.js.map +1 -0
  95. package/dist/esm/src/imageLoader/wadors/loadImage_test.js +42 -0
  96. package/dist/esm/src/imageLoader/wadors/loadImage_test.js.map +1 -0
  97. package/dist/esm/src/imageLoader/wadors/metaData/NMHelpers.js +39 -0
  98. package/dist/esm/src/imageLoader/wadors/metaData/NMHelpers.js.map +1 -0
  99. package/dist/esm/src/imageLoader/wadors/metaData/USHelpers.js +47 -0
  100. package/dist/esm/src/imageLoader/wadors/metaData/USHelpers.js.map +1 -0
  101. package/dist/esm/src/imageLoader/wadors/metaData/extractPositioningFromMetadata.js +19 -0
  102. package/dist/esm/src/imageLoader/wadors/metaData/extractPositioningFromMetadata.js.map +1 -0
  103. package/dist/esm/src/imageLoader/wadors/metaData/getFirstNumberValue.js +7 -0
  104. package/dist/esm/src/imageLoader/wadors/metaData/getFirstNumberValue.js.map +1 -0
  105. package/dist/esm/src/imageLoader/wadors/metaData/getNumberString.js +10 -0
  106. package/dist/esm/src/imageLoader/wadors/metaData/getNumberString.js.map +1 -0
  107. package/dist/esm/src/imageLoader/wadors/metaData/getNumberValue.js +10 -0
  108. package/dist/esm/src/imageLoader/wadors/metaData/getNumberValue.js.map +1 -0
  109. package/dist/esm/src/imageLoader/wadors/metaData/getNumberValues.js +21 -0
  110. package/dist/esm/src/imageLoader/wadors/metaData/getNumberValues.js.map +1 -0
  111. package/dist/esm/src/imageLoader/wadors/metaData/getOverlayPlaneModule.js +39 -0
  112. package/dist/esm/src/imageLoader/wadors/metaData/getOverlayPlaneModule.js.map +1 -0
  113. package/dist/esm/src/imageLoader/wadors/metaData/getSequenceItems.js +15 -0
  114. package/dist/esm/src/imageLoader/wadors/metaData/getSequenceItems.js.map +1 -0
  115. package/dist/esm/src/imageLoader/wadors/metaData/getValue.js +15 -0
  116. package/dist/esm/src/imageLoader/wadors/metaData/getValue.js.map +1 -0
  117. package/dist/esm/src/imageLoader/wadors/metaData/index.js +8 -0
  118. package/dist/esm/src/imageLoader/wadors/metaData/index.js.map +1 -0
  119. package/dist/esm/src/imageLoader/wadors/metaData/metaDataProvider.js +262 -0
  120. package/dist/esm/src/imageLoader/wadors/metaData/metaDataProvider.js.map +1 -0
  121. package/dist/esm/src/imageLoader/wadors/metaDataManager.js +48 -0
  122. package/dist/esm/src/imageLoader/wadors/metaDataManager.js.map +1 -0
  123. package/dist/esm/src/imageLoader/wadors/register.js +7 -0
  124. package/dist/esm/src/imageLoader/wadors/register.js.map +1 -0
  125. package/dist/esm/src/imageLoader/wadors/retrieveMultiframeMetadata.js +27 -0
  126. package/dist/esm/src/imageLoader/wadors/retrieveMultiframeMetadata.js.map +1 -0
  127. package/dist/esm/src/imageLoader/wadouri/combineFrameInstanceDataset.js +68 -0
  128. package/dist/esm/src/imageLoader/wadouri/combineFrameInstanceDataset.js.map +1 -0
  129. package/dist/esm/src/imageLoader/wadouri/dataSetCacheManager.js +143 -0
  130. package/dist/esm/src/imageLoader/wadouri/dataSetCacheManager.js.map +1 -0
  131. package/dist/esm/src/imageLoader/wadouri/dataSetCacheManager_test.js +11 -0
  132. package/dist/esm/src/imageLoader/wadouri/dataSetCacheManager_test.js.map +1 -0
  133. package/dist/esm/src/imageLoader/wadouri/dataset-from-partial-content.js +57 -0
  134. package/dist/esm/src/imageLoader/wadouri/dataset-from-partial-content.js.map +1 -0
  135. package/dist/esm/src/imageLoader/wadouri/fileManager.js +21 -0
  136. package/dist/esm/src/imageLoader/wadouri/fileManager.js.map +1 -0
  137. package/dist/esm/src/imageLoader/wadouri/getEncapsulatedImageFrame.js +34 -0
  138. package/dist/esm/src/imageLoader/wadouri/getEncapsulatedImageFrame.js.map +1 -0
  139. package/dist/esm/src/imageLoader/wadouri/getPixelData.js +14 -0
  140. package/dist/esm/src/imageLoader/wadouri/getPixelData.js.map +1 -0
  141. package/dist/esm/src/imageLoader/wadouri/getUncompressedImageFrame.js +48 -0
  142. package/dist/esm/src/imageLoader/wadouri/getUncompressedImageFrame.js.map +1 -0
  143. package/dist/esm/src/imageLoader/wadouri/index.js +32 -0
  144. package/dist/esm/src/imageLoader/wadouri/index.js.map +1 -0
  145. package/dist/esm/src/imageLoader/wadouri/loadFileRequest.js +18 -0
  146. package/dist/esm/src/imageLoader/wadouri/loadFileRequest.js.map +1 -0
  147. package/dist/esm/src/imageLoader/wadouri/loadImage.js +105 -0
  148. package/dist/esm/src/imageLoader/wadouri/loadImage.js.map +1 -0
  149. package/dist/esm/src/imageLoader/wadouri/metaData/extractPositioningFromDataset.js +81 -0
  150. package/dist/esm/src/imageLoader/wadouri/metaData/extractPositioningFromDataset.js.map +1 -0
  151. package/dist/esm/src/imageLoader/wadouri/metaData/getImagePixelModule.js +80 -0
  152. package/dist/esm/src/imageLoader/wadouri/metaData/getImagePixelModule.js.map +1 -0
  153. package/dist/esm/src/imageLoader/wadouri/metaData/getLUTs.js +45 -0
  154. package/dist/esm/src/imageLoader/wadouri/metaData/getLUTs.js.map +1 -0
  155. package/dist/esm/src/imageLoader/wadouri/metaData/getModalityLUTOutputPixelRepresentation.js +31 -0
  156. package/dist/esm/src/imageLoader/wadouri/metaData/getModalityLUTOutputPixelRepresentation.js.map +1 -0
  157. package/dist/esm/src/imageLoader/wadouri/metaData/getNumberValues.js +17 -0
  158. package/dist/esm/src/imageLoader/wadouri/metaData/getNumberValues.js.map +1 -0
  159. package/dist/esm/src/imageLoader/wadouri/metaData/getOverlayPlaneModule.js +37 -0
  160. package/dist/esm/src/imageLoader/wadouri/metaData/getOverlayPlaneModule.js.map +1 -0
  161. package/dist/esm/src/imageLoader/wadouri/metaData/index.js +6 -0
  162. package/dist/esm/src/imageLoader/wadouri/metaData/index.js.map +1 -0
  163. package/dist/esm/src/imageLoader/wadouri/metaData/metaDataProvider.js +211 -0
  164. package/dist/esm/src/imageLoader/wadouri/metaData/metaDataProvider.js.map +1 -0
  165. package/dist/esm/src/imageLoader/wadouri/parseImageId.js +21 -0
  166. package/dist/esm/src/imageLoader/wadouri/parseImageId.js.map +1 -0
  167. package/dist/esm/src/imageLoader/wadouri/register.js +9 -0
  168. package/dist/esm/src/imageLoader/wadouri/register.js.map +1 -0
  169. package/dist/esm/src/imageLoader/wadouri/retrieveMultiframeDataset.js +58 -0
  170. package/dist/esm/src/imageLoader/wadouri/retrieveMultiframeDataset.js.map +1 -0
  171. package/dist/esm/src/imageLoader/wadouri/unpackBinaryFrame.js +15 -0
  172. package/dist/esm/src/imageLoader/wadouri/unpackBinaryFrame.js.map +1 -0
  173. package/dist/esm/src/shared/calculateMinMax.js +25 -0
  174. package/dist/esm/src/shared/calculateMinMax.js.map +1 -0
  175. package/dist/esm/src/shared/calculateMinMax_test.js +39 -0
  176. package/dist/esm/src/shared/calculateMinMax_test.js.map +1 -0
  177. package/dist/esm/src/shared/decodeImageFrame.js +269 -0
  178. package/dist/esm/src/shared/decodeImageFrame.js.map +1 -0
  179. package/dist/esm/src/shared/decoders/decodeBigEndian.js +29 -0
  180. package/dist/esm/src/shared/decoders/decodeBigEndian.js.map +1 -0
  181. package/dist/esm/src/shared/decoders/decodeHTJ2K.js +110 -0
  182. package/dist/esm/src/shared/decoders/decodeHTJ2K.js.map +1 -0
  183. package/dist/esm/src/shared/decoders/decodeJPEG2000.js +94 -0
  184. package/dist/esm/src/shared/decoders/decodeJPEG2000.js.map +1 -0
  185. package/dist/esm/src/shared/decoders/decodeJPEGBaseline12Bit-js.js +35 -0
  186. package/dist/esm/src/shared/decoders/decodeJPEGBaseline12Bit-js.js.map +1 -0
  187. package/dist/esm/src/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.js +2 -0
  188. package/dist/esm/src/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.js.map +1 -0
  189. package/dist/esm/src/shared/decoders/decodeJPEGBaseline8Bit.js +63 -0
  190. package/dist/esm/src/shared/decoders/decodeJPEGBaseline8Bit.js.map +1 -0
  191. package/dist/esm/src/shared/decoders/decodeJPEGLS.js +85 -0
  192. package/dist/esm/src/shared/decoders/decodeJPEGLS.js.map +1 -0
  193. package/dist/esm/src/shared/decoders/decodeJPEGLossless.js +40 -0
  194. package/dist/esm/src/shared/decoders/decodeJPEGLossless.js.map +1 -0
  195. package/dist/esm/src/shared/decoders/decodeLittleEndian.js +30 -0
  196. package/dist/esm/src/shared/decoders/decodeLittleEndian.js.map +1 -0
  197. package/dist/esm/src/shared/decoders/decodeRLE.js +129 -0
  198. package/dist/esm/src/shared/decoders/decodeRLE.js.map +1 -0
  199. package/dist/esm/src/shared/getMinMax.js +17 -0
  200. package/dist/esm/src/shared/getMinMax.js.map +1 -0
  201. package/dist/esm/src/shared/getMinMax_test.js +10 -0
  202. package/dist/esm/src/shared/getMinMax_test.js.map +1 -0
  203. package/dist/esm/src/shared/getPixelDataTypeFromMinMax.js +23 -0
  204. package/dist/esm/src/shared/getPixelDataTypeFromMinMax.js.map +1 -0
  205. package/dist/esm/src/shared/isColorImage.js +11 -0
  206. package/dist/esm/src/shared/isColorImage.js.map +1 -0
  207. package/dist/esm/src/shared/scaling/bilinear.js +33 -0
  208. package/dist/esm/src/shared/scaling/bilinear.js.map +1 -0
  209. package/dist/esm/src/shared/scaling/replicate.js +21 -0
  210. package/dist/esm/src/shared/scaling/replicate.js.map +1 -0
  211. package/dist/esm/src/shared/scaling/scaleArray.js +16 -0
  212. package/dist/esm/src/shared/scaling/scaleArray.js.map +1 -0
  213. package/dist/esm/src/types/DICOMLoaderDataSetWithFetchMore.js +2 -0
  214. package/dist/esm/src/types/DICOMLoaderDataSetWithFetchMore.js.map +1 -0
  215. package/dist/esm/src/types/DICOMLoaderIImage.js +2 -0
  216. package/dist/esm/src/types/DICOMLoaderIImage.js.map +1 -0
  217. package/dist/esm/src/types/DICOMLoaderImageOptions.js +2 -0
  218. package/dist/esm/src/types/DICOMLoaderImageOptions.js.map +1 -0
  219. package/dist/esm/src/types/ImageFrame.js +2 -0
  220. package/dist/esm/src/types/ImageFrame.js.map +1 -0
  221. package/dist/esm/src/types/LoadRequestFunction.js +2 -0
  222. package/dist/esm/src/types/LoadRequestFunction.js.map +1 -0
  223. package/dist/esm/src/types/LoaderDecodeOptions.js +2 -0
  224. package/dist/esm/src/types/LoaderDecodeOptions.js.map +1 -0
  225. package/dist/esm/src/types/LoaderOptions.js +2 -0
  226. package/dist/esm/src/types/LoaderOptions.js.map +1 -0
  227. package/dist/esm/src/types/LutType.js +2 -0
  228. package/dist/esm/src/types/LutType.js.map +1 -0
  229. package/dist/esm/src/types/MetadataModules.js +2 -0
  230. package/dist/esm/src/types/MetadataModules.js.map +1 -0
  231. package/dist/esm/src/types/PixelDataTypedArray.js +2 -0
  232. package/dist/esm/src/types/PixelDataTypedArray.js.map +1 -0
  233. package/dist/esm/src/types/WADORSMetaData.js +2 -0
  234. package/dist/esm/src/types/WADORSMetaData.js.map +1 -0
  235. package/dist/esm/src/types/WebWorkerTypes.js +2 -0
  236. package/dist/esm/src/types/WebWorkerTypes.js.map +1 -0
  237. package/dist/esm/src/types/XHRRequest.js +2 -0
  238. package/dist/esm/src/types/XHRRequest.js.map +1 -0
  239. package/dist/esm/src/types/index.js +2 -0
  240. package/dist/esm/src/types/index.js.map +1 -0
  241. package/dist/esm/src/version.js +2 -0
  242. package/dist/esm/src/version.js.map +1 -0
  243. package/dist/types/codecs/jpeg.d.ts +11 -0
  244. package/dist/types/codecs/jpeg.d.ts.map +1 -0
  245. package/dist/types/codecs/jpegLossless.d.ts +8 -0
  246. package/dist/types/codecs/jpegLossless.d.ts.map +1 -0
  247. package/dist/types/src/constants/transferSyntaxes.d.ts +47 -0
  248. package/dist/types/src/constants/transferSyntaxes.d.ts.map +1 -0
  249. package/dist/types/src/externalModules.d.ts +6 -0
  250. package/dist/types/src/externalModules.d.ts.map +1 -0
  251. package/dist/types/src/imageLoader/colorSpaceConverters/convertPALETTECOLOR.d.ts +4 -0
  252. package/dist/types/src/imageLoader/colorSpaceConverters/convertPALETTECOLOR.d.ts.map +1 -0
  253. package/dist/types/src/imageLoader/colorSpaceConverters/convertRGBColorByPixel.d.ts +3 -0
  254. package/dist/types/src/imageLoader/colorSpaceConverters/convertRGBColorByPixel.d.ts.map +1 -0
  255. package/dist/types/src/imageLoader/colorSpaceConverters/convertRGBColorByPlane.d.ts +3 -0
  256. package/dist/types/src/imageLoader/colorSpaceConverters/convertRGBColorByPlane.d.ts.map +1 -0
  257. package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFull422ByPixel.d.ts +3 -0
  258. package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFull422ByPixel.d.ts.map +1 -0
  259. package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFullByPixel.d.ts +3 -0
  260. package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFullByPixel.d.ts.map +1 -0
  261. package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFullByPlane.d.ts +3 -0
  262. package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFullByPlane.d.ts.map +1 -0
  263. package/dist/types/src/imageLoader/colorSpaceConverters/index.d.ts +8 -0
  264. package/dist/types/src/imageLoader/colorSpaceConverters/index.d.ts.map +1 -0
  265. package/dist/types/src/imageLoader/configure.d.ts +4 -0
  266. package/dist/types/src/imageLoader/configure.d.ts.map +1 -0
  267. package/dist/types/src/imageLoader/convertColorSpace.d.ts +2 -0
  268. package/dist/types/src/imageLoader/convertColorSpace.d.ts.map +1 -0
  269. package/dist/types/src/imageLoader/createImage.d.ts +5 -0
  270. package/dist/types/src/imageLoader/createImage.d.ts.map +1 -0
  271. package/dist/types/src/imageLoader/decodeImageFrame.d.ts +4 -0
  272. package/dist/types/src/imageLoader/decodeImageFrame.d.ts.map +1 -0
  273. package/dist/types/src/imageLoader/decodeJPEGBaseline8BitColor.d.ts +5 -0
  274. package/dist/types/src/imageLoader/decodeJPEGBaseline8BitColor.d.ts.map +1 -0
  275. package/dist/types/src/imageLoader/getImageFrame.d.ts +4 -0
  276. package/dist/types/src/imageLoader/getImageFrame.d.ts.map +1 -0
  277. package/dist/types/src/imageLoader/getInstanceModule.d.ts +4 -0
  278. package/dist/types/src/imageLoader/getInstanceModule.d.ts.map +1 -0
  279. package/dist/types/src/imageLoader/getMinMax.d.ts +5 -0
  280. package/dist/types/src/imageLoader/getMinMax.d.ts.map +1 -0
  281. package/dist/types/src/imageLoader/getScalingParameters.d.ts +7 -0
  282. package/dist/types/src/imageLoader/getScalingParameters.d.ts.map +1 -0
  283. package/dist/types/src/imageLoader/imageIdToURI.d.ts +2 -0
  284. package/dist/types/src/imageLoader/imageIdToURI.d.ts.map +1 -0
  285. package/dist/types/src/imageLoader/index.d.ts +95 -0
  286. package/dist/types/src/imageLoader/index.d.ts.map +1 -0
  287. package/dist/types/src/imageLoader/internal/index.d.ts +9 -0
  288. package/dist/types/src/imageLoader/internal/index.d.ts.map +1 -0
  289. package/dist/types/src/imageLoader/internal/options.d.ts +4 -0
  290. package/dist/types/src/imageLoader/internal/options.d.ts.map +1 -0
  291. package/dist/types/src/imageLoader/internal/rangeRequest.d.ts +10 -0
  292. package/dist/types/src/imageLoader/internal/rangeRequest.d.ts.map +1 -0
  293. package/dist/types/src/imageLoader/internal/streamRequest.d.ts +3 -0
  294. package/dist/types/src/imageLoader/internal/streamRequest.d.ts.map +1 -0
  295. package/dist/types/src/imageLoader/internal/xhrRequest.d.ts +4 -0
  296. package/dist/types/src/imageLoader/internal/xhrRequest.d.ts.map +1 -0
  297. package/dist/types/src/imageLoader/isColorConversionRequired.d.ts +2 -0
  298. package/dist/types/src/imageLoader/isColorConversionRequired.d.ts.map +1 -0
  299. package/dist/types/src/imageLoader/isJPEGBaseline8BitColor.d.ts +4 -0
  300. package/dist/types/src/imageLoader/isJPEGBaseline8BitColor.d.ts.map +1 -0
  301. package/dist/types/src/imageLoader/isNMReconstructable.d.ts +2 -0
  302. package/dist/types/src/imageLoader/isNMReconstructable.d.ts.map +1 -0
  303. package/dist/types/src/imageLoader/registerLoaders.d.ts +3 -0
  304. package/dist/types/src/imageLoader/registerLoaders.d.ts.map +1 -0
  305. package/dist/types/src/imageLoader/wadors/combineFrameInstance.d.ts +13 -0
  306. package/dist/types/src/imageLoader/wadors/combineFrameInstance.d.ts.map +1 -0
  307. package/dist/types/src/imageLoader/wadors/extractMultipart.d.ts +24 -0
  308. package/dist/types/src/imageLoader/wadors/extractMultipart.d.ts.map +1 -0
  309. package/dist/types/src/imageLoader/wadors/findIndexOfString.d.ts +3 -0
  310. package/dist/types/src/imageLoader/wadors/findIndexOfString.d.ts.map +1 -0
  311. package/dist/types/src/imageLoader/wadors/getImageQualityStatus.d.ts +3 -0
  312. package/dist/types/src/imageLoader/wadors/getImageQualityStatus.d.ts.map +1 -0
  313. package/dist/types/src/imageLoader/wadors/getPixelData.d.ts +27 -0
  314. package/dist/types/src/imageLoader/wadors/getPixelData.d.ts.map +1 -0
  315. package/dist/types/src/imageLoader/wadors/getTagValue.d.ts +2 -0
  316. package/dist/types/src/imageLoader/wadors/getTagValue.d.ts.map +1 -0
  317. package/dist/types/src/imageLoader/wadors/index.d.ts +26 -0
  318. package/dist/types/src/imageLoader/wadors/index.d.ts.map +1 -0
  319. package/dist/types/src/imageLoader/wadors/loadImage.d.ts +26 -0
  320. package/dist/types/src/imageLoader/wadors/loadImage.d.ts.map +1 -0
  321. package/dist/types/src/imageLoader/wadors/loadImage_test.d.ts +2 -0
  322. package/dist/types/src/imageLoader/wadors/loadImage_test.d.ts.map +1 -0
  323. package/dist/types/src/imageLoader/wadors/metaData/NMHelpers.d.ts +6 -0
  324. package/dist/types/src/imageLoader/wadors/metaData/NMHelpers.d.ts.map +1 -0
  325. package/dist/types/src/imageLoader/wadors/metaData/USHelpers.d.ts +20 -0
  326. package/dist/types/src/imageLoader/wadors/metaData/USHelpers.d.ts.map +1 -0
  327. package/dist/types/src/imageLoader/wadors/metaData/extractPositioningFromMetadata.d.ts +4 -0
  328. package/dist/types/src/imageLoader/wadors/metaData/extractPositioningFromMetadata.d.ts.map +1 -0
  329. package/dist/types/src/imageLoader/wadors/metaData/getFirstNumberValue.d.ts +3 -0
  330. package/dist/types/src/imageLoader/wadors/metaData/getFirstNumberValue.d.ts.map +1 -0
  331. package/dist/types/src/imageLoader/wadors/metaData/getNumberString.d.ts +4 -0
  332. package/dist/types/src/imageLoader/wadors/metaData/getNumberString.d.ts.map +1 -0
  333. package/dist/types/src/imageLoader/wadors/metaData/getNumberValue.d.ts +4 -0
  334. package/dist/types/src/imageLoader/wadors/metaData/getNumberValue.d.ts.map +1 -0
  335. package/dist/types/src/imageLoader/wadors/metaData/getNumberValues.d.ts +4 -0
  336. package/dist/types/src/imageLoader/wadors/metaData/getNumberValues.d.ts.map +1 -0
  337. package/dist/types/src/imageLoader/wadors/metaData/getOverlayPlaneModule.d.ts +5 -0
  338. package/dist/types/src/imageLoader/wadors/metaData/getOverlayPlaneModule.d.ts.map +1 -0
  339. package/dist/types/src/imageLoader/wadors/metaData/getSequenceItems.d.ts +4 -0
  340. package/dist/types/src/imageLoader/wadors/metaData/getSequenceItems.d.ts.map +1 -0
  341. package/dist/types/src/imageLoader/wadors/metaData/getValue.d.ts +4 -0
  342. package/dist/types/src/imageLoader/wadors/metaData/getValue.d.ts.map +1 -0
  343. package/dist/types/src/imageLoader/wadors/metaData/index.d.ts +8 -0
  344. package/dist/types/src/imageLoader/wadors/metaData/index.d.ts.map +1 -0
  345. package/dist/types/src/imageLoader/wadors/metaData/metaDataProvider.d.ts +15 -0
  346. package/dist/types/src/imageLoader/wadors/metaData/metaDataProvider.d.ts.map +1 -0
  347. package/dist/types/src/imageLoader/wadors/metaDataManager.d.ts +15 -0
  348. package/dist/types/src/imageLoader/wadors/metaDataManager.d.ts.map +1 -0
  349. package/dist/types/src/imageLoader/wadors/register.d.ts +2 -0
  350. package/dist/types/src/imageLoader/wadors/register.d.ts.map +1 -0
  351. package/dist/types/src/imageLoader/wadors/retrieveMultiframeMetadata.d.ts +16 -0
  352. package/dist/types/src/imageLoader/wadors/retrieveMultiframeMetadata.d.ts.map +1 -0
  353. package/dist/types/src/imageLoader/wadouri/combineFrameInstanceDataset.d.ts +23 -0
  354. package/dist/types/src/imageLoader/wadouri/combineFrameInstanceDataset.d.ts.map +1 -0
  355. package/dist/types/src/imageLoader/wadouri/dataSetCacheManager.d.ts +32 -0
  356. package/dist/types/src/imageLoader/wadouri/dataSetCacheManager.d.ts.map +1 -0
  357. package/dist/types/src/imageLoader/wadouri/dataSetCacheManager_test.d.ts +2 -0
  358. package/dist/types/src/imageLoader/wadouri/dataSetCacheManager_test.d.ts.map +1 -0
  359. package/dist/types/src/imageLoader/wadouri/dataset-from-partial-content.d.ts +7 -0
  360. package/dist/types/src/imageLoader/wadouri/dataset-from-partial-content.d.ts.map +1 -0
  361. package/dist/types/src/imageLoader/wadouri/fileManager.d.ts +12 -0
  362. package/dist/types/src/imageLoader/wadouri/fileManager.d.ts.map +1 -0
  363. package/dist/types/src/imageLoader/wadouri/getEncapsulatedImageFrame.d.ts +3 -0
  364. package/dist/types/src/imageLoader/wadouri/getEncapsulatedImageFrame.d.ts.map +1 -0
  365. package/dist/types/src/imageLoader/wadouri/getPixelData.d.ts +4 -0
  366. package/dist/types/src/imageLoader/wadouri/getPixelData.d.ts.map +1 -0
  367. package/dist/types/src/imageLoader/wadouri/getUncompressedImageFrame.d.ts +4 -0
  368. package/dist/types/src/imageLoader/wadouri/getUncompressedImageFrame.d.ts.map +1 -0
  369. package/dist/types/src/imageLoader/wadouri/index.d.ts +44 -0
  370. package/dist/types/src/imageLoader/wadouri/index.d.ts.map +1 -0
  371. package/dist/types/src/imageLoader/wadouri/loadFileRequest.d.ts +3 -0
  372. package/dist/types/src/imageLoader/wadouri/loadFileRequest.d.ts.map +1 -0
  373. package/dist/types/src/imageLoader/wadouri/loadImage.d.ts +10 -0
  374. package/dist/types/src/imageLoader/wadouri/loadImage.d.ts.map +1 -0
  375. package/dist/types/src/imageLoader/wadouri/metaData/extractPositioningFromDataset.d.ts +7 -0
  376. package/dist/types/src/imageLoader/wadouri/metaData/extractPositioningFromDataset.d.ts.map +1 -0
  377. package/dist/types/src/imageLoader/wadouri/metaData/getImagePixelModule.d.ts +5 -0
  378. package/dist/types/src/imageLoader/wadouri/metaData/getImagePixelModule.d.ts.map +1 -0
  379. package/dist/types/src/imageLoader/wadouri/metaData/getLUTs.d.ts +5 -0
  380. package/dist/types/src/imageLoader/wadouri/metaData/getLUTs.d.ts.map +1 -0
  381. package/dist/types/src/imageLoader/wadouri/metaData/getModalityLUTOutputPixelRepresentation.d.ts +4 -0
  382. package/dist/types/src/imageLoader/wadouri/metaData/getModalityLUTOutputPixelRepresentation.d.ts.map +1 -0
  383. package/dist/types/src/imageLoader/wadouri/metaData/getNumberValues.d.ts +4 -0
  384. package/dist/types/src/imageLoader/wadouri/metaData/getNumberValues.d.ts.map +1 -0
  385. package/dist/types/src/imageLoader/wadouri/metaData/getOverlayPlaneModule.d.ts +5 -0
  386. package/dist/types/src/imageLoader/wadouri/metaData/getOverlayPlaneModule.d.ts.map +1 -0
  387. package/dist/types/src/imageLoader/wadouri/metaData/index.d.ts +6 -0
  388. package/dist/types/src/imageLoader/wadouri/metaData/index.d.ts.map +1 -0
  389. package/dist/types/src/imageLoader/wadouri/metaData/metaDataProvider.d.ts +3 -0
  390. package/dist/types/src/imageLoader/wadouri/metaData/metaDataProvider.d.ts.map +1 -0
  391. package/dist/types/src/imageLoader/wadouri/parseImageId.d.ts +9 -0
  392. package/dist/types/src/imageLoader/wadouri/parseImageId.d.ts.map +1 -0
  393. package/dist/types/src/imageLoader/wadouri/register.d.ts +3 -0
  394. package/dist/types/src/imageLoader/wadouri/register.d.ts.map +1 -0
  395. package/dist/types/src/imageLoader/wadouri/retrieveMultiframeDataset.d.ts +19 -0
  396. package/dist/types/src/imageLoader/wadouri/retrieveMultiframeDataset.d.ts.map +1 -0
  397. package/dist/types/src/imageLoader/wadouri/unpackBinaryFrame.d.ts +4 -0
  398. package/dist/types/src/imageLoader/wadouri/unpackBinaryFrame.d.ts.map +1 -0
  399. package/dist/types/src/shared/calculateMinMax.d.ts +3 -0
  400. package/dist/types/src/shared/calculateMinMax.d.ts.map +1 -0
  401. package/dist/types/src/shared/calculateMinMax_test.d.ts +2 -0
  402. package/dist/types/src/shared/calculateMinMax_test.d.ts.map +1 -0
  403. package/dist/types/src/shared/decodeImageFrame.d.ts +2 -0
  404. package/dist/types/src/shared/decodeImageFrame.d.ts.map +1 -0
  405. package/dist/types/src/shared/decoders/decodeBigEndian.d.ts +5 -0
  406. package/dist/types/src/shared/decoders/decodeBigEndian.d.ts.map +1 -0
  407. package/dist/types/src/shared/decoders/decodeHTJ2K.d.ts +6 -0
  408. package/dist/types/src/shared/decoders/decodeHTJ2K.d.ts.map +1 -0
  409. package/dist/types/src/shared/decoders/decodeJPEG2000.d.ts +5 -0
  410. package/dist/types/src/shared/decoders/decodeJPEG2000.d.ts.map +1 -0
  411. package/dist/types/src/shared/decoders/decodeJPEGBaseline12Bit-js.d.ts +6 -0
  412. package/dist/types/src/shared/decoders/decodeJPEGBaseline12Bit-js.d.ts.map +1 -0
  413. package/dist/types/src/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.d.ts +1 -0
  414. package/dist/types/src/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.d.ts.map +1 -0
  415. package/dist/types/src/shared/decoders/decodeJPEGBaseline8Bit.d.ts +4 -0
  416. package/dist/types/src/shared/decoders/decodeJPEGBaseline8Bit.d.ts.map +1 -0
  417. package/dist/types/src/shared/decoders/decodeJPEGLS.d.ts +5 -0
  418. package/dist/types/src/shared/decoders/decodeJPEGLS.d.ts.map +1 -0
  419. package/dist/types/src/shared/decoders/decodeJPEGLossless.d.ts +6 -0
  420. package/dist/types/src/shared/decoders/decodeJPEGLossless.d.ts.map +1 -0
  421. package/dist/types/src/shared/decoders/decodeLittleEndian.d.ts +5 -0
  422. package/dist/types/src/shared/decoders/decodeLittleEndian.d.ts.map +1 -0
  423. package/dist/types/src/shared/decoders/decodeRLE.d.ts +5 -0
  424. package/dist/types/src/shared/decoders/decodeRLE.d.ts.map +1 -0
  425. package/dist/types/src/shared/getMinMax.d.ts +7 -0
  426. package/dist/types/src/shared/getMinMax.d.ts.map +1 -0
  427. package/dist/types/src/shared/getMinMax_test.d.ts +2 -0
  428. package/dist/types/src/shared/getMinMax_test.d.ts.map +1 -0
  429. package/dist/types/src/shared/getPixelDataTypeFromMinMax.d.ts +3 -0
  430. package/dist/types/src/shared/getPixelDataTypeFromMinMax.d.ts.map +1 -0
  431. package/dist/types/src/shared/isColorImage.d.ts +2 -0
  432. package/dist/types/src/shared/isColorImage.d.ts.map +1 -0
  433. package/dist/types/src/shared/scaling/bilinear.d.ts +2 -0
  434. package/dist/types/src/shared/scaling/bilinear.d.ts.map +1 -0
  435. package/dist/types/src/shared/scaling/replicate.d.ts +2 -0
  436. package/dist/types/src/shared/scaling/replicate.d.ts.map +1 -0
  437. package/dist/types/src/shared/scaling/scaleArray.d.ts +3 -0
  438. package/dist/types/src/shared/scaling/scaleArray.d.ts.map +1 -0
  439. package/dist/types/src/types/DICOMLoaderDataSetWithFetchMore.d.ts +10 -0
  440. package/dist/types/src/types/DICOMLoaderDataSetWithFetchMore.d.ts.map +1 -0
  441. package/dist/types/src/types/DICOMLoaderIImage.d.ts +14 -0
  442. package/dist/types/src/types/DICOMLoaderIImage.d.ts.map +1 -0
  443. package/dist/types/src/types/DICOMLoaderImageOptions.d.ts +27 -0
  444. package/dist/types/src/types/DICOMLoaderImageOptions.d.ts.map +1 -0
  445. package/dist/types/src/types/ImageFrame.d.ts +44 -0
  446. package/dist/types/src/types/ImageFrame.d.ts.map +1 -0
  447. package/dist/types/src/types/LoadRequestFunction.d.ts +2 -0
  448. package/dist/types/src/types/LoadRequestFunction.d.ts.map +1 -0
  449. package/dist/types/src/types/LoaderDecodeOptions.d.ts +5 -0
  450. package/dist/types/src/types/LoaderDecodeOptions.d.ts.map +1 -0
  451. package/dist/types/src/types/LoaderOptions.d.ts +19 -0
  452. package/dist/types/src/types/LoaderOptions.d.ts.map +1 -0
  453. package/dist/types/src/types/LutType.d.ts +7 -0
  454. package/dist/types/src/types/LutType.d.ts.map +1 -0
  455. package/dist/types/src/types/MetadataModules.d.ts +67 -0
  456. package/dist/types/src/types/MetadataModules.d.ts.map +1 -0
  457. package/dist/types/src/types/PixelDataTypedArray.d.ts +3 -0
  458. package/dist/types/src/types/PixelDataTypedArray.d.ts.map +1 -0
  459. package/dist/types/src/types/WADORSMetaData.d.ts +5 -0
  460. package/dist/types/src/types/WADORSMetaData.d.ts.map +1 -0
  461. package/dist/types/src/types/WebWorkerTypes.d.ts +65 -0
  462. package/dist/types/src/types/WebWorkerTypes.d.ts.map +1 -0
  463. package/dist/types/src/types/XHRRequest.d.ts +17 -0
  464. package/dist/types/src/types/XHRRequest.d.ts.map +1 -0
  465. package/dist/types/src/types/index.d.ts +15 -0
  466. package/dist/types/src/types/index.d.ts.map +1 -0
  467. package/dist/types/src/version.d.ts +3 -0
  468. package/dist/types/src/version.d.ts.map +1 -0
  469. package/package.json +19 -9
  470. package/dist/cornerstoneDICOMImageLoaderNoWebWorkers.bundle.min.js +0 -2
  471. package/dist/cornerstoneDICOMImageLoaderNoWebWorkers.bundle.min.js.map +0 -1
  472. package/dist/dynamic-import/610.min.worker.js +0 -2
  473. package/dist/dynamic-import/610.min.worker.js.map +0 -1
  474. package/dist/dynamic-import/945.min.worker.js.map +0 -1
  475. package/dist/dynamic-import/index.worker.5a5a581362c14598c3d9.worker.js +0 -2
  476. package/dist/dynamic-import/index.worker.5a5a581362c14598c3d9.worker.js.map +0 -1
  477. package/dist/index.worker.bundle.min.worker.js +0 -2
  478. package/dist/index.worker.bundle.min.worker.js.map +0 -1
@@ -0,0 +1,269 @@
1
+ import { ByteArray } from 'dicom-parser';
2
+ import bilinear from './scaling/bilinear';
3
+ import replicate from './scaling/replicate';
4
+ import { expose } from 'comlink';
5
+ import decodeLittleEndian from './decoders/decodeLittleEndian';
6
+ import decodeBigEndian from './decoders/decodeBigEndian';
7
+ import decodeRLE from './decoders/decodeRLE';
8
+ import decodeJPEGBaseline8Bit from './decoders/decodeJPEGBaseline8Bit';
9
+ import decodeJPEGBaseline12Bit from './decoders/decodeJPEGBaseline12Bit-js';
10
+ import decodeJPEGLossless from './decoders/decodeJPEGLossless';
11
+ import decodeJPEGLS from './decoders/decodeJPEGLS';
12
+ import decodeJPEG2000 from './decoders/decodeJPEG2000';
13
+ import decodeHTJ2K from './decoders/decodeHTJ2K';
14
+ import applyModalityLUT from './scaling/scaleArray';
15
+ import { ImageFrame, LoaderDecodeOptions, PixelDataTypedArray } from '../types';
16
+ import getMinMax from './getMinMax';
17
+ import getPixelDataTypeFromMinMax from './getPixelDataTypeFromMinMax';
18
+ import isColorImage from './isColorImage';
19
+ const imageUtils = {
20
+ bilinear,
21
+ replicate,
22
+ };
23
+ async function decodeImageFrame(imageFrame, transferSyntax, pixelData, decodeConfig, options, callbackFn) {
24
+ const start = new Date().getTime();
25
+ let decodePromise = null;
26
+ let opts;
27
+ switch (transferSyntax) {
28
+ case '1.2.840.10008.1.2':
29
+ case '1.2.840.10008.1.2.1':
30
+ decodePromise = decodeLittleEndian(imageFrame, pixelData);
31
+ break;
32
+ case '1.2.840.10008.1.2.2':
33
+ decodePromise = decodeBigEndian(imageFrame, pixelData);
34
+ break;
35
+ case '1.2.840.10008.1.2.1.99':
36
+ decodePromise = decodeLittleEndian(imageFrame, pixelData);
37
+ break;
38
+ case '1.2.840.10008.1.2.5':
39
+ decodePromise = decodeRLE(imageFrame, pixelData);
40
+ break;
41
+ case '1.2.840.10008.1.2.4.50':
42
+ opts = {
43
+ ...imageFrame,
44
+ };
45
+ decodePromise = decodeJPEGBaseline8Bit(pixelData, opts);
46
+ break;
47
+ case '1.2.840.10008.1.2.4.51':
48
+ decodePromise = decodeJPEGBaseline12Bit(imageFrame, pixelData);
49
+ break;
50
+ case '1.2.840.10008.1.2.4.57':
51
+ decodePromise = decodeJPEGLossless(imageFrame, pixelData);
52
+ break;
53
+ case '1.2.840.10008.1.2.4.70':
54
+ decodePromise = decodeJPEGLossless(imageFrame, pixelData);
55
+ break;
56
+ case '1.2.840.10008.1.2.4.80':
57
+ opts = {
58
+ signed: imageFrame.pixelRepresentation === 1,
59
+ bytesPerPixel: imageFrame.bitsAllocated <= 8 ? 1 : 2,
60
+ ...imageFrame,
61
+ };
62
+ decodePromise = decodeJPEGLS(pixelData, opts);
63
+ break;
64
+ case '1.2.840.10008.1.2.4.81':
65
+ opts = {
66
+ signed: imageFrame.pixelRepresentation === 1,
67
+ bytesPerPixel: imageFrame.bitsAllocated <= 8 ? 1 : 2,
68
+ ...imageFrame,
69
+ };
70
+ decodePromise = decodeJPEGLS(pixelData, opts);
71
+ break;
72
+ case '1.2.840.10008.1.2.4.90':
73
+ opts = {
74
+ ...imageFrame,
75
+ };
76
+ decodePromise = decodeJPEG2000(pixelData, opts);
77
+ break;
78
+ case '1.2.840.10008.1.2.4.91':
79
+ opts = {
80
+ ...imageFrame,
81
+ };
82
+ decodePromise = decodeJPEG2000(pixelData, opts);
83
+ break;
84
+ case '3.2.840.10008.1.2.4.96':
85
+ case '1.2.840.10008.1.2.4.201':
86
+ case '1.2.840.10008.1.2.4.202':
87
+ case '1.2.840.10008.1.2.4.203':
88
+ opts = {
89
+ ...imageFrame,
90
+ };
91
+ decodePromise = decodeHTJ2K(pixelData, opts);
92
+ break;
93
+ default:
94
+ throw new Error(`no decoder for transfer syntax ${transferSyntax}`);
95
+ }
96
+ if (!decodePromise) {
97
+ throw new Error('decodePromise not defined');
98
+ }
99
+ const decodedFrame = await decodePromise;
100
+ const postProcessed = postProcessDecodedPixels(decodedFrame, options, start, decodeConfig);
101
+ callbackFn?.(postProcessed);
102
+ return postProcessed;
103
+ }
104
+ function postProcessDecodedPixels(imageFrame, options, start, decodeConfig) {
105
+ const { use16BitDataType } = decodeConfig || {};
106
+ const shouldShift = imageFrame.pixelRepresentation !== undefined &&
107
+ imageFrame.pixelRepresentation === 1;
108
+ const shift = shouldShift && imageFrame.bitsStored !== undefined
109
+ ? 32 - imageFrame.bitsStored
110
+ : undefined;
111
+ if (shouldShift && shift !== undefined) {
112
+ for (let i = 0; i < imageFrame.pixelData.length; i++) {
113
+ imageFrame.pixelData[i] = (imageFrame.pixelData[i] << shift) >> shift;
114
+ }
115
+ }
116
+ let pixelDataArray = imageFrame.pixelData;
117
+ imageFrame.pixelDataLength = imageFrame.pixelData.length;
118
+ const { min: minBeforeScale, max: maxBeforeScale } = getMinMax(imageFrame.pixelData);
119
+ const typedArrayConstructors = {
120
+ Uint8Array,
121
+ Uint16Array: use16BitDataType ? Uint16Array : undefined,
122
+ Int16Array: use16BitDataType ? Int16Array : undefined,
123
+ Float32Array,
124
+ };
125
+ const type = options.targetBuffer?.type;
126
+ const canRenderFloat = typeof options.allowFloatRendering !== 'undefined'
127
+ ? options.allowFloatRendering
128
+ : true;
129
+ const invalidType = isColorImage(imageFrame.photometricInterpretation) &&
130
+ options.targetBuffer?.offset === undefined;
131
+ const willScale = options.preScale?.enabled;
132
+ const hasFloatRescale = willScale &&
133
+ Object.values(options.preScale.scalingParameters).some((v) => typeof v === 'number' && !Number.isInteger(v));
134
+ const disableScale = !options.preScale.enabled || (!canRenderFloat && hasFloatRescale);
135
+ if (type && !invalidType) {
136
+ pixelDataArray = _handleTargetBuffer(options, imageFrame, typedArrayConstructors, pixelDataArray);
137
+ }
138
+ else if (options.preScale.enabled && !disableScale) {
139
+ pixelDataArray = _handlePreScaleSetup(options, minBeforeScale, maxBeforeScale, imageFrame);
140
+ }
141
+ else {
142
+ pixelDataArray = _getDefaultPixelDataArray(minBeforeScale, maxBeforeScale, imageFrame);
143
+ }
144
+ let minAfterScale = minBeforeScale;
145
+ let maxAfterScale = maxBeforeScale;
146
+ if (options.preScale.enabled && !disableScale) {
147
+ const scalingParameters = options.preScale.scalingParameters;
148
+ _validateScalingParameters(scalingParameters);
149
+ const { rescaleSlope, rescaleIntercept } = scalingParameters;
150
+ const isSlopeAndInterceptNumbers = typeof rescaleSlope === 'number' && typeof rescaleIntercept === 'number';
151
+ if (isSlopeAndInterceptNumbers) {
152
+ applyModalityLUT(pixelDataArray, scalingParameters);
153
+ imageFrame.preScale = {
154
+ ...options.preScale,
155
+ scaled: true,
156
+ };
157
+ const { rescaleIntercept, rescaleSlope, suvbw } = scalingParameters;
158
+ minAfterScale = rescaleSlope * minBeforeScale + rescaleIntercept;
159
+ maxAfterScale = rescaleSlope * maxBeforeScale + rescaleIntercept;
160
+ if (suvbw) {
161
+ minAfterScale = minAfterScale * suvbw;
162
+ maxAfterScale = maxAfterScale * suvbw;
163
+ }
164
+ }
165
+ }
166
+ else if (disableScale) {
167
+ imageFrame.preScale = {
168
+ enabled: true,
169
+ scaled: false,
170
+ };
171
+ minAfterScale = minBeforeScale;
172
+ maxAfterScale = maxBeforeScale;
173
+ }
174
+ const hasTargetBuffer = options.targetBuffer !== undefined;
175
+ if (!hasTargetBuffer || !options.isSharedArrayBuffer) {
176
+ imageFrame.pixelData = pixelDataArray;
177
+ }
178
+ imageFrame.minAfterScale = minAfterScale;
179
+ imageFrame.maxAfterScale = maxAfterScale;
180
+ const end = new Date().getTime();
181
+ imageFrame.decodeTimeInMS = end - start;
182
+ return imageFrame;
183
+ }
184
+ function _handleTargetBuffer(options, imageFrame, typedArrayConstructors, pixelDataArray) {
185
+ const { arrayBuffer, type, offset: rawOffset = 0, length: rawLength, rows, } = options.targetBuffer;
186
+ const TypedArrayConstructor = typedArrayConstructors[type];
187
+ if (!TypedArrayConstructor) {
188
+ throw new Error(`target array ${type} is not supported, you need to set use16BitDataType to true if you want to use Uint16Array or Int16Array.`);
189
+ }
190
+ if (rows && rows != imageFrame.rows) {
191
+ scaleImageFrame(imageFrame, options.targetBuffer, TypedArrayConstructor);
192
+ }
193
+ const imageFrameLength = imageFrame.pixelDataLength;
194
+ const offset = rawOffset;
195
+ const length = rawLength !== null && rawLength !== undefined
196
+ ? rawLength
197
+ : imageFrameLength - offset;
198
+ const imageFramePixelData = imageFrame.pixelData;
199
+ if (length !== imageFramePixelData.length) {
200
+ throw new Error(`target array for image does not have the same length (${length}) as the decoded image length (${imageFramePixelData.length}).`);
201
+ }
202
+ const typedArray = arrayBuffer
203
+ ? new TypedArrayConstructor(arrayBuffer, offset, length)
204
+ : new TypedArrayConstructor(length);
205
+ typedArray.set(imageFramePixelData, 0);
206
+ pixelDataArray = typedArray;
207
+ return pixelDataArray;
208
+ }
209
+ function _handlePreScaleSetup(options, minBeforeScale, maxBeforeScale, imageFrame) {
210
+ const scalingParameters = options.preScale.scalingParameters;
211
+ _validateScalingParameters(scalingParameters);
212
+ const { rescaleSlope, rescaleIntercept } = scalingParameters;
213
+ const areSlopeAndInterceptNumbers = typeof rescaleSlope === 'number' && typeof rescaleIntercept === 'number';
214
+ let scaledMin = minBeforeScale;
215
+ let scaledMax = maxBeforeScale;
216
+ if (areSlopeAndInterceptNumbers) {
217
+ scaledMin = rescaleSlope * minBeforeScale + rescaleIntercept;
218
+ scaledMax = rescaleSlope * maxBeforeScale + rescaleIntercept;
219
+ }
220
+ return _getDefaultPixelDataArray(scaledMin, scaledMax, imageFrame);
221
+ }
222
+ function _getDefaultPixelDataArray(min, max, imageFrame) {
223
+ const TypedArrayConstructor = getPixelDataTypeFromMinMax(min, max);
224
+ const typedArray = new TypedArrayConstructor(imageFrame.pixelData.length);
225
+ typedArray.set(imageFrame.pixelData, 0);
226
+ return typedArray;
227
+ }
228
+ function _validateScalingParameters(scalingParameters) {
229
+ if (!scalingParameters) {
230
+ throw new Error('options.preScale.scalingParameters must be defined if preScale.enabled is true, and scalingParameters cannot be derived from the metadata providers.');
231
+ }
232
+ }
233
+ function createDestinationImage(imageFrame, targetBuffer, TypedArrayConstructor) {
234
+ const { samplesPerPixel } = imageFrame;
235
+ const { rows, columns } = targetBuffer;
236
+ const typedLength = rows * columns * samplesPerPixel;
237
+ const pixelData = new TypedArrayConstructor(typedLength);
238
+ const bytesPerPixel = pixelData.byteLength / typedLength;
239
+ return {
240
+ pixelData,
241
+ rows,
242
+ columns,
243
+ frameInfo: {
244
+ ...imageFrame.frameInfo,
245
+ rows,
246
+ columns,
247
+ },
248
+ imageInfo: {
249
+ ...imageFrame.imageInfo,
250
+ rows,
251
+ columns,
252
+ bytesPerPixel,
253
+ },
254
+ };
255
+ }
256
+ function scaleImageFrame(imageFrame, targetBuffer, TypedArrayConstructor) {
257
+ const dest = createDestinationImage(imageFrame, targetBuffer, TypedArrayConstructor);
258
+ const { scalingType = 'replicate' } = targetBuffer;
259
+ imageUtils[scalingType](imageFrame, dest);
260
+ Object.assign(imageFrame, dest);
261
+ return imageFrame;
262
+ }
263
+ const obj = {
264
+ decodeTask({ imageFrame, transferSyntax, decodeConfig, options, pixelData, callbackFn, }) {
265
+ return decodeImageFrame(imageFrame, transferSyntax, pixelData, decodeConfig, options, callbackFn);
266
+ },
267
+ };
268
+ expose(obj);
269
+ //# sourceMappingURL=decodeImageFrame.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decodeImageFrame.js","sourceRoot":"","sources":["../../../../src/shared/decodeImageFrame.js"],"names":[],"mappings":"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"}
@@ -0,0 +1,29 @@
1
+ function swap16(val) {
2
+ return ((val & 0xff) << 8) | ((val >> 8) & 0xff);
3
+ }
4
+ async function decodeBigEndian(imageFrame, pixelData) {
5
+ if (imageFrame.bitsAllocated === 16) {
6
+ let arrayBuffer = pixelData.buffer;
7
+ let offset = pixelData.byteOffset;
8
+ const length = pixelData.length;
9
+ if (offset % 2) {
10
+ arrayBuffer = arrayBuffer.slice(offset);
11
+ offset = 0;
12
+ }
13
+ if (imageFrame.pixelRepresentation === 0) {
14
+ imageFrame.pixelData = new Uint16Array(arrayBuffer, offset, length / 2);
15
+ }
16
+ else {
17
+ imageFrame.pixelData = new Int16Array(arrayBuffer, offset, length / 2);
18
+ }
19
+ for (let i = 0; i < imageFrame.pixelData.length; i++) {
20
+ imageFrame.pixelData[i] = swap16(imageFrame.pixelData[i]);
21
+ }
22
+ }
23
+ else if (imageFrame.bitsAllocated === 8) {
24
+ imageFrame.pixelData = pixelData;
25
+ }
26
+ return imageFrame;
27
+ }
28
+ export default decodeBigEndian;
29
+ //# sourceMappingURL=decodeBigEndian.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decodeBigEndian.js","sourceRoot":"","sources":["../../../../../src/shared/decoders/decodeBigEndian.ts"],"names":[],"mappings":"AAIA,SAAS,MAAM,CAAC,GAAG;IACjB,OAAO,CAAC,CAAC,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC,GAAG,IAAI,CAAC,CAAC;AACnD,CAAC;AAED,KAAK,UAAU,eAAe,CAC5B,UAAsB,EACtB,SAAoB;IAEpB,IAAI,UAAU,CAAC,aAAa,KAAK,EAAE,EAAE,CAAC;QACpC,IAAI,WAAW,GAAG,SAAS,CAAC,MAAM,CAAC;QAEnC,IAAI,MAAM,GAAG,SAAS,CAAC,UAAU,CAAC;QAClC,MAAM,MAAM,GAAG,SAAS,CAAC,MAAM,CAAC;QAIhC,IAAI,MAAM,GAAG,CAAC,EAAE,CAAC;YACf,WAAW,GAAG,WAAW,CAAC,KAAK,CAAC,MAAM,CAAC,CAAC;YACxC,MAAM,GAAG,CAAC,CAAC;QACb,CAAC;QAED,IAAI,UAAU,CAAC,mBAAmB,KAAK,CAAC,EAAE,CAAC;YACzC,UAAU,CAAC,SAAS,GAAG,IAAI,WAAW,CAAC,WAAW,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;QAC1E,CAAC;aAAM,CAAC;YACN,UAAU,CAAC,SAAS,GAAG,IAAI,UAAU,CAAC,WAAW,EAAE,MAAM,EAAE,MAAM,GAAG,CAAC,CAAC,CAAC;QACzE,CAAC;QAED,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE,CAAC;YACrD,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,GAAG,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,CAAC;QAC5D,CAAC;IACH,CAAC;SAAM,IAAI,UAAU,CAAC,aAAa,KAAK,CAAC,EAAE,CAAC;QAC1C,UAAU,CAAC,SAAS,GAAG,SAAS,CAAC;IACnC,CAAC;IAED,OAAO,UAAU,CAAC;AACpB,CAAC;AAED,eAAe,eAAe,CAAC"}
@@ -0,0 +1,110 @@
1
+ import openJphFactory from '@cornerstonejs/codec-openjph/wasmjs';
2
+ import openjphWasm from '@cornerstonejs/codec-openjph/wasm';
3
+ const local = {
4
+ codec: undefined,
5
+ decoder: undefined,
6
+ decodeConfig: {},
7
+ };
8
+ function calculateSizeAtDecompositionLevel(decompositionLevel, frameWidth, frameHeight) {
9
+ const result = { width: frameWidth, height: frameHeight };
10
+ while (decompositionLevel > 0) {
11
+ result.width = Math.ceil(result.width / 2);
12
+ result.height = Math.ceil(result.height / 2);
13
+ decompositionLevel--;
14
+ }
15
+ return result;
16
+ }
17
+ export function initialize(decodeConfig) {
18
+ local.decodeConfig = decodeConfig;
19
+ if (local.codec) {
20
+ return Promise.resolve();
21
+ }
22
+ const openJphModule = openJphFactory({
23
+ locateFile: (f) => {
24
+ if (f.endsWith('.wasm')) {
25
+ return openjphWasm;
26
+ }
27
+ return f;
28
+ },
29
+ });
30
+ return new Promise((resolve, reject) => {
31
+ openJphModule.then((instance) => {
32
+ local.codec = instance;
33
+ local.decoder = new instance.HTJ2KDecoder();
34
+ resolve();
35
+ }, reject);
36
+ });
37
+ }
38
+ async function decodeAsync(compressedImageFrame, imageInfo) {
39
+ await initialize();
40
+ const decoder = new local.codec.HTJ2KDecoder();
41
+ const encodedBufferInWASM = decoder.getEncodedBuffer(compressedImageFrame.length);
42
+ encodedBufferInWASM.set(compressedImageFrame);
43
+ const decodeLevel = imageInfo.decodeLevel || 0;
44
+ decoder.decodeSubResolution(decodeLevel);
45
+ const frameInfo = decoder.getFrameInfo();
46
+ if (imageInfo.decodeLevel > 0) {
47
+ const { width, height } = calculateSizeAtDecompositionLevel(imageInfo.decodeLevel, frameInfo.width, frameInfo.height);
48
+ frameInfo.width = width;
49
+ frameInfo.height = height;
50
+ }
51
+ const decodedBufferInWASM = decoder.getDecodedBuffer();
52
+ const imageFrame = new Uint8Array(decodedBufferInWASM.length);
53
+ imageFrame.set(decodedBufferInWASM);
54
+ const imageOffset = `x: ${decoder.getImageOffset().x}, y: ${decoder.getImageOffset().y}`;
55
+ const numDecompositions = decoder.getNumDecompositions();
56
+ const numLayers = decoder.getNumLayers();
57
+ const progessionOrder = ['unknown', 'LRCP', 'RLCP', 'RPCL', 'PCRL', 'CPRL'][decoder.getProgressionOrder() + 1];
58
+ const reversible = decoder.getIsReversible();
59
+ const blockDimensions = `${decoder.getBlockDimensions().width} x ${decoder.getBlockDimensions().height}`;
60
+ const tileSize = `${decoder.getTileSize().width} x ${decoder.getTileSize().height}`;
61
+ const tileOffset = `${decoder.getTileOffset().x}, ${decoder.getTileOffset().y}`;
62
+ const decodedSize = `${decodedBufferInWASM.length.toLocaleString()} bytes`;
63
+ const compressionRatio = `${(decodedBufferInWASM.length / encodedBufferInWASM.length).toFixed(2)}:1`;
64
+ const encodedImageInfo = {
65
+ columns: frameInfo.width,
66
+ rows: frameInfo.height,
67
+ bitsPerPixel: frameInfo.bitsPerSample,
68
+ signed: frameInfo.isSigned,
69
+ bytesPerPixel: imageInfo.bytesPerPixel,
70
+ componentsPerPixel: frameInfo.componentCount,
71
+ };
72
+ let pixelData = getPixelData(frameInfo, decodedBufferInWASM);
73
+ const { buffer: b, byteOffset, byteLength } = pixelData;
74
+ const pixelDataArrayBuffer = b.slice(byteOffset, byteOffset + byteLength);
75
+ pixelData = new pixelData.constructor(pixelDataArrayBuffer);
76
+ const encodeOptions = {
77
+ imageOffset,
78
+ numDecompositions,
79
+ numLayers,
80
+ progessionOrder,
81
+ reversible,
82
+ blockDimensions,
83
+ tileSize,
84
+ tileOffset,
85
+ decodedSize,
86
+ compressionRatio,
87
+ };
88
+ return {
89
+ ...imageInfo,
90
+ pixelData,
91
+ imageInfo: encodedImageInfo,
92
+ encodeOptions,
93
+ ...encodeOptions,
94
+ ...encodedImageInfo,
95
+ };
96
+ }
97
+ function getPixelData(frameInfo, decodedBuffer) {
98
+ if (frameInfo.bitsPerSample > 8) {
99
+ if (frameInfo.isSigned) {
100
+ return new Int16Array(decodedBuffer.buffer, decodedBuffer.byteOffset, decodedBuffer.byteLength / 2);
101
+ }
102
+ return new Uint16Array(decodedBuffer.buffer, decodedBuffer.byteOffset, decodedBuffer.byteLength / 2);
103
+ }
104
+ if (frameInfo.isSigned) {
105
+ return new Int8Array(decodedBuffer.buffer, decodedBuffer.byteOffset, decodedBuffer.byteLength);
106
+ }
107
+ return new Uint8Array(decodedBuffer.buffer, decodedBuffer.byteOffset, decodedBuffer.byteLength);
108
+ }
109
+ export default decodeAsync;
110
+ //# sourceMappingURL=decodeHTJ2K.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decodeHTJ2K.js","sourceRoot":"","sources":["../../../../../src/shared/decoders/decodeHTJ2K.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,94 @@
1
+ import openJpegFactory from '@cornerstonejs/codec-openjpeg/decodewasmjs';
2
+ import openjpegWasm from '@cornerstonejs/codec-openjpeg/decodewasm';
3
+ const local = {
4
+ codec: undefined,
5
+ decoder: undefined,
6
+ decodeConfig: {},
7
+ };
8
+ export function initialize(decodeConfig) {
9
+ local.decodeConfig = decodeConfig;
10
+ if (local.codec) {
11
+ return Promise.resolve();
12
+ }
13
+ const openJpegModule = openJpegFactory({
14
+ locateFile: (f) => {
15
+ if (f.endsWith('.wasm')) {
16
+ return openjpegWasm.toString();
17
+ }
18
+ return f;
19
+ },
20
+ });
21
+ return new Promise((resolve, reject) => {
22
+ openJpegModule.then((instance) => {
23
+ local.codec = instance;
24
+ local.decoder = new instance.J2KDecoder();
25
+ resolve();
26
+ }, reject);
27
+ });
28
+ }
29
+ async function decodeAsync(compressedImageFrame, imageInfo) {
30
+ await initialize();
31
+ const decoder = local.decoder;
32
+ const encodedBufferInWASM = decoder.getEncodedBuffer(compressedImageFrame.length);
33
+ encodedBufferInWASM.set(compressedImageFrame);
34
+ decoder.decode();
35
+ const frameInfo = decoder.getFrameInfo();
36
+ const decodedBufferInWASM = decoder.getDecodedBuffer();
37
+ const imageFrame = new Uint8Array(decodedBufferInWASM.length);
38
+ imageFrame.set(decodedBufferInWASM);
39
+ const imageOffset = `x: ${decoder.getImageOffset().x}, y: ${decoder.getImageOffset().y}`;
40
+ const numDecompositions = decoder.getNumDecompositions();
41
+ const numLayers = decoder.getNumLayers();
42
+ const progessionOrder = ['unknown', 'LRCP', 'RLCP', 'RPCL', 'PCRL', 'CPRL'][decoder.getProgressionOrder() + 1];
43
+ const reversible = decoder.getIsReversible();
44
+ const blockDimensions = `${decoder.getBlockDimensions().width} x ${decoder.getBlockDimensions().height}`;
45
+ const tileSize = `${decoder.getTileSize().width} x ${decoder.getTileSize().height}`;
46
+ const tileOffset = `${decoder.getTileOffset().x}, ${decoder.getTileOffset().y}`;
47
+ const colorTransform = decoder.getColorSpace();
48
+ const decodedSize = `${decodedBufferInWASM.length.toLocaleString()} bytes`;
49
+ const compressionRatio = `${(decodedBufferInWASM.length / encodedBufferInWASM.length).toFixed(2)}:1`;
50
+ const encodedImageInfo = {
51
+ columns: frameInfo.width,
52
+ rows: frameInfo.height,
53
+ bitsPerPixel: frameInfo.bitsPerSample,
54
+ signed: frameInfo.isSigned,
55
+ bytesPerPixel: imageInfo.bytesPerPixel,
56
+ componentsPerPixel: frameInfo.componentCount,
57
+ };
58
+ const pixelData = getPixelData(frameInfo, decodedBufferInWASM);
59
+ const encodeOptions = {
60
+ imageOffset,
61
+ numDecompositions,
62
+ numLayers,
63
+ progessionOrder,
64
+ reversible,
65
+ blockDimensions,
66
+ tileSize,
67
+ tileOffset,
68
+ colorTransform,
69
+ decodedSize,
70
+ compressionRatio,
71
+ };
72
+ return {
73
+ ...imageInfo,
74
+ pixelData,
75
+ imageInfo: encodedImageInfo,
76
+ encodeOptions,
77
+ ...encodeOptions,
78
+ ...encodedImageInfo,
79
+ };
80
+ }
81
+ function getPixelData(frameInfo, decodedBuffer) {
82
+ if (frameInfo.bitsPerSample > 8) {
83
+ if (frameInfo.isSigned) {
84
+ return new Int16Array(decodedBuffer.buffer, decodedBuffer.byteOffset, decodedBuffer.byteLength / 2);
85
+ }
86
+ return new Uint16Array(decodedBuffer.buffer, decodedBuffer.byteOffset, decodedBuffer.byteLength / 2);
87
+ }
88
+ if (frameInfo.isSigned) {
89
+ return new Int8Array(decodedBuffer.buffer, decodedBuffer.byteOffset, decodedBuffer.byteLength);
90
+ }
91
+ return new Uint8Array(decodedBuffer.buffer, decodedBuffer.byteOffset, decodedBuffer.byteLength);
92
+ }
93
+ export default decodeAsync;
94
+ //# sourceMappingURL=decodeJPEG2000.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decodeJPEG2000.js","sourceRoot":"","sources":["../../../../../src/shared/decoders/decodeJPEG2000.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,35 @@
1
+ const local = {
2
+ JpegImage: undefined,
3
+ decodeConfig: {},
4
+ };
5
+ export function initialize(decodeConfig) {
6
+ local.decodeConfig = decodeConfig;
7
+ if (local.JpegImage) {
8
+ return Promise.resolve();
9
+ }
10
+ return new Promise((resolve, reject) => {
11
+ import('../../../codecs/jpeg').then(({ JpegImage }) => {
12
+ local.JpegImage = JpegImage;
13
+ resolve();
14
+ }, reject);
15
+ });
16
+ }
17
+ async function decodeJPEGBaseline12BitAsync(imageFrame, pixelData) {
18
+ await initialize();
19
+ if (typeof local.JpegImage === 'undefined') {
20
+ throw new Error('No JPEG Baseline decoder loaded');
21
+ }
22
+ const jpeg = new local.JpegImage();
23
+ jpeg.parse(pixelData);
24
+ jpeg.colorTransform = false;
25
+ if (imageFrame.bitsAllocated === 8) {
26
+ imageFrame.pixelData = jpeg.getData(imageFrame.columns, imageFrame.rows);
27
+ return imageFrame;
28
+ }
29
+ else if (imageFrame.bitsAllocated === 16) {
30
+ imageFrame.pixelData = jpeg.getData16(imageFrame.columns, imageFrame.rows);
31
+ return imageFrame;
32
+ }
33
+ }
34
+ export default decodeJPEGBaseline12BitAsync;
35
+ //# sourceMappingURL=decodeJPEGBaseline12Bit-js.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decodeJPEGBaseline12Bit-js.js","sourceRoot":"","sources":["../../../../../src/shared/decoders/decodeJPEGBaseline12Bit-js.ts"],"names":[],"mappings":"AAGA,MAAM,KAAK,GAAG;IACZ,SAAS,EAAE,SAAS;IACpB,YAAY,EAAE,EAA2B;CAC1C,CAAC;AAEF,MAAM,UAAU,UAAU,CACxB,YAAoC;IAEpC,KAAK,CAAC,YAAY,GAAG,YAAY,CAAC;IAElC,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;QACpB,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;IAED,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;QAErC,MAAM,CAAC,sBAAsB,CAAC,CAAC,IAAI,CAAC,CAAC,EAAE,SAAS,EAAE,EAAE,EAAE;YACpD,KAAK,CAAC,SAAS,GAAG,SAAS,CAAC;YAC5B,OAAO,EAAE,CAAC;QACZ,CAAC,EAAE,MAAM,CAAC,CAAC;IACb,CAAC,CAAC,CAAC;AACL,CAAC;AAED,KAAK,UAAU,4BAA4B,CACzC,UAAsB,EACtB,SAAoB;IAGpB,MAAM,UAAU,EAAE,CAAC;IACnB,IAAI,OAAO,KAAK,CAAC,SAAS,KAAK,WAAW,EAAE,CAAC;QAC3C,MAAM,IAAI,KAAK,CAAC,iCAAiC,CAAC,CAAC;IACrD,CAAC;IACD,MAAM,IAAI,GAAG,IAAI,KAAK,CAAC,SAAS,EAAE,CAAC;IAEnC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC,CAAC;IAItB,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;IAE5B,IAAI,UAAU,CAAC,aAAa,KAAK,CAAC,EAAE,CAAC;QACnC,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,OAAO,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;QAEzE,OAAO,UAAU,CAAC;IACpB,CAAC;SAAM,IAAI,UAAU,CAAC,aAAa,KAAK,EAAE,EAAE,CAAC;QAC3C,UAAU,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,OAAO,EAAE,UAAU,CAAC,IAAI,CAAC,CAAC;QAE3E,OAAO,UAAU,CAAC;IACpB,CAAC;AACH,CAAC;AAED,eAAe,4BAA4B,CAAC"}
@@ -0,0 +1,2 @@
1
+ "use strict";
2
+ //# sourceMappingURL=decodeJPEGBaseline12Bit-wasm-not-yet-working.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"decodeJPEGBaseline12Bit-wasm-not-yet-working.js","sourceRoot":"","sources":["../../../../../src/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.ts"],"names":[],"mappings":""}
@@ -0,0 +1,63 @@
1
+ import libjpegTurboFactory from '@cornerstonejs/codec-libjpeg-turbo-8bit/decodewasmjs';
2
+ import libjpegTurboWasm from '@cornerstonejs/codec-libjpeg-turbo-8bit/decodewasm';
3
+ const local = {
4
+ codec: undefined,
5
+ decoder: undefined,
6
+ };
7
+ function initLibjpegTurbo() {
8
+ if (local.codec) {
9
+ return Promise.resolve();
10
+ }
11
+ const libjpegTurboModule = libjpegTurboFactory({
12
+ locateFile: (f) => {
13
+ if (f.endsWith('.wasm')) {
14
+ return libjpegTurboWasm.toString();
15
+ }
16
+ return f;
17
+ },
18
+ });
19
+ return new Promise((resolve, reject) => {
20
+ libjpegTurboModule.then((instance) => {
21
+ local.codec = instance;
22
+ local.decoder = new instance.JPEGDecoder();
23
+ resolve();
24
+ }, reject);
25
+ });
26
+ }
27
+ async function decodeAsync(compressedImageFrame, imageInfo) {
28
+ await initLibjpegTurbo();
29
+ const decoder = local.decoder;
30
+ const encodedBufferInWASM = decoder.getEncodedBuffer(compressedImageFrame.length);
31
+ encodedBufferInWASM.set(compressedImageFrame);
32
+ decoder.decode();
33
+ const frameInfo = decoder.getFrameInfo();
34
+ const decodedPixelsInWASM = decoder.getDecodedBuffer();
35
+ const encodedImageInfo = {
36
+ columns: frameInfo.width,
37
+ rows: frameInfo.height,
38
+ bitsPerPixel: frameInfo.bitsPerSample,
39
+ signed: imageInfo.signed,
40
+ bytesPerPixel: imageInfo.bytesPerPixel,
41
+ componentsPerPixel: frameInfo.componentCount,
42
+ };
43
+ const pixelData = getPixelData(frameInfo, decodedPixelsInWASM);
44
+ const encodeOptions = {
45
+ frameInfo,
46
+ };
47
+ return {
48
+ ...imageInfo,
49
+ pixelData,
50
+ imageInfo: encodedImageInfo,
51
+ encodeOptions,
52
+ ...encodeOptions,
53
+ ...encodedImageInfo,
54
+ };
55
+ }
56
+ function getPixelData(frameInfo, decodedBuffer) {
57
+ if (frameInfo.isSigned) {
58
+ return new Int8Array(decodedBuffer.buffer, decodedBuffer.byteOffset, decodedBuffer.byteLength);
59
+ }
60
+ return new Uint8Array(decodedBuffer.buffer, decodedBuffer.byteOffset, decodedBuffer.byteLength);
61
+ }
62
+ export default decodeAsync;
63
+ //# sourceMappingURL=decodeJPEGBaseline8Bit.js.map