Main Page   Namespace List   Class Hierarchy   Compound List   File List   Namespace Members   Compound Members   File Members  

ZE::ZEngine Class Reference

#include <ZE_ZEngine.h>

List of all members.


Detailed Description

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.


Public Methods

void SetupDisplay (int width, int height, int bpp, bool fullscreen)
 Setup Display for SDL.

void SetupSound (int rate, bool stereo)
 Initialize Sound for SDL.

void CreateDisplay (string title, string icon="")
 Create Display with predefined settings.

void CloseDisplay ()
 Quit SDL and any Subsystems.

SDL_Surface * Display ()
 Allow access to Screen Surface.

void Update ()
 Update display contents.

void Clear (float red=0.0f, float green=0.0f, float blue=0.0f, float alpha=1.0f)
 Clear screen to a certain color (Black by default).

void SetGL2D ()
 Setup OpenGL ortho mode.

void Delay (Uint32 milliseconds)
 Sleep for a certain amount of time.

Uint32 GetTime ()
 Get Global ZEngine time.

void PauseTimer ()
 Pause ZEngine.

void UnpauseTimer ()
 Unpause ZEngine.

double GetFrameTime ()
 Get Seconds Per Frame.

bool IsPaused ()
 Check Engine Paused State.

bool IsActive ()
 Find out if application is active.

void RequestQuit ()
 Request A Quit.

bool QuitRequested ()
 Find out if user has requested to quit.

void SetKeyRepeatRate (int rate)
 Set Key repeat rate.

bool KeyIsPressed (SDLKey key)
 Find the state of a key.

bool KeyPress (SDLKey key)
 Find if key has been pressed since last check.

void HideCursor ()
 Hide mouse cursor.

void ShowCursor ()
 Show mouse cursor.

int MouseX ()
 Get X Position of Mouse.

int MouseY ()
 Get Y Position of Mouse.

bool LButtonPressed ()
 Get Status of Left Button.

bool RButtonPressed ()
 Get Status of Right Button.

bool MouseInRect (SDL_Rect *rect)
 Check if mouse is in given rectangle.

void CheckEvents ()
 Check for Activation, Window Manager, and Quit Events.

SDL_Surface * LoadImage (string filename)
 Load an Image.

Mix_Chunk * LoadSound (string filename)
 Load a Sound.

Mix_Music * LoadMusic (string filename)
 Load a Music File.

TTF_Font * LoadFont (string filename, int size)
 Load a Font.

int Width ()
 Get Current Display Width.

int Height ()
 Get Current Display Height.

int BPP ()
 Get Current Display BPP.

bool IsFullscreen ()
 Get Fullscreen setting.


Static Public Methods

ZEngine * GetInstance ()
 Get Instance.

void ReleaseInstance ()
 Release Instance.

string GetVersion ()
 Get Current Version.


Private Methods

 ZEngine ()
 Constructor for ZEngine.


Private Attributes

int mWidth
 Width of Display.

int mHeight
 Height of Display.

int mBPP
 BPP Setting of Display.

bool mFullscreen
 Fullscreen setting of Display.

int mRate
 Sound Bitrate.

bool mStereo
 Stereo setting of Sound Subsystem.

SDL_Surface * mScreen
 Pointer to Display.

bool mPaused
 Keep track of paused state of game.

bool mUnpauseOnActive
 Keep track of if ZEngine should unpause on active event.

Uint32 mLastPause
 Keep track of time game was last paused.

Uint32 mPausedTime
 Keep track of total globally paused time.

Uint32 mLastTime
 Keep track of last screen update time.

double mSecPerFrame
 Seconds per frame.

bool mActive
 bool describing Active or Inactive State of Game

bool mQuit
 bool for checking if a Quit event has been detected

Uint8 * mKeyIsPressed
 Pointer to array of Keys.

bool mKeyPress [SDLK_LAST]
 Array of keys, used by KeyPress.

int mMouseX
 X Position of Mouse.

int mMouseY
 Y Position of Mouse.

Uint8 mMouseB
 Mouse Button Information.


Static Private Attributes

ZEngine * sInstance = NULL
 Static Pointer to Instance of ZEngine for Singleton.


Constructor & Destructor Documentation

ZE::ZEngine::ZEngine   [private]
 

Initialize ZEngine values to defaults. (Private so that only one instance may be created.)


Member Function Documentation

ZEngine * ZE::ZEngine::GetInstance   [static]
 

Static function, returns pointer to instance of ZEngine, creating an instance if none exist.

Returns:
Instance to the ZEngine.

void ZE::ZEngine::ReleaseInstance   [static]
 

Release memory held by instance of engine and closes window.

string ZE::ZEngine::GetVersion   [static]
 

