Crazy Eddie's GUI System  0.8.0
 All Classes Namespaces Functions Variables Typedefs Enumerations Enumerator Friends Pages
CEGUI::System Class Reference

The System class is the CEGUI class that provides access to all other elements in this system. More...

+ Inheritance diagram for CEGUI::System:
+ Collaboration diagram for CEGUI::System:

Public Member Functions

RenderergetRenderer (void) const
 Return a pointer to the Renderer object being used by the system. More...
 
ClipboardgetClipboard () const
 Retrieves internal CEGUI clipboard, optionally synced with system wide clipboard.
 
GUIContextgetDefaultGUIContext () const
 
void renderAllGUIContexts ()
 Depending upon the internal state, for each GUIContext this may either re-use cached rendering from last time or trigger a full re-draw of all elements.
 
ScriptModulegetScriptingModule (void) const
 Return a pointer to the ScriptModule being used for scripting within the GUI system. More...
 
void setScriptingModule (ScriptModule *scriptModule)
 Set the ScriptModule to be used for scripting within the GUI system. More...
 
ResourceProvidergetResourceProvider (void) const
 Return a pointer to the ResourceProvider being used within the GUI system. More...
 
void executeScriptFile (const String &filename, const String &resourceGroup="") const
 Execute a script file if possible. More...
 
int executeScriptGlobal (const String &function_name) const
 Execute a scripted global function if possible. The function should not take any parameters and should return an integer. More...
 
void executeScriptString (const String &str) const
 If possible, execute script code contained in the given CEGUI::String object. More...
 
void setXMLParser (const String &parserName)
 Set a new XML parser module to be used. More...
 
void setXMLParser (XMLParser *parser)
 Sets the XMLParser object to be used by the system. More...
 
XMLParsergetXMLParser (void) const
 Return the XMLParser object.
 
ImageCodecgetImageCodec () const
 Retrieve the image codec to be used by the system.
 
void setImageCodec (const String &codecName)
 Set the image codec to be used by the system.
 
void setImageCodec (ImageCodec &codec)
 Set the image codec to use from an existing image codec. More...
 
void notifyDisplaySizeChanged (const Sizef &new_size)
 Notification function to be called when the main display changes size. Client code should call this function when the host window changes size, or if the display resolution is changed in full-screen mode. More...
 
RenderedStringParsergetDefaultCustomRenderedStringParser () const
 Return pointer to the currently set global default custom RenderedStringParser object. More...
 
void setDefaultCustomRenderedStringParser (RenderedStringParser *parser)
 Set the global default custom RenderedStringParser object. This change is reflected the next time an affected window reparses it's text. This may be set to 0 for no system wide custom parser (which is the default). More...
 
void invalidateAllCachedRendering ()
 Invalidate all imagery and geometry caches for CEGUI managed elements. More...
 
RegexMatchercreateRegexMatcher () const
 Create a RegexMatcher instance if support is available. More...
 
void destroyRegexMatcher (RegexMatcher *rm) const
 destroy a RegexMatcher instance returned by System::createRegexMatcher.
 
bool injectTimePulse (float timeElapsed)
 call this to ensure system-level time based updates occur.
 
GUIContextcreateGUIContext (RenderTarget &rt)
 
void destroyGUIContext (GUIContext &context)
 
void addStandardWindowFactories ()
 adds factories for all the basic window types More...
 
- Public Member Functions inherited from CEGUI::EventSet
 EventSet ()
 Constructor for EventSet objects.
 
virtual ~EventSet (void)
 Destructor for EventSet objects.
 
void addEvent (const String &name)
 Creates a new Event object with the given name and adds it to the EventSet. More...
 
void addEvent (Event &event)
 Adds the given Event object to the EventSet. Ownership of the object passes to EventSet and it will be deleted when it is removed from the EventSet - whether explicitly via removeEvent or when the EventSet is destroyed. More...
 
void removeEvent (const String &name)
 Removes the Event with the given name. All connections to the event are disconnected, and the underlying Event object is destroyed. More...
 
void removeEvent (Event &event)
 Removes the given event from the EventSet. All connections to the event are disconnected, and the event object is destroyed. More...
 
void removeAllEvents (void)
 Remove all Event objects from the EventSet. Add connections will be disconnected, and all Event objects destroyed.
 
bool isEventPresent (const String &name)
 Checks to see if an Event with the given name is present in this EventSet. More...
 
virtual Event::Connection subscribeEvent (const String &name, Event::Subscriber subscriber)
 Subscribes a handler to the named Event. If the named Event is not yet present in the EventSet, it is created and added. More...
 
