/* ScummVM - Graphic Adventure Engine * * ScummVM is the legal property of its developers, whose names * are too numerous to list here. Please refer to the COPYRIGHT * file distributed with this source distribution. * * This program is free software; you can redistribute it and/or * modify it under the terms of the GNU General Public License * as published by the Free Software Foundation; either version 2 * of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. * */ /* * This code is based on Labyrinth of Time code with assistance of * * Copyright (c) 1993 Terra Nova Development * Copyright (c) 2004 The Wyrmkeep Entertainment Co. * */ #include "lab/lab.h" #include "lab/intro.h" #include "lab/labfun.h" #include "lab/resource.h" #include "lab/diff.h" #include "lab/text.h" #include "lab/interface.h" namespace Lab { extern bool nopalchange, DoBlack, IsHiRes; extern char diffcmap[256 * 3]; extern uint32 VGAScreenWidth, VGAScreenHeight; extern uint16 *FadePalette; Intro::Intro() { _msgfont = &_filler; _quitIntro = false; } /******************************************************************************/ /* Goes thru, and responds to all the intuition messages currently in the */ /* the message port. */ /******************************************************************************/ void Intro::introEatMessages() { while (1) { IntuiMessage *msg = getMsg(); if (g_engine->shouldQuit()) { _quitIntro = true; return; } if (msg == NULL) return; else { if (((msg->Class == MOUSEBUTTONS) && (IEQUALIFIER_RBUTTON & msg->Qualifier)) || ((msg->Class == RAWKEY) && (msg->Code == 27)) ) _quitIntro = true; } } } /*****************************************************************************/ /* Reads in a picture. */ /*****************************************************************************/ void Intro::doPictText(const char *filename, bool isscreen) { uint32 lastsecs = 0L, lastmicros = 0L, secs = 0L, micros = 0L; IntuiMessage *msg; char path[50] = "Lab:rooms/Intro/"; byte *curplace, **tfile; bool drawNextText = true, end = false, begin = true; int32 cls, code, Drawn; int16 qualifier; uint timedelay; strcat(path, filename); if (isscreen) { g_music->updateMusic(); timedelay = 35; } else { g_music->updateMusic(); timedelay = 7; } if (_quitIntro) return; while (1) { if (drawNextText) { if (begin) { begin = false; tfile = g_music->newOpen(path); if (!tfile) return; curplace = *tfile; } else if (isscreen) fade(false, 0); if (isscreen) { setAPen(7L); rectFill(VGAScaleX(10), VGAScaleY(10), VGAScaleX(310), VGAScaleY(190)); Drawn = flowText(_msgfont, (!IsHiRes) * -1, 5, 7, false, false, true, true, VGAScaleX(14), VGAScaleY(11), VGAScaleX(306), VGAScaleY(189), (char *)curplace); fade(true, 0); } else { Drawn = longDrawMessage((char *)curplace); } curplace += Drawn; end = (*curplace == 0); drawNextText = false; introEatMessages(); if (_quitIntro) { if (isscreen) fade(false, 0); return; } g_lab->getTime(&lastsecs, &lastmicros); } msg = getMsg(); if (msg == NULL) { g_music->updateMusic(); diffNextFrame(); g_lab->getTime(&secs, µs); g_lab->anyTimeDiff(lastsecs, lastmicros, secs, micros, &secs, µs); if (secs > timedelay) { if (end) { if (isscreen) fade(false, 0); return; } else { drawNextText = true; } } waitTOF(); } else { cls = msg->Class; qualifier = msg->Qualifier; code = msg->Code; if (((cls == MOUSEBUTTONS) && (IEQUALIFIER_RBUTTON & qualifier)) || ((cls == RAWKEY) && (code == 27))) { _quitIntro = true; if (isscreen) fade(false, 0); return; } else if (cls == MOUSEBUTTONS) { if (IEQUALIFIER_LEFTBUTTON & qualifier) { if (end) { if (isscreen) fade(false, 0); return; } else drawNextText = true; } introEatMessages(); if (_quitIntro) { if (isscreen) fade(false, 0); return; } } if (end) { if (isscreen) fade(false, 0); return; } else drawNextText = true; } } } /*****************************************************************************/ /* Does a one second delay, but checks the music while doing it. */ /*****************************************************************************/ void Intro::musicDelay() { int16 counter; g_music->updateMusic(); if (_quitIntro) return; for (counter = 0; counter < 20; counter++) { g_music->updateMusic(); waitTOF(); waitTOF(); waitTOF(); } } void Intro::nReadPict(const char *filename, bool playOnce) { Common::String finalFileName = Common::String("P:Intro/") + filename; g_music->updateMusic(); introEatMessages(); if (_quitIntro) return; DoBlack = _introDoBlack; stopDiffEnd(); readPict(finalFileName.c_str(), playOnce); } /*****************************************************************************/ /* Does the introduction sequence for Labyrinth. */ /*****************************************************************************/ void Intro::introSequence() { uint16 counter, counter1; uint16 palette[16] = { 0x0000, 0x0855, 0x0FF9, 0x0EE7, 0x0ED5, 0x0DB4, 0x0CA2, 0x0C91, 0x0B80, 0x0B80, 0x0B91, 0x0CA2, 0x0CB3, 0x0DC4, 0x0DD6, 0x0EE7 }; DoBlack = true; if (g_lab->getPlatform() != Common::kPlatformWindows) { nReadPict("EA0", true); nReadPict("EA1", true); nReadPict("EA2", true); nReadPict("EA3", true); } else { nReadPict("WYRMKEEP", true); // Wait 4 seconds for (counter = 0; counter < 4 * 1000 / 10; counter++) { introEatMessages(); if (_quitIntro) break; g_system->delayMillis(10); } } blackAllScreen(); g_music->initMusic(); nopalchange = true; if (g_lab->getPlatform() != Common::kPlatformWindows) nReadPict("TNDcycle.pic", true); else nReadPict("TNDcycle2.pic", true); nopalchange = false; FadePalette = palette; for (counter = 0; counter < 16; counter++) { if (_quitIntro) break; palette[counter] = ((diffcmap[counter * 3] >> 2) << 8) + ((diffcmap[counter * 3 + 1] >> 2) << 4) + (diffcmap[counter * 3 + 2] >> 2); } g_music->updateMusic(); fade(true, 0); for (int times = 0; times < 150; times++) { if (_quitIntro) break; g_music->updateMusic(); uint16 temp = palette[2]; for (counter = 2; counter < 15; counter++) palette[counter] = palette[counter + 1]; palette[15] = temp; setAmigaPal(palette, 16); waitTOF(); } fade(false, 0); blackAllScreen(); g_music->updateMusic(); nReadPict("Title.A", true); nReadPict("AB", true); musicDelay(); nReadPict("BA", true); nReadPict("AC", true); musicDelay(); if (g_lab->getPlatform() == Common::kPlatformWindows) musicDelay(); // more credits on this page now nReadPict("CA", true); nReadPict("AD", true); musicDelay(); if (g_lab->getPlatform() == Common::kPlatformWindows) musicDelay(); // more credits on this page now nReadPict("DA", true); musicDelay(); g_music->newOpen("p:Intro/Intro.1"); /* load the picture into the buffer */ g_music->updateMusic(); blackAllScreen(); g_music->updateMusic(); _msgfont = g_resource->getFont("P:Map.fon"); nopalchange = true; nReadPict("Intro.1", true); nopalchange = false; for (counter = 0; counter < 16; counter++) { palette[counter] = ((diffcmap[counter * 3] >> 2) << 8) + ((diffcmap[counter * 3 + 1] >> 2) << 4) + (diffcmap[counter * 3 + 2] >> 2); } doPictText("i.1", true); doPictText("i.2A", true); doPictText("i.2B", true); freeAllStolenMem(); blackAllScreen(); g_music->updateMusic(); _introDoBlack = true; nReadPict("Station1", true); doPictText("i.3", false); nReadPict("Station2", true); doPictText("i.4", false); nReadPict("Stiles4", true); doPictText("i.5", false); nReadPict("Stiles3", true); doPictText("i.6", false); nReadPict("Platform2", true); doPictText("i.7", false); nReadPict("Subway.1", true); doPictText("i.8", false); nReadPict("Subway.2", true); doPictText("i.9", false); doPictText("i.10", false); doPictText("i.11", false); if (!_quitIntro) for (counter = 0; counter < 50; counter++) { for (counter1 = (8 * 3); counter1 < (255 * 3); counter1++) diffcmap[counter1] = 255 - diffcmap[counter1]; g_music->updateMusic(); waitTOF(); VGASetPal(diffcmap, 256); waitTOF(); waitTOF(); } doPictText("i.12", false); doPictText("i.13", false); _introDoBlack = false; nReadPict("Daed0", true); doPictText("i.14", false); nReadPict("Daed1", true); doPictText("i.15", false); nReadPict("Daed2", true); doPictText("i.16", false); doPictText("i.17", false); doPictText("i.18", false); nReadPict("Daed3", true); doPictText("i.19", false); doPictText("i.20", false); nReadPict("Daed4", true); doPictText("i.21", false); nReadPict("Daed5", true); doPictText("i.22", false); doPictText("i.23", false); doPictText("i.24", false); nReadPict("Daed6", true); doPictText("i.25", false); doPictText("i.26", false); nReadPict("Daed7", false); doPictText("i.27", false); doPictText("i.28", false); stopDiffEnd(); nReadPict("Daed8", true); doPictText("i.29", false); doPictText("i.30", false); nReadPict("Daed9", true); doPictText("i.31", false); doPictText("i.32", false); doPictText("i.33", false); nReadPict("Daed9a", true); nReadPict("Daed10", true); doPictText("i.34", false); doPictText("i.35", false); doPictText("i.36", false); nReadPict("SubX", true); if (_quitIntro) { setAPen(0); rectFill(0, 0, VGAScreenWidth - 1, VGAScreenHeight - 1); DoBlack = true; } } } // End of namespace Lab