diff options
| author | James Brown | 2003-05-14 11:08:57 +0000 |
|---|---|---|
| committer | James Brown | 2003-05-14 11:08:57 +0000 |
| commit | 0106191abd1362b7c19d21f258bd56be12dbd552 (patch) | |
| tree | 1dec8692ccd9c466314e29ef0a86ced12e85eb02 | |
| parent | feee7422687e5a0e3252b793cef383f78cd03808 (diff) | |
| download | scummvm-rg350-0106191abd1362b7c19d21f258bd56be12dbd552.tar.gz scummvm-rg350-0106191abd1362b7c19d21f258bd56be12dbd552.tar.bz2 scummvm-rg350-0106191abd1362b7c19d21f258bd56be12dbd552.zip | |
Some Zak input stuff
svn-id: r7498
| -rw-r--r-- | scumm/scummvm.cpp | 23 |
1 files changed, 16 insertions, 7 deletions
diff --git a/scumm/scummvm.cpp b/scumm/scummvm.cpp index 9c6333755e..347f346f49 100644 --- a/scumm/scummvm.cpp +++ b/scumm/scummvm.cpp @@ -1031,13 +1031,6 @@ load_game: clearClickedStatus(); } -#if 1 - // FIXME - MM / Zak hack - if ((_features & GF_AFTER_V2) && (_mouseButStat & MBS_LEFT_CLICK)) { - _scummVars[32] = 2; - printf("mouse click\n"); - } -#endif if (!_verbRedraw && _cursor.state > 0) { verbMouseOver(checkMouseOver(mouse.x, mouse.y)); @@ -1860,6 +1853,22 @@ int Scumm::getKeyInput() { VAR(VAR_LEFTBTN_HOLD) = (_leftBtnPressed & msDown) != 0; // VAR(VAR_RIGHTBTN_DOWN) = (_rightBtnPressed&msClicked) != 0; VAR(VAR_RIGHTBTN_HOLD) = (_rightBtnPressed & msDown) != 0; + } else if (_features & GF_AFTER_V2) { + // Store the input type. So far we can't distinguise + // between 1, 3 and 5. + // 1) Verb 2) Scene 3) Inv. 4) Key + // 5) Sentence Bar + + if (_mouseButStat & MBS_LEFT_CLICK) { + VirtScreen *zone = findVirtScreen(mouse.y); + + if (zone->number == 0) // Clicked in scene + _scummVars[32] = 2; + else if (zone->number == 2) // Clicked in verb/sentence + _scummVars[32] = 1; + + } else if (_lastKeyHit) // Key Input + _scummVars[32] = 4; } _leftBtnPressed &= ~msClicked; |
