diff options
-rw-r--r-- | engines/sword1/screen.cpp | 14 | ||||
-rw-r--r-- | engines/sword1/screen.h | 1 |
2 files changed, 10 insertions, 5 deletions
diff --git a/engines/sword1/screen.cpp b/engines/sword1/screen.cpp index d7498ade31..3f4938fe99 100644 --- a/engines/sword1/screen.cpp +++ b/engines/sword1/screen.cpp @@ -55,6 +55,7 @@ Screen::Screen(OSystem *system, ResMan *pResMan, ObjectMan *pObjMan) { _backLength = _foreLength = _sortLength = 0; _fadingStep = 0; _currentScreen = 0xFFFF; + _updatePalette = false; } Screen::~Screen(void) { @@ -169,7 +170,7 @@ bool Screen::stillFading(void) { } bool Screen::showScrollFrame(void) { - if ((!_fullRefresh) || Logic::_scriptVars[NEW_PALETTE]) + if ((!_fullRefresh) || Logic::_scriptVars[NEW_PALETTE] || _updatePalette) return false; // don't draw an additional frame if we aren't scrolling or have to change the palette if ((_oldScrollX == Logic::_scriptVars[SCROLL_OFFSET_X]) && (_oldScrollY == Logic::_scriptVars[SCROLL_OFFSET_Y])) @@ -187,10 +188,14 @@ void Screen::updateScreen(void) { if (Logic::_scriptVars[NEW_PALETTE]) { _fadingStep = 1; _fadingDirection = FADE_UP; - fnSetPalette(0, 184, _roomDefTable[_currentScreen].palettes[0], true); - fnSetPalette(184, 72, _roomDefTable[_currentScreen].palettes[1], true); + _updatePalette = true; Logic::_scriptVars[NEW_PALETTE] = 0; } + if (_updatePalette) { + fnSetPalette(0, 184, _roomDefTable[_currentScreen].palettes[0], false); + fnSetPalette(184, 72, _roomDefTable[_currentScreen].palettes[1], false); + _updatePalette = false; + } if (_fadingStep) { fadePalette(); _system->setPalette(_currentPalette, 0, 256); @@ -336,8 +341,7 @@ void Screen::newScreen(uint32 screen) { if (_roomDefTable[_currentScreen].parallax[1]) _parallax[1] = (uint8*)_resMan->openFetchRes(_roomDefTable[_currentScreen].parallax[1]); - fnSetPalette(0, 184, _roomDefTable[_currentScreen].palettes[0], SwordEngine::_systemVars.wantFade); - fnSetPalette(184, 72, _roomDefTable[_currentScreen].palettes[1], SwordEngine::_systemVars.wantFade); + _updatePalette = true; _fullRefresh = true; } diff --git a/engines/sword1/screen.h b/engines/sword1/screen.h index f9cf9b7179..b115408120 100644 --- a/engines/sword1/screen.h +++ b/engines/sword1/screen.h @@ -137,6 +137,7 @@ private: uint8 _rleBuffer[RLE_BUFFER_SIZE]; uint8 _shrinkBuffer[SHRINK_BUFFER_SIZE]; bool _fullRefresh; + bool _updatePalette; uint16 _oldScrollX, _oldScrollY; // for drawing additional frames uint32 _foreList[MAX_FORE]; |