diff options
Diffstat (limited to 'engines')
-rw-r--r-- | engines/mads/interface.cpp | 4 | ||||
-rw-r--r-- | engines/mads/palette.cpp | 85 | ||||
-rw-r--r-- | engines/mads/palette.h | 4 |
3 files changed, 68 insertions, 25 deletions
diff --git a/engines/mads/interface.cpp b/engines/mads/interface.cpp index cd2f162cf3..68e2341ccc 100644 --- a/engines/mads/interface.cpp +++ b/engines/mads/interface.cpp @@ -49,14 +49,14 @@ void InterfaceSurface::load(const Common::String &resName) { // Load in the palette Common::SeekableReadStream *palStream = madsPack.getItemStream(0); - RGB4 *gamePalP = &_vm->_palette->_gamePalette[0]; + uint32 *gamePalP = &_vm->_palette->_gamePalette[0]; byte *palP = &_vm->_palette->_mainPalette[0]; for (int i = 0; i < 16; ++i, gamePalP++, palP += 3) { palP[0] = palStream->readByte(); palP[1] = palStream->readByte(); palP[2] = palStream->readByte(); - gamePalP->r |= 1; + *gamePalP |= 1; palStream->skip(3); } delete palStream; diff --git a/engines/mads/palette.cpp b/engines/mads/palette.cpp index da59707a91..1303ea264a 100644 --- a/engines/mads/palette.cpp +++ b/engines/mads/palette.cpp @@ -78,7 +78,7 @@ void PaletteUsage::prioritize(Common::Array<RGB6> &palette) { } int PaletteUsage::process(Common::Array<RGB6> &palette, int v) { - byte *palette1 = nullptr, *palette2 = nullptr; + byte *pal1 = nullptr, *pal2 = nullptr; int palLow; int palHigh = (v & 0x800) ? 0x100 : 0xC; int palIdx; @@ -117,8 +117,8 @@ int PaletteUsage::process(Common::Array<RGB6> &palette, int v) { int freeIndex; int palCount = getGamePalFreeIndex(&freeIndex); - byte *pal1 = new byte[PALETTE_COUNT]; - byte *pal2 = new byte[PALETTE_COUNT]; + pal1 = new byte[PALETTE_COUNT]; + pal2 = new byte[PALETTE_COUNT]; for (uint palIndex = 0; palIndex < palette.size(); ++palIndex) { pal2[palIndex] = palIndex; @@ -180,10 +180,52 @@ int PaletteUsage::process(Common::Array<RGB6> &palette, int v) { int var36 = (palette[palIndex]._flags & 0x80) ? 0 : 2; for (int idx = palLow; idx < palIdx; ++idx) { - // TODO + uint32 v = _vm->_palette->_gamePalette[idx]; + if ((v & var3A) && !(v & var36)) { + int var10; + + if (var2 > 1) { + var10 = rgbFactor(&_vm->_palette->_mainPalette[idx * 3], palette[palIndex]); + } + else if (_vm->_palette->_mainPalette[idx * 3] != palette[palIndex].r || + _vm->_palette->_mainPalette[idx * 3 + 1] != palette[palIndex].g || + _vm->_palette->_mainPalette[idx * 3 + 2] != palette[palIndex].b) { + var10 = 1; + } else { + var10 = 0; + } + + if (var2 > var10) { + var48 = true; + var2 = idx; + var2 = var10; + } + } } } - //TODO + + if (!var48 && (!(v & 0x1000) || (!(palette[palIndex]._flags & 0x60) && !(v & 0x2000)))) { + for (int idx = freeIndex; idx < palIdx && !var48; ++idx) { + if (!_vm->_palette->_gamePalette[idx]) { + --palCount; + ++freeIndex; + var48 = true; + var4 = idx; + + RGB6 &pSrc = palette[palIndex]; + byte *pDest = &_vm->_palette->_mainPalette[idx * 3]; + pDest[0] = pSrc.r; + pDest[1] = pSrc.g; + pDest[2] = pSrc.b; + } + } + } + + assert(var48); + int var52 = (varA && palette[palIndex]._u2) ? 2 : 0; + + _vm->_palette->_gamePalette[var4] |= var52 | rgbMask; + palette[palIndex]._palIndex = var4; } _vm->_palette->_rgbList[rgbIndex] = 0xffff; @@ -266,8 +308,7 @@ int PaletteUsage::getGamePalFreeIndex(int *palIndex) { int count = 0; for (int i = 0; i < PALETTE_COUNT; ++i) { - RGB4 &r = _vm->_palette->_gamePalette[i]; - if (!(r.r | r.g | r.b | r.u)) { + if (!_vm->_palette->_gamePalette[i]) { ++count; if (*palIndex < 0) *palIndex = i; @@ -277,6 +318,15 @@ int PaletteUsage::getGamePalFreeIndex(int *palIndex) { return count; } +int PaletteUsage::rgbFactor(byte *palEntry, RGB6 &pal6) { + int total = 0; + total += (palEntry[0] - pal6.r) * (palEntry[0] - pal6.r); + total += (palEntry[1] - pal6.g) * (palEntry[1] - pal6.g); + total += (palEntry[2] - pal6.b) * (palEntry[2] - pal6.b); + + return total; +} + /*------------------------------------------------------------------------*/ void RGBList::clear() { @@ -474,16 +524,14 @@ void Palette::resetGamePalette(int lowRange, int highRange) { // Init low range to common RGB values if (lowRange) { - _gamePalette[0].r = 1; - _gamePalette[0].b = 0; + _gamePalette[0] = 1; Common::fill(&_gamePalette[1], &_gamePalette[lowRange - 1], _gamePalette[0]); } // Init high range to common RGB values if (highRange) { - _gamePalette[255].r = 1; - _gamePalette[255].b = 0; + _gamePalette[255] = 1; Common::fill(&_gamePalette[255 - highRange], &_gamePalette[254], _gamePalette[255]); } @@ -496,7 +544,7 @@ void Palette::resetGamePalette(int lowRange, int highRange) { void Palette::initGamePalette() { RGB4 rgb; - rgb.r = 1; + uint32 palMask = 1; if (_vm->_game->_player._spritesLoaded && _vm->_game->_player._numSprites) { @@ -508,19 +556,12 @@ void Palette::initGamePalette() { if (asset->_field6) mask <<= asset->_field6; - rgb.r = mask & 0xff; - rgb.g = (mask >> 8) & 0xff; - rgb.b = (mask >> 16) & 0xff; - rgb.u = (mask >> 24) & 0xff; + palMask = mask; } } - for (int idx = 0; idx < PALETTE_COUNT; ++idx) { - _gamePalette[idx].r &= rgb.r; - _gamePalette[idx].g &= rgb.g; - _gamePalette[idx].b &= rgb.b; - _gamePalette[idx].u &= rgb.u; - } + for (int idx = 0; idx < PALETTE_COUNT; ++idx) + _gamePalette[idx] = palMask; _v1 = 0; _rgbList.reset(); diff --git a/engines/mads/palette.h b/engines/mads/palette.h index 83e406a229..a7c3285aa3 100644 --- a/engines/mads/palette.h +++ b/engines/mads/palette.h @@ -62,6 +62,8 @@ private: void prioritizeFromList(int lst[3]); int getGamePalFreeIndex(int *palIndex); + + int rgbFactor(byte *palEntry, RGB6 &pal6); public: /** * Constructor @@ -128,7 +130,7 @@ protected: public: byte _mainPalette[PALETTE_SIZE]; byte _savedPalette[PALETTE_SIZE]; - RGB4 _gamePalette[PALETTE_COUNT]; + uint32 _gamePalette[PALETTE_COUNT]; PaletteUsage _paletteUsage; RGBList _rgbList; int _v1; |