UNPKG

@cleerlycode/cornerstone-wado-image-loader

Version:
321 lines (320 loc) 11.4 kB
<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/webWorker/decodeTask/decodeImageFrame.js</title> <meta charset="utf-8" /> <link rel="stylesheet" href="../../../prettify.css" /> <link rel="stylesheet" href="../../../base.css" /> <meta name="viewport" content="width=device-width, initial-scale=1"> <style type='text/css'> .coverage-summary .sorter { background-image: url(../../../sort-arrow-sprite.png); } </style> </head> <body> <div class='wrapper'> <div class='pad1'> <h1> <a href="../../../index.html">all files</a> / <a href="index.html">src/webWorker/decodeTask/</a> decodeImageFrame.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">72.22% </span> <span class="quiet">Statements</span> <span class='fraction'>26/36</span> </div> <div class='fl pad1y space-right2'> <span class="strong">72.22% </span> <span class="quiet">Branches</span> <span class='fraction'>26/36</span> </div> <div class='fl pad1y space-right2'> <span class="strong">100% </span> <span class="quiet">Functions</span> <span class='fraction'>1/1</span> </div> <div class='fl pad1y space-right2'> <span class="strong">72.22% </span> <span class="quiet">Lines</span> <span class='fraction'>26/36</span> </div> </div> </div> <div class='status-line medium'></div> <pre><table class="coverage"> <tr><td class="line-count quiet">1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86</td><td class="line-coverage quiet"><span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">2097152×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes"></span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span></td><td class="text"><pre class="prettyprint lang-js">import decodeLittleEndian from './decoders/decodeLittleEndian.js'; import decodeBigEndian from './decoders/decodeBigEndian.js'; import decodeRLE from './decoders/decodeRLE.js'; import decodeJPEGBaseline from './decoders/decodeJPEGBaseline.js'; import decodeJPEGLossless from './decoders/decodeJPEGLossless.js'; import decodeJPEGLS from './decoders/decodeJPEGLS.js'; import decodeJPEG2000 from './decoders/decodeJPEG2000.js'; &nbsp; function decodeImageFrame (imageFrame, transferSyntax, pixelData, decodeConfig, options) { const start = new Date().getTime(); &nbsp; if (transferSyntax === '1.2.840.10008.1.2') { // Implicit VR Little Endian imageFrame = decodeLittleEndian(imageFrame, pixelData); } else if (transferSyntax === '1.2.840.10008.1.2.1') { // Explicit VR Little Endian imageFrame = decodeLittleEndian(imageFrame, pixelData); } else if (transferSyntax === '1.2.840.10008.1.2.2') { // Explicit VR Big Endian (retired) imageFrame = decodeBigEndian(imageFrame, pixelData); } else <span class="missing-if-branch" title="if path not taken" >I</span>if (transferSyntax === '1.2.840.10008.1.2.1.99') { // Deflate transfer syntax (deflated by dicomParser) <span class="cstat-no" title="statement not covered" > imageFrame = decodeLittleEndian(imageFrame, pixelData);</span> } else if (transferSyntax === '1.2.840.10008.1.2.5') { // RLE Lossless imageFrame = decodeRLE(imageFrame, pixelData); } else if (transferSyntax === '1.2.840.10008.1.2.4.50') { // JPEG Baseline lossy process 1 (8 bit) imageFrame = decodeJPEGBaseline(imageFrame, pixelData); } else <span class="missing-if-branch" title="if path not taken" >I</span>if (transferSyntax === '1.2.840.10008.1.2.4.51') { // JPEG Baseline lossy process 2 &amp; 4 (12 bit) <span class="cstat-no" title="statement not covered" > imageFrame = decodeJPEGBaseline(imageFrame, pixelData);</span> } else <span class="missing-if-branch" title="if path not taken" >I</span>if (transferSyntax === '1.2.840.10008.1.2.4.57') { // JPEG Lossless, Nonhierarchical (Processes 14) <span class="cstat-no" title="statement not covered" > imageFrame = decodeJPEGLossless(imageFrame, pixelData);</span> } else if (transferSyntax === '1.2.840.10008.1.2.4.70') { // JPEG Lossless, Nonhierarchical (Processes 14 [Selection 1]) imageFrame = decodeJPEGLossless(imageFrame, pixelData); } else <span class="missing-if-branch" title="else path not taken" >E</span>if (transferSyntax === '1.2.840.10008.1.2.4.80') { // JPEG-LS Lossless Image Compression imageFrame = decodeJPEGLS(imageFrame, pixelData); } else <span class="cstat-no" title="statement not covered" >if (transferSyntax === '1.2.840.10008.1.2.4.81') {</span> // JPEG-LS Lossy (Near-Lossless) Image Compression <span class="cstat-no" title="statement not covered" > imageFrame = decodeJPEGLS(imageFrame, pixelData);</span> } else <span class="cstat-no" title="statement not covered" >if (transferSyntax === '1.2.840.10008.1.2.4.90') {</span> // JPEG 2000 Lossless <span class="cstat-no" title="statement not covered" > imageFrame = decodeJPEG2000(imageFrame, pixelData, decodeConfig, options);</span> } else <span class="cstat-no" title="statement not covered" >if (transferSyntax === '1.2.840.10008.1.2.4.91') {</span> // JPEG 2000 Lossy <span class="cstat-no" title="statement not covered" > imageFrame = decodeJPEG2000(imageFrame, pixelData, decodeConfig, options);</span> } else { <span class="cstat-no" title="statement not covered" > throw new Error(`no decoder for transfer syntax ${transferSyntax}`);</span> } &nbsp; /* Don't know if these work... // JPEG 2000 Part 2 Multicomponent Image Compression (Lossless Only) else if(transferSyntax === "1.2.840.10008.1.2.4.92") { return decodeJPEG2000(dataSet, frame); } // JPEG 2000 Part 2 Multicomponent Image Compression else if(transferSyntax === "1.2.840.10008.1.2.4.93") { return decodeJPEG2000(dataSet, frame); } */ &nbsp; const shouldShift = imageFrame.pixelRepresentation !== undefined &amp;&amp; imageFrame.pixelRepresentation === 1; const shift = (shouldShift &amp;&amp; imageFrame.bitsStored !== undefined) ? (32 - imageFrame.bitsStored) : undefined; &nbsp; if (shouldShift &amp;&amp; shift !== undefined) { for (let i = 0; i &lt; imageFrame.pixelData.length; i++) { // eslint-disable-next-line no-bitwise imageFrame.pixelData[i] = (imageFrame.pixelData[i] &lt;&lt; shift &gt;&gt; shift); } } &nbsp; const end = new Date().getTime(); &nbsp; imageFrame.decodeTimeInMS = end - start; &nbsp; return imageFrame; } &nbsp; export default decodeImageFrame; &nbsp;</pre></td></tr> </table></pre> <div class='push'></div><!-- for sticky footer --> </div><!-- /wrapper --> <div class='footer quiet pad2 space-top1 center small'> Code coverage generated by <a href="http://istanbul-js.org/" target="_blank">istanbul</a> at Sun Apr 01 2018 20:02:13 GMT+0800 (CST) </div> </div> <script src="../../../prettify.js"></script> <script> window.onload = function () { if (typeof prettyPrint === 'function') { prettyPrint(); } }; </script> <script src="../../../sorter.js"></script> </body> </html>