application Class Reference

#include <application.hpp>

Inheritance diagram for application:

Inheritance graph
[legend]
Collaboration diagram for application:

Collaboration graph
[legend]

List of all members.


Detailed Description

Base class for applications.

Definition at line 84 of file application.hpp.


Public Member Functions

 application (const string &title, const int &argc, const char **argv)
 Creates the global application object.
virtual ~application ()
Virtual Functions
virtual void cleanup ()
 This function when the application ends. Do not call it yourself.
virtual bool draw ()
 This function is called for every frame. Do not call it yourself. If it returns false and the sim pointer is valid, the sim's draw function is called.
virtual bool handle_event (const SDL_Event &e)
 Handles SDL events.
virtual void init ()
 This function is called by the constructor. Do not call it yourself.
virtual void update ()
 This function is called after every frame. Do not call it yourself.
Accessors
platform::displayget_console ()
widgetget_focus_widget ()
 Return the widget with the current keyboard focus.
platform::budgetget_global_budget ()
scenegraph::nodeget_global_scenery ()
void get_mousedown_info (int &button, int &x, int &y)
scenegraph::simulationget_simulation ()
stringget_title ()
data::simple_stack< widget * > & get_widgets ()
Game Lifecycle Functions
const gsgl::data::list
< package * > & 
get_loaded_packages () const
void load_and_run_simulation (const string &fname, gsgl::scenegraph::context *c)
 Loads and runs a simulation. This will set the top widget to be invisible.
void load_package (const string &fname)
 Load a game package containing specifications for shared libraries, scenery, and vehicles.
void load_scenery (platform::synchronized< string > &status_string)
void quit_application ()
 Quits the application. Unloads and quits any simulation loaded.
void run ()
void unload_and_quit_simulation ()
 Unloads and quits a simulation. This will set the top widget to be visible, so make sure that any extra widgets have been popped off the stack.
void unload_scenery ()

Static Public Member Functions

static T * global_instance ()

Static Public Attributes

System Configuration Variables
static data::config_variable
< gsgl::string
EVENT_MAP_PATH
 The program's event map.
static data::config_variable
< gsgl::string
PROGRAM_PATH
 The path that the program is running in.
static data::config_variable
< gsgl::string
SYS_DATA_PATH
 The directory of the system data.
static data::config_variable
< gsgl::string
USER_CONFIG_PATH
 The program's user config file.
static data::config_variable
< gsgl::string
USER_DATA_PATH
 The user's data directory.

Protected Types

enum  app_state {
  APP_NO_STATE = 0, APP_INITIALIZING, APP_UI_RUNNING, APP_SIM_LOADING,
  APP_SIM_RUNNING, APP_QUITTING, APP_DEAD
}

Protected Attributes

widgetfocus_widget
platform::budgetglobal_budget
platform::displayglobal_console
scenegraph::contextglobal_context
scenegraph::event_mapglobal_mapper
scenegraph::nodeglobal_scenery
scenegraph::simulationglobal_simulation
data::list< package * > loaded_packages
platform::texturesplash_screen
app_state state
gsgl::string title
data::simple_stack< widget * > widgets

Private Member Functions

void draw_budget (unsigned int ticks)
void draw_splash_screen ()
void draw_ui (framework::widget *)
bool get_cmdline_dir (const int &argc, const char **argv, const int &pos, const gsgl::string &arg_key, gsgl::data::config_record &conf, const gsgl::string &conf_key)
void get_config_overrides (const int &argc, const char **argv)
gsgl::string get_program_dir (const gsgl::string &arg)
gsgl::string get_user_dir ()
bool handle_ui_event (const SDL_Event &e, widget *w, int mouse_x, int mouse_y)
bool handle_ui_event (const SDL_Event &e, widget *w)
scenegraph::nodeload_objects (const data::config_record &obj_config, platform::synchronized< string > &status_string)
void remove_viewpoint_nodes (scenegraph::node *)

Private Attributes

data::list< gsgl::data_object * > global_caches
int mouse_button_pressed
int mouse_button_x
int mouse_button_y

Member Enumeration Documentation

enum app_state [protected]

Enumerator:
APP_NO_STATE 
APP_INITIALIZING 
APP_UI_RUNNING 
APP_SIM_LOADING 
APP_SIM_RUNNING 
APP_QUITTING 
APP_DEAD 

Definition at line 90 of file application.hpp.


Constructor & Destructor Documentation

application ( const string title,
const int &  argc,
const char **  argv 
)

~application (  )  [virtual]


Member Function Documentation

void cleanup (  )  [virtual]

This function when the application ends. Do not call it yourself.

Implement this if cleanup is needed after the main loop terminates.

Definition at line 613 of file application.cpp.

Referenced by application::quit_application().

bool draw (  )  [virtual]

This function is called for every frame. Do not call it yourself. If it returns false and the sim pointer is valid, the sim's draw function is called.

Implement this to draw the simulation in a custom manner.

