Crazy Eddie's GUI System
0.8.5
|
Renderer implementation using Direct3D 10. More...
Public Member Functions | |
IDevice11 & | getDirect3DDevice () |
bool | isTexCoordSystemFlipped () const |
Returns if the texture coordinate system is vertically flipped or not. The original of a texture coordinate system is typically located either at the the top-left or the bottom-left. CEGUI, Direct3D and most rendering engines assume it to be on the top-left. OpenGL assumes it to be at the bottom left. More... | |
void | bindTechniquePass (const BlendMode mode, const bool clipped) |
low-level function that binds the technique pass ready for use | |
void | setCurrentTextureShaderResource (ID3D11ShaderResourceView *srv) |
low-level function to set the texture shader resource view to be used. | |
void | setProjectionMatrix (D3DXMATRIX &matrix) |
low-level function to set the projection matrix to be used. | |
void | setWorldMatrix (D3DXMATRIX &matrix) |
low-level function to set the world matrix to be used. | |
RenderTarget & | getDefaultRenderTarget () |
Returns the default RenderTarget object. The default render target is is typically one that targets the entire screen (or rendering window). More... | |
GeometryBuffer & | createGeometryBuffer () |
Create a new GeometryBuffer and return a reference to it. You should remove the GeometryBuffer from any RenderQueues and call destroyGeometryBuffer when you want to destroy the GeometryBuffer. More... | |
void | destroyGeometryBuffer (const GeometryBuffer &buffer) |
Destroy a GeometryBuffer that was returned when calling the createGeometryBuffer function. Before destroying any GeometryBuffer you should ensure that it has been removed from any RenderQueue that was using it. More... | |
void | destroyAllGeometryBuffers () |
Destroy all GeometryBuffer objects created by this Renderer. | |
TextureTarget * | createTextureTarget () |
Create a TextureTarget that can be used to cache imagery; this is a RenderTarget that does not lose it's content from one frame to another. More... | |
void | destroyTextureTarget (TextureTarget *target) |
Function that cleans up TextureTarget objects created with the createTextureTarget function. More... | |
void | destroyAllTextureTargets () |
Destory all TextureTarget objects created by this Renderer. | |
Texture & | createTexture (const String &name) |
Create a 'null' Texture object. More... | |
Texture & | createTexture (const String &name, const String &filename, const String &resourceGroup) |
Create a Texture object using the given image file. More... | |
Texture & | createTexture (const String &name, const Sizef &size) |
Create a Texture object with the given pixel dimensions as specified by size. More... | |
void | destroyTexture (Texture &texture) |
Destroy a Texture object that was previously created by calling the createTexture functions. More... | |
void | destroyTexture (const String &name) |
Destroy a Texture object that was previously created by calling the createTexture functions. More... | |
void | destroyAllTextures () |
Destroy all Texture objects created by this Renderer. | |
Texture & | getTexture (const String &name) const |
Return a Texture object that was previously created by calling the createTexture functions. More... | |
bool | isTextureDefined (const String &name) const |
Return whether a texture with the given name exists. | |
void | beginRendering () |
Perform any operations required to put the system into a state ready for rendering operations to begin. | |
void | endRendering () |
Perform any operations required to finalise rendering. | |
void | setDisplaySize (const Sizef &sz) |
Set the size of the display or host window in pixels for this Renderer object. More... | |
const Sizef & | getDisplaySize () const |
Return the size of the display or host window in pixels. More... | |
const Vector2f & | getDisplayDPI () const |
Return the resolution of the display or host window in dots per inch. More... | |
uint | getMaxTextureSize () const |
Return the pixel size of the maximum supported texture. More... | |
const String & | getIdentifierString () const |
Return identification string for the renderer module. More... | |
Public Member Functions inherited from CEGUI::Renderer | |
virtual | ~Renderer () |
Destructor. | |
Static Public Member Functions | |
static Direct3D11Renderer & | bootstrapSystem (ID3D11Device *device, ID3D11DeviceContext *context, const int abi=CEGUI_VERSION_ABI) |
Convenience function that creates the required objects to initialise the CEGUI system. More... | |
static void | destroySystem () |
Convenience function to cleanup the CEGUI system and related objects that were created by calling the bootstrapSystem function. More... | |
static Direct3D11Renderer & | create (ID3D11Device *device, ID3D11DeviceContext *context, const int abi=CEGUI_VERSION_ABI) |
Create an Direct3D11Renderer object. | |
static void | destroy (Direct3D11Renderer &renderer) |
Destroy an Direct3D11Renderer object. More... | |
Protected Types | |
typedef std::vector< TextureTarget * > | TextureTargetList |
container type used to hold TextureTargets we create. | |
typedef std::vector< Direct3D11GeometryBuffer * > | GeometryBufferList |
container type used to hold GeometryBuffers we create. | |
typedef std::map< String, Direct3D11Texture *, StringFastLessCompare CEGUI_MAP_ALLOC(String, Direct3D11Texture *)> | TextureMap |
container type used to hold Textures we create. | |
Protected Member Functions | |
Direct3D11Renderer (ID3D11Device *device, ID3D11DeviceContext *context) | |
constructor | |
~Direct3D11Renderer () | |
destructor. | |
Sizef | getViewportSize () |
return size of the D3D device viewport. | |
void | throwIfNameExists (const String &name) const |
helper to throw exception if name is already used. | |
Static Protected Member Functions | |
static void | logTextureCreation (const String &name) |
helper to safely log the creation of a named texture | |
static void | logTextureDestruction (const String &name) |
helper to safely log the destruction of a named texture | |
Protected Attributes | |
IDevice11 | d_device |
The D3D device we're using to render with. | |
Sizef | d_displaySize |
What the renderer considers to be the current display size. | |
Vector2f | d_displayDPI |
What the renderer considers to be the current display DPI resolution. | |
RenderTarget * | d_defaultTarget |
The default RenderTarget. | |
TextureTargetList | d_textureTargets |
Container used to track texture targets. | |
GeometryBufferList | d_geometryBuffers |
Container used to track geometry buffers. | |
TextureMap | d_textures |
Container used to track textures. | |
ID3DX11Effect * | d_effect |
Effect (shader) used when rendering. | |
ID3DX11EffectTechnique * | d_normalClippedTechnique |
Rendering technique that supplies scissor clipped BM_NORMAL type rendering. | |
ID3DX11EffectTechnique * | d_normalUnclippedTechnique |
Rendering technique that supplies BM_NORMAL type rendering. | |
ID3DX11EffectTechnique * | d_premultipliedClippedTechnique |
Rendering technique that supplies scissor clipped BM_RTT_PREMULTIPLIED type rendering. | |
ID3DX11EffectTechnique * | d_premultipliedUnclippedTechnique |
Rendering technique that supplies BM_RTT_PREMULTIPLIED type rendering. | |
ID3D11InputLayout * | d_inputLayout |
D3D11 input layout describing the vertex format we use. | |
ID3DX11EffectShaderResourceVariable * | d_boundTextureVariable |
Variable to access current texture (actually shader resource view) | |
ID3DX11EffectMatrixVariable * | d_worldMatrixVariable |
Variable to access world matrix used in geometry transformation. | |
ID3DX11EffectMatrixVariable * | d_projectionMatrixVariable |
Variable to access projection matrix used in geometry transformation. | |
Static Protected Attributes | |
static String | d_rendererID |
String holding the renderer identification text. | |
Renderer implementation using Direct3D 10.
|
static |
Convenience function that creates the required objects to initialise the CEGUI system.
This will create and initialise the following objects for you:
device | Pointer to the ID3D11Device interface that is to be used for CEGUI rendering operations. |
context | Pointer to the ID3D11DeviceContext interface that is to be used for CEGUI rendering operations. |
abi | This must be set to CEGUI_VERSION_ABI |
|
virtual |
Create a new GeometryBuffer and return a reference to it. You should remove the GeometryBuffer from any RenderQueues and call destroyGeometryBuffer when you want to destroy the GeometryBuffer.
Implements CEGUI::Renderer.
Create a 'null' Texture object.
name | String holding the name for the new texture. Texture names must be unique within the Renderer. |
Implements CEGUI::Renderer.
|
virtual |
Create a Texture object using the given image file.
name | String holding the name for the new texture. Texture names must be unique within the Renderer. |
filename | String object that specifies the path and filename of the image file to use when creating the texture. |
resourceGroup | String objet that specifies the resource group identifier to be passed to the resource provider when loading the texture file filename. |
Implements CEGUI::Renderer.
|
virtual |
Create a Texture object with the given pixel dimensions as specified by size.
name | String holding the name for the new texture. Texture names must be unique within the Renderer. |
size | Size object that describes the desired texture size. |
Implements CEGUI::Renderer.
|
virtual |
Create a TextureTarget that can be used to cache imagery; this is a RenderTarget that does not lose it's content from one frame to another.
If the renderer is unable to offer such a thing, 0 should be returned.
Implements CEGUI::Renderer.
|
static |
Destroy an Direct3D11Renderer object.
renderer | The Direct3D11Renderer object to be destroyed. |
|
virtual |
Destroy a GeometryBuffer that was returned when calling the createGeometryBuffer function. Before destroying any GeometryBuffer you should ensure that it has been removed from any RenderQueue that was using it.
buffer | The GeometryBuffer object to be destroyed. |
Implements CEGUI::Renderer.
|
static |
Convenience function to cleanup the CEGUI system and related objects that were created by calling the bootstrapSystem function.
This function will destroy the following objects for you:
|
virtual |
Destroy a Texture object that was previously created by calling the createTexture functions.
texture | Texture object to be destroyed. |
Implements CEGUI::Renderer.
|
virtual |
Destroy a Texture object that was previously created by calling the createTexture functions.
name | String holding the name of the texture to destroy. |
Implements CEGUI::Renderer.
|
virtual |
Function that cleans up TextureTarget objects created with the createTextureTarget function.
target | A pointer to a TextureTarget object that was previously returned from a call to createTextureTarget. |
Implements CEGUI::Renderer.
|
virtual |
Returns the default RenderTarget object. The default render target is is typically one that targets the entire screen (or rendering window).
Implements CEGUI::Renderer.
|
virtual |
Return the resolution of the display or host window in dots per inch.
Implements CEGUI::Renderer.
|
virtual |
Return the size of the display or host window in pixels.
Implements CEGUI::Renderer.
|
virtual |
Return identification string for the renderer module.
Implements CEGUI::Renderer.
|
virtual |
Return the pixel size of the maximum supported texture.
Implements CEGUI::Renderer.
Return a Texture object that was previously created by calling the createTexture functions.
Implements CEGUI::Renderer.
|
inline |
Returns if the texture coordinate system is vertically flipped or not. The original of a texture coordinate system is typically located either at the the top-left or the bottom-left. CEGUI, Direct3D and most rendering engines assume it to be on the top-left. OpenGL assumes it to be at the bottom left.
This function is intended to be used when generating geometry for rendering the TextureTarget onto another surface. It is also intended to be used when trying to use a custom texture (RTT) inside CEGUI using the Image class, in order to determine the Image coordinates correctly.
|
virtual |
Set the size of the display or host window in pixels for this Renderer object.
This is intended to be called by the System as part of the notification process when display size changes are notified to it via the System::notifyDisplaySizeChanged function.
size | Size object describing the dimesions of the current or host window in pixels. |
Implements CEGUI::Renderer.