UNPKG

@cleerlycode/cornerstone-wado-image-loader

Version:
360 lines (359 loc) 14.5 kB
<!doctype html> <html lang="en"> <head> <title>Code coverage report for src/imageLoader/wadouri/metaData/getImagePixelModule.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/imageLoader/wadouri/metaData/</a> getImagePixelModule.js </h1> <div class='clearfix'> <div class='fl pad1y space-right2'> <span class="strong">26.32% </span> <span class="quiet">Statements</span> <span class='fraction'>10/38</span> </div> <div class='fl pad1y space-right2'> <span class="strong">22.22% </span> <span class="quiet">Branches</span> <span class='fraction'>4/18</span> </div> <div class='fl pad1y space-right2'> <span class="strong">40% </span> <span class="quiet">Functions</span> <span class='fraction'>2/5</span> </div> <div class='fl pad1y space-right2'> <span class="strong">26.32% </span> <span class="quiet">Lines</span> <span class='fraction'>10/38</span> </div> </div> </div> <div class='status-line low'></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 87 88 89 90 91 92 93 94 95 96 97 98 99</td><td class="line-coverage quiet"><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-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-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-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-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-no">&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-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&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-no">&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-no">&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-neutral">&nbsp;</span> <span class="cline-any cline-no">&nbsp;</span> <span class="cline-any cline-no">&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-neutral">&nbsp;</span> <span class="cline-any cline-no">&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-neutral">&nbsp;</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">18×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">18×</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">16×</span> <span class="cline-any cline-yes">16×</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">18×</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">18×</span> <span class="cline-any cline-neutral">&nbsp;</span> <span class="cline-any cline-yes">18×</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-yes">18×</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">function getLutDescriptor (dataSet, tag) <span class="fstat-no" title="function not covered" >{</span> <span class="cstat-no" title="statement not covered" > if (!dataSet.elements[tag] || dataSet.elements[tag].length !== 6) {</span> <span class="cstat-no" title="statement not covered" > return;</span> } &nbsp; <span class="cstat-no" title="statement not covered" > return [dataSet.uint16(tag, 0), dataSet.uint16(tag, 1), dataSet.uint16(tag, 2)];</span> } &nbsp; function getLutData (lutDataSet, tag, lutDescriptor) <span class="fstat-no" title="function not covered" >{</span> const lut = <span class="cstat-no" title="statement not covered" >[];</span> const lutData = <span class="cstat-no" title="statement not covered" >lutDataSet.elements[tag];</span> &nbsp; <span class="cstat-no" title="statement not covered" > for (let i = 0; i &lt; lutDescriptor[0]; i++) {</span> // Output range is always unsigned <span class="cstat-no" title="statement not covered" > if (lutDescriptor[2] === 16) {</span> <span class="cstat-no" title="statement not covered" > lut[i] = lutDataSet.uint16(tag, i);</span> } else { <span class="cstat-no" title="statement not covered" > lut[i] = lutDataSet.byteArray[i + lutData.dataOffset];</span> } } &nbsp; <span class="cstat-no" title="statement not covered" > return lut;</span> } &nbsp; function populatePaletteColorLut (dataSet, imagePixelModule) <span class="fstat-no" title="function not covered" >{</span> <span class="cstat-no" title="statement not covered" > imagePixelModule.redPaletteColorLookupTableDescriptor = getLutDescriptor(dataSet, 'x00281101');</span> <span class="cstat-no" title="statement not covered" > imagePixelModule.greenPaletteColorLookupTableDescriptor = getLutDescriptor(dataSet, 'x00281102');</span> <span class="cstat-no" title="statement not covered" > imagePixelModule.bluePaletteColorLookupTableDescriptor = getLutDescriptor(dataSet, 'x00281103');</span> &nbsp; // The first Palette Color Lookup Table Descriptor value is the number of entries in the lookup table. // When the number of table entries is equal to 2ˆ16 then this value shall be 0. // See http://dicom.nema.org/MEDICAL/DICOM/current/output/chtml/part03/sect_C.7.6.3.html#sect_C.7.6.3.1.5 <span class="cstat-no" title="statement not covered" > if (imagePixelModule.redPaletteColorLookupTableDescriptor[0] === 0) {</span> <span class="cstat-no" title="statement not covered" > imagePixelModule.redPaletteColorLookupTableDescriptor[0] = 65536;</span> <span class="cstat-no" title="statement not covered" > imagePixelModule.greenPaletteColorLookupTableDescriptor[0] = 65536;</span> <span class="cstat-no" title="statement not covered" > imagePixelModule.bluePaletteColorLookupTableDescriptor[0] = 65536;</span> } &nbsp; // The third Palette Color Lookup Table Descriptor value specifies the number of bits for each entry in the Lookup Table Data. // It shall take the value of 8 or 16. // The LUT Data shall be stored in a format equivalent to 8 bits allocated when the number of bits for each entry is 8, and 16 bits allocated when the number of bits for each entry is 16, where in both cases the high bit is equal to bits allocated-1. // The third value shall be identical for each of the Red, Green and Blue Palette Color Lookup Table Descriptors. // // Note: Some implementations have encoded 8 bit entries with 16 bits allocated, padding the high bits; // this can be detected by comparing the number of entries specified in the LUT Descriptor with the actual value length of the LUT Data entry. // The value length in bytes should equal the number of entries if bits allocated is 8, and be twice as long if bits allocated is 16. const numLutEntries = <span class="cstat-no" title="statement not covered" >imagePixelModule.redPaletteColorLookupTableDescriptor[0];</span> const lutData = <span class="cstat-no" title="statement not covered" >dataSet.elements.x00281201;</span> const lutBitsAllocated = <span class="cstat-no" title="statement not covered" >lutData.length === numLutEntries ? 8 : 16;</span> &nbsp; // If the descriptors do not appear to have the correct values, correct them <span class="cstat-no" title="statement not covered" > if (imagePixelModule.redPaletteColorLookupTableDescriptor[2] !== lutBitsAllocated) {</span> <span class="cstat-no" title="statement not covered" > imagePixelModule.redPaletteColorLookupTableDescriptor[2] = lutBitsAllocated;</span> <span class="cstat-no" title="statement not covered" > imagePixelModule.greenPaletteColorLookupTableDescriptor[2] = lutBitsAllocated;</span> <span class="cstat-no" title="statement not covered" > imagePixelModule.bluePaletteColorLookupTableDescriptor[2] = lutBitsAllocated;</span> } &nbsp; <span class="cstat-no" title="statement not covered" > imagePixelModule.redPaletteColorLookupTableData = getLutData(dataSet, 'x00281201', imagePixelModule.redPaletteColorLookupTableDescriptor);</span> <span class="cstat-no" title="statement not covered" > imagePixelModule.greenPaletteColorLookupTableData = getLutData(dataSet, 'x00281202', imagePixelModule.greenPaletteColorLookupTableDescriptor);</span> <span class="cstat-no" title="statement not covered" > imagePixelModule.bluePaletteColorLookupTableData = getLutData(dataSet, 'x00281203', imagePixelModule.bluePaletteColorLookupTableDescriptor);</span> } &nbsp; function populateSmallestLargestPixelValues (dataSet, imagePixelModule) { const pixelRepresentation = dataSet.uint16('x00280103'); &nbsp; if (pixelRepresentation === 0) { imagePixelModule.smallestPixelValue = dataSet.uint16('x00280106'); imagePixelModule.largestPixelValue = dataSet.uint16('x00280107'); } else { imagePixelModule.smallestPixelValue = dataSet.int16('x00280106'); imagePixelModule.largestPixelValue = dataSet.int16('x00280107'); } } &nbsp; function getImagePixelModule (dataSet) { const imagePixelModule = { samplesPerPixel: dataSet.uint16('x00280002'), photometricInterpretation: dataSet.string('x00280004'), rows: dataSet.uint16('x00280010'), columns: dataSet.uint16('x00280011'), bitsAllocated: dataSet.uint16('x00280100'), bitsStored: dataSet.uint16('x00280101'), highBit: dataSet.uint16('x00280102'), pixelRepresentation: dataSet.uint16('x00280103'), planarConfiguration: dataSet.uint16('x00280006'), pixelAspectRatio: dataSet.string('x00280034') }; &nbsp; populateSmallestLargestPixelValues(dataSet, imagePixelModule); &nbsp; <span class="missing-if-branch" title="if path not taken" >I</span>if (imagePixelModule.photometricInterpretation === 'PALETTE COLOR' &amp;&amp; <span class="branch-1 cbranch-no" title="branch not covered" >dataSet.elements.x00281101)</span> { <span class="cstat-no" title="statement not covered" > populatePaletteColorLut(dataSet, imagePixelModule);</span> } &nbsp; return imagePixelModule; } &nbsp; export default getImagePixelModule; &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>