2002-11-21 05:40:49 +00:00
|
|
|
/*******************************************************************************
|
2002-12-29 06:50:19 +00:00
|
|
|
This file is Part of the ZEngine Library for 2D game development.
|
|
|
|
Copyright (C) 2002, 2003 James Turk
|
2002-11-21 05:40:49 +00:00
|
|
|
|
2002-12-29 06:50:19 +00:00
|
|
|
Licensed under a BSD-style license.
|
2002-11-21 05:40:49 +00:00
|
|
|
|
2002-12-29 06:50:19 +00:00
|
|
|
The maintainer of this library is James Turk (james@conceptofzero.net)
|
|
|
|
and the home of this Library is http://www.zengine.sourceforge.net
|
2002-11-21 05:40:49 +00:00
|
|
|
*******************************************************************************/
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\par File Header:
|
|
|
|
File: ZE_ZEngine.h <br>
|
|
|
|
Description: Header file for ZEngine class, the core of the ZEngine. <br>
|
|
|
|
Author(s): James Turk <br>
|
2003-02-03 00:04:28 +00:00
|
|
|
$Id: ZE_ZEngine.h,v 1.20 2003/02/03 00:04:28 cozman Exp $<br>
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
\file ZE_ZEngine.h
|
|
|
|
\brief Definition file for core ZEngine class.
|
|
|
|
|
|
|
|
ZEngine Game Engine core Engine definition.
|
|
|
|
**/
|
|
|
|
|
|
|
|
#ifndef __ze_zengine_h__
|
|
|
|
#define __ze_zengine_h__
|
|
|
|
|
|
|
|
#include "ZE_Defines.h"
|
2003-01-15 05:51:18 +00:00
|
|
|
#include "ZE_Utility.h"
|
2002-11-21 05:40:49 +00:00
|
|
|
#include "ZE_Includes.h"
|
2003-01-13 06:31:08 +00:00
|
|
|
#include "ZE_ZError.h"
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief ZEngine Namespace.
|
|
|
|
|
|
|
|
Namespace for ZEngine classes and utility functions.
|
|
|
|
**/
|
|
|
|
namespace ZE
|
|
|
|
{
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Main ZEngine Singleton Class
|
|
|
|
|
|
|
|
ZEngine Singleton Class, accessible from anywhere in a ZEngine-based program by nature. Controls core elements of program and does
|
|
|
|
majority of SDL wrapping. Also keeps track of loaded data and helps programs avoid memory leaks and dangling pointers.
|
|
|
|
**/
|
|
|
|
class ZEngine
|
|
|
|
{
|
|
|
|
/////////////////////////////////
|
|
|
|
//Singleton + Memory Management//
|
|
|
|
/////////////////////////////////
|
|
|
|
|
|
|
|
private:
|
|
|
|
//! Static Pointer to Instance of ZEngine for Singleton.
|
|
|
|
static ZEngine *sInstance;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Constructor for ZEngine.
|
|
|
|
|
|
|
|
Initialize ZEngine values to defaults. (Private so that only one instance may be created.)
|
|
|
|
**/
|
|
|
|
ZEngine();
|
|
|
|
|
|
|
|
public:
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Instance.
|
|
|
|
|
|
|
|
Static function, returns pointer to instance of ZEngine, creating an instance if none exist.
|
|
|
|
\return Instance to the ZEngine.
|
|
|
|
**/
|
|
|
|
static ZEngine* GetInstance();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Release Instance.
|
|
|
|
|
|
|
|
Release memory held by instance of engine and closes window.
|
|
|
|
**/
|
|
|
|
static void ReleaseInstance();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Current Version.
|
|
|
|
|
|
|
|
Get Version Number of ZEngine. (Major.Minor.Extension#)
|
|
|
|
\return string containing version number
|
|
|
|
**/
|
|
|
|
static string GetVersion();
|
|
|
|
|
|
|
|
//////////////////
|
|
|
|
//Initialization//
|
|
|
|
//////////////////
|
|
|
|
|
|
|
|
private:
|
|
|
|
//! Width of Display
|
|
|
|
int mWidth;
|
|
|
|
//! Height of Display
|
|
|
|
int mHeight;
|
|
|
|
//! BPP Setting of Display
|
|
|
|
int mBPP;
|
|
|
|
//! Fullscreen setting of Display
|
|
|
|
bool mFullscreen;
|
2003-01-27 04:33:34 +00:00
|
|
|
//! If ZEngine display has been setup.
|
|
|
|
bool mInitialized;
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
#ifdef USE_SDL_MIXER
|
|
|
|
//! Sound Bitrate
|
|
|
|
int mRate;
|
|
|
|
//! Stereo setting of Sound Subsystem
|
|
|
|
bool mStereo;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
|
|
|
|
public:
|
|
|
|
//add initialization
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Setup Display for SDL.
|
|
|
|
|
|
|
|
Sets display parameters to specified parameters. (called before CreateDisplay)
|
|
|
|
|
|
|
|
\param width Desired width of screen or window.
|
|
|
|
\param height Desired height of screen or window.
|
2003-01-24 19:41:54 +00:00
|
|
|
\param bpp Desired BPP for screen, generally use 8,16 or 32, pass -1 if you want ZEngine to guess the best choice.
|
2002-11-21 05:40:49 +00:00
|
|
|
\param fullscreen A bool for fullscreen setting.
|
|
|
|
**/
|
|
|
|
void SetupDisplay(int width, int height, int bpp, bool fullscreen);
|
|
|
|
|
|
|
|
#ifdef USE_SDL_MIXER
|
|
|
|
/*!
|
|
|
|
\brief Initialize Sound for SDL.
|
|
|
|
|
2003-02-02 23:30:15 +00:00
|
|
|
Set sound settings to specified parameters. (If not called before CreateDisplay rate will default to 22050+mono)
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
\param rate Desired sound bitrate.
|
|
|
|
\param stereo A bool for stereo setting.
|
|
|
|
**/
|
|
|
|
void SetupSound(int rate, bool stereo);
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/*!
|
2002-11-28 23:15:52 +00:00
|
|
|
\brief Create Display with predefined settings.
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
SetupDisplay and SetupSound should be called prior to this to change settings, settings from those do not go into effect
|
2003-02-02 23:30:15 +00:00
|
|
|
until this function is called. Specify no icon file to use default icon for OS. Returns result of setting up ZEngine, and logs
|
2003-01-24 19:41:54 +00:00
|
|
|
error if false is returned (Trys not to fail + returns bool in versions >= 0.8.2).
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
\param title Window Title.
|
|
|
|
\param icon Path to Icon File.
|
2003-01-19 02:05:13 +00:00
|
|
|
\return result of setting up the display, true if everything went ok, false if any setup failed (check GetLastError).
|
2002-11-21 05:40:49 +00:00
|
|
|
**/
|
2003-01-12 07:09:04 +00:00
|
|
|
bool CreateDisplay(string title, string icon="");
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Quit SDL and any Subsystems.
|
|
|
|
|
2003-01-13 06:31:08 +00:00
|
|
|
Shut down SDL (and SDL_ttf,SDL_mixer if necessary) You shouldn't ever have to call this, ReleaseInstance calls this for you.
|
2002-11-21 05:40:49 +00:00
|
|
|
**/
|
2002-11-28 23:15:52 +00:00
|
|
|
void CloseDisplay();
|
2002-11-21 05:40:49 +00:00
|
|
|
|
2003-01-25 19:55:13 +00:00
|
|
|
/*!
|
|
|
|
\brief Toggle fullscreen/windowed mode.
|
|
|
|
|
|
|
|
Safely toggles fullscreen/windowed mode, generally toggling modes will bring the need to reload images so it will
|
|
|
|
set the ImagesNeedReload state to true.
|
|
|
|
\since 0.8.2
|
|
|
|
**/
|
|
|
|
void ToggleFullscreen();
|
|
|
|
|
2003-01-27 04:33:34 +00:00
|
|
|
/*!
|
|
|
|
\brief Check state of ZEngine.
|
|
|
|
|
|
|
|
Checks if ZEngine display has been properly setup.
|
|
|
|
\since 0.8.2
|
|
|
|
\return Boolean status of ZEngine, true if CreateDisplay has been successfully called, false if ZEngine has no display.
|
|
|
|
**/
|
|
|
|
bool Initialized();
|
|
|
|
|
2002-11-21 05:40:49 +00:00
|
|
|
/////////////////
|
|
|
|
//Screen Access//
|
|
|
|
/////////////////
|
|
|
|
|
|
|
|
private:
|
|
|
|
//! Pointer to Display
|
|
|
|
SDL_Surface *mScreen;
|
|
|
|
|
|
|
|
public:
|
|
|
|
/*!
|
|
|
|
\brief Allow access to Screen Surface.
|
|
|
|
|
|
|
|
Get pointer to screen SDL_Surface, allowing direct screen manipulation using SDL.
|
|
|
|
\return Pointer to Display Surface.
|
|
|
|
**/
|
2002-11-28 23:15:52 +00:00
|
|
|
SDL_Surface *Display();
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
2002-12-12 02:50:35 +00:00
|
|
|
\brief Update display contents.
|
2002-11-21 05:40:49 +00:00
|
|
|
|
2003-01-04 05:16:01 +00:00
|
|
|
Swap OpenGL buffers, and update screen, if a desired framerate is set it will delay to stay under that rate.
|
|
|
|
Must be called every frame.
|
2002-11-21 05:40:49 +00:00
|
|
|
**/
|
2002-12-12 02:50:35 +00:00
|
|
|
void Update();
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
2002-12-01 07:56:17 +00:00
|
|
|
\brief Clear screen to a certain color (Black by default).
|
2002-11-21 05:40:49 +00:00
|
|
|
|
2002-12-01 07:56:17 +00:00
|
|
|
Clears a rectangle on screen to a color, defaults to solid black.
|
|
|
|
\param red Red component (0.0-1.0) of new color.
|
|
|
|
\param green Green component (0.0-1.0) of new color.
|
|
|
|
\param blue Blue component (0.0-1.0) of new color.
|
|
|
|
\param alpha Alpha component (0.0-1.0) of new color.
|
2002-11-21 05:40:49 +00:00
|
|
|
**/
|
2002-12-01 07:56:17 +00:00
|
|
|
void Clear(float red=0.0f, float green=0.0f, float blue=0.0f, float alpha=1.0f);
|
|
|
|
|
|
|
|
/////////////////////////////
|
|
|
|
//OpenGL Specific Functions//
|
|
|
|
/////////////////////////////
|
|
|
|
public:
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
2002-12-01 07:56:17 +00:00
|
|
|
\brief Setup OpenGL ortho mode.
|
2002-11-21 05:40:49 +00:00
|
|
|
|
2002-12-01 07:56:17 +00:00
|
|
|
Sets the OpenGL scaled orthographic mode, called once at beginning, no need to call
|
|
|
|
unless you change the OpenGL mode manually.
|
2002-11-21 05:40:49 +00:00
|
|
|
**/
|
2002-12-01 07:56:17 +00:00
|
|
|
void SetGL2D();
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
////////////////////////////////////////////
|
|
|
|
//Timer and Framerate Independent Movement//
|
|
|
|
////////////////////////////////////////////
|
|
|
|
|
|
|
|
private:
|
|
|
|
//! Keep track of paused state of game.
|
|
|
|
bool mPaused;
|
|
|
|
//! Keep track of if ZEngine should unpause on active event.
|
|
|
|
bool mUnpauseOnActive;
|
2003-01-04 05:16:01 +00:00
|
|
|
//! Value framerate strives to be at, set by SetDesiredFramerate.
|
|
|
|
Uint8 mDesiredFramerate;
|
|
|
|
//! Time scheduled for next update (used for framerate locked movement).
|
|
|
|
Uint32 mNextUpdate;
|
2002-11-21 05:40:49 +00:00
|
|
|
//! Keep track of time game was last paused.
|
|
|
|
Uint32 mLastPause;
|
|
|
|
//! Keep track of total globally paused time.
|
|
|
|
Uint32 mPausedTime;
|
|
|
|
//! Keep track of last screen update time.
|
|
|
|
Uint32 mLastTime;
|
|
|
|
//! Seconds per frame.
|
|
|
|
double mSecPerFrame;
|
|
|
|
|
|
|
|
public:
|
|
|
|
/*!
|
|
|
|
\brief Sleep for a certain amount of time.
|
|
|
|
|
|
|
|
Freeze everything for given number of milliseconds.
|
|
|
|
\param milliseconds Number of milliseconds to freeze.
|
|
|
|
**/
|
2002-11-28 23:15:52 +00:00
|
|
|
void Delay(Uint32 milliseconds);
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Global ZEngine time.
|
|
|
|
|
|
|
|
Get active time since ZEngine initialization in milliseconds, paused time doesn't count.
|
|
|
|
\return Number of active milliseconds since initialization.
|
|
|
|
**/
|
|
|
|
Uint32 GetTime();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Pause ZEngine.
|
|
|
|
|
|
|
|
Pause ZEngine timer and all ZTimer objects that rely on ZEngine.
|
|
|
|
**/
|
|
|
|
void PauseTimer();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Unpause ZEngine.
|
|
|
|
|
|
|
|
Unpause ZEngine timer and all ZTimer objects that rely on ZEngine.
|
|
|
|
**/
|
|
|
|
void UnpauseTimer();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Seconds Per Frame.
|
|
|
|
|
2003-01-04 05:16:01 +00:00
|
|
|
Get double that describes the time passed between screen updates. (should be used for Framerate Independant Movement)
|
2002-11-21 05:40:49 +00:00
|
|
|
\return Time between screen updates.
|
|
|
|
**/
|
|
|
|
double GetFrameTime();
|
|
|
|
|
2003-01-04 05:16:01 +00:00
|
|
|
/*!
|
|
|
|
\brief Get Frames Per Second.
|
|
|
|
|
|
|
|
Get double representing current (approximate) FPS. This value is always the same as 1/GetFrameTime().
|
|
|
|
\since 0.8.2
|
|
|
|
\return Current Framerate.
|
|
|
|
**/
|
|
|
|
double GetFramerate();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Set Desired Framerate.
|
|
|
|
|
|
|
|
Sets desired framerate, if engine gets ahead of desired rate during a frame it will stall in Update until
|
|
|
|
current framerate is closer to that desired. Acceptable values are 1-255, setting this value to 0 will disable this
|
|
|
|
feature. (Desired framerate is disabled upon initialization of ZEngine.)
|
|
|
|
\since 0.8.2
|
|
|
|
\param rate Desired framerate 1-255, or 0 to disable.
|
|
|
|
**/
|
|
|
|
void SetDesiredFramerate(Uint8 rate);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Desired Framerate.
|
|
|
|
|
|
|
|
Get desired framerate set by SetDesiredFramerate.
|
|
|
|
\since 0.8.2
|
|
|
|
\return Current setting for desired framerate.
|
|
|
|
**/
|
|
|
|
Uint8 GetDesiredFramerate();
|
|
|
|
|
2002-11-21 05:40:49 +00:00
|
|
|
/*!
|
|
|
|
\brief Check Engine Paused State.
|
|
|
|
|
|
|
|
Find out if engine timer is paused.
|
|
|
|
\return Paused State of engine.
|
|
|
|
**/
|
|
|
|
bool IsPaused();
|
|
|
|
|
|
|
|
////////////////////////////
|
|
|
|
//Event and Input Handling//
|
|
|
|
////////////////////////////
|
|
|
|
private:
|
2002-12-27 03:15:33 +00:00
|
|
|
//! bool which is only set to true if the engine thinks the images need to be reloaded (loss of focus in fullscreen).
|
|
|
|
bool mNeedReload;
|
2002-11-21 05:40:49 +00:00
|
|
|
//! bool describing Active or Inactive State of Game
|
|
|
|
bool mActive;
|
|
|
|
//! bool for checking if a Quit event has been detected
|
|
|
|
bool mQuit;
|
|
|
|
//! Pointer to array of Keys
|
2002-12-03 06:19:43 +00:00
|
|
|
Uint8 *mKeyIsPressed;
|
|
|
|
//! Array of keys, used by KeyPress
|
|
|
|
bool mKeyPress[SDLK_LAST];
|
2002-11-21 05:40:49 +00:00
|
|
|
//! X Position of Mouse
|
|
|
|
int mMouseX;
|
|
|
|
//! Y Position of Mouse
|
|
|
|
int mMouseY;
|
|
|
|
//! Mouse Button Information
|
|
|
|
Uint8 mMouseB;
|
|
|
|
|
|
|
|
public:
|
|
|
|
/*!
|
|
|
|
\brief Find out if application is active.
|
|
|
|
|
|
|
|
Function to find out if application currently has focus.
|
|
|
|
\return bool telling active/inactive state of application.
|
|
|
|
**/
|
|
|
|
bool IsActive();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Request A Quit.
|
|
|
|
|
|
|
|
Tell the engine that it should behave as if a Quit was requested, does not call
|
|
|
|
any shutdown functions.
|
|
|
|
**/
|
|
|
|
void RequestQuit();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Find out if user has requested to quit.
|
|
|
|
|
|
|
|
Function to find out if user or operating system has requested program cease execution, can be
|
|
|
|
set by Alt-F4, SDL_Quit event or ZEngine::RequestQuit().
|
|
|
|
\return bool telling if quit has been requested.
|
|
|
|
**/
|
|
|
|
bool QuitRequested();
|
2002-12-27 03:15:33 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Set State of ImagesNeedReload.
|
|
|
|
\param state False if images need to be reloaded, True if images have been reloaded.
|
|
|
|
**/
|
|
|
|
void SetReloadNeed(bool state);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Find out if images should be reloaded.
|
|
|
|
|
|
|
|
Function that is good to call every frame to check if images should be reloaded, usually only caused by loss of focus in
|
|
|
|
fullscreen.
|
|
|
|
\return bool, True if images should be reloaded, false otherwise.
|
|
|
|
**/
|
|
|
|
bool ImagesNeedReload();
|
2002-11-21 05:40:49 +00:00
|
|
|
|
2002-12-03 06:19:43 +00:00
|
|
|
/*!
|
|
|
|
\brief Set Key repeat rate.
|
|
|
|
|
2003-02-03 00:04:28 +00:00
|
|
|
Calls SDL_EnableKeyRepeat(rate,rate) because usually this is the desired movement style for games. 0 to disable.
|
|
|
|
If 2 different values are needed SDL_EnableKeyRepeat can be called separately: http://sdldoc.csn.ul.ie/sdlenablekeyrepeat.php.
|
2002-12-03 06:19:43 +00:00
|
|
|
|
|
|
|
\param rate Desired key repeat rate.
|
|
|
|
**/
|
|
|
|
void SetKeyRepeatRate(int rate);
|
|
|
|
|
2002-11-21 05:40:49 +00:00
|
|
|
/*!
|
|
|
|
\brief Find the state of a key.
|
|
|
|
|
2002-12-04 23:58:54 +00:00
|
|
|
Function returns true/false based on if key is currently pressed or not.
|
2002-12-03 06:19:43 +00:00
|
|
|
\param key Code of key to find status of.
|
|
|
|
\return State of requested key.
|
2002-11-21 05:40:49 +00:00
|
|
|
**/
|
|
|
|
bool KeyIsPressed(SDLKey key);
|
|
|
|
|
2002-12-03 06:19:43 +00:00
|
|
|
/*!
|
|
|
|
\brief Find if key has been pressed since last check.
|
|
|
|
|
|
|
|
Function returns true/false based on if key has been pressed since last check.
|
|
|
|
\param key Code of key to find status of.
|
|
|
|
\return State of requested key.
|
|
|
|
**/
|
|
|
|
bool KeyPress(SDLKey key);
|
|
|
|
|
2002-11-21 05:40:49 +00:00
|
|
|
/*!
|
|
|
|
\brief Hide mouse cursor.
|
|
|
|
|
|
|
|
Hide the system mouse cursor.
|
|
|
|
**/
|
|
|
|
void HideCursor();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Show mouse cursor.
|
|
|
|
|
|
|
|
Show the system mouse cursor.
|
|
|
|
**/
|
|
|
|
void ShowCursor();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get X Position of Mouse.
|
|
|
|
|
|
|
|
Find X Position of Mouse on screen.
|
|
|
|
\return X Position of Mouse.
|
|
|
|
**/
|
2002-11-28 23:15:52 +00:00
|
|
|
int MouseX();
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Y Position of Mouse.
|
|
|
|
|
|
|
|
Find Y Position of Mouse on screen.
|
|
|
|
\return Y Position of Mouse.
|
|
|
|
**/
|
2002-11-28 23:15:52 +00:00
|
|
|
int MouseY();
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Status of Left Button.
|
|
|
|
|
|
|
|
Get pressed status of left button of mouse.
|
|
|
|
\return true if left button is pressed, false otherwise.
|
|
|
|
**/
|
|
|
|
bool LButtonPressed();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Status of Right Button.
|
|
|
|
|
|
|
|
Get pressed status of right button of mouse.
|
|
|
|
\return true if right button is pressed, false otherwise.
|
|
|
|
**/
|
|
|
|
bool RButtonPressed();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Check if mouse is in given rectangle.
|
|
|
|
|
|
|
|
Return status of mouse in current rectangle (used for buttons)
|
|
|
|
\param rect Rectangle to check if mouse is in.
|
|
|
|
\return true if mouse is in rectangle, false otherwise
|
|
|
|
**/
|
|
|
|
bool MouseInRect(SDL_Rect *rect);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Check for Activation, Window Manager, and Quit Events.
|
|
|
|
|
|
|
|
Cycle through event queue, processing events, updating all Event Related variables, should be called once per frame.
|
|
|
|
**/
|
|
|
|
void CheckEvents();
|
|
|
|
|
2003-01-24 11:05:24 +00:00
|
|
|
/*!
|
|
|
|
\brief Add a SDL Event Filter for user processing of events.
|
|
|
|
|
|
|
|
This is only needed when you need tight control with ZEngine. The parameter is simply passed to SDL_SetEventFilter,
|
|
|
|
generally only those with a good amount of SDL experience should use this function or ZEngine's internal message
|
|
|
|
state could be corrupted. For more information on SDL_SetEventFilter see http://sdldoc.csn.ul.ie/sdlseteventfilter.php.
|
|
|
|
\since 0.8.2
|
|
|
|
\param filter An SDL_EventFilter (A function that takes a const SDL_Event* and returns 0 if the event should be removed from
|
|
|
|
the event queue and 1 otherwise.)
|
|
|
|
**/
|
|
|
|
void SetEventFilter(SDL_EventFilter filter);
|
|
|
|
|
2002-11-21 05:40:49 +00:00
|
|
|
#ifdef USE_PHYSFS
|
|
|
|
////////////////////
|
|
|
|
//Physfs Utilities//
|
|
|
|
////////////////////
|
|
|
|
public:
|
|
|
|
/*!
|
|
|
|
\brief Initialize PhysicsFS
|
|
|
|
|
|
|
|
Sets up PhysicsFS, must be called when application is started.
|
|
|
|
\param argv argv[0] from application's main.
|
|
|
|
**/
|
|
|
|
void InitPhysFS(string argv);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Add Directory to PhysFS Search Path.
|
|
|
|
|
|
|
|
Add Directory to PhysicsFS search path, the path it looks in for files when attempting to load.
|
|
|
|
\param dir Directory to add to search path.
|
|
|
|
**/
|
|
|
|
void AddPhysFSDir(string dir);
|
|
|
|
|
|
|
|
#endif //USE_PHYSFS
|
|
|
|
|
2003-01-13 06:31:08 +00:00
|
|
|
/////////////////
|
|
|
|
//Error Logging//
|
|
|
|
/////////////////
|
|
|
|
private:
|
|
|
|
//! Stack of Errors which have occured.
|
|
|
|
queue<ZError> mErrorQueue;
|
|
|
|
//! Current error.
|
|
|
|
ZError mCurError;
|
|
|
|
//! Option controlling how logfile is used.
|
|
|
|
bool mLogAllErrors;
|
|
|
|
//! C-style FILE* for error logging.
|
|
|
|
FILE *mErrlog;
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Writes an error to file.
|
|
|
|
|
|
|
|
Writes error to current error file.
|
|
|
|
\since 0.8.2
|
|
|
|
\param error ZError to write to file.
|
|
|
|
**/
|
|
|
|
void LogError(ZError error);
|
|
|
|
|
|
|
|
public:
|
|
|
|
/*!
|
|
|
|
\brief Modify Error Logging.
|
|
|
|
|
|
|
|
Change the way errors are logged and the file they are logged to, before calling this errors are logged to stderr.
|
|
|
|
(SDL may define stderr.txt on some platforms.)
|
|
|
|
\since 0.8.2
|
|
|
|
\param logAll If set to true every error will be written to file instead of stored in the logfile.
|
|
|
|
\param logFile Name of file to use as log, passing in stderr or stdio will set the log to the C streams.
|
|
|
|
Passing in nothing will not change the current error log file, which defaults to stderr.
|
|
|
|
**/
|
|
|
|
void SetErrorLog(bool logAll, string logFile="");
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Report an error.
|
|
|
|
|
|
|
|
Adds the error to the the error queue, and sets the current error to this error.
|
|
|
|
\since 0.8.2
|
|
|
|
\param code ZErrorCode of error.
|
|
|
|
\param desc Optional string describing error.
|
|
|
|
\param file Optional argument specifying the file the error occured in.
|
|
|
|
\param line Optional argument specifying the line the error occured on.
|
|
|
|
**/
|
|
|
|
void ReportError(ZErrorCode code, string desc="", string file="", unsigned int line=0);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get the last error.
|
|
|
|
|
|
|
|
Get the last error reported.
|
|
|
|
\since 0.8.2
|
|
|
|
\return ZErrorCode of last error reported.
|
|
|
|
**/
|
|
|
|
ZErrorCode GetLastError();
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Write to the log.
|
|
|
|
|
|
|
|
Write a string to the log, allowing special usage of the error log.
|
|
|
|
\since 0.8.2
|
|
|
|
\param str String to write to log file.
|
|
|
|
**/
|
|
|
|
void WriteLog(string str);
|
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Flush Stack of Errors to file.
|
|
|
|
|
|
|
|
Write the error stack to the error log.
|
|
|
|
\since 0.8.2
|
|
|
|
**/
|
|
|
|
void FlushErrors();
|
|
|
|
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
////////////////////////////
|
|
|
|
//Data Loading + Unloading//
|
|
|
|
////////////////////////////
|
|
|
|
public:
|
|
|
|
/*!
|
|
|
|
\brief Load an Image.
|
|
|
|
|
|
|
|
Loads an Image to an ImageData class which keeps vital information on the Image.
|
|
|
|
\param filename path to file to load.
|
2002-12-01 07:56:17 +00:00
|
|
|
\return A SDL_Surface pointer to data.
|
2002-11-21 05:40:49 +00:00
|
|
|
**/
|
2002-12-01 07:56:17 +00:00
|
|
|
SDL_Surface* LoadImage(string filename);
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
#ifdef USE_SDL_MIXER
|
|
|
|
/*!
|
|
|
|
\brief Load a Sound
|
|
|
|
|
|
|
|
Loads a Sound to a SoundData class which keeps vital information on the Sound
|
|
|
|
\param filename path to file to load.
|
2002-12-01 07:56:17 +00:00
|
|
|
\return A Mix_Chunk pointer to data.
|
2002-11-21 05:40:49 +00:00
|
|
|
**/
|
2002-12-01 07:56:17 +00:00
|
|
|
Mix_Chunk* LoadSound(string filename);
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Load a Music File
|
|
|
|
|
|
|
|
Loads a Music Clip to a MusicData class which keeps vital information on the Music Data
|
|
|
|
\param filename path to file to load.
|
2002-12-01 07:56:17 +00:00
|
|
|
\return A Mix_Music pointer to data.
|
2002-11-21 05:40:49 +00:00
|
|
|
**/
|
2002-12-01 07:56:17 +00:00
|
|
|
Mix_Music* LoadMusic(string filename);
|
2002-11-21 05:40:49 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef USE_SDL_TTF
|
|
|
|
/*!
|
|
|
|
\brief Load a Font.
|
|
|
|
|
|
|
|
Loads a Font to a FontData class which keeps vital information on the Font
|
|
|
|
\param filename path to file to load.
|
|
|
|
\param size point size of font
|
2002-12-01 07:56:17 +00:00
|
|
|
\return A TTF_Font pointer to data.
|
2002-11-21 05:40:49 +00:00
|
|
|
**/
|
2002-12-01 07:56:17 +00:00
|
|
|
TTF_Font* LoadFont(string filename, int size);
|
2002-11-21 05:40:49 +00:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/////////////
|
|
|
|
//Accessors//
|
|
|
|
/////////////
|
2002-12-01 07:56:17 +00:00
|
|
|
|
2002-11-21 05:40:49 +00:00
|
|
|
public:
|
|
|
|
/*!
|
|
|
|
\brief Get Current Display Width.
|
|
|
|
|
|
|
|
Get Width of Window or Fullscreen mode.
|
|
|
|
\return Width of Display.
|
|
|
|
**/
|
2002-11-28 23:15:52 +00:00
|
|
|
int Width();
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Current Display Height.
|
|
|
|
|
|
|
|
Get Height of Window or Fullscreen mode.
|
|
|
|
\return Height of Display.
|
|
|
|
**/
|
2002-11-28 23:15:52 +00:00
|
|
|
int Height();
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Current Display BPP.
|
|
|
|
|
|
|
|
Get BPP of Window or Fullscreen mode.
|
|
|
|
\return BPP of Display.
|
|
|
|
**/
|
2002-11-28 23:15:52 +00:00
|
|
|
int BPP();
|
2002-11-21 05:40:49 +00:00
|
|
|
|
|
|
|
/*!
|
|
|
|
\brief Get Fullscreen setting.
|
|
|
|
|
|
|
|
Get Fullscreen setting of Display.
|
|
|
|
\return True if Fullscreen, False if Windowed
|
|
|
|
**/
|
|
|
|
bool IsFullscreen();
|
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif //__ze_zengine_h__
|