|
|
//===== Copyright � Valve Corporation, All rights reserved. ======//
#ifndef IGAMEUISYSTEMMGR_H
#define IGAMEUISYSTEMMGR_H
#ifdef _WIN32
#pragma once
#endif
// Forward declarations
class IGameUISystemMgr; class IGameUIScreenController; class IGameUIScreenControllerFactory; class IGameUISystem; class IGameUIMiscUtils; class IGameUISystemSurface; class IGameUISchemeMgr; class IGameUIScheme; class IGameUISoundPlayback; class IMaterialProxy;
// External includes
#include "tier1/timeutils.h"
#include "tier1/utlsymbol.h"
#include "materialsystem/MaterialSystemUtil.h"
#include "materialsystem/imaterialsystem.h"
#include "vgui_surfacelib/ifontsurface.h"
#include "rendersystem/irenderdevice.h"
#include "inputsystem/InputEnums.h"
// Game controls includes
#include "miscutils.h"
// Types
FORWARD_DECLARE_HANDLE( InputContextHandle_t );
//-----------------------------------------------------------------------------
// Interface used to drive gameui (tier3)
//-----------------------------------------------------------------------------
#define GAMEUISYSTEMMGR_INTERFACE_VERSION "GameUISystemMgr001"
abstract_class IGameUISystemMgr : public IAppSystem { public: virtual void SetGameUIVisible( bool bVisible ) = 0; virtual bool GetGameUIVisible() = 0;
// Load the game UI menu screen
// key values are owned and released by caller
virtual IGameUISystem * LoadGameUIScreen( KeyValues *kvScreenLoadSettings ) = 0; virtual void ReleaseAllGameUIScreens() = 0;
virtual void SetSoundPlayback( IGameUISoundPlayback *pPlayback ) = 0; virtual void UseGameInputSystemEventQueue( bool bEnable ) = 0; virtual void SetInputContext( InputContextHandle_t hInputContext ) = 0; virtual void RegisterInputEvent( const InputEvent_t &iEvent ) = 0;
virtual void RunFrame() = 0; virtual void Render( const Rect_t &viewport, DmeTime_t flCurrentTime ) = 0; virtual void Render( IRenderContext *pRenderContext, PlatWindow_t hWnd, const Rect_t &viewport, DmeTime_t flCurrentTime ) = 0;
virtual void RegisterScreenControllerFactory( char const *szControllerName, IGameUIScreenControllerFactory *pFactory ) = 0; virtual IGameUIScreenControllerFactory * GetScreenControllerFactory( char const *szControllerName ) = 0;
virtual void SendEventToAllScreens( KeyValues *kvGlobalEvent ) = 0;
virtual IGameUISystemSurface * GetSurface() = 0; virtual IGameUISchemeMgr * GetSchemeMgr() = 0; virtual IGameUIMiscUtils * GetMiscUtils() = 0;
// Init any render targets needed by the UI.
virtual void InitRenderTargets() = 0; virtual IMaterialProxy *CreateProxy( const char *proxyName ) = 0; };
//-----------------------------------------------------------------------------
// Used to allow clients to install code hooks to the gui screens
//-----------------------------------------------------------------------------
abstract_class IGameUIScreenController { public: // Connects a screen to the controller, returns number of
// remaining connected screens (or 1 for the first connection)
virtual int OnScreenConnected( IGameUISystem *pScreenView ) = 0;
// Releases the screen from controller, returns number of
// remaining connected screens (returns 0 if no screens are
// connected - new object must be reacquired from factory
// in this case)
virtual int OnScreenDisconnected( IGameUISystem *pScreenView ) = 0;
// Callback for screen events handling (caller retains ownership of keyvalues)
virtual KeyValues * OnScreenEvent( IGameUISystem *pScreenView, KeyValues *kvEvent ) = 0;
// Broadcast an event to all connected screens (caller retains ownership of keyvalues)
virtual void BroadcastEventToScreens( KeyValues *kvEvent ) = 0; };
abstract_class IGameUIScreenControllerFactory { public: // Returns an instance of a controller interface (keyvalues owned by caller)
virtual IGameUIScreenController * GetController( KeyValues *kvRequest ) = 0;
// Access controller instances
virtual int GetControllerInstancesCount() = 0; virtual IGameUIScreenController * GetControllerInstance( int iIndex ) = 0; };
//-----------------------------------------------------------------------------
// IGameUISystem represents a logical collection of UI screens
//-----------------------------------------------------------------------------
abstract_class IGameUISystem { public: virtual char const * GetName() = 0; virtual bool ExecuteScript( KeyValues *kvEvent, KeyValues **ppResult = NULL ) = 0;
virtual int32 GetScriptHandle() = 0;
virtual void SetStageSize( int nWide, int nTall ) = 0; virtual void GetStageSize( Vector2D &stageSize ) = 0; };
//-----------------------------------------------------------------------------
// This class is the interface to the font and font texture, systems.
// Load fonts given by schemes into the systems using this class.
//-----------------------------------------------------------------------------
class IGameUISystemSurface { public: virtual InitReturnVal_t Init() = 0; virtual void Shutdown() = 0;
virtual void PrecacheFontCharacters( FontHandle_t font, wchar_t *pCharacterString = NULL ) = 0;
virtual FontHandle_t CreateFont() = 0; virtual bool SetFontGlyphSet( FontHandle_t font, const char *windowsFontName, int tall, int weight, int blur, int scanlines, int flags, int nRangeMin = 0, int nRangeMax = 0 ) = 0; virtual int GetFontTall( FontHandle_t font ) = 0; virtual void GetCharABCwide( FontHandle_t font, int ch, int &a, int &b, int &c ) = 0; virtual int GetCharacterWidth( FontHandle_t font, int ch ) = 0; virtual const char *GetFontName( FontHandle_t font ) = 0;
virtual bool AddCustomFontFile( const char *fontFileName ) = 0;
// Helper fxns for loading bitmap fonts
virtual bool AddBitmapFontFile( const char *fontFileName ) = 0; virtual void SetBitmapFontName( const char *pName, const char *pFontFilename ) = 0; virtual const char *GetBitmapFontName( const char *pName ) = 0; virtual bool SetBitmapFontGlyphSet( FontHandle_t font, const char *windowsFontName, float scalex, float scaley, int flags) = 0;
virtual void ClearTemporaryFontCache( void ) = 0;
// Causes fonts to get reloaded, etc.
virtual void ResetFontCaches() = 0;
virtual bool SupportsFontFeature( FontFeature_t feature ) = 0;
virtual bool GetUnicodeCharRenderPositions( FontCharRenderInfo& info, Vector2D *pPositions ) = 0; virtual IMaterial *GetTextureForChar( FontCharRenderInfo &info, float **texCoords ) = 0; virtual IMaterial *GetTextureAndCoordsForChar( FontCharRenderInfo &info, float *texCoords ) = 0;
// Used for debugging.
virtual void DrawFontTexture( int textureId, int xPos, int yPos ) = 0; virtual void DrawFontTexture( IRenderContext *pRenderContext, int textureId, int xPos, int yPos ) = 0; virtual IMaterial *GetMaterial( int textureId ) = 0; virtual HRenderTexture GetTextureHandle( int textureId ) = 0;
virtual void SetLanguage( const char *pLanguage ) = 0; virtual const char *GetLanguage() = 0; };
//-----------------------------------------------------------------------------
// Game UI scheme manager
//-----------------------------------------------------------------------------
abstract_class IGameUISchemeMgr { public: // loads a scheme from a file
// first scheme loaded becomes the default scheme, and all subsequent loaded scheme are derivitives of that
// tag is friendly string representing the name of the loaded scheme
virtual IGameUIScheme * LoadSchemeFromFile( const char *fileName, const char *tag ) = 0;
// reloads the schemes from the file
virtual void ReloadSchemes() = 0;
// reloads scheme fonts
virtual void ReloadFonts( int inScreenTall = -1 ) = 0;
// returns a handle to the default (first loaded) scheme
virtual IGameUIScheme * GetDefaultScheme() = 0;
// returns a handle to the scheme identified by "tag"
virtual IGameUIScheme * GetScheme( const char *tag ) = 0;
virtual void SetLanguage( const char *pLanguage ) = 0; virtual char const * GetLanguage() = 0; };
//-----------------------------------------------------------------------------
// Game UI version of a vgui scheme
//-----------------------------------------------------------------------------
abstract_class IGameUIScheme { public: // Gets at the scheme's name
virtual const char *GetName() = 0; virtual const char *GetFileName() = 0;
virtual FontHandle_t GetFont( const char *fontName, bool proportional = false ) = 0; virtual FontHandle_t GetFontNextSize( bool bUp, const char *fontName, bool proportional = false ) = 0; virtual char const * GetFontName( const FontHandle_t &font ) = 0; };
//-----------------------------------------------------------------------------
// Used to allow clients to install different sound playback systems
//-----------------------------------------------------------------------------
abstract_class IGameUISoundPlayback { public: // EmitSound will return a handle to the sound being played.
// StopSound stops the sound given the handle to the sound
virtual void *EmitSound( const char *pSoundName ) = 0; virtual void StopSound( void *pSoundHandle ) = 0; };
//
// LINK_GAME_CONTROLS_LIB() macro must be included in the outer .dll code
// to force all required lib objects linked into the DLL.
//
extern void LinkGameControlsLib(); #define LINK_GAME_CONTROLS_LIB() \
namespace { \ static class CLinkGameControlsLib { \ public: \ CLinkGameControlsLib() { \ LinkGameControlsLib(); \ } \ } s_LinkHelper; \ };
#endif // IGAMEUISYSTEMMGR_H
|