diff options
Diffstat (limited to 'engines/parallaction')
-rw-r--r-- | engines/parallaction/defs.h | 12 | ||||
-rw-r--r-- | engines/parallaction/dialogue.cpp | 2 | ||||
-rw-r--r-- | engines/parallaction/graphics.cpp | 8 | ||||
-rw-r--r-- | engines/parallaction/inventory.cpp | 4 | ||||
-rw-r--r-- | engines/parallaction/menu.cpp | 18 | ||||
-rw-r--r-- | engines/parallaction/parallaction.cpp | 18 | ||||
-rw-r--r-- | engines/parallaction/parallaction.h | 3 |
7 files changed, 23 insertions, 42 deletions
diff --git a/engines/parallaction/defs.h b/engines/parallaction/defs.h index d58dbd64b4..6f864215b6 100644 --- a/engines/parallaction/defs.h +++ b/engines/parallaction/defs.h @@ -55,18 +55,6 @@ public: } }; -struct Point { - int16 _x; - int16 _y; -}; - -struct Rect { - int16 _left; - int16 _top; - int16 _right; - int16 _bottom; -}; - struct SpeakData; struct Question; typedef Question Dialogue; diff --git a/engines/parallaction/dialogue.cpp b/engines/parallaction/dialogue.cpp index fccf61a4c2..73567f3ca1 100644 --- a/engines/parallaction/dialogue.cpp +++ b/engines/parallaction/dialogue.cpp @@ -486,7 +486,7 @@ int16 selectAnswer(Question *q, StaticCnv *cnv) { while (_mouseButtons != kMouseLeftUp) { _vm->updateInput(); - _si = getHoverAnswer(_mousePos._x, _mousePos._y, q); + _si = getHoverAnswer(_vm->_mousePos.x, _vm->_mousePos.y, q); if (_si != v2) { if (v2 != -1) diff --git a/engines/parallaction/graphics.cpp b/engines/parallaction/graphics.cpp index def57c5d6a..6067a329fc 100644 --- a/engines/parallaction/graphics.cpp +++ b/engines/parallaction/graphics.cpp @@ -429,11 +429,11 @@ void jobEraseLabel(void *parm, Job *j) { int16 _si, _di; if (_vm->_activeItem._id != 0) { - _si = _mousePos._x + 16 - label->_cnv._width/2; - _di = _mousePos._y + 34; + _si = _vm->_mousePos.x + 16 - label->_cnv._width/2; + _di = _vm->_mousePos.y + 34; } else { - _si = _mousePos._x + 8 - label->_cnv._width/2; - _di = _mousePos._y + 21; + _si = _vm->_mousePos.x + 8 - label->_cnv._width/2; + _di = _vm->_mousePos.y + 21; } if (_si < 0) _si = 0; diff --git a/engines/parallaction/inventory.cpp b/engines/parallaction/inventory.cpp index d2386fa0f3..0a70df12db 100644 --- a/engines/parallaction/inventory.cpp +++ b/engines/parallaction/inventory.cpp @@ -316,14 +316,14 @@ void openInventory() { uint16 _LOCALinventory_lines = (_si + 4) / INVENTORY_ITEMS_PER_LINE; - _invPosition.x = _mousePos._x - (INVENTORY_WIDTH / 2); + _invPosition.x = _vm->_mousePos.x - (INVENTORY_WIDTH / 2); if (_invPosition.x < 0) _invPosition.x = 0; if ((_invPosition.x + INVENTORY_WIDTH) > SCREEN_WIDTH) _invPosition.x = SCREEN_WIDTH - INVENTORY_WIDTH; - _invPosition.y = _mousePos._y - 2 - (_LOCALinventory_lines * INVENTORYITEM_HEIGHT); + _invPosition.y = _vm->_mousePos.y - 2 - (_LOCALinventory_lines * INVENTORYITEM_HEIGHT); if (_invPosition.y < 0) _invPosition.y = 0; diff --git a/engines/parallaction/menu.cpp b/engines/parallaction/menu.cpp index 5c883da8b1..aa62bc55ad 100644 --- a/engines/parallaction/menu.cpp +++ b/engines/parallaction/menu.cpp @@ -191,17 +191,14 @@ uint16 Menu::chooseLanguage() { _engine->updateInput(); _vm->_gfx->swapBuffers(); - uint16 _di = _mousePos._x; - uint16 v2 = _mousePos._y; - if (_mouseButtons == kMouseLeftUp) { for (uint16 _si = 0; _si < 4; _si++) { - if (80 + _si*49 >= _di) continue; - if (110 - _si*25 >= v2) continue; + if (80 + _si*49 >= _vm->_mousePos.x) continue; + if (110 - _si*25 >= _vm->_mousePos.y) continue; - if (128 + _si*49 <= _di) continue; - if (180 - _si*25 <= v2) continue; + if (128 + _si*49 <= _vm->_mousePos.x) continue; + if (180 - _si*25 <=_vm->_mousePos.y) continue; beep(); return _si; @@ -232,7 +229,7 @@ uint16 Menu::selectGame() { _engine->waitTime( 1 ); _si = 0; - if (_mousePos._x > 160) + if (_vm->_mousePos.x > 160) _si = 1; if (_si == _di) continue; @@ -313,9 +310,6 @@ void Menu::selectCharacter() { _engine->waitTime(1); } while (_mouseButtons != kMouseLeftUp); // waits for left click - uint16 x = _mousePos._x; - uint16 y = _mousePos._y; - for (uint16 _si = 0; _si < 9; _si++) { Common::Rect r( @@ -325,7 +319,7 @@ void Menu::selectCharacter() { BLOCK_SELECTION_Y + BLOCK_HEIGHT - _si * BLOCK_Y_OFFSET ); - if (!r.contains(x, y)) continue; + if (!r.contains(_vm->_mousePos)) continue; r.setWidth(BLOCK_WIDTH); r.setHeight(BLOCK_HEIGHT); diff --git a/engines/parallaction/parallaction.cpp b/engines/parallaction/parallaction.cpp index 325ee132e2..a73f48598b 100644 --- a/engines/parallaction/parallaction.cpp +++ b/engines/parallaction/parallaction.cpp @@ -47,7 +47,7 @@ namespace Parallaction { Parallaction *_vm = NULL; // public stuff -Point _mousePos = { 0, 0 }; + uint16 _mouseButtons = 0; @@ -314,8 +314,7 @@ uint16 Parallaction::updateInput() { break; case Common::EVENT_MOUSEMOVE: - _mousePos._x = e.mouse.x; - _mousePos._y = e.mouse.y; + _mousePos = e.mouse; break; case Common::EVENT_QUIT: @@ -477,7 +476,7 @@ void Parallaction::processInput(InputData *data) { _jDrawLabel = NULL; addJob(&jobWaitRemoveJob, _jEraseLabel, kPriority2); } - if (hitZone(kZoneYou, _mousePos._x, _mousePos._y) == 0) + if (hitZone(kZoneYou, _mousePos.x, _mousePos.y) == 0) changeCursor(kCursorArrow); removeJob(_jRunScripts); _jDrawInventory = addJob(&jobShowInventory, 0, kPriority2); @@ -552,8 +551,7 @@ Parallaction::InputData *Parallaction::translateInput() { return &_input; } - _input._mousePos.x = _mousePos._x; - _input._mousePos.y = _mousePos._y; + _input._mousePos = _mousePos; if (((_engineFlags & kEnginePauseJobs) == 0) && ((_engineFlags & kEngineInventory) == 0)) { @@ -564,12 +562,12 @@ Parallaction::InputData *Parallaction::translateInput() { return &_input; } - Zone *z = hitZone(_activeItem._id, _mousePos._x, _mousePos._y); + Zone *z = hitZone(_activeItem._id, _mousePos.x, _mousePos.y); if (_mouseButtons == kMouseRightDown) { // right button down shows inventory - if (hitZone(kZoneYou, _mousePos._x, _mousePos._y) && (_activeItem._id != 0)) { + if (hitZone(kZoneYou, _mousePos.x, _mousePos.y) && (_activeItem._id != 0)) { _activeItem._index = (_activeItem._id >> 16) & 0xFFFF; _engineFlags |= kEngineDragging; } @@ -629,13 +627,13 @@ Parallaction::InputData *Parallaction::translateInput() { if ((_engineFlags & kEngineInventory) == 0) return NULL; // in inventory - int16 _si = getHoverInventoryItem(_mousePos._x, _mousePos._y); + int16 _si = getHoverInventoryItem(_mousePos.x, _mousePos.y); if (_mouseButtons == kMouseRightUp) { // right up hides inventory _input._event = kEvCloseInventory; - _input._inventoryIndex = getHoverInventoryItem(_mousePos._x, _mousePos._y); + _input._inventoryIndex = getHoverInventoryItem(_mousePos.x, _mousePos.y); highlightInventoryItem(_transCurrentHoverItem, 12); // disable if ((_engineFlags & kEngineDragging) == 0) return &_input; diff --git a/engines/parallaction/parallaction.h b/engines/parallaction/parallaction.h index 5efa287eea..fd7d6d77e5 100644 --- a/engines/parallaction/parallaction.h +++ b/engines/parallaction/parallaction.h @@ -99,7 +99,6 @@ public: } }; -extern Point _mousePos; extern uint16 _mouseButtons; extern uint16 _score; @@ -338,6 +337,8 @@ public: Script *_locationScript; + Common::Point _mousePos; + protected: // data struct InputData { |