virtual Event::Connection subscribeEvent (const String &name, Event::Group group, Event::Subscriber subscriber)
 Subscribes a handler to the specified group of the named Event. If the named Event is not yet present in the EventSet, it is created and added. More...
 
template<typename Arg1 , typename Arg2 >
Event::Connection subscribeEvent (const String &name, Arg1 arg1, Arg2 arg2)
 Subscribes a handler to the named Event. If the named Event is not yet present in the EventSet, it is created and added. More...
 
template<typename Arg1 , typename Arg2 >
Event::Connection subscribeEvent (const String &name, Event::Group group, Arg1 arg1, Arg2 arg2)
 Subscribes a handler to the named Event. If the named Event is not yet present in the EventSet, it is created and added. More...
 
virtual Event::Connection subscribeScriptedEvent (const String &name, const String &subscriber_name)
 Subscribes the named Event to a scripted funtion. More...
 
virtual Event::Connection subscribeScriptedEvent (const String &name, Event::Group group, const String &subscriber_name)
 Subscribes the specified group of the named Event to a scripted funtion. More...
 
virtual void fireEvent (const String &name, EventArgs &args, const String &eventNamespace="")
 Fires the named event passing the given EventArgs object. More...
 
bool isMuted (void) const
 Return whether the EventSet is muted or not. More...
 
void setMutedState (bool setting)
 Set the mute state for this EventSet. More...
 
EventgetEventObject (const String &name, bool autoAdd=false)
 Return a pointer to the Event object with the given name, optionally adding such an Event object to the EventSet if it does not already exist. More...
 
EventIterator getEventIterator (void) const
 Return a EventSet::EventIterator object to iterate over the events currently added to the EventSet.
 

Static Public Member Functions

static Systemcreate (Renderer &renderer, ResourceProvider *resourceProvider=0, XMLParser *xmlParser=0, ImageCodec *imageCodec=0, ScriptModule *scriptModule=0, const String &configFile="", const String &logFile="CEGUI.log", const int abi=CEGUI_VERSION_ABI)
 Create the System object and return a reference to it. More...
 
static void destroy ()
 Destroy the System object.
 
static unsigned int getMajorVersion ()
 Retrieves CEGUI's major version as an integer. More...
 
static unsigned int getMinorVersion ()
 Retrieves CEGUI's minor version as an integer. More...
 
static unsigned int getPatchVersion ()
 Retrieves CEGUI's patch version as an integer. More...
 
static const StringgetVersion ()
 Retrieves CEGUI's "short" version ("1.2.3" for example) More...
 
static const StringgetVerboseVersion ()
 Retrieves CEGUI's "verbose" version, includes info about compiler, platform, etc... More...
 
static SystemgetSingleton (void)
 Return singleton System object. More...
 
static SystemgetSingletonPtr (void)
 Return pointer to singleton System object. More...
 
static void setDefaultXMLParserName (const String &parserName)
 Static member to set the name of the default XML parser module that should be used. More...
 
static const String getDefaultXMLParserName ()
 Return the name of the currently set default xml parser module. More...
 
static void setDefaultImageCodecName (const String &codecName)
 Set the name of the default image codec to be used.
 
static const StringgetDefaultImageCodecName ()
 Get the name of the default image codec.
 
static const StringTranscodergetStringTranscoder ()
 Return the system StringTranscoder object.
 
static void performVersionTest (const int expected, const int received, const String &func)
 Internal CEGUI version validation function.
 
- Static Public Member Functions inherited from CEGUI::Singleton< System >
static SystemgetSingleton (void)
 
static SystemgetSingletonPtr (void)
 

Static Public Attributes

static const String EventNamespace
 Namespace for global events.
 
static const String EventDisplaySizeChanged
 
static const String EventRenderedStringParserChanged
 

Protected Types

typedef std::vector
< GUIContext
*CEGUI_VECTOR_ALLOC(GUIContext *)> 
GUIContextCollection
 
- Protected Types inherited from CEGUI::EventSet
typedef std::map< String,
Event *, StringFastLessCompare
CEGUI_MAP_ALLOC(String, Event *)> 
EventMap
 

Protected Member Functions

 System (Renderer &renderer, ResourceProvider *resourceProvider, XMLParser *xmlParser, ImageCodec *imageCodec, ScriptModule *scriptModule, const String &configFile, const String &logFile)
 Construct a new System object. More...
 
 ~System (void)
 Destructor for System objects.
 
