From a89694c0d61a75a960f5bec6c498659c988401cc Mon Sep 17 00:00:00 2001 From: Filippos Karapetis Date: Wed, 19 Sep 2007 08:27:32 +0000 Subject: [PATCH] Moved some keyboard code from Winnie together with the other keyboard functions svn-id: r28965 --- engines/agi/preagi.h | 2 ++ engines/agi/preagi_common.cpp | 27 +++++++++++++++++++++++++++ engines/agi/preagi_winnie.cpp | 30 ++---------------------------- 3 files changed, 31 insertions(+), 28 deletions(-) diff --git a/engines/agi/preagi.h b/engines/agi/preagi.h index 50c68991c93..7476dde3cf2 100644 --- a/engines/agi/preagi.h +++ b/engines/agi/preagi.h @@ -75,6 +75,8 @@ public: // Keyboard int getSelection(SelectionTypes type); bool waitAnyKeyChoice(); + bool getSelOkBack(); + int rnd(int hi) { return (_rnd->getRandomNumber(hi) + 1); } // Text diff --git a/engines/agi/preagi_common.cpp b/engines/agi/preagi_common.cpp index a1d6883f58b..5e735b896a4 100644 --- a/engines/agi/preagi_common.cpp +++ b/engines/agi/preagi_common.cpp @@ -208,4 +208,31 @@ bool PreAgiEngine::waitAnyKeyChoice() { } } +bool PreAgiEngine::getSelOkBack() { + Common::Event event; + + for (;;) { + while (_eventMan->pollEvent(event)) { + switch (event.type) { + case Common::EVENT_QUIT: + _system->quit(); + break; + case Common::EVENT_LBUTTONUP: + return true; + case Common::EVENT_RBUTTONUP: + return false; + case Common::EVENT_KEYDOWN: + switch (event.kbd.keycode) { + case Common::KEYCODE_BACKSPACE: + return false; + default: + return true; + } + default: + break; + } + } + } +} + } diff --git a/engines/agi/preagi_winnie.cpp b/engines/agi/preagi_winnie.cpp index 28ccec294e0..02682c92f43 100644 --- a/engines/agi/preagi_winnie.cpp +++ b/engines/agi/preagi_winnie.cpp @@ -218,7 +218,7 @@ int Winnie::parser(int pc, int index, uint8 *buffer) { default: // print description _vm->printStrXOR((char *)(buffer + pc)); - if (getSelOkBack()) + if (_vm->getSelOkBack()) return IDI_WTP_PAR_OK; else return IDI_WTP_PAR_BACK; @@ -854,7 +854,7 @@ void Winnie::getMenuSel(char *szMenu, int *iSel, int fCanSel[]) { break; case Common::KEYCODE_s: if (event.kbd.flags & Common::KBD_CTRL) { - //FlipSound(); + _vm->flipflag(fSoundOn); } else { *iSel = IDI_WTP_SEL_SOUTH; makeSel(); @@ -1018,32 +1018,6 @@ void Winnie::drawRoomPic() { delete [] buffer; } -bool Winnie::getSelOkBack() { - Common::Event event; - - for (;;) { - while (_vm->_system->getEventManager()->pollEvent(event)) { - switch (event.type) { - case Common::EVENT_QUIT: - _vm->_system->quit(); - break; - case Common::EVENT_LBUTTONUP: - return true; - case Common::EVENT_RBUTTONUP: - return false; - case Common::EVENT_KEYDOWN: - switch (event.kbd.keycode) { - case Common::KEYCODE_BACKSPACE: - return false; - default: - return true; - } - default: - break; - } - } - } -} void Winnie::clrMenuSel(int *iSel, int fCanSel[]) { *iSel = IDI_WTP_SEL_OPT_1; while (!fCanSel[*iSel]) {