diff options
Diffstat (limited to 'engines')
-rw-r--r-- | engines/titanic/game_manager.h | 10 | ||||
-rw-r--r-- | engines/titanic/game_state.cpp | 25 | ||||
-rw-r--r-- | engines/titanic/game_state.h | 7 | ||||
-rw-r--r-- | engines/titanic/input_handler.cpp | 12 | ||||
-rw-r--r-- | engines/titanic/input_handler.h | 16 | ||||
-rw-r--r-- | engines/titanic/screen_manager.h | 7 |
6 files changed, 70 insertions, 7 deletions
diff --git a/engines/titanic/game_manager.h b/engines/titanic/game_manager.h index 1d2a88e626..d53a611a72 100644 --- a/engines/titanic/game_manager.h +++ b/engines/titanic/game_manager.h @@ -87,6 +87,16 @@ public: void postLoad(CProjectItem *project); int fn2() { return _gameState._sub.fn2(); } + + /** + * Lock the input handler + */ + void lockInputHandler() { _inputHandler.incLockCount(); } + + /** + * Unlock the input handler + */ + void unlockInputHandler() { _inputHandler.decLockCount(); } }; } // End of namespace Titanic diff --git a/engines/titanic/game_state.cpp b/engines/titanic/game_state.cpp index 59e4b7b837..41c4388f64 100644 --- a/engines/titanic/game_state.cpp +++ b/engines/titanic/game_state.cpp @@ -21,12 +21,14 @@ */ #include "titanic/game_state.h" +#include "titanic/game_manager.h" +#include "titanic/screen_manager.h" namespace Titanic { CGameState::CGameState(CGameManager *gameManager) : _gameManager(gameManager), _sub(this), - _field8(0), _fieldC(0), _field10(10), _field14(0), _field18(0), + _field8(0), _fieldC(0), _mode(10), _field14(0), _field18(0), _field1C(0), _field20(0), _field24(0), _field28(0), _field2C(0), _field30(0), _field34(0), _field38(0) { } @@ -55,4 +57,25 @@ void CGameState::load(SimpleFile *file) { _field28 = _field2C = 0; } +void CGameState::setMode(int newMode) { + CScreenManager *sm = CScreenManager::_screenManagerPtr; + + if (newMode == 2 && newMode != _mode) { + if (_gameManager) + _gameManager->lockInputHandler(); + + if (sm && sm->_mouseCursor) + sm->_mouseCursor->hide(); + + } else if (newMode != 2 && newMode != _mode) { + if (sm && sm->_mouseCursor) + sm->_mouseCursor->show(); + + if (_gameManager) + _gameManager->unlockInputHandler(); + } + + _mode = newMode; +} + } // End of namespace Titanic z diff --git a/engines/titanic/game_state.h b/engines/titanic/game_state.h index e6275dee01..1f93f693c8 100644 --- a/engines/titanic/game_state.h +++ b/engines/titanic/game_state.h @@ -46,7 +46,7 @@ public: CGameStateList _list; int _field8; int _fieldC; - int _field10; + int _mode; int _field14; int _field18; int _field1C; @@ -69,6 +69,11 @@ public: * Load the data for the class from file */ void load(SimpleFile *file); + + /** + * Sets a new mode + */ + void setMode(int newMode); }; } // End of namespace Titanic diff --git a/engines/titanic/input_handler.cpp b/engines/titanic/input_handler.cpp index 0c09429bd4..d5825c0c32 100644 --- a/engines/titanic/input_handler.cpp +++ b/engines/titanic/input_handler.cpp @@ -28,7 +28,7 @@ namespace Titanic { CInputHandler::CInputHandler(CGameManager *owner) : _gameManager(owner), _inputTranslator(nullptr), _field4(0), _field8(0), _fieldC(0), _field10(0), _field14(0), - _field18(0), _field1C(0), _field20(0), _field24(0) { + _lockCount(0), _field24(0) { CScreenManager::_screenManagerPtr->_inputHandler = this; } @@ -36,4 +36,14 @@ void CInputHandler::setTranslator(CInputTranslator *translator) { _inputTranslator = translator; } +void CInputHandler::incLockCount() { + ++_lockCount; +} + +void CInputHandler::decLockCount() { + if (--_lockCount == 0 && _inputTranslator) { + warning("TODO"); + } +} + } // End of namespace Titanic z diff --git a/engines/titanic/input_handler.h b/engines/titanic/input_handler.h index 288630c633..1bc6dc9fe7 100644 --- a/engines/titanic/input_handler.h +++ b/engines/titanic/input_handler.h @@ -23,6 +23,7 @@ #ifndef TITANIC_INPUT_HANDLER_H #define TITANIC_INPUT_HANDLER_H +#include "common/rect.h" #include "titanic/input_translator.h" namespace Titanic { @@ -38,14 +39,23 @@ public: int _fieldC; int _field10; int _field14; - int _field18; - int _field1C; - int _field20; + Common::Point _mousePos; + int _lockCount; int _field24; public: CInputHandler(CGameManager *owner); void setTranslator(CInputTranslator *translator); + + /** + * Increment the lock count + */ + void incLockCount(); + + /** + * Decrement the lock count on the input handler + */ + void decLockCount(); }; } // End of namespace Titanic diff --git a/engines/titanic/screen_manager.h b/engines/titanic/screen_manager.h index 914fc85eb7..d0bcc5dbd8 100644 --- a/engines/titanic/screen_manager.h +++ b/engines/titanic/screen_manager.h @@ -47,6 +47,11 @@ public: CScreenManagerRec(); }; +struct MouseCursor { + void show() {} + void hide() {} +}; + class CScreenManager { protected: TitanicEngine *_vm; @@ -62,7 +67,7 @@ public: Common::Array<CVideoSurface *> _backSurfaces; CVideoSurface *_frontRenderSurface; CScreenManagerRec _entries[2]; - void *_mouseCursor; + MouseCursor *_mouseCursor; void *_textCursor; CInputHandler *_inputHandler; int _fontNumber; |