aboutsummaryrefslogtreecommitdiff
path: root/engines/kyra
diff options
context:
space:
mode:
Diffstat (limited to 'engines/kyra')
-rw-r--r--engines/kyra/sequence/sequences_darkmoon.cpp128
1 files changed, 98 insertions, 30 deletions
diff --git a/engines/kyra/sequence/sequences_darkmoon.cpp b/engines/kyra/sequence/sequences_darkmoon.cpp
index 629cf8132d..5d313755a1 100644
--- a/engines/kyra/sequence/sequences_darkmoon.cpp
+++ b/engines/kyra/sequence/sequences_darkmoon.cpp
@@ -62,6 +62,7 @@ public:
void delay(uint32 ticks);
void waitForSongNotifier(int index, bool introUpdateAnim = false);
+ void updateAmigaSound();
private:
void setPaletteWithoutTextColor(int index);
@@ -99,6 +100,10 @@ private:
int _fadePalRate;
int _fadePalIndex;
+ uint8 _sndNextTrack;
+ uint16 _sndNextTrackMarker;
+ const uint16 *_sndMarkersFMTowns;
+
uint8 _textColor[3];
int _platformAnimOffset;
@@ -109,6 +114,7 @@ private:
static const char *const _palFilesIntroEGA[];
static const char *const _palFilesFinaleVGA[];
static const char *const _palFilesFinaleEGA[];
+ static const char *const _palFilesFinaleAmiga[];
};
int DarkMoonEngine::mainMenu() {
@@ -601,6 +607,10 @@ void DarkMoonEngine::seq_playIntro() {
}
void DarkMoonEngine::seq_playFinale() {
+ _screen->fadeToBlack();
+ _screen->clearCurPage();
+ _screen->clearPage(2);
+
DarkmoonSequenceHelper sq(_system, this, _screen, DarkmoonSequenceHelper::kFinale);
_screen->setCurPage(0);
@@ -608,9 +618,6 @@ void DarkMoonEngine::seq_playFinale() {
_sound->loadSoundFile(0);
snd_stopSound();
sq.delay(3);
-
- _screen->clearCurPage();
- _screen->clearPage(2);
_screen->updateScreen();
uint8 textColor1 = 10;
@@ -619,18 +626,14 @@ void DarkMoonEngine::seq_playFinale() {
if (_flags.platform == Common::kPlatformAmiga) {
textColor1 = 29;
textColor2 = 31;
- sq.loadScene(13, 2);
- sq.loadScene(14, 2);
- sq.loadScene(15, 2);
} else if (_configRenderMode == Common::kRenderEGA) {
textColor1 = 15;
}
-
sq.loadScene(0, 2);
sq.delay(18);
- if (!skipFlag() && !shouldQuit())
+ if (!skipFlag() && !shouldQuit() && _flags.platform != Common::kPlatformAmiga)
snd_playSong(1);
sq.update(2);
@@ -762,14 +765,16 @@ void DarkMoonEngine::seq_playFinale() {
sq.animCommand(10);
sq.animCommand(13);
- sq.initDelayedPaletteFade(4, 1);
+ if (_flags.platform != Common::kPlatformAmiga)
+ sq.initDelayedPaletteFade(4, 1);
sq.animCommand(14);
sq.animCommand(13);
sq.animCommand(14);
sq.animCommand(14);
sq.animCommand(13);
- sq.initDelayedPaletteFade(2, 1);
+ if (_flags.platform != Common::kPlatformAmiga)
+ sq.initDelayedPaletteFade(2, 1);
sq.animCommand(15);
sq.animCommand(14);
@@ -793,7 +798,8 @@ void DarkMoonEngine::seq_playFinale() {
sq.delay(8);
sq.animCommand(10);
- sq.initDelayedPaletteFade(5, 1);
+ if (_flags.platform != Common::kPlatformAmiga)
+ sq.initDelayedPaletteFade(5, 1);
sq.animCommand(13);
sq.animCommand(14);
sq.animCommand(13);
@@ -804,13 +810,22 @@ void DarkMoonEngine::seq_playFinale() {
sq.animCommand(14);
sq.animCommand(13);
sq.animCommand(12);
+ if (_flags.platform == Common::kPlatformAmiga)
+ sq.fadePalette(2, 3);
for (int i = 0; i < 4; i++)
sq.animCommand(16);
+ if (_flags.platform == Common::kPlatformAmiga)
+ sq.fadePalette(4, 3);
sq.animCommand(17);
sq.animCommand(18);
sq.printText(15, textColor1); // The temple ceases to exist
- sq.initDelayedPaletteFade(6, 1);
+ if (_flags.platform != Common::kPlatformAmiga) {
+ sq.initDelayedPaletteFade(6, 1);
+ } else {
+ _screen->fadePalette(_screen->getPalette(5), 127);
+ sq.copyPalette(5, 0);
+ }
sq.delay(36);
if (!skipFlag() && !shouldQuit())
@@ -819,12 +834,15 @@ void DarkMoonEngine::seq_playFinale() {
sq.delay(54);
sq.fadeText();
sq.loadScene(12, 2);
-
+
sq.waitForSongNotifier(_flags.platform == Common::kPlatformFMTowns ? 3475 : 5);
if (!skipFlag() && !shouldQuit())
snd_playSoundEffect(6);
+ if (_flags.platform == Common::kPlatformAmiga)
+ sq.copyPalette(6, 0);
+
if (!skipFlag() && !shouldQuit()) {
if (_configRenderMode != Common::kRenderEGA)
sq.setPaletteWithoutTextColor(0);
@@ -873,6 +891,7 @@ void DarkMoonEngine::seq_playFinale() {
if (skipFlag() || shouldQuit()) {
_screen->copyRegion(0, 0, 8, 8, 304, 128, 2, 0, Screen::CR_NO_P_CHECK);
} else {
+ sq.updateAmigaSound();
snd_playSoundEffect(6);
if (_configRenderMode != Common::kRenderEGA)
sq.setPaletteWithoutTextColor(0);
@@ -893,6 +912,7 @@ void DarkMoonEngine::seq_playFinale() {
sq.delay(12);
if (!skipFlag() && !shouldQuit())
snd_playSoundEffect(12);
+ sq.updateAmigaSound();
removeInputTop();
resetSkipFlag(true);
@@ -900,13 +920,17 @@ void DarkMoonEngine::seq_playFinale() {
sq.loadScene(10, 2);
sq.loadScene(9, 2);
- snd_stopSound();
- sq.delay(3);
-
- _sound->loadSoundFile(1);
+ if (_flags.platform == Common::kPlatformAmiga) {
+ sq.setPalette(7);
+ sq.delay(3);
+ } else {
+ snd_stopSound();
+ sq.delay(3);
+ _sound->loadSoundFile(1);
+ }
sq.delay(18);
- if (!skipFlag() && !shouldQuit())
+ if (!skipFlag() && !shouldQuit() && _flags.platform != Common::kPlatformAmiga)
snd_playSong(_flags.platform == Common::kPlatformFMTowns ? 16 : 1);
int temp = 0;
@@ -919,11 +943,13 @@ void DarkMoonEngine::seq_playFinale() {
sq.delay(90);
+ removeInputTop();
resetSkipFlag(true);
if (_configRenderMode != Common::kRenderEGA) {
- sq.setPalette(11);
- sq.fadePalette(9, textColor1);
+ if (_flags.platform != Common::kPlatformAmiga)
+ sq.setPalette(11);
+ sq.fadePalette(9, 10);
}
_screen->clearCurPage();
@@ -943,14 +969,20 @@ void DarkMoonEngine::seq_playFinale() {
if (_flags.platform == Common::kPlatformFMTowns)
sq.copyPalette(12, 0);
-
- sq.setPalette(9);
+
+ if (_flags.platform != Common::kPlatformAmiga)
+ sq.setPalette(9);
sq.fadePalette(0, 18);
- while (!skipFlag() && !shouldQuit())
+ while (!skipFlag() && !shouldQuit()) {
+ sq.updateAmigaSound();
delay(_tickLength);
+ }
snd_stopSound();
+ removeInputTop();
+ resetSkipFlag(true);
+
sq.fadePalette(9, 10);
}
@@ -962,6 +994,8 @@ void DarkMoonEngine::seq_playCredits(DarkmoonSequenceHelper *sq, const uint8 *da
_screen->setScreenDim(sd);
const ScreenDim *dm = _screen->_curDim;
+ const uint8 col1 = _flags.platform == Common::kPlatformAmiga ? 19 : 12;
+ const uint8 col2 = _flags.platform == Common::kPlatformAmiga ? 29 : 240;
_screen->copyRegion(dm->sx << 3, dm->sy, dm->sx << 3, dm->sy, dm->w << 3, dm->h, 0, backupPage, Screen::CR_NO_P_CHECK);
@@ -1037,6 +1071,7 @@ void DarkMoonEngine::seq_playCredits(DarkmoonSequenceHelper *sq, const uint8 *da
}
_screen->copyRegion(dm->sx << 3, dm->sy, dm->sx << 3, dm->sy, dm->w << 3, dm->h, backupPage, tempPage, Screen::CR_NO_P_CHECK);
+ sq->updateAmigaSound();
for (int h = 0; h < i; h++) {
if (items[h + 1].y < dm->h) {
@@ -1048,8 +1083,8 @@ void DarkMoonEngine::seq_playCredits(DarkmoonSequenceHelper *sq, const uint8 *da
if (items[h + 1].size == 6)
_screen->setFont(Screen::FID_6_FNT);
- _screen->printText(items[h + 1].str, (dm->sx << 3) + items[h + 1].x - 1, dm->sy + items[h + 1].y + 1, 12, 0);
- _screen->printText(items[h + 1].str, (dm->sx << 3) + items[h + 1].x, dm->sy + items[h + 1].y, 240, 0);
+ _screen->printText(items[h + 1].str, (dm->sx << 3) + items[h + 1].x - 1, dm->sy + items[h + 1].y + 1, col1, 0);
+ _screen->printText(items[h + 1].str, (dm->sx << 3) + items[h + 1].x, dm->sy + items[h + 1].y, col2, 0);
if (items[h + 1].size == 6)
_screen->setFont(Screen::FID_8_FNT);
@@ -1089,6 +1124,8 @@ DarkmoonSequenceHelper::DarkmoonSequenceHelper(OSystem *system, DarkMoonEngine *
int size = 0;
_platformAnimOffset = 0;
+ _sndNextTrack = 1;
+ _sndNextTrackMarker = 0;
if (mode == kIntro) {
_config = new Config(
@@ -1128,14 +1165,14 @@ DarkmoonSequenceHelper::DarkmoonSequenceHelper(OSystem *system, DarkMoonEngine *
_vm->staticres()->loadStrings(kEoB2FinaleStrings, size),
_vm->staticres()->loadStrings(kEoB2FinaleCPSFiles, size),
new const uint8*[13],
- _vm->_configRenderMode == Common::kRenderEGA ? _palFilesFinaleEGA : _palFilesFinaleVGA,
+ _vm->_flags.platform == Common::kPlatformAmiga ? _palFilesFinaleAmiga : (_vm->_configRenderMode == Common::kRenderEGA ? _palFilesFinaleEGA : _palFilesFinaleVGA),
new const DarkMoonShapeDef*[13],
new const DarkMoonAnimCommand *[21],
true,
true,
false,
false,
- 1,
+ _vm->_flags.platform == Common::kPlatformAmiga ? 2 : 1,
18,
true,
6
@@ -1159,9 +1196,16 @@ DarkmoonSequenceHelper::DarkmoonSequenceHelper(OSystem *system, DarkMoonEngine *
int numColors = 256;
if (_vm->_flags.platform == Common::kPlatformAmiga) {
- numColors = 32;
+ static const int8 palIndex[13] = { -1, -1, 3, 2, 4, 5, 6, 7, -1, -1, -1, -1, -1 };
for (int i = 0; i < 13; ++i)
_palettes[i] = &_screen->getPalette(i);
+ Common::SeekableReadStream *s = _config->palFiles ? _vm->resource()->createReadStream(_config->palFiles[0]) : 0;
+ numColors = 32;
+ for (int i = 0; i < 13; ++i) {
+ if (s && palIndex[i] != -1)
+ _palettes[palIndex[i]]->loadAmigaPalette(*s, 0, 32);
+ }
+ delete s;
} else {
for (int i = 0; _config->palFiles[i]; i++) {
if (i < 4)
@@ -1279,8 +1323,9 @@ void DarkmoonSequenceHelper::loadScene(int index, int pageNum, bool ignorePalett
if (_config->cpsData[index]) {
_screen->decodeSHP(_config->cpsData[index], pageNum);
} else if (s && chunkID == MKTAG('F', 'O', 'R', 'M')) {
- // The original code also handles files with FORM chunks and ILBM and PBM sub chunks. This will probably be necessary for Amiga versions.
- // The DOS versions do not need this, but still have the code for it. We error out for now.
+ // The original code also handles files with FORM chunks and ILBM and PBM sub chunks.
+ // Up until now I haven't found any need for these (Amiga versions included).
+ // We error out here theoretically, but this should never happen.
error("DarkmoonSequenceHelper::loadScene(): CPS file loading failure in scene %d - unhandled FORM chunk encountered", index);
} else if (s && !isRawData) {
@@ -1338,6 +1383,8 @@ void DarkmoonSequenceHelper::animCommand(int index, int del) {
uint32 end = 0;
for (const DarkMoonAnimCommand *s = _config->animData[index]; s->command != 0xFF && !_vm->skipFlag() && !_vm->shouldQuit(); s++) {
+ updateAmigaSound();
+
int palIndex = s->pal + _config->animPalOffs;
int x = s->x1;
@@ -1675,6 +1722,22 @@ void DarkmoonSequenceHelper::waitForSongNotifier(int index, bool introUpdateAnim
}
}
+void DarkmoonSequenceHelper::updateAmigaSound() {
+ if (_vm->gameFlags().platform != Common::kPlatformAmiga)
+ return;
+
+ int ct = _vm->sound()->checkTrigger();
+ if (ct < _sndNextTrackMarker)
+ return;
+
+ _vm->snd_playSong(_sndNextTrack++);
+ if (_sndNextTrack == 4)
+ _sndNextTrack = 1;
+
+ static const uint16 interval[4] = { 0, 1015, 4461, 1770 };
+ _sndNextTrackMarker = interval[_sndNextTrack];
+}
+
const char *const DarkmoonSequenceHelper::_palFilesIntroVGA[] = {
"PALETTE1.PAL",
"PALETTE3.PAL",
@@ -1717,6 +1780,11 @@ const char *const DarkmoonSequenceHelper::_palFilesFinaleEGA[] = {
0
};
+const char *const DarkmoonSequenceHelper::_palFilesFinaleAmiga[] = {
+ "FINALE.PAL",
+ 0
+};
+
void DarkMoonEngine::seq_nightmare() {
Screen::FontId of = _screen->setFont(Screen::FID_6_FNT);
if (_flags.lang == Common::JA_JPN)