aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--engines/xeen/files.cpp6
-rw-r--r--engines/xeen/worldofxeen/darkside_cutscenes.cpp168
-rw-r--r--engines/xeen/worldofxeen/darkside_cutscenes.h8
3 files changed, 89 insertions, 93 deletions
diff --git a/engines/xeen/files.cpp b/engines/xeen/files.cpp
index 9cbc36ffc5..83a4ca9072 100644
--- a/engines/xeen/files.cpp
+++ b/engines/xeen/files.cpp
@@ -271,8 +271,10 @@ bool FileManager::setup() {
}
void FileManager::setGameCc(int ccMode) {
- if (g_vm->getGameID() != GType_WorldOfXeen)
- ccMode = g_vm->getGameID() == GType_Clouds ? 0 : 1;
+ if (ccMode != 2) {
+ if (g_vm->getGameID() != GType_WorldOfXeen)
+ ccMode = g_vm->getGameID() == GType_Clouds ? 0 : 1;
+ }
File::setCurrentArchive(ccMode);
_isDarkCc = ccMode != 0;
diff --git a/engines/xeen/worldofxeen/darkside_cutscenes.cpp b/engines/xeen/worldofxeen/darkside_cutscenes.cpp
index 388a9b72a6..abd8d691fd 100644
--- a/engines/xeen/worldofxeen/darkside_cutscenes.cpp
+++ b/engines/xeen/worldofxeen/darkside_cutscenes.cpp
@@ -41,29 +41,29 @@ const int PHAROAH_YLIST[32] = {
-3, -3, -3, -3, -3, -3, -3, -3, -1, 0, 0, 0, 0, 0, 0, 0,
-1, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3, -3
};
-const int CLAW_XLIST[32] = {
+const int LEFT_CLAW_RUB_X[32] = {
223, 208, 187, 158, 129, 104, 85, 70, 61, 53, 49,
46, 46, 49, 53, 56, 61, 67, 72, 82, 91, 103,
117, 130, 142, 156, 170, 184, 199, 210, 221, 227
};
-const int CLAW_YLIST[32] = {
+const int LEFT_CLAW_RUB_Y[32] = {
116, 111, 105, 103, 101, 96, 93, 92, 92, 95, 98,
100, 104, 107, 107, 105, 102, 100, 98, 99, 101, 104,
107, 109, 110, 111, 114, 115, 115, 116, 116, 118
};
-static const int CLAW_XLIST2[32] = {
+static const int RIGHT_CLAW_IDLE_X[32] = {
146, 145, 143, 141, 141, 141, 141, 141, 141, 141, 141, 142, 143, 144, 145, 146,
146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146, 146
};
-static const int CLAW_YLIST2[32] = {
+static const int RIGHT_CLAW_IDLE_Y[32] = {
143, 143, 143, 143, 143, 143, 143, 143, 143, 143, 143, 143, 143, 143, 143, 143,
143, 143, 144, 145, 145, 145, 145, 145, 145, 145, 145, 144, 143, 143, 143, 143
};
-const int CLAW_XLIST3[32] = {
+const int LEFT_CLAW_IDLE_X[32] = {
223, 222, 220, 219, 219, 219, 219, 219, 219, 219, 219, 219, 219, 219, 219, 219,
219, 219, 220, 220, 220, 220, 220, 220, 220, 220, 220, 220, 220, 220, 220, 221
};
-const int CLAW_YLIST3[32] = {
+const int LEFT_CLAW_IDLE_Y[32] = {
116, 116, 116, 117, 117, 117, 117, 117, 118, 118, 118, 118, 118, 118, 118, 118,
118, 118, 118, 118, 118, 118, 118, 118, 118, 118, 118, 118, 118, 118, 118, 118
};
@@ -163,17 +163,22 @@ bool DarkSideCutscenes::showDarkSideTitle() {
}
bool DarkSideCutscenes::showDarkSideIntro() {
- _vm->_files->_isDarkCc = true;
- _vm->_files->setGameCc(1);
+ FileManager &files = *g_vm->_files;
+ Screen &screen = *g_vm->_screen;
+ Sound &sound = *g_vm->_sound;
+
+ files._isDarkCc = true;
+ files.setGameCc(1);
_ball.load("ball.int");
_dragon1.load("dragon1.int");
_claw.load("claw.int");
- bool result = showDarkSideIntro1() && showDarkSideIntro2();
+ bool result = showDarkSideIntro1() && showDarkSideIntro2() && showDarkSideIntro3();
- _vm->_sound->stopAllAudio();
- _vm->_sound->setMusicVolume(100);
+ sound.stopAllAudio();
+ sound.setMusicVolume(100);
+ screen.freePages();
_ball.clear();
_dragon1.clear();
_claw.clear();
@@ -181,22 +186,39 @@ bool DarkSideCutscenes::showDarkSideIntro() {
return result;
}
-void DarkSideCutscenes::animatePharoah2(int frame) {
- if (frame)
- _ball.draw(0, frame - 1);
- _claw.draw(0, 5, Common::Point(CLAW_XLIST2[frame], CLAW_YLIST2[frame]), SPRFLAG_800);
- _claw.draw(0, 6, Common::Point(149, 184));
- _dragon1.draw(0, PHAROAH_FRAMES[frame], Common::Point(139, PHAROAH_YLIST[frame]), SPRFLAG_800);
- _claw.draw(0, frame % 5, Common::Point(CLAW_XLIST[frame], CLAW_YLIST[frame]), SPRFLAG_800);
+bool DarkSideCutscenes::rubCrystalBall(bool fadeIn) {
+ EventsManager &events = *g_vm->_events;
+ Screen &screen = *g_vm->_screen;
+
+ for (int frame = 0; frame < 32; ++frame) {
+ screen.restoreBackground();
+
+ if (frame)
+ _ball.draw(0, frame - 1);
+ _claw.draw(0, 5, Common::Point(RIGHT_CLAW_IDLE_X[frame], RIGHT_CLAW_IDLE_Y[frame]), SPRFLAG_800);
+ _claw.draw(0, 6, Common::Point(149, 184));
+
+ _dragon1.draw(0, PHAROAH_FRAMES[frame], Common::Point(139, PHAROAH_YLIST[frame]), SPRFLAG_800);
+ _claw.draw(0, frame % 5, Common::Point(LEFT_CLAW_RUB_X[frame], LEFT_CLAW_RUB_Y[frame]), SPRFLAG_800);
+
+ if (_subtitleSize)
+ showSubtitles();
+
+ if (fadeIn && frame == 0)
+ screen.fadeIn();
+ WAIT(3);
+ }
+
+ return true;
}
void DarkSideCutscenes::animatePharoah(int frame) {
if (frame)
_ball.draw(0, frame - 1);
- _claw.draw(0, 5, Common::Point(CLAW_XLIST2[frame], CLAW_YLIST2[frame]), SPRFLAG_800);
+ _claw.draw(0, 5, Common::Point(RIGHT_CLAW_IDLE_X[frame], RIGHT_CLAW_IDLE_Y[frame]), SPRFLAG_800);
_claw.draw(0, 6, Common::Point(149, 184));
_dragon1.draw(0, PHAROAH_FRAMES[frame], Common::Point(139, PHAROAH_YLIST[frame]), SPRFLAG_800);
- _claw.draw(0, frame % 5, Common::Point(CLAW_XLIST2[frame], CLAW_YLIST2[frame]), SPRFLAG_800);
+ _claw.draw(0, frame % 5, Common::Point(LEFT_CLAW_IDLE_X[frame], LEFT_CLAW_IDLE_Y[frame]), SPRFLAG_800);
}
bool DarkSideCutscenes::showDarkSideIntro1() {
@@ -215,7 +237,7 @@ bool DarkSideCutscenes::showDarkSideIntro1() {
// Play the intro music
sound.setMusicVolume(95);
-// sound.playSong("bigtheme.m");
+ sound.playSong("bigtheme.m");
screen.loadBackground("jvc.raw");
screen.loadPalette("dark.pal");
@@ -381,20 +403,20 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
Screen &screen = *_vm->_screen;
Sound &sound = *_vm->_sound;
SpriteResource goon("goon.int"), darkLord("darklord.int"), queen("queen.int"),
- wizard("wizard.int"), fizzle("fizzle.int"), wizMth("izmth.int");
+ wizard("wizard.int"), fizzle("fizzle.int"), wizMth("wizmth.int");
int idx, clawCtr;
+ screen.loadPalette("dark.pal");
screen.loadBackground("ball.raw");
screen.saveBackground();
- for (idx = 0; idx < 32; ++idx) {
- screen.restoreBackground();
- animatePharoah2(idx);
+ if (!rubCrystalBall(true))
+ return false;
- if (idx == 0)
- screen.fadeIn();
- WAIT(3);
- }
+ // TODO: Subtitle stuff
+ recordTime();
+ _subtitleSize = 1;
+ sound.playFX(42);
for (idx = 0, clawCtr = 0; idx < 11; ++idx) {
ANIMATE_PHAROAH;
@@ -403,11 +425,10 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
fizzle.draw(0, idx, Common::Point(9, 57));
if (idx == 6) {
- sound.playSound("ido2.voc");
- //sound.stopSong(); ?
+ sound.playSound("pharoh3.voc");
+ sound.playFX(0);
}
- clawCtr = (clawCtr + 1) % 32;
if (idx > 6)
showSubtitles();
WAIT(3);
@@ -442,12 +463,12 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
Common::Point(9, 57));
}
- clawCtr = (clawCtr + 1) % 32;
showSubtitles();
WAIT(3);
} while (vocIndex < 3 || sound.isSoundPlaying() || _subtitleSize);
// TODO: Subtitle stuff
+ sound.playSound(VOC_NAMES[3]);
recordTime();
_subtitleSize = 1;
@@ -456,7 +477,6 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
ANIMATE_PHAROAH;
queen.draw(0, 0, Common::Point(9, 57));
- clawCtr = (clawCtr + 1) % 32;
if (++idx <= 37)
idx = 34;
@@ -469,19 +489,18 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
_subtitleSize = 1;
sound.playSound("dark3.voc");
- const char *const VOC_NAMES2[3] = { "pharoh5a.voc", "pharoh5b.voc", "laff1.voc" };
+ const char *const VOC_NAMES2[2] = { "pharoh5a.voc", "pharoh5b.voc" };
vocIndex = 0;
do {
ANIMATE_PHAROAH;
- darkLord.draw(0, vocIndex == 1 ? getSpeakingFrame(0, 3) : 0, Common::Point(9, 57));
+ darkLord.draw(0, vocIndex == 0 ? getSpeakingFrame(0, 3) : 0, Common::Point(9, 57));
- clawCtr = (clawCtr + 1) % 32;
showSubtitles();
WAIT(3);
- if (!sound.isSoundPlaying())
+ if (!sound.isSoundPlaying() && vocIndex < 2)
sound.playSound(VOC_NAMES2[vocIndex++]);
- } while (vocIndex < 3 && _subtitleSize);
+ } while (vocIndex < 2 || sound.isSoundPlaying() || _subtitleSize);
// TODO: Subtitle stuff
recordTime();
@@ -502,7 +521,6 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
darkLord.draw(0, getSpeakingFrame(0, 3), Common::Point(9, 57));
fizzle.draw(0, idx, Common::Point(9, 57));
- clawCtr = (clawCtr + 1) % 32;
showSubtitles();
WAIT(3);
}
@@ -511,32 +529,23 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
do {
ANIMATE_PHAROAH;
- queen.draw(0, 0, Common::Point(9, 57));
- clawCtr = (clawCtr + 1) % 32;
showSubtitles();
WAIT(3);
} while (sound.isSoundPlaying() || _subtitleSize);
- for (idx = 0; idx < 32; ++idx) {
- screen.restoreBackground();
- animatePharoah2(idx);
-
- showSubtitles();
- WAIT(3);
- }
+ if (!rubCrystalBall())
+ return false;
for (idx = 0, clawCtr = 0; idx < 11; ++idx) {
ANIMATE_PHAROAH;
if (idx > 3)
goon.draw(0, 0, Common::Point(9, 57));
- if (idx == 6)
- sound.playSound("pharoh6w.voc");
-
fizzle.draw(0, idx, Common::Point(9, 57));
- clawCtr = (clawCtr + 1) % 32;
+ if (idx == 6)
+ sound.playSound("pharoh6w.voc");
if (idx > 6)
showSubtitles();
WAIT(3);
@@ -558,8 +567,6 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
}
nwcIndex = (nwcIndex + 1) % 17;
- clawCtr = (clawCtr + 1) % 32;
-
showSubtitles();
WAIT(3);
} while (!vocIndex || sound.isSoundPlaying() || _subtitleSize);
@@ -569,7 +576,7 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
_subtitleSize = 1;
sound.playFX(42);
- for (idx = 10; idx >= 0; --idx) {
+ for (idx = 10, vocIndex = 0; idx >= 0; --idx) {
ANIMATE_PHAROAH;
if (idx > 4)
goon.draw(0, 0, Common::Point(9, 57));
@@ -586,14 +593,8 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
sound.playFX(0);
- for (idx = 0; idx < 32; ++idx) {
- screen.restoreBackground();
- animatePharoah2(idx);
-
- if (_subtitleSize)
- showSubtitles();
- WAIT(3);
- }
+ if (!rubCrystalBall())
+ return false;
// TODO: Subtitle stuff
recordTime();
@@ -604,9 +605,8 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
if (idx > 3)
wizard.draw(0, 0, Common::Point(9, 57));
- fizzle.draw(0, 0, Common::Point(9, 57));
+ fizzle.draw(0, idx, Common::Point(9, 57));
- clawCtr = (clawCtr + 1) % 32;
if (idx == 5)
sound.playSound("pharoh8.voc");
if (idx > 6)
@@ -635,7 +635,6 @@ bool DarkSideCutscenes::showDarkSideIntro2() {
sound.playFX(0);
}
- clawCtr = (clawCtr + 1) % 32;
showSubtitles();
WAIT(3);
} while (vocIndex < 2 || sound.isSoundPlaying() || _subtitleSize);
@@ -688,9 +687,9 @@ bool DarkSideCutscenes::showDarkSideIntro3() {
SpriteResource bird[11];
SpriteResource drop[4];
for (int idx = 0; idx < 11; ++idx)
- bird[idx].load(Common::String::format("bird%02d.int", idx));
+ bird[idx].load(Common::String::format("bird%02d.int", idx + 1));
for (int idx = 0; idx < 4; ++idx)
- drop[idx].load(Common::String::format("drop%d.int", idx));
+ drop[idx].load(Common::String::format("drop%d.int", idx + 1));
screen.loadPalette("fly.pal");
screen.loadBackground("fly.raw");
@@ -701,7 +700,7 @@ bool DarkSideCutscenes::showDarkSideIntro3() {
showSubtitles();
screen.fadeIn();
- sound.playSound("pharoh11.voc");
+ sound.playSound("pharoh11.voc", 2, 0);
for (int idx = 0; idx < 35; ++idx) {
screen.restoreBackground();
@@ -721,7 +720,7 @@ bool DarkSideCutscenes::showDarkSideIntro3() {
for (int idx = 0; idx < 81; ++idx) {
screen.restoreBackground();
- bird[idx % 8].draw(0, 0);
+ bird[idx / 8].draw(0, idx % 8);
switch (idx) {
case 1:
@@ -1676,10 +1675,11 @@ void DarkSideCutscenes::showDarkSideScore(uint endingScore) {
Common::String str = Common::String::format(Res.DARKSIDE_ENDING1, endingScore);
showPharaohEndText(str.c_str(), Res.DARKSIDE_ENDING2);
- saves.saveGame();
+ if (!_vm->shouldExit())
+ saves.saveGame();
}
-void DarkSideCutscenes::showPharaohEndText(const char *msg1, const char *msg2, const char *msg3) {
+bool DarkSideCutscenes::showPharaohEndText(const char *msg1, const char *msg2, const char *msg3) {
Screen &screen = *_vm->_screen;
EventsManager &events = *_vm->_events;
Windows &windows = *_vm->_windows;
@@ -1691,26 +1691,17 @@ void DarkSideCutscenes::showPharaohEndText(const char *msg1, const char *msg2, c
screen.loadBackground("3room.raw");
screen.saveBackground();
screen.loadPalette("dark.pal");
- claw.draw(0, 5, Common::Point(CLAW_XLIST3[0], CLAW_YLIST3[0]), SPRFLAG_800);
- claw.draw(0, 6, Common::Point(149, 184));
- dragon1.draw(0, PHAROAH_FRAMES[0], Common::Point(139, PHAROAH_YLIST[0]), SPRFLAG_800);
- claw.draw(0, 0, Common::Point(CLAW_XLIST3[0], CLAW_YLIST3[0]), SPRFLAG_800);
- screen.update();
+
+ int clawCtr = 0;
+ ANIMATE_PHAROAH;
screen.fadeIn();
events.clearEvents();
// Iterate through showing the pages
- int idx = 1;
for (int pageNum = 0; !_vm->shouldExit() && pageNum < numPages; ++pageNum) {
// Show each page until a key is pressed
do {
- // Draw the dragon pharoah
- events.updateGameCounter();
- screen.restoreBackground();
- claw.draw(0, 5, Common::Point(CLAW_XLIST3[idx], CLAW_YLIST3[idx]), SPRFLAG_800);
- claw.draw(0, 6, Common::Point(145, 185));
- dragon1.draw(0, PHAROAH_FRAMES[idx], Common::Point(139, PHAROAH_YLIST[idx]), SPRFLAG_800);
- claw.draw(0, idx % 5, Common::Point(CLAW_XLIST3[idx], CLAW_YLIST3[idx]), SPRFLAG_800);
+ ANIMATE_PHAROAH;
// Form the text string to display the text
Common::String str1 = Common::String::format(Res.PHAROAH_ENDING_TEXT1,
@@ -1722,12 +1713,13 @@ void DarkSideCutscenes::showPharaohEndText(const char *msg1, const char *msg2, c
windows[39].writeString(str2);
windows[0].update();
- events.wait(3);
- idx = (idx + 1) % 32;
+ WAIT(3);
} while (!_vm->shouldExit() && !events.isKeyMousePressed());
events.clearEvents();
}
+
+ return true;
}
} // End of namespace WorldOfXeen
diff --git a/engines/xeen/worldofxeen/darkside_cutscenes.h b/engines/xeen/worldofxeen/darkside_cutscenes.h
index 2822aed007..8a013794a9 100644
--- a/engines/xeen/worldofxeen/darkside_cutscenes.h
+++ b/engines/xeen/worldofxeen/darkside_cutscenes.h
@@ -36,9 +36,11 @@ private:
SpriteResource _ball, _claw, _dragon1;
private:
/**
- * Initial animation of the dragon pharoah
+ * Initial animation of the Dragon Pharoah moving his hands to the
+ * crystal ball, and then moving them back again
+ * @param fadeIn If set, fades in screen after first frame
*/
- void animatePharoah2(int frame);
+ bool rubCrystalBall(bool fadeIn = false);
/**
* Animates the dragon pharoah
@@ -89,7 +91,7 @@ protected:
/**
* Shows the Pharaoh ending screen where score text is shown
*/
- void showPharaohEndText(const char *msg1, const char *msg2 = nullptr, const char *msg3 = nullptr);
+ bool showPharaohEndText(const char *msg1, const char *msg2 = nullptr, const char *msg3 = nullptr);
public:
DarkSideCutscenes(XeenEngine *vm) : Cutscenes(vm) {}