void outputLogHeader ()
 output the standard log header
 
void createSingletons ()
 create the other core system singleton objects (except the logger)
 
void destroySingletons ()
 cleanup the core system singleton objects
 
void setupXMLParser ()
 handle creation and initialisation of the XML parser.
 
void cleanupXMLParser ()
 handle cleanup of the XML parser
 
void setupImageCodec (const String &codecName)
 setup image codec
 
void cleanupImageCodec ()
 cleanup image codec
 
void invalidateAllWindows ()
 invalidate all windows and any rendering surfaces they may be using.
 
- Protected Member Functions inherited from CEGUI::EventSet
void fireEvent_impl (const String &name, EventArgs &args)
 Implementation event firing member.
 
ScriptModulegetScriptModule () const
 Helper to return the script module pointer or throw.
 
 EventSet (EventSet &)
 
EventSetoperator= (EventSet &)
 

Protected Attributes

Rendererd_renderer
 Holds the pointer to the Renderer object given to us in the constructor.
 
ResourceProviderd_resourceProvider
 Holds the pointer to the ResourceProvider object given to us by the renderer or the System constructor.
 
bool d_ourResourceProvider
 
Clipboardd_clipboard
 Internal clipboard with optional sync with native clipboard.
 
ScriptModuled_scriptModule
 Points to the scripting support module.
 
String d_termScriptName
 Name of the script to run upon system shutdown.
 
XMLParserd_xmlParser
 XMLParser object we use to process xml files.
 
bool d_ourXmlParser
 true when we created the xml parser.
 
DynamicModuled_parserModule
 
ImageCodecd_imageCodec
 Holds a pointer to the image codec to use.
 
bool d_ourImageCodec
 true when we created the image codec.
 
DynamicModuled_imageCodecModule
 
bool d_ourLogger
 true when we created the CEGUI::Logger based object.
 
RenderedStringParserd_customRenderedStringParser
 currently set global RenderedStringParser.
 
GUIContextCollection d_guiContexts
 
- Protected Attributes inherited from CEGUI::EventSet
EventMap d_events
 
bool d_muted
 true if events for this EventSet have been muted.
 

Static Protected Attributes

static String d_defaultXMLParserName
 pointer to parser module. More...
 
static String d_defaultImageCodecName
 Holds the name of the default codec to use.
 
static const IconvStringTranscoder d_stringTranscoder
 instance of class that can convert string encodings
 
- Static Protected Attributes inherited from CEGUI::Singleton< System >
static Systemms_Singleton
 

Additional Inherited Members

- Public Types inherited from CEGUI::EventSet
typedef ConstMapIterator
< EventMap > 
EventIterator
 

Detailed Description

The System class is the CEGUI class that provides access to all other elements in this system.

This object must be created by the client application. The System object requires that you pass it an initialised Renderer object which it can use to interface to whatever rendering system will be used to display the GUI imagery.

Constructor & Destructor Documentation

CEGUI::System::System ( Renderer renderer,
ResourceProvider resourceProvider,
XMLParser xmlParser,
ImageCodec imageCodec,
ScriptModule scriptModule,
const String configFile,
const String logFile 
)
protected

Construct a new System object.

Parameters
rendererReference to a valid Renderer object that will be used to render GUI imagery.
resourceProviderPointer to a ResourceProvider object, or NULL to use whichever default the Renderer provides.
xmlParserPointer to a valid XMLParser object to be used when parsing XML files, or NULL to use a default parser.
imageCodecPointer to a valid ImageCodec object to be used when loading image files, or NULL to use a default image codec.
scriptModulePointer to a ScriptModule object. may be NULL for none.
configFileString object containing the name of a configuration file to use.
logFileString object containing the name to use for the log file.

Member Function Documentation

void CEGUI::System::addStandardWindowFactories ( )

adds factories for all the basic window types

You do not need to call this manually! Standard Window factories will be added automatically. One occasion when you will need this is if you remove all window factories from WindowFactoryManager and want to add the standard ones back

static System& CEGUI::System::create ( Renderer renderer,
ResourceProvider resourceProvider = 0,
XMLParser xmlParser = 0,
ImageCodec imageCodec = 0,
ScriptModule scriptModule = 0,
const String configFile = "",
const String logFile = "CEGUI.log",
const int  abi = CEGUI_VERSION_ABI 
)
static

Create the System object and return a reference to it.

