diff options
author | Florian Kagerer | 2009-05-10 23:53:05 +0000 |
---|---|---|
committer | Florian Kagerer | 2009-05-10 23:53:05 +0000 |
commit | 3d13c3ea36b36c9e0b84b0f741675d390066d98d (patch) | |
tree | e2bbbcabab741b3848ab6b4986d8f263de2d0da0 | |
parent | 670eb3badf94470283225462e30aa129208cb359 (diff) | |
download | scummvm-rg350-3d13c3ea36b36c9e0b84b0f741675d390066d98d.tar.gz scummvm-rg350-3d13c3ea36b36c9e0b84b0f741675d390066d98d.tar.bz2 scummvm-rg350-3d13c3ea36b36c9e0b84b0f741675d390066d98d.zip |
LOL: - fix last commit
svn-id: r40443
-rw-r--r-- | engines/kyra/gui_lol.cpp | 80 |
1 files changed, 41 insertions, 39 deletions
diff --git a/engines/kyra/gui_lol.cpp b/engines/kyra/gui_lol.cpp index 9a1b7673ee..dbf0fe16b0 100644 --- a/engines/kyra/gui_lol.cpp +++ b/engines/kyra/gui_lol.cpp @@ -747,9 +747,9 @@ void LoLEngine::gui_triggerEvent(int eventType) { evt.mouse.x = _mouseX; evt.mouse.y = _mouseY; - if (eventType == 65) { + if (eventType == 65 || eventType == 199) { evt.type = Common::EVENT_LBUTTONDOWN; - } else if (eventType == 66) { + } else if (eventType == 66 || eventType == 201) { evt.type = Common::EVENT_RBUTTONDOWN; } else { evt.type = Common::EVENT_KEYDOWN; @@ -1617,49 +1617,51 @@ int LoLEngine::clickedRestParty(Button *button) { int f = checkInput(0); removeInputTop(); - if (f & !(f & 0x800)) { - gui_triggerEvent(f); - } else { + if (f & 0x800) { gui_notifyButtonListChanged(); - - if (!_partyAwake) { - if (_system->getMillis() > delay3) { - for (int i = 0; i < 4; i++) { - if (!(needPoisoningFlags & (1 << i))) - continue; - inflictDamage(i, 1, 0x8000, 1, 0x80); - if (_characters[i].flags & 8) - needPoisoningFlags &= ~(1 << i); - } - delay3 = _system->getMillis() + a * _tickLength; + } else if (f) { + gui_triggerEvent(f); + break; + } + + if (!_partyAwake) { + if (_system->getMillis() > delay3) { + for (int i = 0; i < 4; i++) { + if (!(needPoisoningFlags & (1 << i))) + continue; + inflictDamage(i, 1, 0x8000, 1, 0x80); + if (_characters[i].flags & 8) + needPoisoningFlags &= ~(1 << i); } + delay3 = _system->getMillis() + a * _tickLength; + } - if (_system->getMillis() > delay1) { - for (int i = 0; i < 4; i++) { - if (!(needHealingFlags & (1 << i))) - continue; - increaseCharacterHitpoints(i, 1, false); - gui_drawCharPortraitWithStats(i); - if (_characters[i].hitPointsCur == _characters[i].hitPointsMax) - needHealingFlags &= ~(1 << i); - } - delay1 = _system->getMillis() + h * _tickLength; - } + if (_system->getMillis() > delay1) { + for (int i = 0; i < 4; i++) { + if (!(needHealingFlags & (1 << i))) + continue; + increaseCharacterHitpoints(i, 1, false); + gui_drawCharPortraitWithStats(i); + if (_characters[i].hitPointsCur == _characters[i].hitPointsMax) + needHealingFlags &= ~(1 << i); + } + delay1 = _system->getMillis() + h * _tickLength; + } - if (_system->getMillis() > delay2) { - for (int i = 0; i < 4; i++) { - if (!(needMagicGainFlags & (1 << i))) - continue; - _characters[i].magicPointsCur++; - gui_drawCharPortraitWithStats(i); - if (_characters[i].magicPointsCur == _characters[i].magicPointsMax) - needMagicGainFlags &= ~(1 << i); - } - delay2 = _system->getMillis() + m * _tickLength; - } - _screen->updateScreen(); + if (_system->getMillis() > delay2) { + for (int i = 0; i < 4; i++) { + if (!(needMagicGainFlags & (1 << i))) + continue; + _characters[i].magicPointsCur++; + gui_drawCharPortraitWithStats(i); + if (_characters[i].magicPointsCur == _characters[i].magicPointsMax) + needMagicGainFlags &= ~(1 << i); + } + delay2 = _system->getMillis() + m * _tickLength; } + _screen->updateScreen(); } + } while (!_partyAwake && (needHealingFlags || needMagicGainFlags)); for (int i = 0; i < 4; i++) { |