Main Page | Namespace List | Class Hierarchy | Alphabetical List | Class List | File List | Namespace Members | Class Members | File Members | Related Pages

Ogre::BorderRenderable Class Reference

Class for rendering the border of a BorderPanelOverlayElement. More...

#include <OgreBorderPanelOverlayElement.h>

Inheritance diagram for Ogre::BorderRenderable:

Ogre::Renderable List of all members.

Public Member Functions

 BorderRenderable (BorderPanelOverlayElement *parent)
 Constructed with pointers to parent.

const MaterialPtrgetMaterial (void) const
 Retrieves a weak reference to the material this renderable object uses.

void getRenderOperation (RenderOperation &op)
 Gets the render operation required to send this object to the frame buffer.

void getWorldTransforms (Matrix4 *xform) const
 Gets the world transform matrix / matrices for this renderable object.

const QuaterniongetWorldOrientation (void) const
 Gets the worldspace orientation of this renderable; this is used in order to more efficiently update parameters to vertex & fragment programs, since inverting Quaterion and Vector in order to derive object-space positions / directions for cameras and lights is much more efficient than inverting a complete 4x4 matrix, and also eliminates problems introduced by scaling.

const Vector3getWorldPosition (void) const
 Gets the worldspace orientation of this renderable; this is used in order to more efficiently update parameters to vertex & fragment programs, since inverting Quaterion and Vector in order to derive object-space positions / directions for cameras and lights is much more efficient than inverting a complete 4x4 matrix, and also eliminates problems introduced by scaling.

unsigned short getNumWorldTransforms (void) const
 Returns the number of world transform matrices this renderable requires.

bool useIdentityProjection (void) const
 Returns whether or not to use an 'identity' projection.

bool useIdentityView (void) const
 Returns whether or not to use an 'identity' projection.

Real getSquaredViewDepth (const Camera *cam) const
 Returns the camera-relative squared depth of this renderable.

const LightListgetLights (void) const
 Gets a list of lights, ordered relative to how close they are to this renderable.

bool getRenderDetailOverrideable (void) const
 Gets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting.

virtual TechniquegetTechnique (void) const
 Retrieves a pointer to the Material Technique this renderable object uses.

virtual SceneDetailLevel getRenderDetail () const
 Returns the preferred rasterisation mode of this renderable.

virtual bool getNormaliseNormals (void) const
 Returns whether or not this Renderable wishes the hardware to normalise normals.

virtual const PlaneListgetClipPlanes () const
virtual bool getCastsShadows (void) const
 Method which reports whether this renderable would normally cast a shadow.

void setCustomParameter (size_t index, const Vector4 &value)
 Sets a custom parameter for this Renderable, which may be used to drive calculations for this specific Renderable, like GPU program parameters.

const Vector4getCustomParameter (size_t index) const
 Gets the custom value associated with this Renderable at the given index.

virtual void _updateCustomGpuParameter (const GpuProgramParameters::AutoConstantEntry &constantEntry, GpuProgramParameters *params) const
 Update a custom GpuProgramParameters constant which is derived from information only this Renderable knows.

virtual void setRenderDetailOverrideable (bool override)
 Sets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting.


Protected Types

typedef std::map< size_t,
Vector4
CustomParameterMap

Protected Attributes

BorderPanelOverlayElementmParent
CustomParameterMap mCustomParameters
bool mRenderDetailOverrideable

Static Protected Attributes

const PlaneList msDummyPlaneList

Detailed Description

Class for rendering the border of a BorderPanelOverlayElement.

Remarks:
We need this because we have to render twice, once with the inner panel's repeating material (handled by superclass) and once for the border's separate meterial.

Definition at line 308 of file OgreBorderPanelOverlayElement.h.


Member Typedef Documentation

typedef std::map<size_t, Vector4> Ogre::Renderable::CustomParameterMap [protected, inherited]
 

Definition at line 251 of file OgreRenderable.h.


Constructor & Destructor Documentation

Ogre::BorderRenderable::BorderRenderable BorderPanelOverlayElement parent  ) 
 

Constructed with pointers to parent.

Definition at line 314 of file OgreBorderPanelOverlayElement.h.


Member Function Documentation

virtual void Ogre::Renderable::_updateCustomGpuParameter const GpuProgramParameters::AutoConstantEntry constantEntry,
GpuProgramParameters params
const [virtual, inherited]
 

Update a custom GpuProgramParameters constant which is derived from information only this Renderable knows.

