diff options
Diffstat (limited to 'engines/titanic/game/gondolier/gondolier_chest.cpp')
-rw-r--r-- | engines/titanic/game/gondolier/gondolier_chest.cpp | 29 |
1 files changed, 29 insertions, 0 deletions
diff --git a/engines/titanic/game/gondolier/gondolier_chest.cpp b/engines/titanic/game/gondolier/gondolier_chest.cpp index b3e7217502..cf6656732b 100644 --- a/engines/titanic/game/gondolier/gondolier_chest.cpp +++ b/engines/titanic/game/gondolier/gondolier_chest.cpp @@ -24,6 +24,12 @@ namespace Titanic { +BEGIN_MESSAGE_MAP(CGondolierChest, CGondolierBase) + ON_MESSAGE(MouseButtonDownMsg) + ON_MESSAGE(MovieEndMsg) + ON_MESSAGE(MouseDragStartMsg) +END_MESSAGE_MAP() + void CGondolierChest::save(SimpleFile *file, int indent) { file->writeNumberLine(1, indent); CGondolierBase::save(file, indent); @@ -34,4 +40,27 @@ void CGondolierChest::load(SimpleFile *file) { CGondolierBase::load(file); } +bool CGondolierChest::MouseButtonDownMsg(CMouseButtonDownMsg *msg) { + if (!_v1) + playMovie(0, 14, MOVIE_NOTIFY_OBJECT); + else if (msg->_mousePos.y < 330) + return false; + else if (!_v8 && !_v5) { + playMovie(14, 29, 0); + _v1 = 0; + } + + return true; +} + +bool CGondolierChest::MovieEndMsg(CMovieEndMsg *msg) { + if (msg->_endFrame == 14) + _v1 = 1; + return true; +} + +bool CGondolierChest::MouseDragStartMsg(CMouseDragStartMsg *msg) { + return false; +} + } // End of namespace Titanic |