* Introduced PaletteConverter::IndexForRGBA32() which checks if the alpha
component of a 32 bit color is below 128 and returns the special CMAP8 index for indicating transparency. * Changed the WriteCMAP() color conversion function to expext a 32bit RGBA value and use IndexForRGBA32(). * Adapted B_CMAP8 target color space case of ConvertBits() to the new semantics. This allows transparency in bitmaps when converting B_RGBA32 bitmaps to B_CMAP8, tested only for this case and working as expected. git-svn-id: file:///srv/svn/repos/haiku/haiku/trunk@36549 a95241bf-73f2-0310-859d-f6bbb57e9c96
This commit is contained in:
parent
8cd3dac13e
commit
59d0c2e45e
@ -38,6 +38,7 @@ public:
|
|||||||
inline uint8 IndexForRGB16(uint8 red, uint8 green, uint8 blue) const;
|
inline uint8 IndexForRGB16(uint8 red, uint8 green, uint8 blue) const;
|
||||||
inline uint8 IndexForRGB24(uint32 rgb) const;
|
inline uint8 IndexForRGB24(uint32 rgb) const;
|
||||||
inline uint8 IndexForRGB24(uint8 red, uint8 green, uint8 blue) const;
|
inline uint8 IndexForRGB24(uint8 red, uint8 green, uint8 blue) const;
|
||||||
|
inline uint8 IndexForRGBA32(uint32 rgba) const;
|
||||||
inline uint8 IndexForGray(uint8 gray) const;
|
inline uint8 IndexForGray(uint8 gray) const;
|
||||||
|
|
||||||
inline const rgb_color &RGBColorForIndex(uint8 index) const;
|
inline const rgb_color &RGBColorForIndex(uint8 index) const;
|
||||||
|
@ -308,6 +308,23 @@ PaletteConverter::IndexForRGB24(uint8 red, uint8 green, uint8 blue) const
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/*! \brief Returns the palette color index closest to a given RGBA 32 color.
|
||||||
|
|
||||||
|
The object must be properly initialized.
|
||||||
|
|
||||||
|
\param rgb The RGB 32A color value (R[31:24]G[23:16]B[15:8]A[7:0]).
|
||||||
|
\return The palette color index for the supplied color.
|
||||||
|
*/
|
||||||
|
inline
|
||||||
|
uint8
|
||||||
|
PaletteConverter::IndexForRGBA32(uint32 rgba) const
|
||||||
|
{
|
||||||
|
if ((rgba & 0x000000ff) < 128)
|
||||||
|
return B_TRANSPARENT_MAGIC_CMAP8;
|
||||||
|
return IndexForRGB24(rgba);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/*! \brief Returns the palette color index closest to a given Gray 8 color.
|
/*! \brief Returns the palette color index closest to a given Gray 8 color.
|
||||||
|
|
||||||
The object must be properly initialized.
|
The object must be properly initialized.
|
||||||
@ -539,7 +556,7 @@ ReadGray1(const uint8 **source, int32 index)
|
|||||||
void
|
void
|
||||||
WriteCMAP8(uint8 **dest, uint8 *data, int32 index)
|
WriteCMAP8(uint8 **dest, uint8 *data, int32 index)
|
||||||
{
|
{
|
||||||
**dest = sPaletteConverter.IndexForRGB15(*(uint16 *)data);
|
**dest = sPaletteConverter.IndexForRGBA32(*(uint32 *)data);
|
||||||
(*dest)++;
|
(*dest)++;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -836,11 +853,11 @@ ConvertBits(const srcByte *srcBits, void *dstBits, int32 srcBitsLength,
|
|||||||
case B_CMAP8:
|
case B_CMAP8:
|
||||||
PaletteConverter::InitializeDefault();
|
PaletteConverter::InitializeDefault();
|
||||||
ConvertBits(srcBits, (uint8 *)dstBits, srcBitsLength,
|
ConvertBits(srcBits, (uint8 *)dstBits, srcBitsLength,
|
||||||
dstBitsLength, redShift - 15, greenShift - 10, blueShift - 5,
|
dstBitsLength, redShift - 32, greenShift - 24, blueShift - 16,
|
||||||
0, 0, 0x7c00, 0x03e0, 0x001f, 0x0000, srcBytesPerRow,
|
alphaShift - 8, alphaBits, 0xff000000, 0x00ff0000, 0x0000ff00,
|
||||||
dstBytesPerRow, srcBitsPerPixel, 8, srcColorSpace,
|
0x000000ff, srcBytesPerRow, dstBytesPerRow, srcBitsPerPixel, 8,
|
||||||
dstColorSpace, srcOffset, dstOffset, width, height, srcSwap,
|
srcColorSpace, dstColorSpace, srcOffset, dstOffset,
|
||||||
false, srcFunc, WriteCMAP8);
|
width, height, srcSwap, false, srcFunc, WriteCMAP8);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
default:
|
default:
|
||||||
|
Loading…
Reference in New Issue
Block a user