Get Version Number of ZEngine. (Major.Minor.Extension#)

Returns:
string containing version number

void ZE::ZEngine::SetupDisplay int    width,
int    height,
int    bpp,
bool    fullscreen
 

Sets display parameters to specified parameters. (called before CreateDisplay)

Parameters:
width Desired width of screen or window.
height Desired height of screen or window.
bpp Desired BPP for screen (only works in fullscreen).
fullscreen A bool for fullscreen setting.

void ZE::ZEngine::SetupSound int    rate,
bool    stereo
 

Set sound settings to specified parameters. (called before CreateDisplay)

Parameters:
rate Desired sound bitrate.
stereo A bool for stereo setting.

void ZE::ZEngine::CreateDisplay string    title,
string    icon = ""
 

SetupDisplay and SetupSound should be called prior to this to change settings, settings from those do not go into effect until this function is called. Specify no icon file to use default OS icon.

Parameters:
title Window Title.
icon Path to Icon File.

void ZE::ZEngine::CloseDisplay  
 

Shut down SDL (and SDL_ttf,SDL_mixer if necessary).

SDL_Surface * ZE::ZEngine::Display  
 

Get pointer to screen SDL_Surface, allowing direct screen manipulation using SDL.

Returns:
Pointer to Display Surface.

void ZE::ZEngine::Update  
 

Swap OpenGL buffers, and update screen. Must be called every frame.

void ZE::ZEngine::Clear float    red = 0.0f,
float    green = 0.0f,
float    blue = 0.0f,
float    alpha = 1.0f
 

Clears a rectangle on screen to a color, defaults to solid black.

Parameters:
red Red component (0.0-1.0) of new color.
green Green component (0.0-1.0) of new color.
blue Blue component (0.0-1.0) of new color.
alpha Alpha component (0.0-1.0) of new color.

void ZE::ZEngine::SetGL2D  
 

Sets the OpenGL scaled orthographic mode, called once at beginning, no need to call unless you change the OpenGL mode manually.

void ZE::ZEngine::Delay Uint32    milliseconds
 

Freeze everything for given number of milliseconds.

Parameters:
milliseconds Number of milliseconds to freeze.

Uint32 ZE::ZEngine::GetTime  
 

Get active time since ZEngine initialization in milliseconds, paused time doesn't count.

Returns:
Number of active milliseconds since initialization.

void ZE::ZEngine::PauseTimer  
 

Pause ZEngine timer and all ZTimer objects that rely on ZEngine.

void ZE::ZEngine::UnpauseTimer  
 

Unpause ZEngine timer and all ZTimer objects that rely on ZEngine.

double ZE::ZEngine::GetFrameTime  
 

Get double that describes the time passed between screen updates. (used for Framerate Independant Movement)

Returns:
Time between screen updates.

bool ZE::ZEngine::IsPaused  
 

Find out if engine timer is paused.

Returns:
Paused State of engine.

bool ZE::ZEngine::IsActive  
 

Function to find out if application currently has focus.

Returns:
bool telling active/inactive state of application.

void ZE::ZEngine::RequestQuit  
 

Tell the engine that it should behave as if a Quit was requested, does not call any shutdown functions.

bool ZE::ZEngine::QuitRequested  
 

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().

Returns:
bool telling if quit has been requested.

void ZE::ZEngine::SetKeyRepeatRate int    rate
 

Calls SDL_EnableKeyRepeat(rate,rate) because usually this is the desired movement style for games. The rate is set to 30 upon the creation of the display, pass zero to disable this. SDL_EnableKeyRepeat can be called separately: http://sdldoc.csn.ul.ie/sdlenablekeyrepeat.php.

Parameters:
rate Desired key repeat rate.

bool ZE::ZEngine::KeyIsPressed SDLKey    key
 

Function returns true/false based on if key is currently pressed or not.

Parameters:
key Code of key to find status of.
Returns:
State of requested key.

bool ZE::ZEngine::KeyPress SDLKey    key
 

Function returns true/false based on if key has been pressed since last check.

Parameters:
key Code of key to find status of.
Returns:
State of requested key.

void ZE::ZEngine::HideCursor  
 

Hide the system mouse cursor.

void ZE::ZEngine::ShowCursor  
 

Show the system mouse cursor.

int ZE::ZEngine::MouseX  
 

Find X Position of Mouse on screen.

Returns:
X Position of Mouse.

int ZE::ZEngine::MouseY  
 

Find Y Position of Mouse on screen.

Returns:
Y Position of Mouse.

bool ZE::ZEngine::LButtonPressed  
 

Get pressed status of left button of mouse.

Returns:
true if left button is pressed, false otherwise.

bool ZE::ZEngine::RButtonPressed  
 

Get pressed status of right button of mouse.

Returns:
true if right button is pressed, false otherwise.

bool ZE::ZEngine::MouseInRect SDL_Rect *    rect
 

Return status of mouse in current rectangle (used for buttons)

Parameters:
rect Rectangle to check if mouse is in.
Returns:
true if mouse is in rectangle, false otherwise

void ZE::ZEngine::CheckEvents  
 

Cycle through event queue, processing events, updating all Event Related variables, should be called once per frame.

SDL_Surface * ZE::ZEngine::LoadImage string    filename
 

Loads an Image to an ImageData class which keeps vital information on the Image.

Parameters:
filename path to file to load.
Returns:
A SDL_Surface pointer to data.

Mix_Chunk* ZE::ZEngine::LoadSound string    filename
 

Loads a Sound to a SoundData class which keeps vital information on the Sound

Parameters:
filename path to file to load.
Returns:
A Mix_Chunk pointer to data.

Mix_Music* ZE::ZEngine::LoadMusic string    filename
 

Loads a Music Clip to a MusicData class which keeps vital information on the Music Data

Parameters:
filename path to file to load.
Returns:
A Mix_Music pointer to data.

TTF_Font* ZE::ZEngine::LoadFont string    filename,
int    size
 

Loads a Font to a FontData class which keeps vital information on the Font

Parameters:
filename path to file to load.
size point size of font
Returns:
A TTF_Font pointer to data.

int ZE::ZEngine::Width  
 

Get Width of Window or Fullscreen mode.

Returns:
Width of Display.

int ZE::ZEngine::Height  
 

Get Height of Window or Fullscreen mode.

Returns:
Height of Display.

int ZE::ZEngine::BPP  
 

Get BPP of Window or Fullscreen mode.

Returns:
BPP of Display.

bool ZE::ZEngine::IsFullscreen  
 

Get Fullscreen setting of Display.

Returns:
True if Fullscreen, False if Windowed


The documentation for this class was generated from the following files:
Generated on Sat Dec 21 23:20:23 2002 for ZEngine by doxygen1.3-rc2