<html dir="ltr">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<style id="owaParaStyle" type="text/css">
<!--
p
        {margin-top:0;
        margin-bottom:0}
-->
P {margin-top:0;margin-bottom:0;}</style>
</head>
<body ocsi="0" fpstyle="1">
<div style="direction: ltr;font-family: Tahoma;color: #000000;font-size: 10pt;">After an afternoon of work - I am able to get the Actual Bits per pixel by getting the metadata, and doing a bunch of string parsing. This is not really that ideal either, so I
 am still open to suggestions if there is a cleaner way of doing it via the API that I just havent stumbled upon.<br>
<br>
Derek<br>
<div style="font-family: Times New Roman; color: rgb(0, 0, 0); font-size: 16px;">
<hr tabindex="-1">
<div style="direction: ltr;" id="divRpF10231"><font color="#000000" face="Tahoma" size="2"><b>From:</b> gdal-dev-bounces@lists.osgeo.org [gdal-dev-bounces@lists.osgeo.org] on behalf of Cole, Derek [dcole@integrity-apps.com]<br>
<b>Sent:</b> Friday, June 10, 2011 4:15 PM<br>
<b>To:</b> gdal-dev@lists.osgeo.org<br>
<b>Subject:</b> [gdal-dev] Finding Actual Bits Per pixel<br>
</font><br>
</div>
<div></div>
<div>
<div style="direction: ltr; font-family: Tahoma; color: rgb(0, 0, 0); font-size: 10pt;">
&nbsp;&nbsp; Similar to another ongoing thread, I am needing to convert imagery to 8 bit to display in my own viewer.
<br>
<br>
This has presented me with a few issues. It seems like no matter what of the GDALDataTypes I perform a sizeof() operation on, be it GDT_Byte or GDT_Float32, the size is always 4 bytes.
<br>
<br>
I am trying to use RasterIO presently to display image. As it turns out, if i run a gdalinfo on the image, i see that it uses uint16 as the Type, but only uses 11 bits per pixel actually!
<br>
<br>
Since the data types all had a sizeof() = 4, I allocated a float, and I have been reading the data like so<br>
<br>
&nbsp;&nbsp;&nbsp; float * floatData = (float *) CPLMalloc(sizeof(float)*nXSize*nYSize);<br>
<br>
&nbsp;&nbsp;&nbsp; poBand-&gt;RasterIO( GF_Read, 0, 0, nXSize, nYSize, floatData, nXSize, nYSize,GDT_Float32, 0, 0 );<br>
<br>
This seems to be working presently at getting the data, however, I have to use a scaling function like so:<br>
<br>
&nbsp;&nbsp;&nbsp; float two_eight =&nbsp; pow(2.0,8);<br>
&nbsp;&nbsp;&nbsp; float two_eleven = pow(2.0,11);<br>
&nbsp;&nbsp;&nbsp; for (int i = 0 ; i &lt; imheight ; i&#43;&#43;)<br>
&nbsp;&nbsp;&nbsp; {<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; for (int j = 0 ; j &lt; imwidth ; j&#43;&#43;)<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; {<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; floatData[i*imwidth&#43;j] = (two_eight* floatData[i*imwidth&#43;j])/two_eleven;<br>
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }<br>
&nbsp;&nbsp;&nbsp;&nbsp; }<br>
<br>
Which is obviously not ideal, especially when you consider I still have to cast this to unsigned char to be displayed.<br>
<br>
My question is - is there a better way to have this conversion done for me? I tried to allocated my data as unsigned char, and read in a GDT_Byte, but the image looked bad. If I continue with this way, is there a way to dynamically figure out the actual bits
 per pixel from the band? It is not clear to me from the API how this was performed, as it seems like it is buried in the nitf image format code in the example application.<br>
<br>
Thanks<br>
<br>
</div>
</div>
</div>
</div>
</body>
</html>