If this is not implemented or returns false, the sim will be updated and drawn automatically.

Definition at line 601 of file application.cpp.

Referenced by application::run().

void draw_budget ( unsigned int  ticks  )  [private]

void draw_splash_screen (  )  [private]

void draw_ui ( framework::widget w  )  [private]

bool get_cmdline_dir ( const int &  argc,
const char **  argv,
const int &  pos,
const gsgl::string arg_key,
gsgl::data::config_record conf,
const gsgl::string conf_key 
) [private]

void get_config_overrides ( const int &  argc,
const char **  argv 
) [private]

platform::display* get_console (  )  [inline]

Definition at line 145 of file application.hpp.

Referenced by periapsis_app::init().

widget* get_focus_widget (  )  [inline]

Return the widget with the current keyboard focus.

Definition at line 150 of file application.hpp.

platform::budget* get_global_budget (  )  [inline]

Definition at line 147 of file application.hpp.

scenegraph::node* get_global_scenery (  )  [inline]

Definition at line 144 of file application.hpp.

const gsgl::data::list<package *>& get_loaded_packages (  )  const [inline]

Definition at line 160 of file application.hpp.

void get_mousedown_info ( int &  button,
int &  x,
int &  y 
)

string get_program_dir ( const gsgl::string arg  )  [private]

scenegraph::simulation* get_simulation (  )  [inline]

Definition at line 146 of file application.hpp.

string& get_title (  )  [inline]

Definition at line 142 of file application.hpp.

Referenced by periapsis_app::init().

string get_user_dir (  )  [private]

data::simple_stack<widget *>& get_widgets (  )  [inline]

Definition at line 149 of file application.hpp.

static T* global_instance (  )  [inline, static, inherited]

bool handle_event ( const SDL_Event &  e  )  [virtual]

Handles SDL events.

Implement this to handle SDL events other than through the default scene graph event handler.

Does not normally need to be reimplemented, as UI elements and scenegraph events will propagate by default.

If it returns true, the scene graph event handler will NOT be called. If it returns false, and the current simulation pointer is valid, then the event mapper will be called with the simulation's set event targets.

Definition at line 587 of file application.cpp.

Referenced by application::run().

bool handle_ui_event ( const SDL_Event &  e,
widget w,
int  mouse_x,
int  mouse_y 
) [private]

bool handle_ui_event ( const SDL_Event &  e,
widget w 
) [private]

void init (  )  [virtual]

This function is called by the constructor. Do not call it yourself.

Implement this if initialization is needed prior to the main loop.

Reimplemented in periapsis_app.

Definition at line 594 of file application.cpp.

Referenced by application::run().

void load_and_run_simulation ( const string fname,
gsgl::scenegraph::context c 
)

node * load_objects ( const data::config_record obj_config,
platform::synchronized< string > &  status_string 
) [private]

void load_package ( const string fname  ) 

Load a game package containing specifications for shared libraries, scenery, and vehicles.

Definition at line 204 of file application.cpp.

References application::loaded_packages, and string::w_string().

Referenced by application::application().

void load_scenery ( platform::synchronized< string > &  status_string  ) 

void quit_application (  ) 

Quits the application. Unloads and quits any simulation loaded.

This contains the main event loop of the application. It clears the screen, calls draw(), draws UI elements, and flips the buffers.

Definition at line 276 of file application.cpp.

References application::APP_QUITTING, application::cleanup(), application::global_simulation, application::state, and application::unload_and_quit_simulation().

Referenced by application::run().

void remove_viewpoint_nodes ( scenegraph::node n  )  [private]

void run (  ) 

void unload_and_quit_simulation (  ) 

void unload_scenery (  ) 

Definition at line 785 of file application.cpp.

References application::global_scenery.

void update (  )  [virtual]

This function is called after every frame. Do not call it yourself.

Reimplemented in periapsis_app.

Definition at line 607 of file application.cpp.

Referenced by application::run().


Member Data Documentation

The program's event map.

Definition at line 134 of file application.hpp.

Referenced by application::application(), and application::get_config_overrides().

widget* focus_widget [protected]

Definition at line 111 of file application.hpp.

Referenced by application::~application().

Definition at line 87 of file application.hpp.

Referenced by application::application(), and application::~application().

Definition at line 106 of file application.hpp.

Referenced by application::load_package(), and application::load_scenery().

int mouse_button_pressed [private]

int mouse_button_x [private]

int mouse_button_y [private]

The path that the program is running in.

Definition at line 131 of file application.hpp.

Referenced by package::package().

app_state state [protected]

gsgl::string title [protected]

The program's user config file.

Definition at line 135 of file application.hpp.

Referenced by application::get_config_overrides().

The user's data directory.

Definition at line 133 of file application.hpp.

Referenced by application::get_config_overrides().


The documentation for this class was generated from the following files:

Generated on Sat Mar 1 13:50:06 2008 for Periapsis Project by  doxygen 1.5.5