aboutsummaryrefslogtreecommitdiff
path: root/engines/neverhood/modules/module2500.cpp
diff options
context:
space:
mode:
authorFilippos Karapetis2013-10-01 01:24:56 +0300
committerFilippos Karapetis2013-10-01 01:24:56 +0300
commitd798a4f12a95c3911b46e3bfddb9bc84f1b6a540 (patch)
treef1484a4f9f6ec2773490df535e850e739d335fb4 /engines/neverhood/modules/module2500.cpp
parentaab55c24fd1e1dd757e0d7b735f31662de871e70 (diff)
downloadscummvm-rg350-d798a4f12a95c3911b46e3bfddb9bc84f1b6a540.tar.gz
scummvm-rg350-d798a4f12a95c3911b46e3bfddb9bc84f1b6a540.tar.bz2
scummvm-rg350-d798a4f12a95c3911b46e3bfddb9bc84f1b6a540.zip
NEVERHOOD: Split some more sprites from their respective scenes
This splits modules 2400, 2500 and 2600
Diffstat (limited to 'engines/neverhood/modules/module2500.cpp')
-rw-r--r--engines/neverhood/modules/module2500.cpp49
1 files changed, 1 insertions, 48 deletions
diff --git a/engines/neverhood/modules/module2500.cpp b/engines/neverhood/modules/module2500.cpp
index 183793f06d..dcb3e94741 100644
--- a/engines/neverhood/modules/module2500.cpp
+++ b/engines/neverhood/modules/module2500.cpp
@@ -21,6 +21,7 @@
*/
#include "neverhood/modules/module2500.h"
+#include "neverhood/modules/module2500_sprites.h"
#include "neverhood/modules/module2700_sprites.h"
#include "neverhood/modules/module1600.h"
@@ -471,54 +472,6 @@ void Scene2501::updateKlaymenClipRect() {
_kmScene2501->setClipRect(0, 0, 640, 388);
}
-SsScene2504Button::SsScene2504Button(NeverhoodEngine *vm)
- : StaticSprite(vm, 1400), _countdown(0), _isSoundPlaying(false) {
-
- loadSprite(0x070220D9, kSLFDefDrawOffset | kSLFDefPosition | kSLFDefCollisionBoundsOffset, 400);
- setVisible(false);
- loadSound(0, 0x4600204C);
- loadSound(1, 0x408C0034);
- loadSound(2, 0x44043000);
- loadSound(3, 0x44045000);
- SetMessageHandler(&SsScene2504Button::handleMessage);
- SetUpdateHandler(&SsScene2504Button::update);
-}
-
-void SsScene2504Button::update() {
- updatePosition();
- if (_isSoundPlaying && !isSoundPlaying(0) && !isSoundPlaying(1)) {
- playSound(3);
- setVisible(false);
- _isSoundPlaying = false;
- }
- if (_countdown != 0 && (--_countdown) == 0) {
- if (getSubVar(VA_LOCKS_DISABLED, 0x01180951))
- playSound(0);
- else
- playSound(1);
- _isSoundPlaying = true;
- }
-}
-
-uint32 SsScene2504Button::handleMessage(int messageNum, const MessageParam &param, Entity *sender) {
- uint32 messageResult = Sprite::handleMessage(messageNum, param, sender);
- switch (messageNum) {
- case 0x1011:
- if (_countdown == 0 && !_isSoundPlaying) {
- setVisible(true);
- _countdown = 2;
- if (getSubVar(VA_LOCKS_DISABLED, 0x01180951))
- setSubVar(VA_LOCKS_DISABLED, 0x01180951, 0);
- else
- setSubVar(VA_LOCKS_DISABLED, 0x01180951, 1);
- playSound(2);
- }
- messageResult = 1;
- break;
- }
- return messageResult;
-}
-
Scene2504::Scene2504(NeverhoodEngine *vm, Module *parentModule, int which)
: Scene(vm, parentModule) {