mirror of
https://port.numenaute.org/aleajactaest/khanat-opennel-code.git
synced 2024-11-17 13:01:42 +00:00
Changed: Added helpers methods to CBitmap
--HG-- branch : develop
This commit is contained in:
parent
27a2263bd6
commit
437aa5b939
2 changed files with 170 additions and 0 deletions
|
@ -348,6 +348,27 @@ public:
|
||||||
*/
|
*/
|
||||||
void makeNonPowerOf2Dummy();
|
void makeNonPowerOf2Dummy();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Make a bitmap fully opaque (set alpha to 255).
|
||||||
|
*/
|
||||||
|
void makeOpaque();
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return if the bitmap has uniform alpha values for all pixels.
|
||||||
|
* \param alpha return the uniform value if return is true
|
||||||
|
* \return uniform or not
|
||||||
|
*/
|
||||||
|
bool isAlphaUniform(uint8 *alpha = NULL) const;
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return if the bitmap is a real grayscale.
|
||||||
|
* \return grayscale or not
|
||||||
|
*/
|
||||||
|
bool isGrayscale() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Return the pixels buffer of the image, or of one of its mipmap.
|
* Return the pixels buffer of the image, or of one of its mipmap.
|
||||||
* Return a reference of an array in pixel format get with getPixelFormat().
|
* Return a reference of an array in pixel format get with getPixelFormat().
|
||||||
|
|
|
@ -309,6 +309,155 @@ void CBitmap::makeDummyFromBitField(const uint8 bitmap[1024])
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*-------------------------------------------------------------------*\
|
||||||
|
makeOpaque
|
||||||
|
\*-------------------------------------------------------------------*/
|
||||||
|
void CBitmap::makeOpaque()
|
||||||
|
{
|
||||||
|
if (_Width*_Height == 0) return;
|
||||||
|
|
||||||
|
uint pixelSize;
|
||||||
|
|
||||||
|
switch(PixelFormat)
|
||||||
|
{
|
||||||
|
case RGBA: pixelSize = 4; break;
|
||||||
|
case AlphaLuminance: pixelSize = 2; break;
|
||||||
|
case Alpha: pixelSize = 1; break;
|
||||||
|
default: return;
|
||||||
|
}
|
||||||
|
|
||||||
|
for(uint8 m = 0; m < _MipMapCount; ++m)
|
||||||
|
{
|
||||||
|
// get a pointer on original data
|
||||||
|
uint8 *data = _Data[m].getPtr();
|
||||||
|
|
||||||
|
// special case for only alpha values
|
||||||
|
if (pixelSize == 1)
|
||||||
|
{
|
||||||
|
memset(data, 255, _Data[m].size());
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// end of data
|
||||||
|
uint8 *endData = data + _Data[m].size();
|
||||||
|
|
||||||
|
// first alpha
|
||||||
|
data += pixelSize - 1;
|
||||||
|
|
||||||
|
// replace all alpha values by 255
|
||||||
|
while(data < endData)
|
||||||
|
{
|
||||||
|
*data = 255;
|
||||||
|
data += pixelSize;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*-------------------------------------------------------------------*\
|
||||||
|
isAlphaUniform
|
||||||
|
\*-------------------------------------------------------------------*/
|
||||||
|
bool CBitmap::isAlphaUniform(uint8 *alpha) const
|
||||||
|
{
|
||||||
|
uint32 size = _Data[0].size();
|
||||||
|
|
||||||
|
if (size == 0) return false;
|
||||||
|
|
||||||
|
uint pixelSize;
|
||||||
|
|
||||||
|
switch(PixelFormat)
|
||||||
|
{
|
||||||
|
// formats with alpha channel
|
||||||
|
case RGBA:
|
||||||
|
pixelSize = 4;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case AlphaLuminance:
|
||||||
|
pixelSize = 2;
|
||||||
|
break;
|
||||||
|
|
||||||
|
case Alpha:
|
||||||
|
pixelSize = 1;
|
||||||
|
break;
|
||||||
|
|
||||||
|
// formats without alpha channel
|
||||||
|
case Luminance:
|
||||||
|
if (alpha) *alpha = 255;
|
||||||
|
return true;
|
||||||
|
|
||||||
|
default:
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
// get a pointer on original data
|
||||||
|
uint8 *data = (uint8*)_Data[0].getPtr();
|
||||||
|
uint8 *endData = data + size;
|
||||||
|
|
||||||
|
// first alpha
|
||||||
|
data += pixelSize - 1;
|
||||||
|
|
||||||
|
// first alpha value
|
||||||
|
uint8 value = *data;
|
||||||
|
|
||||||
|
// check if all alphas have the same value
|
||||||
|
while(data < endData && *data == value) data += pixelSize;
|
||||||
|
|
||||||
|
// texture can be converted if all alphas are 0 or 255
|
||||||
|
if (data >= endData)
|
||||||
|
{
|
||||||
|
// return the uniform value
|
||||||
|
if (alpha) *alpha = value;
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*-------------------------------------------------------------------*\
|
||||||
|
isGrayscale
|
||||||
|
\*-------------------------------------------------------------------*/
|
||||||
|
bool CBitmap::isGrayscale() const
|
||||||
|
{
|
||||||
|
// all grayscale formats or, al least, without color information
|
||||||
|
switch(PixelFormat)
|
||||||
|
{
|
||||||
|
case Luminance:
|
||||||
|
case AlphaLuminance:
|
||||||
|
case Alpha:
|
||||||
|
return true;
|
||||||
|
|
||||||
|
case RGBA:
|
||||||
|
break;
|
||||||
|
|
||||||
|
default:
|
||||||
|
// DXTC formats won't be managed at the moment
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
uint32 size = _Data[0].size();
|
||||||
|
if (size == 0) return false;
|
||||||
|
|
||||||
|
// get a pointer on original data
|
||||||
|
uint32 *data = (uint32*)_Data[0].getPtr();
|
||||||
|
uint32 *endData = (uint32*)((uint8*)data + size);
|
||||||
|
|
||||||
|
NLMISC::CRGBA color;
|
||||||
|
|
||||||
|
// check if all alphas have the same value
|
||||||
|
while(data < endData)
|
||||||
|
{
|
||||||
|
color.set8888(*data);
|
||||||
|
|
||||||
|
if (!color.isGray()) return false;
|
||||||
|
|
||||||
|
++data;
|
||||||
|
}
|
||||||
|
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue