mirror of
https://github.com/libretro/scummvm.git
synced 2025-01-10 11:51:52 +00:00
268 lines
9.0 KiB
C++
268 lines
9.0 KiB
C++
/* 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.
|
|
*
|
|
*
|
|
* Based on the original sources
|
|
* Faery Tale II -- The Halls of the Dead
|
|
* (c) 1993-1996 The Wyrmkeep Entertainment Co.
|
|
*/
|
|
|
|
#ifndef SAGA2_FTA_H
|
|
#define SAGA2_FTA_H
|
|
|
|
#include "saga2/gpointer.h"
|
|
#include "saga2/rmem.h"
|
|
|
|
namespace Saga2 {
|
|
|
|
class SaveFileConstructor;
|
|
class SaveFileReader;
|
|
class hResContext;
|
|
class hResource;
|
|
|
|
/* ===================================================================== *
|
|
Constants
|
|
* ===================================================================== */
|
|
|
|
// For GameMode Stack
|
|
const int Max_Modes = 8, //Max Game Mode Objects
|
|
End_List = 0; //Variable To Indicate End Of Arg List
|
|
|
|
// Width and height of full screen
|
|
const int screenWidth = 640,
|
|
screenHeight = 480;
|
|
|
|
// Number of ticks per second
|
|
const int ticksPerSecond = 72; // 72 ticks per second
|
|
|
|
// Desired frame rate of game (fps)
|
|
const int frameRate = 10,
|
|
framePeriod = ticksPerSecond / frameRate;
|
|
|
|
/* ====================================================================== *
|
|
Overall game modes
|
|
* ====================================================================== */
|
|
|
|
/* There are basically 5 different 'modes' in the game. Three of those modes
|
|
are exclusive, while the other two "nest" on top of the others.
|
|
|
|
The exclusive modes are:
|
|
1. Intro The animated slideshow of the introduction.
|
|
2. Finale The animated slideshow of the finale.
|
|
3. Main Play The scrolling tilemap view.
|
|
|
|
The modes which can nest on top of the others are:
|
|
4. Modal Dialog A popup window that blocks all other input.
|
|
5. Cut Scene A non-interactive animated interlude.
|
|
|
|
The GameMode class represents these modes as an explicit object.
|
|
*/
|
|
|
|
struct gMouseState;
|
|
|
|
class GameMode {
|
|
public:
|
|
GameMode *prev; // previous nested mode
|
|
int16 nestable; // true if mode nests
|
|
|
|
static GameMode *modeStackPtr[Max_Modes]; // Array Of Current Mode Stack Pointers to Game Objects
|
|
static int modeStackCtr; // Counter For Array Of Mode Stack Pointers to Game Objects
|
|
static GameMode *newmodeStackPtr[Max_Modes]; // Array Of New Mode Stack Pointers to Game Objects
|
|
static int newmodeStackCtr; // Counter For Array Of Mode Stack Pointers to Game Objects
|
|
static int newmodeFlag; // Flag Telling EventLoop Theres A New Mode So Update
|
|
static GameMode *currentMode, // pointer to current mode.
|
|
*newMode; // next mode to run
|
|
|
|
void (*setup)(void); // initialize this mode
|
|
void (*cleanup)(void); // deallocate mode resources
|
|
void (*handleTask)(void); // "application task" for mode
|
|
void (*handleKey)(int16 key, int16 qual); // handle keystroke from window
|
|
void (*draw)(void); // handle draw functions for window
|
|
|
|
static void modeUnStack(void);
|
|
static void modeUnStack(int StopHere);
|
|
static int getStack(GameMode **saveStackPtr);
|
|
static void SetStack(GameMode *modeFirst, ...);
|
|
static void SetStack(GameMode **newStack, int newStackSize);
|
|
static bool update(void);
|
|
static void modeStack(GameMode *AddThisMode);
|
|
void begin(void); // launch this mode
|
|
void end(void); // quit this mode
|
|
static void modeSwitch(void); // quit this mode
|
|
};
|
|
|
|
extern GameMode IntroMode,
|
|
FinaleMode,
|
|
PlayMode,
|
|
TileMode,
|
|
StageMode,
|
|
ModalDialogMode,
|
|
CutSceneMode,
|
|
VideoMode; //stageprob
|
|
|
|
/* ====================================================================== *
|
|
Game Clock routines
|
|
* ====================================================================== */
|
|
|
|
// Initialize the timer
|
|
void initTimer(void);
|
|
|
|
// Save the timer to a save file
|
|
void saveTimer(SaveFileConstructor &saveGame);
|
|
|
|
// Load the timer from a save file
|
|
void loadTimer(SaveFileReader &saveGame);
|
|
|
|
// Cleanup the timer -- nothing to do
|
|
inline void cleanupTimer(void) {}
|
|
|
|
void pauseTimer(void); // pause game clock
|
|
void resumeTimer(void); // resume game clock
|
|
|
|
// Alarm is a useful class for specifying time delays. It will
|
|
// work correctly even if the game counter wraps around.
|
|
|
|
class Alarm {
|
|
private:
|
|
uint32 basetime; // timer alarm was set
|
|
uint32 duration; // duration of alarm
|
|
public:
|
|
void set(uint32 duration);
|
|
bool check(void);
|
|
uint32 elapsed(void); // time elapsed since alarm set
|
|
};
|
|
|
|
/* ===================================================================== *
|
|
Misc Prototypes
|
|
* ===================================================================== */
|
|
|
|
// Debugging status
|
|
|
|
void WriteStatusF(int16 lin, const char *msg, ...);
|
|
|
|
// File loading
|
|
|
|
void *LoadFile(char *filename); // load file into buffer
|
|
RHANDLE LoadFileToHandle(char *filename); // load file into relocatable buf
|
|
|
|
// Resource loading
|
|
|
|
void *LoadResource(hResContext *con, uint32 id, const char desc[]);
|
|
RHANDLE LoadResourceToHandle(hResContext *con, uint32 id, const char desc[]);
|
|
Common::SeekableReadStream *loadResourceToStream(hResContext *con, uint32 id, const char desc[]);
|
|
|
|
// Asynchronous resource loading
|
|
|
|
void RequestResource(
|
|
RHANDLE handle,
|
|
int32 offset,
|
|
int32 length,
|
|
// Function to notify when request is done.
|
|
void *notify = NULL,
|
|
void *userData = NULL);
|
|
|
|
void syncResources(void);
|
|
void *lockResource(RHANDLE h);
|
|
void unlockResource(RHANDLE h);
|
|
|
|
void loadAsyncResources(void);
|
|
|
|
// Directory control
|
|
|
|
void restoreProgramDir(void); // chdir() to program directory
|
|
|
|
// Memory allocation
|
|
|
|
void *mustAlloc(uint32 size, const char desc[]); // alloc 'size' bytes or fail
|
|
RHANDLE mustAllocHandle(uint32 size, const char desc[]); // as above, but relocatable
|
|
//void checkAlloc( void *ptr ); // check allocation
|
|
#define checkAlloc(ptr) (ptr)
|
|
|
|
// Returns Random Number
|
|
|
|
int16 GetRandomBetween(int start, int end);
|
|
|
|
// Distance calculation
|
|
|
|
int16 quickDistance(const Point16 &p);
|
|
int32 quickDistance(const Point32 &p);
|
|
|
|
void initPathFinder(void);
|
|
void cleanupPathFinder(void);
|
|
|
|
/* ===================================================================== *
|
|
Miscellaneous globals management functions
|
|
* ===================================================================== */
|
|
|
|
void initGlobals(void);
|
|
void saveGlobals(SaveFileConstructor &saveGame);
|
|
void loadGlobals(SaveFileReader &saveGame);
|
|
inline void cleanupGlobals(void) {} // do nothing
|
|
|
|
/* ===================================================================== *
|
|
General redraw routine
|
|
* ===================================================================== */
|
|
|
|
void reDrawScreen(void);
|
|
|
|
/* ===================================================================== *
|
|
Script-related
|
|
* ===================================================================== */
|
|
|
|
typedef int16 ThreadID;
|
|
const ThreadID NoThread = -1;
|
|
|
|
// Wake up a thread unconditionally
|
|
void wakeUpThread(ThreadID thread);
|
|
|
|
// Wake up a thread and set return value from SAGA function
|
|
void wakeUpThread(ThreadID thread, int16 returnVal);
|
|
|
|
// Script system initialization and cleanup
|
|
void initScripts(void);
|
|
void cleanupScripts(void);
|
|
void dispatchScripts(void);
|
|
|
|
// An extended script is running -- suspend all background processing.
|
|
extern int16 extendedThreadLevel;
|
|
|
|
/* ===================================================================== *
|
|
Misc Globals
|
|
* ===================================================================== */
|
|
|
|
extern bool gameRunning; // true while game running
|
|
|
|
extern gDisplayPort mainPort; // main drawing port
|
|
extern gMousePointer pointer; // the mouse pointer
|
|
|
|
extern RHeapPtr gameHeap; // memory heap for game
|
|
|
|
extern volatile int32 gameTime; // current timer
|
|
|
|
// Resource files
|
|
|
|
extern hResource *resFile, // our main resource file
|
|
*objResFile,
|
|
*auxResFile;
|
|
|
|
} // end of namespace Saga2
|
|
|
|
#endif
|