diff options
author | Strangerke | 2014-07-09 15:48:47 +0200 |
---|---|---|
committer | Strangerke | 2014-07-09 15:48:47 +0200 |
commit | dc2330a3b14cd31806785cc8b2fd98a49d3721fc (patch) | |
tree | 3c26eacffe5156b4b60b04c1628d69b33d326c2d /engines | |
parent | dbea97b7c451fedec35bac35dcff3af7b62e5b1e (diff) | |
download | scummvm-rg350-dc2330a3b14cd31806785cc8b2fd98a49d3721fc.tar.gz scummvm-rg350-dc2330a3b14cd31806785cc8b2fd98a49d3721fc.tar.bz2 scummvm-rg350-dc2330a3b14cd31806785cc8b2fd98a49d3721fc.zip |
CGE2: Implement the keyboard handler
Diffstat (limited to 'engines')
-rw-r--r-- | engines/cge2/cge2_main.h | 2 | ||||
-rw-r--r-- | engines/cge2/events.cpp | 74 |
2 files changed, 72 insertions, 4 deletions
diff --git a/engines/cge2/cge2_main.h b/engines/cge2/cge2_main.h index d6f2371964..e2f67854a8 100644 --- a/engines/cge2/cge2_main.h +++ b/engines/cge2/cge2_main.h @@ -32,6 +32,8 @@ namespace CGE2 { +#define kShowScummVMVersion 10 + class System : public Sprite { public: int _funDel; diff --git a/engines/cge2/events.cpp b/engines/cge2/events.cpp index c56f005fbb..7dab8f72e6 100644 --- a/engines/cge2/events.cpp +++ b/engines/cge2/events.cpp @@ -41,23 +41,89 @@ namespace CGE2 { Keyboard::Keyboard(CGE2Engine *vm) : _client(nullptr), _vm(vm) { warning("STUB: Keyboard::Keyboard() - Recheck the whole implementation!!!"); + _keyAlt = false; } Keyboard::~Keyboard() { } Sprite *Keyboard::setClient(Sprite *spr) { - warning("STUB: Keyboard::setClient()"); + SWAP(_client, spr); return spr; } bool Keyboard::getKey(Common::Event &event) { - warning("STUB: Keyboard::getKey()"); - return false; + Common::KeyCode keycode = event.kbd.keycode; + + if (((keycode == Common::KEYCODE_LALT) || (keycode == Common::KEYCODE_RALT)) && event.type == Common::EVENT_KEYDOWN) + _keyAlt = true; + else + _keyAlt = false; + + switch (keycode) { + case Common::KEYCODE_F1: + if (event.type == Common::EVENT_KEYUP) + return false; + // Display ScummVM version and translation strings + for (int i = 0; i < 5; i++) + _vm->_commandHandler->addCommand(kCmdInf, 1, kShowScummVMVersion + i, NULL); + return false; + case Common::KEYCODE_F5: + if (_vm->canSaveGameStateCurrently()) { + GUI::SaveLoadChooser *dialog = new GUI::SaveLoadChooser("Save game:", "Save", true); + int16 savegameId = dialog->runModalWithCurrentTarget(); + Common::String savegameDescription = dialog->getResultString(); + delete dialog; + + if (savegameId != -1) + _vm->saveGameState(savegameId, savegameDescription); + } + return false; + case Common::KEYCODE_F7: + if (_vm->canLoadGameStateCurrently()) { + GUI::SaveLoadChooser *dialog = new GUI::SaveLoadChooser("Restore game:", "Restore", false); + int16 savegameId = dialog->runModalWithCurrentTarget(); + delete dialog; + + if (savegameId != -1) + _vm->loadGameState(savegameId); + } + return false; + case Common::KEYCODE_d: + /* + if (event.kbd.flags & Common::KBD_CTRL) { + // Start the debugger + _vm->getDebugger()->attach(); + _vm->getDebugger()->onFrame(); + return false; + } + */ + break; + case Common::KEYCODE_x: + if (event.kbd.flags & Common::KBD_ALT) { + _vm->quit(); + return false; + } + break; + default: + break; + } + + return true; } void Keyboard::newKeyboard(Common::Event &event) { - warning("STUB: Keyboard::newKeyboard()"); + if (!getKey(event)) + return; + + if ((event.type == Common::EVENT_KEYDOWN) && (_client)) { + CGE2Event &evt = _vm->_eventManager->getNextEvent(); + evt._x = 0; + evt._y = 0; + evt._keyCode = event.kbd.keycode; // Keycode + evt._mask = kEventKeyb; // Event mask + evt._spritePtr = _client; // Sprite pointer + } } /*----------------- MOUSE interface -----------------*/ |