Remarks:
This method allows a Renderable to map in a custom GPU program parameter based on it's own data. This is represented by a GPU auto parameter of ACT_CUSTOM, and to allow there to be more than one of these per Renderable, the 'data' field on the auto parameter will identify which parameter is being updated. The implementation of this method must identify the parameter being updated, and call a 'setConstant' method on the passed in GpuProgramParameters object, using the details provided in the incoming auto constant setting to identify the index at which to set the parameter.
You do not need to override this method if you're using the standard sets of data associated with the Renderable as provided by setCustomParameter and getCustomParameter. By default, the implementation will map from the value indexed by the 'constantEntry.data' parameter to a value previously set by setCustomParameter. But custom Renderables are free to override this if they want, in any case.
Parameters:
constantEntry The auto constant entry referring to the parameter being updated
params The parameters object which this method should call to set the updated parameters.

Reimplemented in Ogre::TerrainRenderable.

Definition at line 219 of file OgreRenderable.h.

References Ogre::GpuProgramParameters::AutoConstantEntry::data, Ogre::GpuProgramParameters::AutoConstantEntry::index, and params.

virtual bool Ogre::Renderable::getCastsShadows void   )  const [virtual, inherited]
 

Method which reports whether this renderable would normally cast a shadow.

Remarks:
Subclasses should override this if they could have been used to generate a shadow.

Reimplemented in Ogre::StaticGeometry::GeometryBucket, and Ogre::SubEntity.

Definition at line 154 of file OgreRenderable.h.

virtual const PlaneList& Ogre::Renderable::getClipPlanes  )  const [virtual, inherited]
 

Definition at line 146 of file OgreRenderable.h.

References Ogre::PlaneList.

const Vector4& Ogre::Renderable::getCustomParameter size_t  index  )  const [inherited]
 

Gets the custom value associated with this Renderable at the given index.

Parameters:
@see setCustomParaemter for full details.

Definition at line 180 of file OgreRenderable.h.

References OGRE_EXCEPT.

const LightList& Ogre::BorderRenderable::getLights void   )  const [virtual]
 

Gets a list of lights, ordered relative to how close they are to this renderable.

Remarks:
Directional lights, which have no position, will always be first on this list.

Implements Ogre::Renderable.

Definition at line 324 of file OgreBorderPanelOverlayElement.h.

References Ogre::LightList.

const MaterialPtr& Ogre::BorderRenderable::getMaterial void   )  const [virtual]
 

Retrieves a weak reference to the material this renderable object uses.

Remarks:
Note that the Renderable also has the option to override the getTechnique method to specify a particular Technique to use instead of the best one available.

Implements Ogre::Renderable.

Definition at line 315 of file OgreBorderPanelOverlayElement.h.

virtual bool Ogre::Renderable::getNormaliseNormals void   )  const [virtual, inherited]
 

Returns whether or not this Renderable wishes the hardware to normalise normals.

Reimplemented in Ogre::SubEntity.

Definition at line 138 of file OgreRenderable.h.

unsigned short Ogre::BorderRenderable::getNumWorldTransforms void   )  const [virtual]
 

Returns the number of world transform matrices this renderable requires.

Remarks:
When a renderable uses vertex blending, it uses multiple world matrices instead of a single one. Each vertex sent to the pipeline can reference one or more matrices in this list with given weights. If a renderable does not use vertex blending this method returns 1, which is the default for simplicity.

Reimplemented from Ogre::Renderable.

Definition at line 320 of file OgreBorderPanelOverlayElement.h.

virtual SceneDetailLevel Ogre::Renderable::getRenderDetail  )  const [virtual, inherited]
 

Returns the preferred rasterisation mode of this renderable.

Reimplemented in Ogre::SubEntity.

Definition at line 135 of file OgreRenderable.h.

References Ogre::SceneDetailLevel, and Ogre::SDL_SOLID.

bool Ogre::BorderRenderable::getRenderDetailOverrideable void   )  const [virtual]
 

Gets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting.

Reimplemented from Ogre::Renderable.

Definition at line 330 of file OgreBorderPanelOverlayElement.h.

void Ogre::BorderRenderable::getRenderOperation RenderOperation op  )  [virtual]
 

Gets the render operation required to send this object to the frame buffer.

Implements Ogre::Renderable.

Definition at line 316 of file OgreBorderPanelOverlayElement.h.

Real Ogre::BorderRenderable::getSquaredViewDepth const Camera cam  )  const [virtual]
 

Returns the camera-relative squared depth of this renderable.

Remarks:
Used to sort transparent objects. Squared depth is used rather than actual depth to avoid having to perform a square root on the result.

Implements Ogre::Renderable.

Definition at line 323 of file OgreBorderPanelOverlayElement.h.

References Ogre::Real.

virtual Technique* Ogre::Renderable::getTechnique void   )  const [virtual, inherited]
 

Retrieves a pointer to the Material Technique this renderable object uses.

