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 | |
| parent | a19d39c79b75f29daeacf9257e29a49d0d11bbc0 (diff) | |
| download | scummvm-rg350-15c0f4b274146973f78c422e0237e904efc1f232.tar.gz scummvm-rg350-15c0f4b274146973f78c422e0237e904efc1f232.tar.bz2 scummvm-rg350-15c0f4b274146973f78c422e0237e904efc1f232.zip  | |
TITANIC: Implemented CArmchair class
| -rw-r--r-- | engines/titanic/core/background.cpp | 14 | ||||
| -rw-r--r-- | engines/titanic/core/background.h | 4 | ||||
| -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 | 
5 files changed, 65 insertions, 11 deletions
diff --git a/engines/titanic/core/background.cpp b/engines/titanic/core/background.cpp index f180df8867..733dfc1cf3 100644 --- a/engines/titanic/core/background.cpp +++ b/engines/titanic/core/background.cpp @@ -30,13 +30,13 @@ BEGIN_MESSAGE_MAP(CBackground, CGameObject)  	ON_MESSAGE(VisibleMsg)  END_MESSAGE_MAP() -CBackground::CBackground() : CGameObject(), _fieldBC(0), _fieldC0(0), _fieldDC(0) { +CBackground::CBackground() : CGameObject(), _startFrame(0), _endFrame(0), _fieldDC(0) {  }  void CBackground::save(SimpleFile *file, int indent) {  	file->writeNumberLine(1, indent); -	file->writeNumberLine(_fieldBC, indent); -	file->writeNumberLine(_fieldC0, indent); +	file->writeNumberLine(_startFrame, indent); +	file->writeNumberLine(_endFrame, indent);  	file->writeQuotedLine(_string1, indent);  	file->writeQuotedLine(_string2, indent);  	file->writeNumberLine(_fieldDC, indent); @@ -46,8 +46,8 @@ void CBackground::save(SimpleFile *file, int indent) {  void CBackground::load(SimpleFile *file) {  	file->readNumber(); -	_fieldBC = file->readNumber(); -	_fieldC0 = file->readNumber(); +	_startFrame = file->readNumber(); +	_endFrame = file->readNumber();  	_string1 = file->readString();  	_string2 = file->readString();  	_fieldDC = file->readNumber(); @@ -58,9 +58,9 @@ void CBackground::load(SimpleFile *file) {  bool CBackground::StatusChangeMsg(CStatusChangeMsg *msg) {  	setVisible(true);  	if (_fieldDC) { -		playMovie(_fieldBC, _fieldC0, 16); +		playMovie(_startFrame, _endFrame, 16);  	} else { -		playMovie(_fieldBC, _fieldC0, 0); +		playMovie(_startFrame, _endFrame, 0);  	}  	return true;  } diff --git a/engines/titanic/core/background.h b/engines/titanic/core/background.h index 6a2fd21454..b7f160db28 100644 --- a/engines/titanic/core/background.h +++ b/engines/titanic/core/background.h @@ -34,8 +34,8 @@ class CBackground : public CGameObject {  	bool SetFrameMsg(CSetFrameMsg *msg);  	bool VisibleMsg(CVisibleMsg *msg);  protected: -	int _fieldBC; -	int _fieldC0; +	int _startFrame; +	int _endFrame;  	CString _string1;  	CString _string2;  	int _fieldDC; 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;  | 
