@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.
- package/dist/744.bundle.min.js +3 -0
- package/dist/744.bundle.min.js.LICENSE.txt +5 -0
- package/dist/744.bundle.min.js.map +1 -0
- package/dist/cornerstoneDICOMImageLoader.bundle.min.js +1 -1
- package/dist/cornerstoneDICOMImageLoader.bundle.min.js.map +1 -1
- package/dist/dynamic-import/{945.min.worker.js → 584.min.js} +2 -2
- package/dist/dynamic-import/584.min.js.map +1 -0
- package/dist/dynamic-import/595.min.js +2 -0
- package/dist/dynamic-import/595.min.js.map +1 -0
- package/dist/dynamic-import/610.min.js +2 -0
- package/dist/dynamic-import/610.min.js.map +1 -0
- package/dist/dynamic-import/958.min.js +3 -0
- package/dist/dynamic-import/958.min.js.LICENSE.txt +5 -0
- package/dist/dynamic-import/958.min.js.map +1 -0
- package/dist/dynamic-import/cornerstoneDICOMImageLoader.min.js +1 -1
- package/dist/dynamic-import/cornerstoneDICOMImageLoader.min.js.map +1 -1
- package/dist/esm/codecs/jpeg.js +891 -0
- package/dist/esm/codecs/jpeg.js.map +1 -0
- package/dist/esm/codecs/jpegLossless.js +1220 -0
- package/dist/esm/codecs/jpegLossless.js.map +1 -0
- package/dist/esm/src/constants/transferSyntaxes.js +47 -0
- package/dist/esm/src/constants/transferSyntaxes.js.map +1 -0
- package/dist/esm/src/externalModules.js +45 -0
- package/dist/esm/src/externalModules.js.map +1 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertPALETTECOLOR.js +78 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertPALETTECOLOR.js.map +1 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertRGBColorByPixel.js +22 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertRGBColorByPixel.js.map +1 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertRGBColorByPlane.js +29 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertRGBColorByPlane.js.map +1 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFull422ByPixel.js +45 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFull422ByPixel.js.map +1 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFullByPixel.js +34 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFullByPixel.js.map +1 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFullByPlane.js +36 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/convertYBRFullByPlane.js.map +1 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/index.js +8 -0
- package/dist/esm/src/imageLoader/colorSpaceConverters/index.js.map +1 -0
- package/dist/esm/src/imageLoader/configure.js +12 -0
- package/dist/esm/src/imageLoader/configure.js.map +1 -0
- package/dist/esm/src/imageLoader/convertColorSpace.js +41 -0
- package/dist/esm/src/imageLoader/convertColorSpace.js.map +1 -0
- package/dist/esm/src/imageLoader/createImage.js +249 -0
- package/dist/esm/src/imageLoader/createImage.js.map +1 -0
- package/dist/esm/src/imageLoader/decodeImageFrame.js +66 -0
- package/dist/esm/src/imageLoader/decodeImageFrame.js.map +1 -0
- package/dist/esm/src/imageLoader/decodeJPEGBaseline8BitColor.js +65 -0
- package/dist/esm/src/imageLoader/decodeJPEGBaseline8BitColor.js.map +1 -0
- package/dist/esm/src/imageLoader/getImageFrame.js +27 -0
- package/dist/esm/src/imageLoader/getImageFrame.js.map +1 -0
- package/dist/esm/src/imageLoader/getInstanceModule.js +41 -0
- package/dist/esm/src/imageLoader/getInstanceModule.js.map +1 -0
- package/dist/esm/src/imageLoader/getMinMax.js +16 -0
- package/dist/esm/src/imageLoader/getMinMax.js.map +1 -0
- package/dist/esm/src/imageLoader/getScalingParameters.js +16 -0
- package/dist/esm/src/imageLoader/getScalingParameters.js.map +1 -0
- package/dist/esm/src/imageLoader/imageIdToURI.js +5 -0
- package/dist/esm/src/imageLoader/imageIdToURI.js.map +1 -0
- package/dist/esm/src/imageLoader/index.js +37 -0
- package/dist/esm/src/imageLoader/index.js.map +1 -0
- package/dist/esm/src/imageLoader/internal/index.js +9 -0
- package/dist/esm/src/imageLoader/internal/index.js.map +1 -0
- package/dist/esm/src/imageLoader/internal/options.js +24 -0
- package/dist/esm/src/imageLoader/internal/options.js.map +1 -0
- package/dist/esm/src/imageLoader/internal/rangeRequest.js +122 -0
- package/dist/esm/src/imageLoader/internal/rangeRequest.js.map +1 -0
- package/dist/esm/src/imageLoader/internal/streamRequest.js +93 -0
- package/dist/esm/src/imageLoader/internal/streamRequest.js.map +1 -0
- package/dist/esm/src/imageLoader/internal/xhrRequest.js +103 -0
- package/dist/esm/src/imageLoader/internal/xhrRequest.js.map +1 -0
- package/dist/esm/src/imageLoader/isColorConversionRequired.js +23 -0
- package/dist/esm/src/imageLoader/isColorConversionRequired.js.map +1 -0
- package/dist/esm/src/imageLoader/isJPEGBaseline8BitColor.js +10 -0
- package/dist/esm/src/imageLoader/isJPEGBaseline8BitColor.js.map +1 -0
- package/dist/esm/src/imageLoader/isNMReconstructable.js +4 -0
- package/dist/esm/src/imageLoader/isNMReconstructable.js.map +1 -0
- package/dist/esm/src/imageLoader/registerLoaders.js +8 -0
- package/dist/esm/src/imageLoader/registerLoaders.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/combineFrameInstance.js +45 -0
- package/dist/esm/src/imageLoader/wadors/combineFrameInstance.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/extractMultipart.js +74 -0
- package/dist/esm/src/imageLoader/wadors/extractMultipart.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/findIndexOfString.js +33 -0
- package/dist/esm/src/imageLoader/wadors/findIndexOfString.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/getImageQualityStatus.js +9 -0
- package/dist/esm/src/imageLoader/wadors/getImageQualityStatus.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/getPixelData.js +36 -0
- package/dist/esm/src/imageLoader/wadors/getPixelData.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/getTagValue.js +10 -0
- package/dist/esm/src/imageLoader/wadors/getTagValue.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/index.js +22 -0
- package/dist/esm/src/imageLoader/wadors/index.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/loadImage.js +126 -0
- package/dist/esm/src/imageLoader/wadors/loadImage.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/loadImage_test.js +42 -0
- package/dist/esm/src/imageLoader/wadors/loadImage_test.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/NMHelpers.js +39 -0
- package/dist/esm/src/imageLoader/wadors/metaData/NMHelpers.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/USHelpers.js +47 -0
- package/dist/esm/src/imageLoader/wadors/metaData/USHelpers.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/extractPositioningFromMetadata.js +19 -0
- package/dist/esm/src/imageLoader/wadors/metaData/extractPositioningFromMetadata.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getFirstNumberValue.js +7 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getFirstNumberValue.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getNumberString.js +10 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getNumberString.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getNumberValue.js +10 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getNumberValue.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getNumberValues.js +21 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getNumberValues.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getOverlayPlaneModule.js +39 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getOverlayPlaneModule.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getSequenceItems.js +15 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getSequenceItems.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getValue.js +15 -0
- package/dist/esm/src/imageLoader/wadors/metaData/getValue.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/index.js +8 -0
- package/dist/esm/src/imageLoader/wadors/metaData/index.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaData/metaDataProvider.js +262 -0
- package/dist/esm/src/imageLoader/wadors/metaData/metaDataProvider.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/metaDataManager.js +48 -0
- package/dist/esm/src/imageLoader/wadors/metaDataManager.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/register.js +7 -0
- package/dist/esm/src/imageLoader/wadors/register.js.map +1 -0
- package/dist/esm/src/imageLoader/wadors/retrieveMultiframeMetadata.js +27 -0
- package/dist/esm/src/imageLoader/wadors/retrieveMultiframeMetadata.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/combineFrameInstanceDataset.js +68 -0
- package/dist/esm/src/imageLoader/wadouri/combineFrameInstanceDataset.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/dataSetCacheManager.js +143 -0
- package/dist/esm/src/imageLoader/wadouri/dataSetCacheManager.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/dataSetCacheManager_test.js +11 -0
- package/dist/esm/src/imageLoader/wadouri/dataSetCacheManager_test.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/dataset-from-partial-content.js +57 -0
- package/dist/esm/src/imageLoader/wadouri/dataset-from-partial-content.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/fileManager.js +21 -0
- package/dist/esm/src/imageLoader/wadouri/fileManager.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/getEncapsulatedImageFrame.js +34 -0
- package/dist/esm/src/imageLoader/wadouri/getEncapsulatedImageFrame.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/getPixelData.js +14 -0
- package/dist/esm/src/imageLoader/wadouri/getPixelData.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/getUncompressedImageFrame.js +48 -0
- package/dist/esm/src/imageLoader/wadouri/getUncompressedImageFrame.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/index.js +32 -0
- package/dist/esm/src/imageLoader/wadouri/index.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/loadFileRequest.js +18 -0
- package/dist/esm/src/imageLoader/wadouri/loadFileRequest.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/loadImage.js +105 -0
- package/dist/esm/src/imageLoader/wadouri/loadImage.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/extractPositioningFromDataset.js +81 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/extractPositioningFromDataset.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/getImagePixelModule.js +80 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/getImagePixelModule.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/getLUTs.js +45 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/getLUTs.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/getModalityLUTOutputPixelRepresentation.js +31 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/getModalityLUTOutputPixelRepresentation.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/getNumberValues.js +17 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/getNumberValues.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/getOverlayPlaneModule.js +37 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/getOverlayPlaneModule.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/index.js +6 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/index.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/metaDataProvider.js +211 -0
- package/dist/esm/src/imageLoader/wadouri/metaData/metaDataProvider.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/parseImageId.js +21 -0
- package/dist/esm/src/imageLoader/wadouri/parseImageId.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/register.js +9 -0
- package/dist/esm/src/imageLoader/wadouri/register.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/retrieveMultiframeDataset.js +58 -0
- package/dist/esm/src/imageLoader/wadouri/retrieveMultiframeDataset.js.map +1 -0
- package/dist/esm/src/imageLoader/wadouri/unpackBinaryFrame.js +15 -0
- package/dist/esm/src/imageLoader/wadouri/unpackBinaryFrame.js.map +1 -0
- package/dist/esm/src/shared/calculateMinMax.js +25 -0
- package/dist/esm/src/shared/calculateMinMax.js.map +1 -0
- package/dist/esm/src/shared/calculateMinMax_test.js +39 -0
- package/dist/esm/src/shared/calculateMinMax_test.js.map +1 -0
- package/dist/esm/src/shared/decodeImageFrame.js +269 -0
- package/dist/esm/src/shared/decodeImageFrame.js.map +1 -0
- package/dist/esm/src/shared/decoders/decodeBigEndian.js +29 -0
- package/dist/esm/src/shared/decoders/decodeBigEndian.js.map +1 -0
- package/dist/esm/src/shared/decoders/decodeHTJ2K.js +110 -0
- package/dist/esm/src/shared/decoders/decodeHTJ2K.js.map +1 -0
- package/dist/esm/src/shared/decoders/decodeJPEG2000.js +94 -0
- package/dist/esm/src/shared/decoders/decodeJPEG2000.js.map +1 -0
- package/dist/esm/src/shared/decoders/decodeJPEGBaseline12Bit-js.js +35 -0
- package/dist/esm/src/shared/decoders/decodeJPEGBaseline12Bit-js.js.map +1 -0
- package/dist/esm/src/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.js +2 -0
- package/dist/esm/src/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.js.map +1 -0
- package/dist/esm/src/shared/decoders/decodeJPEGBaseline8Bit.js +63 -0
- package/dist/esm/src/shared/decoders/decodeJPEGBaseline8Bit.js.map +1 -0
- package/dist/esm/src/shared/decoders/decodeJPEGLS.js +85 -0
- package/dist/esm/src/shared/decoders/decodeJPEGLS.js.map +1 -0
- package/dist/esm/src/shared/decoders/decodeJPEGLossless.js +40 -0
- package/dist/esm/src/shared/decoders/decodeJPEGLossless.js.map +1 -0
- package/dist/esm/src/shared/decoders/decodeLittleEndian.js +30 -0
- package/dist/esm/src/shared/decoders/decodeLittleEndian.js.map +1 -0
- package/dist/esm/src/shared/decoders/decodeRLE.js +129 -0
- package/dist/esm/src/shared/decoders/decodeRLE.js.map +1 -0
- package/dist/esm/src/shared/getMinMax.js +17 -0
- package/dist/esm/src/shared/getMinMax.js.map +1 -0
- package/dist/esm/src/shared/getMinMax_test.js +10 -0
- package/dist/esm/src/shared/getMinMax_test.js.map +1 -0
- package/dist/esm/src/shared/getPixelDataTypeFromMinMax.js +23 -0
- package/dist/esm/src/shared/getPixelDataTypeFromMinMax.js.map +1 -0
- package/dist/esm/src/shared/isColorImage.js +11 -0
- package/dist/esm/src/shared/isColorImage.js.map +1 -0
- package/dist/esm/src/shared/scaling/bilinear.js +33 -0
- package/dist/esm/src/shared/scaling/bilinear.js.map +1 -0
- package/dist/esm/src/shared/scaling/replicate.js +21 -0
- package/dist/esm/src/shared/scaling/replicate.js.map +1 -0
- package/dist/esm/src/shared/scaling/scaleArray.js +16 -0
- package/dist/esm/src/shared/scaling/scaleArray.js.map +1 -0
- package/dist/esm/src/types/DICOMLoaderDataSetWithFetchMore.js +2 -0
- package/dist/esm/src/types/DICOMLoaderDataSetWithFetchMore.js.map +1 -0
- package/dist/esm/src/types/DICOMLoaderIImage.js +2 -0
- package/dist/esm/src/types/DICOMLoaderIImage.js.map +1 -0
- package/dist/esm/src/types/DICOMLoaderImageOptions.js +2 -0
- package/dist/esm/src/types/DICOMLoaderImageOptions.js.map +1 -0
- package/dist/esm/src/types/ImageFrame.js +2 -0
- package/dist/esm/src/types/ImageFrame.js.map +1 -0
- package/dist/esm/src/types/LoadRequestFunction.js +2 -0
- package/dist/esm/src/types/LoadRequestFunction.js.map +1 -0
- package/dist/esm/src/types/LoaderDecodeOptions.js +2 -0
- package/dist/esm/src/types/LoaderDecodeOptions.js.map +1 -0
- package/dist/esm/src/types/LoaderOptions.js +2 -0
- package/dist/esm/src/types/LoaderOptions.js.map +1 -0
- package/dist/esm/src/types/LutType.js +2 -0
- package/dist/esm/src/types/LutType.js.map +1 -0
- package/dist/esm/src/types/MetadataModules.js +2 -0
- package/dist/esm/src/types/MetadataModules.js.map +1 -0
- package/dist/esm/src/types/PixelDataTypedArray.js +2 -0
- package/dist/esm/src/types/PixelDataTypedArray.js.map +1 -0
- package/dist/esm/src/types/WADORSMetaData.js +2 -0
- package/dist/esm/src/types/WADORSMetaData.js.map +1 -0
- package/dist/esm/src/types/WebWorkerTypes.js +2 -0
- package/dist/esm/src/types/WebWorkerTypes.js.map +1 -0
- package/dist/esm/src/types/XHRRequest.js +2 -0
- package/dist/esm/src/types/XHRRequest.js.map +1 -0
- package/dist/esm/src/types/index.js +2 -0
- package/dist/esm/src/types/index.js.map +1 -0
- package/dist/esm/src/version.js +2 -0
- package/dist/esm/src/version.js.map +1 -0
- package/dist/types/codecs/jpeg.d.ts +11 -0
- package/dist/types/codecs/jpeg.d.ts.map +1 -0
- package/dist/types/codecs/jpegLossless.d.ts +8 -0
- package/dist/types/codecs/jpegLossless.d.ts.map +1 -0
- package/dist/types/src/constants/transferSyntaxes.d.ts +47 -0
- package/dist/types/src/constants/transferSyntaxes.d.ts.map +1 -0
- package/dist/types/src/externalModules.d.ts +6 -0
- package/dist/types/src/externalModules.d.ts.map +1 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertPALETTECOLOR.d.ts +4 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertPALETTECOLOR.d.ts.map +1 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertRGBColorByPixel.d.ts +3 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertRGBColorByPixel.d.ts.map +1 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertRGBColorByPlane.d.ts +3 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertRGBColorByPlane.d.ts.map +1 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFull422ByPixel.d.ts +3 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFull422ByPixel.d.ts.map +1 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFullByPixel.d.ts +3 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFullByPixel.d.ts.map +1 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFullByPlane.d.ts +3 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/convertYBRFullByPlane.d.ts.map +1 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/index.d.ts +8 -0
- package/dist/types/src/imageLoader/colorSpaceConverters/index.d.ts.map +1 -0
- package/dist/types/src/imageLoader/configure.d.ts +4 -0
- package/dist/types/src/imageLoader/configure.d.ts.map +1 -0
- package/dist/types/src/imageLoader/convertColorSpace.d.ts +2 -0
- package/dist/types/src/imageLoader/convertColorSpace.d.ts.map +1 -0
- package/dist/types/src/imageLoader/createImage.d.ts +5 -0
- package/dist/types/src/imageLoader/createImage.d.ts.map +1 -0
- package/dist/types/src/imageLoader/decodeImageFrame.d.ts +4 -0
- package/dist/types/src/imageLoader/decodeImageFrame.d.ts.map +1 -0
- package/dist/types/src/imageLoader/decodeJPEGBaseline8BitColor.d.ts +5 -0
- package/dist/types/src/imageLoader/decodeJPEGBaseline8BitColor.d.ts.map +1 -0
- package/dist/types/src/imageLoader/getImageFrame.d.ts +4 -0
- package/dist/types/src/imageLoader/getImageFrame.d.ts.map +1 -0
- package/dist/types/src/imageLoader/getInstanceModule.d.ts +4 -0
- package/dist/types/src/imageLoader/getInstanceModule.d.ts.map +1 -0
- package/dist/types/src/imageLoader/getMinMax.d.ts +5 -0
- package/dist/types/src/imageLoader/getMinMax.d.ts.map +1 -0
- package/dist/types/src/imageLoader/getScalingParameters.d.ts +7 -0
- package/dist/types/src/imageLoader/getScalingParameters.d.ts.map +1 -0
- package/dist/types/src/imageLoader/imageIdToURI.d.ts +2 -0
- package/dist/types/src/imageLoader/imageIdToURI.d.ts.map +1 -0
- package/dist/types/src/imageLoader/index.d.ts +95 -0
- package/dist/types/src/imageLoader/index.d.ts.map +1 -0
- package/dist/types/src/imageLoader/internal/index.d.ts +9 -0
- package/dist/types/src/imageLoader/internal/index.d.ts.map +1 -0
- package/dist/types/src/imageLoader/internal/options.d.ts +4 -0
- package/dist/types/src/imageLoader/internal/options.d.ts.map +1 -0
- package/dist/types/src/imageLoader/internal/rangeRequest.d.ts +10 -0
- package/dist/types/src/imageLoader/internal/rangeRequest.d.ts.map +1 -0
- package/dist/types/src/imageLoader/internal/streamRequest.d.ts +3 -0
- package/dist/types/src/imageLoader/internal/streamRequest.d.ts.map +1 -0
- package/dist/types/src/imageLoader/internal/xhrRequest.d.ts +4 -0
- package/dist/types/src/imageLoader/internal/xhrRequest.d.ts.map +1 -0
- package/dist/types/src/imageLoader/isColorConversionRequired.d.ts +2 -0
- package/dist/types/src/imageLoader/isColorConversionRequired.d.ts.map +1 -0
- package/dist/types/src/imageLoader/isJPEGBaseline8BitColor.d.ts +4 -0
- package/dist/types/src/imageLoader/isJPEGBaseline8BitColor.d.ts.map +1 -0
- package/dist/types/src/imageLoader/isNMReconstructable.d.ts +2 -0
- package/dist/types/src/imageLoader/isNMReconstructable.d.ts.map +1 -0
- package/dist/types/src/imageLoader/registerLoaders.d.ts +3 -0
- package/dist/types/src/imageLoader/registerLoaders.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/combineFrameInstance.d.ts +13 -0
- package/dist/types/src/imageLoader/wadors/combineFrameInstance.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/extractMultipart.d.ts +24 -0
- package/dist/types/src/imageLoader/wadors/extractMultipart.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/findIndexOfString.d.ts +3 -0
- package/dist/types/src/imageLoader/wadors/findIndexOfString.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/getImageQualityStatus.d.ts +3 -0
- package/dist/types/src/imageLoader/wadors/getImageQualityStatus.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/getPixelData.d.ts +27 -0
- package/dist/types/src/imageLoader/wadors/getPixelData.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/getTagValue.d.ts +2 -0
- package/dist/types/src/imageLoader/wadors/getTagValue.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/index.d.ts +26 -0
- package/dist/types/src/imageLoader/wadors/index.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/loadImage.d.ts +26 -0
- package/dist/types/src/imageLoader/wadors/loadImage.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/loadImage_test.d.ts +2 -0
- package/dist/types/src/imageLoader/wadors/loadImage_test.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/NMHelpers.d.ts +6 -0
- package/dist/types/src/imageLoader/wadors/metaData/NMHelpers.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/USHelpers.d.ts +20 -0
- package/dist/types/src/imageLoader/wadors/metaData/USHelpers.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/extractPositioningFromMetadata.d.ts +4 -0
- package/dist/types/src/imageLoader/wadors/metaData/extractPositioningFromMetadata.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/getFirstNumberValue.d.ts +3 -0
- package/dist/types/src/imageLoader/wadors/metaData/getFirstNumberValue.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/getNumberString.d.ts +4 -0
- package/dist/types/src/imageLoader/wadors/metaData/getNumberString.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/getNumberValue.d.ts +4 -0
- package/dist/types/src/imageLoader/wadors/metaData/getNumberValue.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/getNumberValues.d.ts +4 -0
- package/dist/types/src/imageLoader/wadors/metaData/getNumberValues.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/getOverlayPlaneModule.d.ts +5 -0
- package/dist/types/src/imageLoader/wadors/metaData/getOverlayPlaneModule.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/getSequenceItems.d.ts +4 -0
- package/dist/types/src/imageLoader/wadors/metaData/getSequenceItems.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/getValue.d.ts +4 -0
- package/dist/types/src/imageLoader/wadors/metaData/getValue.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/index.d.ts +8 -0
- package/dist/types/src/imageLoader/wadors/metaData/index.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaData/metaDataProvider.d.ts +15 -0
- package/dist/types/src/imageLoader/wadors/metaData/metaDataProvider.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/metaDataManager.d.ts +15 -0
- package/dist/types/src/imageLoader/wadors/metaDataManager.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/register.d.ts +2 -0
- package/dist/types/src/imageLoader/wadors/register.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadors/retrieveMultiframeMetadata.d.ts +16 -0
- package/dist/types/src/imageLoader/wadors/retrieveMultiframeMetadata.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/combineFrameInstanceDataset.d.ts +23 -0
- package/dist/types/src/imageLoader/wadouri/combineFrameInstanceDataset.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/dataSetCacheManager.d.ts +32 -0
- package/dist/types/src/imageLoader/wadouri/dataSetCacheManager.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/dataSetCacheManager_test.d.ts +2 -0
- package/dist/types/src/imageLoader/wadouri/dataSetCacheManager_test.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/dataset-from-partial-content.d.ts +7 -0
- package/dist/types/src/imageLoader/wadouri/dataset-from-partial-content.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/fileManager.d.ts +12 -0
- package/dist/types/src/imageLoader/wadouri/fileManager.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/getEncapsulatedImageFrame.d.ts +3 -0
- package/dist/types/src/imageLoader/wadouri/getEncapsulatedImageFrame.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/getPixelData.d.ts +4 -0
- package/dist/types/src/imageLoader/wadouri/getPixelData.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/getUncompressedImageFrame.d.ts +4 -0
- package/dist/types/src/imageLoader/wadouri/getUncompressedImageFrame.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/index.d.ts +44 -0
- package/dist/types/src/imageLoader/wadouri/index.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/loadFileRequest.d.ts +3 -0
- package/dist/types/src/imageLoader/wadouri/loadFileRequest.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/loadImage.d.ts +10 -0
- package/dist/types/src/imageLoader/wadouri/loadImage.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/metaData/extractPositioningFromDataset.d.ts +7 -0
- package/dist/types/src/imageLoader/wadouri/metaData/extractPositioningFromDataset.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/metaData/getImagePixelModule.d.ts +5 -0
- package/dist/types/src/imageLoader/wadouri/metaData/getImagePixelModule.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/metaData/getLUTs.d.ts +5 -0
- package/dist/types/src/imageLoader/wadouri/metaData/getLUTs.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/metaData/getModalityLUTOutputPixelRepresentation.d.ts +4 -0
- package/dist/types/src/imageLoader/wadouri/metaData/getModalityLUTOutputPixelRepresentation.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/metaData/getNumberValues.d.ts +4 -0
- package/dist/types/src/imageLoader/wadouri/metaData/getNumberValues.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/metaData/getOverlayPlaneModule.d.ts +5 -0
- package/dist/types/src/imageLoader/wadouri/metaData/getOverlayPlaneModule.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/metaData/index.d.ts +6 -0
- package/dist/types/src/imageLoader/wadouri/metaData/index.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/metaData/metaDataProvider.d.ts +3 -0
- package/dist/types/src/imageLoader/wadouri/metaData/metaDataProvider.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/parseImageId.d.ts +9 -0
- package/dist/types/src/imageLoader/wadouri/parseImageId.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/register.d.ts +3 -0
- package/dist/types/src/imageLoader/wadouri/register.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/retrieveMultiframeDataset.d.ts +19 -0
- package/dist/types/src/imageLoader/wadouri/retrieveMultiframeDataset.d.ts.map +1 -0
- package/dist/types/src/imageLoader/wadouri/unpackBinaryFrame.d.ts +4 -0
- package/dist/types/src/imageLoader/wadouri/unpackBinaryFrame.d.ts.map +1 -0
- package/dist/types/src/shared/calculateMinMax.d.ts +3 -0
- package/dist/types/src/shared/calculateMinMax.d.ts.map +1 -0
- package/dist/types/src/shared/calculateMinMax_test.d.ts +2 -0
- package/dist/types/src/shared/calculateMinMax_test.d.ts.map +1 -0
- package/dist/types/src/shared/decodeImageFrame.d.ts +2 -0
- package/dist/types/src/shared/decodeImageFrame.d.ts.map +1 -0
- package/dist/types/src/shared/decoders/decodeBigEndian.d.ts +5 -0
- package/dist/types/src/shared/decoders/decodeBigEndian.d.ts.map +1 -0
- package/dist/types/src/shared/decoders/decodeHTJ2K.d.ts +6 -0
- package/dist/types/src/shared/decoders/decodeHTJ2K.d.ts.map +1 -0
- package/dist/types/src/shared/decoders/decodeJPEG2000.d.ts +5 -0
- package/dist/types/src/shared/decoders/decodeJPEG2000.d.ts.map +1 -0
- package/dist/types/src/shared/decoders/decodeJPEGBaseline12Bit-js.d.ts +6 -0
- package/dist/types/src/shared/decoders/decodeJPEGBaseline12Bit-js.d.ts.map +1 -0
- package/dist/types/src/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.d.ts +1 -0
- package/dist/types/src/shared/decoders/decodeJPEGBaseline12Bit-wasm-not-yet-working.d.ts.map +1 -0
- package/dist/types/src/shared/decoders/decodeJPEGBaseline8Bit.d.ts +4 -0
- package/dist/types/src/shared/decoders/decodeJPEGBaseline8Bit.d.ts.map +1 -0
- package/dist/types/src/shared/decoders/decodeJPEGLS.d.ts +5 -0
- package/dist/types/src/shared/decoders/decodeJPEGLS.d.ts.map +1 -0
- package/dist/types/src/shared/decoders/decodeJPEGLossless.d.ts +6 -0
- package/dist/types/src/shared/decoders/decodeJPEGLossless.d.ts.map +1 -0
- package/dist/types/src/shared/decoders/decodeLittleEndian.d.ts +5 -0
- package/dist/types/src/shared/decoders/decodeLittleEndian.d.ts.map +1 -0
- package/dist/types/src/shared/decoders/decodeRLE.d.ts +5 -0
- package/dist/types/src/shared/decoders/decodeRLE.d.ts.map +1 -0
- package/dist/types/src/shared/getMinMax.d.ts +7 -0
- package/dist/types/src/shared/getMinMax.d.ts.map +1 -0
- package/dist/types/src/shared/getMinMax_test.d.ts +2 -0
- package/dist/types/src/shared/getMinMax_test.d.ts.map +1 -0
- package/dist/types/src/shared/getPixelDataTypeFromMinMax.d.ts +3 -0
- package/dist/types/src/shared/getPixelDataTypeFromMinMax.d.ts.map +1 -0
- package/dist/types/src/shared/isColorImage.d.ts +2 -0
- package/dist/types/src/shared/isColorImage.d.ts.map +1 -0
- package/dist/types/src/shared/scaling/bilinear.d.ts +2 -0
- package/dist/types/src/shared/scaling/bilinear.d.ts.map +1 -0
- package/dist/types/src/shared/scaling/replicate.d.ts +2 -0
- package/dist/types/src/shared/scaling/replicate.d.ts.map +1 -0
- package/dist/types/src/shared/scaling/scaleArray.d.ts +3 -0
- package/dist/types/src/shared/scaling/scaleArray.d.ts.map +1 -0
- package/dist/types/src/types/DICOMLoaderDataSetWithFetchMore.d.ts +10 -0
- package/dist/types/src/types/DICOMLoaderDataSetWithFetchMore.d.ts.map +1 -0
- package/dist/types/src/types/DICOMLoaderIImage.d.ts +14 -0
- package/dist/types/src/types/DICOMLoaderIImage.d.ts.map +1 -0
- package/dist/types/src/types/DICOMLoaderImageOptions.d.ts +27 -0
- package/dist/types/src/types/DICOMLoaderImageOptions.d.ts.map +1 -0
- package/dist/types/src/types/ImageFrame.d.ts +44 -0
- package/dist/types/src/types/ImageFrame.d.ts.map +1 -0
- package/dist/types/src/types/LoadRequestFunction.d.ts +2 -0
- package/dist/types/src/types/LoadRequestFunction.d.ts.map +1 -0
- package/dist/types/src/types/LoaderDecodeOptions.d.ts +5 -0
- package/dist/types/src/types/LoaderDecodeOptions.d.ts.map +1 -0
- package/dist/types/src/types/LoaderOptions.d.ts +19 -0
- package/dist/types/src/types/LoaderOptions.d.ts.map +1 -0
- package/dist/types/src/types/LutType.d.ts +7 -0
- package/dist/types/src/types/LutType.d.ts.map +1 -0
- package/dist/types/src/types/MetadataModules.d.ts +67 -0
- package/dist/types/src/types/MetadataModules.d.ts.map +1 -0
- package/dist/types/src/types/PixelDataTypedArray.d.ts +3 -0
- package/dist/types/src/types/PixelDataTypedArray.d.ts.map +1 -0
- package/dist/types/src/types/WADORSMetaData.d.ts +5 -0
- package/dist/types/src/types/WADORSMetaData.d.ts.map +1 -0
- package/dist/types/src/types/WebWorkerTypes.d.ts +65 -0
- package/dist/types/src/types/WebWorkerTypes.d.ts.map +1 -0
- package/dist/types/src/types/XHRRequest.d.ts +17 -0
- package/dist/types/src/types/XHRRequest.d.ts.map +1 -0
- package/dist/types/src/types/index.d.ts +15 -0
- package/dist/types/src/types/index.d.ts.map +1 -0
- package/dist/types/src/version.d.ts +3 -0
- package/dist/types/src/version.d.ts.map +1 -0
- package/package.json +19 -9
- package/dist/cornerstoneDICOMImageLoaderNoWebWorkers.bundle.min.js +0 -2
- package/dist/cornerstoneDICOMImageLoaderNoWebWorkers.bundle.min.js.map +0 -1
- package/dist/dynamic-import/610.min.worker.js +0 -2
- package/dist/dynamic-import/610.min.worker.js.map +0 -1
- package/dist/dynamic-import/945.min.worker.js.map +0 -1
- package/dist/dynamic-import/index.worker.5a5a581362c14598c3d9.worker.js +0 -2
- package/dist/dynamic-import/index.worker.5a5a581362c14598c3d9.worker.js.map +0 -1
- package/dist/index.worker.bundle.min.worker.js +0 -2
- 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 @@
|
|
|
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
|