UNPKG

js-dicom

Version:

this is js-dicom

27 lines (22 loc) 873 B
function decodeLittleEndian (imageFrame, pixelData) { if (imageFrame.bitsAllocated === 16) { let arrayBuffer = pixelData.buffer; let offset = pixelData.byteOffset; const length = pixelData.length; // if pixel data is not aligned on even boundary, shift it so we can create the 16 bit array // buffers on it if (offset % 2) { arrayBuffer = arrayBuffer.slice(offset); offset = 0; } if (imageFrame.pixelRepresentation === 0) { imageFrame.pixelData = new Uint16Array(arrayBuffer, offset, length / 2); } else { imageFrame.pixelData = new Int16Array(arrayBuffer, offset, length / 2); } } else if (imageFrame.bitsAllocated === 8) { imageFrame.pixelData = pixelData; } return imageFrame; } export default decodeLittleEndian;