Parameters
rendererReference to a valid Renderer object that will be used to render GUI imagery.
resourceProviderPointer to a ResourceProvider object, or NULL to use whichever default the Renderer provides.
xmlParserPointer to a valid XMLParser object to be used when parsing XML files, or NULL to use a default parser.
imageCodecPointer to a valid ImageCodec object to be used when loading image files, or NULL to use a default image codec.
scriptModulePointer to a ScriptModule object. may be NULL for none.
configFileString object containing the name of a configuration file to use.
logFileString object containing the name to use for the log file.
abiThis must be set to CEGUI_VERSION_ABI
RegexMatcher* CEGUI::System::createRegexMatcher ( ) const

Create a RegexMatcher instance if support is available.

Returns
Pointer to an object that implements the RegexMatcher interface, or 0 if the system has no built in support for RegexMatcher creation.
Note
The created RegexMatcher is not tracked in any way, and it is the resposibility of the caller to destroy the RegexMatcher when it is no longer needed by calling System::destroyRegexMatcher.
void CEGUI::System::executeScriptFile ( const String filename,
const String resourceGroup = "" 
) const

Execute a script file if possible.

Parameters
filenameString object holding the filename of the script file that is to be executed
resourceGroupResource group identifier to be passed to the ResourceProvider when loading the script file.
int CEGUI::System::executeScriptGlobal ( const String function_name) const

Execute a scripted global function if possible. The function should not take any parameters and should return an integer.

Parameters
function_nameString object holding the name of the function, in the global script environment, that is to be executed.
Returns
The integer value returned from the script function.
void CEGUI::System::executeScriptString ( const String str) const

If possible, execute script code contained in the given CEGUI::String object.

Parameters
strString object holding the valid script code that should be executed.
Returns
Nothing.
RenderedStringParser* CEGUI::System::getDefaultCustomRenderedStringParser ( ) const

Return pointer to the currently set global default custom RenderedStringParser object.

The returned RenderedStringParser is used for all windows that have parsing enabled and no custom RenderedStringParser set on the window itself.

If this global custom RenderedStringParser is set to 0, then all windows with parsing enabled and no custom RenderedStringParser set on the window itself will use the systems BasicRenderedStringParser.

static const String CEGUI::System::getDefaultXMLParserName ( )
static

Return the name of the currently set default xml parser module.

Returns
String holding the currently set default xml parser name. Note that if this name has been changed after instantiating the system, the name returned may not actually correspond to the module in use.
static unsigned int CEGUI::System::getMajorVersion ( )
static

Retrieves CEGUI's major version as an integer.

Note
API/headers major version is a macro called CEGUI_MAJOR_VERSION, this returns the version your application is linking to
static unsigned int CEGUI::System::getMinorVersion ( )
static

Retrieves CEGUI's minor version as an integer.

Note
API/headers minor version is a macro called CEGUI_MINOR_VERSION, this returns the version your application is linking to
static unsigned int CEGUI::System::getPatchVersion ( )
static

Retrieves CEGUI's patch version as an integer.

Note
API/headers patch version is a macro called CEGUI_PATCH_VERSION, this returns the version your application is linking to
Renderer* CEGUI::System::getRenderer ( void  ) const
inline

Return a pointer to the Renderer object being used by the system.

Returns
Pointer to the Renderer object used by the system.
ResourceProvider* CEGUI::System::getResourceProvider ( void  ) const

Return a pointer to the ResourceProvider being used within the GUI system.

Returns
Pointer to a ResourceProvider based object.

Referenced by CEGUI::NamedXMLResourceManager< T, U >::createAll().

ScriptModule* CEGUI::System::getScriptingModule ( void  ) const

Return a pointer to the ScriptModule being used for scripting within the GUI system.

Returns
Pointer to a ScriptModule based object.
static System& CEGUI::System::getSingleton ( void  )
static
static System* CEGUI::System::getSingletonPtr ( void  )
static

Return pointer to singleton System object.

Returns
Pointer to singleton System object
static const String& CEGUI::System::getVerboseVersion ( )
static

Retrieves CEGUI's "verbose" version, includes info about compiler, platform, etc...

Note
API/headers verbose version can be constructed using various compiler specific macros, this returns the version your application is linking to
static const String& CEGUI::System::getVersion ( )
static

Retrieves CEGUI's "short" version ("1.2.3" for example)

Note
API/headers version can be constructed using CEGUI_*_VERSION macros, this returns the version your application is linking to
void CEGUI::System::invalidateAllCachedRendering ( )

Invalidate all imagery and geometry caches for CEGUI managed elements.

