diff options
author | Paul Gilbert | 2016-08-12 13:11:25 -0400 |
---|---|---|
committer | Paul Gilbert | 2016-08-12 13:11:25 -0400 |
commit | 15c0f4b274146973f78c422e0237e904efc1f232 (patch) | |
tree | 4450e57722f434f32ef8b8f75cfd28c3357305db /engines/titanic/game/sgt | |
parent | a19d39c79b75f29daeacf9257e29a49d0d11bbc0 (diff) | |
download | scummvm-rg350-15c0f4b274146973f78c422e0237e904efc1f232.tar.gz scummvm-rg350-15c0f4b274146973f78c422e0237e904efc1f232.tar.bz2 scummvm-rg350-15c0f4b274146973f78c422e0237e904efc1f232.zip |
TITANIC: Implemented CArmchair class
Diffstat (limited to 'engines/titanic/game/sgt')
-rw-r--r-- | engines/titanic/game/sgt/armchair.cpp | 50 | ||||
-rw-r--r-- | engines/titanic/game/sgt/armchair.h | 4 | ||||
-rw-r--r-- | engines/titanic/game/sgt/sgt_state_room.h | 4 |
3 files changed, 56 insertions, 2 deletions
diff --git a/engines/titanic/game/sgt/armchair.cpp b/engines/titanic/game/sgt/armchair.cpp index 4c4ef44199..f547c3ef9a 100644 --- a/engines/titanic/game/sgt/armchair.cpp +++ b/engines/titanic/game/sgt/armchair.cpp @@ -24,6 +24,12 @@ namespace Titanic { +BEGIN_MESSAGE_MAP(CArmchair, CSGTStateRoom) + ON_MESSAGE(TurnOn) + ON_MESSAGE(TurnOff) + ON_MESSAGE(MovieEndMsg) +END_MESSAGE_MAP() + void CArmchair::save(SimpleFile *file, int indent) { file->writeNumberLine(1, indent); CSGTStateRoom::save(file, indent); @@ -34,4 +40,48 @@ void CArmchair::load(SimpleFile *file) { CSGTStateRoom::load(file); } +bool CArmchair::TurnOn(CTurnOn *msg) { + if (_statics->_v8 == "Closed" && _statics->_v12 == "Closed") { + CVisibleMsg visibleMsg(false); + visibleMsg.execute("Deskchair"); + + if (_statics->_v9 == "Open") { + CActMsg actMsg("Squash"); + actMsg.execute("Deskchair"); + _startFrame = 22; + _endFrame = 31; + } else { + _startFrame = 0; + _endFrame = 10; + } + + playMovie(_startFrame, _endFrame, MOVIE_GAMESTATE); + playSound("b#0.wav"); + _statics->_v8 = "Open"; + _fieldE0 = 0; + } + + return true; +} + +bool CArmchair::TurnOff(CTurnOff *msg) { + if (_statics->_v8 == "Open") { + _statics->_v8 = "Closed"; + _startFrame = 11; + _endFrame = 21; + _fieldE0 = 1; + playMovie(11, 21, MOVIE_GAMESTATE | MOVIE_NOTIFY_OBJECT); + playSound("b#0.wav"); + } + + return true; +} + +bool CArmchair::MovieEndMsg(CMovieEndMsg *msg) { + if (_statics->_v8 == "Closed") + loadFrame(0); + + return true; +} + } // End of namespace Titanic diff --git a/engines/titanic/game/sgt/armchair.h b/engines/titanic/game/sgt/armchair.h index b5505554f0..169b9b4aa0 100644 --- a/engines/titanic/game/sgt/armchair.h +++ b/engines/titanic/game/sgt/armchair.h @@ -28,6 +28,10 @@ namespace Titanic { class CArmchair : public CSGTStateRoom { + DECLARE_MESSAGE_MAP; + bool TurnOn(CTurnOn *msg); + bool TurnOff(CTurnOff *msg); + bool MovieEndMsg(CMovieEndMsg *msg); public: CLASSDEF; diff --git a/engines/titanic/game/sgt/sgt_state_room.h b/engines/titanic/game/sgt/sgt_state_room.h index 375da71326..d9ffdb8e9e 100644 --- a/engines/titanic/game/sgt/sgt_state_room.h +++ b/engines/titanic/game/sgt/sgt_state_room.h @@ -48,9 +48,9 @@ struct CSGTStateRoomStatics { class CSGTStateRoom : public CBackground { DECLARE_MESSAGE_MAP; bool EnterRoomMsg(CEnterRoomMsg *msg); -private: +protected: static CSGTStateRoomStatics *_statics; -private: +protected: int _fieldE0; int _fieldE4; int _fieldE8; |