mirror of
https://github.com/isledecomp/isle.git
synced 2024-11-26 17:46:38 -05:00
Fix/match MxBitmap::SetBitDepth
This commit is contained in:
parent
77755570f2
commit
a25bcecf47
1 changed files with 27 additions and 22 deletions
|
@ -296,8 +296,9 @@ MxResult MxBitmap::SetBitDepth(MxBool p_isHighColor)
|
|||
if (m_isHighColor == p_isHighColor) {
|
||||
// no change: do nothing.
|
||||
ret = SUCCESS;
|
||||
goto done;
|
||||
}
|
||||
else {
|
||||
|
||||
switch (p_isHighColor) {
|
||||
case FALSE:
|
||||
ImportColorsToPalette(m_paletteData, m_palette);
|
||||
|
@ -306,11 +307,13 @@ MxResult MxBitmap::SetBitDepth(MxBool p_isHighColor)
|
|||
|
||||
m_palette = NULL;
|
||||
break;
|
||||
|
||||
case TRUE:
|
||||
case TRUE: {
|
||||
pal = NULL;
|
||||
pal = new MxPalette(m_paletteData);
|
||||
if (pal) {
|
||||
|
||||
if (!pal)
|
||||
goto done;
|
||||
|
||||
m_palette = pal;
|
||||
|
||||
// TODO: what is this? zeroing out top half of palette?
|
||||
|
@ -318,14 +321,16 @@ MxResult MxBitmap::SetBitDepth(MxBool p_isHighColor)
|
|||
for (MxU16 i = 0; i < 256; i++) {
|
||||
buf[i] = i;
|
||||
}
|
||||
break;
|
||||
}
|
||||
default:
|
||||
goto done;
|
||||
}
|
||||
|
||||
m_isHighColor = p_isHighColor;
|
||||
ret = SUCCESS;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
|
||||
done:
|
||||
// If we were unsuccessful overall but did manage to alloc
|
||||
// the MxPalette, free it.
|
||||
if (ret && pal)
|
||||
|
|
Loading…
Reference in a new issue