This function will invalidate the caches used for both imagery and geometry for all content that is managed by the core CEGUI manager objects, causing a full and total redraw of that content. This includes Window object's cached geometry, rendering surfaces and rendering windows and the mouse pointer geometry.

void CEGUI::System::notifyDisplaySizeChanged ( const Sizef new_size)

Notification function to be called when the main display changes size. Client code should call this function when the host window changes size, or if the display resolution is changed in full-screen mode.

Calling this function ensures that any other parts of the system that
need to know about display size changes are notified.  This affects
things such as the MouseCursor default constraint area, and also the
auto-scale functioning of Imagesets and Fonts.
Note
This function will also fire the System::EventDisplaySizeChanged event.
Parameters
new_sizeSize object describing the new display size in pixels.
void CEGUI::System::setDefaultCustomRenderedStringParser ( RenderedStringParser parser)

Set the global default custom RenderedStringParser object. This change is reflected the next time an affected window reparses it's text. This may be set to 0 for no system wide custom parser (which is the default).

The set RenderedStringParser is used for all windows that have parsing enabled and no custom RenderedStringParser set on the window itself.

If this global custom RenderedStringParser is set to 0, then all windows with parsing enabled and no custom RenderedStringParser set on the window itself will use the systems BasicRenderedStringParser.

static void CEGUI::System::setDefaultXMLParserName ( const String parserName)
static

Static member to set the name of the default XML parser module that should be used.

If you want to modify the default parser from the one compiled in, you
need to call this static member prior to instantiating the main
CEGUI::System object.

Note that calling this member to change the name of the default module
after CEGUI::System, and therefore the default xml parser, has been
created will have no real effect - the default parser name will be
updated, though no actual changes to the xml parser module will occur.

The built-in options for this are:
 - XercesParser
 - ExpatParser
 - LibxmlParser
 - TinyXMLParser

Whether these are actually available, depends upon how you built the
system.  If you have some custom parser, you can provide the name of
that here to have it used as the default, though note that the
final filename of the parser module should be of the form:

[prefix]CEGUI[parserName][suffix]

where:
- [prefix] is some optional prefix; like 'lib' on linux.
- CEGUI is a required prefix.
- [parserName] is the name of the parser, as supplied to this function.
- [suffix] is the filename suffix, like .dll or .so

Final module filenames are, thus, of the form:
- CEGUIXercesParser.dll
- libCEGUIXercesParser.so
Parameters
parserNameString describing the name of the xml parser module to be used as the default.
Returns
Nothing.
void CEGUI::System::setImageCodec ( ImageCodec codec)

Set the image codec to use from an existing image codec.

In this case the renderer does not take the ownership of the image codec
object.
Parameters
codecThe ImageCodec object to be used.
void CEGUI::System::setScriptingModule ( ScriptModule scriptModule)

Set the ScriptModule to be used for scripting within the GUI system.

Parameters
scriptModulePointer to a ScriptModule based object, or 0 for none (be careful!)
Returns
Nothing
void CEGUI::System::setXMLParser ( const String parserName)

Set a new XML parser module to be used.

The current XMLParser will be cleaned up and, if owned by the system,
also deleted, as will any dynamically loaded module associated with the
XMLParser object.  The newly created XMLParser object, and the
associated module will be owned by the system.
Parameters
parserNameString object describing the name of the XML parser module to be used.
void CEGUI::System::setXMLParser ( XMLParser parser)

Sets the XMLParser object to be used by the system.

The current XMLParser will be cleaned up and, if owned by the system,
also deleted, as will any dynamically loaded module associated with the
XMLParser object.

If the argument passed in the \a parser parameter is 0, the system will
cleanup any existing parser as described above, and revert to using
the parser provided by the default module (see getDefaultXMLParserName
and setDefaultXMLParserName).
Parameters
parserPointer to the XMLParser object to be used by the system, or 0 to cause the system to initialise a default parser.

Member Data Documentation

String CEGUI::System::d_defaultXMLParserName
staticprotected

pointer to parser module.

Holds name of default XMLParser

DynamicModule* CEGUI::System::d_imageCodecModule
protected

Holds a pointer to the image codec module. If d_imageCodecModule is 0 we are not owner of the image codec object

const String CEGUI::System::EventDisplaySizeChanged
static

Event fired for display size changes (as notified by client code). Handlers are passed a const DisplayEventArgs reference with DisplayEventArgs::size set to the pixel size that was notifiied to the system.

const String CEGUI::System::EventRenderedStringParserChanged
static

Event fired when global custom RenderedStringParser is set. Handlers are passed a const reference to a generic EventArgs struct.