Remarks:
This is to allow Renderables to use a chosen Technique if they wish, otherwise they will use the best Technique available for the Material they are using.

Reimplemented in Ogre::StaticGeometry::GeometryBucket, and Ogre::SubEntity.

Definition at line 69 of file OgreRenderable.h.

const Quaternion& Ogre::BorderRenderable::getWorldOrientation void   )  const [virtual]
 

Gets the worldspace orientation of this renderable; this is used in order to more efficiently update parameters to vertex & fragment programs, since inverting Quaterion and Vector in order to derive object-space positions / directions for cameras and lights is much more efficient than inverting a complete 4x4 matrix, and also eliminates problems introduced by scaling.

Implements Ogre::Renderable.

Definition at line 318 of file OgreBorderPanelOverlayElement.h.

const Vector3& Ogre::BorderRenderable::getWorldPosition void   )  const [virtual]
 

Gets the worldspace orientation of this renderable; this is used in order to more efficiently update parameters to vertex & fragment programs, since inverting Quaterion and Vector in order to derive object-space positions / directions for cameras and lights is much more efficient than inverting a complete 4x4 matrix, and also eliminates problems introduced by scaling.

Implements Ogre::Renderable.

Definition at line 319 of file OgreBorderPanelOverlayElement.h.

void Ogre::BorderRenderable::getWorldTransforms Matrix4 xform  )  const [virtual]
 

Gets the world transform matrix / matrices for this renderable object.

Remarks:
If the object has any derived transforms, these are expected to be up to date as long as all the SceneNode structures have been updated before this is called.
This method will populate xform with 1 matrix if it does not use vertex blending. If it does use vertex blending it will fill the passed in pointer with an array of matrices, the length being the value returned from getNumWorldTransforms.

Implements Ogre::Renderable.

Definition at line 317 of file OgreBorderPanelOverlayElement.h.

void Ogre::Renderable::setCustomParameter size_t  index,
const Vector4 value
[inherited]
 

Sets a custom parameter for this Renderable, which may be used to drive calculations for this specific Renderable, like GPU program parameters.

Remarks:
Calling this method simply associates a numeric index with a 4-dimensional value for this specific Renderable. This is most useful if the material which this Renderable uses a vertex or fragment program, and has an ACT_CUSTOM parameter entry. This parameter entry can refer to the index you specify as part of this call, thereby mapping a custom parameter for this renderable to a program parameter.
Parameters:
index The index with which to associate the value. Note that this does not have to start at 0, and can include gaps. It also has no direct correlation with a GPU program parameter index - the mapping between the two is performed by the ACT_CUSTOM entry, if that is used.
value The value to associate.

Definition at line 171 of file OgreRenderable.h.

virtual void Ogre::Renderable::setRenderDetailOverrideable bool  override  )  [virtual, inherited]
 

Sets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting.

Parameters:
override true means that a lower camera detail will override this renderables detail level, false means it won't.

Definition at line 235 of file OgreRenderable.h.

bool Ogre::BorderRenderable::useIdentityProjection void   )  const [virtual]
 

Returns whether or not to use an 'identity' projection.

Remarks:
Usually Renderable objects will use a projection matrix as determined by the active camera. However, if they want they can cancel this out and use an identity projection, which effectively projects in 2D using a {-1, 1} view space. Useful for overlay rendering. Normal renderables need not override this.

Reimplemented from Ogre::Renderable.

Definition at line 321 of file OgreBorderPanelOverlayElement.h.

bool Ogre::BorderRenderable::useIdentityView void   )  const [virtual]
 

Returns whether or not to use an 'identity' projection.

Remarks:
Usually Renderable objects will use a view matrix as determined by the active camera. However, if they want they can cancel this out and use an identity matrix, which means all geometry is assumed to be relative to camera space already. Useful for overlay rendering. Normal renderables need not override this.

Reimplemented from Ogre::Renderable.

Definition at line 322 of file OgreBorderPanelOverlayElement.h.


Member Data Documentation

CustomParameterMap Ogre::Renderable::mCustomParameters [protected, inherited]
 

Definition at line 252 of file OgreRenderable.h.

BorderPanelOverlayElement* Ogre::BorderRenderable::mParent [protected]
 

Definition at line 311 of file OgreBorderPanelOverlayElement.h.

bool Ogre::Renderable::mRenderDetailOverrideable [protected, inherited]
 

Definition at line 253 of file OgreRenderable.h.

const PlaneList Ogre::Renderable::msDummyPlaneList [static, protected, inherited]
 

Definition at line 250 of file OgreRenderable.h.


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

Copyright © 2000-2005 by The OGRE Team
Creative Commons License
This work is licensed under a Creative Commons Attribution-ShareAlike 2.5 License.
Last modified Sun Feb 12 13:00:13 2006