OGRE-Next
2.3
Object-Oriented Graphics Rendering Engine
|
Utility class which defines the sub-parts of an Entity. More...
#include <OgreSubEntity.h>
Public Types | |
typedef map< size_t, Vector4 >::type | CustomParameterMap |
Public Member Functions | |
virtual | ~SubEntity () |
Destructor. More... | |
bool | _getBuffersMarkedForAnimation () const |
Are buffers already marked as vertex animated? More... | |
VertexData * | _getHardwareVertexAnimVertexData () |
Advanced method to get the hardware morph vertex information. More... | |
TempBlendedBufferInfo * | _getSkelAnimTempBufferInfo () |
Advanced method to get the temp buffer information for software skeletal animation. More... | |
VertexData * | _getSkelAnimVertexData () |
Advanced method to get the temporarily blended vertex information for entities which are software skinned. More... | |
VertexData * | _getSoftwareVertexAnimVertexData () |
Advanced method to get the temporarily blended software morph vertex information. More... | |
TempBlendedBufferInfo * | _getVertexAnimTempBufferInfo () |
Advanced method to get the temp buffer information for software morph animation. More... | |
const TempBlendedBufferInfo * | _getVertexAnimTempBufferInfo () const |
void | _markBuffersUnusedForAnimation () |
Mark all vertex data as so far unanimated. More... | |
void | _markBuffersUsedForAnimation () |
Mark all vertex data as animated. More... | |
void | _restoreBuffersForUnusedAnimation (bool hardwareAnimation) |
Internal method to copy original vertex data to the morph structures should there be no active animation in use. More... | |
virtual void | _setHlmsHashes (uint32 hash, uint32 casterHash) |
Manually sets the hlms hashes. Don't call this directly. More... | |
void | _setNullDatablock () override |
Sets the datablock to a null pointer. More... | |
void | _updateCustomGpuParameter (const GpuProgramParameters_AutoConstantEntry &constantEntry, GpuProgramParameters *params) const override |
Overridden from Renderable to provide some custom behaviour. More... | |
void | addPoseWeight (size_t index, float w) |
bool | getCastsShadows () const override |
Method which reports whether this renderable would normally cast a shadow. More... | |
uint8 | getCurrentMaterialLod () const |
const Vector4 & | getCustomParameter (size_t index) const |
Gets the custom value associated with this Renderable at the given index. More... | |
const CustomParameterMap & | getCustomParameters () const |
HlmsDatablock * | getDatablock () const |
const String & | getDatablockOrMaterialName () const |
uint32 | getHlmsCasterHash () const |
uint32 | getHlmsHash () const |
size_t | getIndexDataEndIndex () const |
Returns the current value of the start index used for drawing. More... | |
size_t | getIndexDataStartIndex () const |
Returns the current value of the start index used for drawing. More... | |
const LightList & | getLights () const override |
Gets a list of lights, ordered relative to how close they are to this renderable. More... | |
MaterialPtr | getMaterial () const |
Retrieves the material this renderable object uses. More... | |
unsigned short | getNumPoses () const |
unsigned short | getNumWorldTransforms () const override |
Overridden - see Renderable. More... | |
Entity * | getParent () const |
Accessor to get parent Entity. More... | |
virtual bool | getPolygonModeOverrideable () const |
Gets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting. More... | |
bool | getPoseHalfPrecision () const |
bool | getPoseNormals () const |
TexBufferPacked * | getPoseTexBuffer () const |
float | getPoseWeight (size_t index) const |
float * | getPoseWeights () const |
void | getRenderOperation (RenderOperation &op, bool casterPass) override |
Overridden - see Renderable. More... | |
uint8 | getRenderQueueSubGroup () const |
Real | getSquaredViewDepth (const Camera *cam) const |
Overridden, see Renderable. More... | |
SubMesh * | getSubMesh () const |
Accessor method to read mesh data. More... | |
bool | getUseIdentityProjection () const |
Returns whether or not to use an 'identity' projection. More... | |
bool | getUseIdentityView () const |
Returns whether or not to use an 'identity' view. More... | |
virtual bool | getUseIdentityViewProjMatrixIsDynamic () const |
Returns whether the Hlms implementation should evaluate getUseIdentityProjection per object at runtime, or if it can assume the Renderable will remain with the same setting until the datablock is flushed (performance optimization) More... | |
virtual bool | getUseIdentityWorldMatrix () const |
Returns whether the world matrix is an identity matrix. More... | |
virtual OGRE_DEPRECATED const Any & | getUserAny () const |
UserObjectBindings & | getUserObjectBindings () |
Return an instance of user objects binding associated with this class. More... | |
const UserObjectBindings & | getUserObjectBindings () const |
Return an instance of user objects binding associated with this class. More... | |
const VertexArrayObjectArray & | getVaos (VertexPass vertexPass) const |
VertexData * | getVertexDataForBinding (bool casterPass) |
Retrieve the VertexData which should be used for GPU binding. More... | |
void | getWorldTransforms (Matrix4 *xform) const override |
Overridden - see Renderable. More... | |
bool | hasCustomParameter (size_t index) const |
Checks whether a custom value is associated with this Renderable at the given index. More... | |
bool | hasSkeletonAnimation () const |
void | operator delete (void *ptr) |
void | operator delete (void *ptr, const char *, int, const char *) |
void | operator delete (void *ptr, void *) |
void | operator delete[] (void *ptr) |
void | operator delete[] (void *ptr, const char *, int, const char *) |
void * | operator new (size_t sz) |
void * | operator new (size_t sz, const char *file, int line, const char *func) |
operator new, with debug line info More... | |
void * | operator new (size_t sz, void *ptr) |
placement operator new More... | |
void * | operator new[] (size_t sz) |
void * | operator new[] (size_t sz, const char *file, int line, const char *func) |
array operator new, with debug line info More... | |
virtual void | postRender (SceneManager *sm, RenderSystem *rsys) |
Called immediately after the Renderable has been rendered. More... | |
virtual bool | preRender (SceneManager *sm, RenderSystem *rsys) |
Called just prior to the Renderable being rendered. More... | |
void | removeCustomParameter (size_t index) |
Removes a custom value which is associated with this Renderable at the given index. More... | |
void | resetIndexDataStartEndIndex () |
Reset the custom start/end index to the default values. More... | |
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. More... | |
virtual void | setDatablock (HlmsDatablock *datablock) |
Make every setDatablock method from Renderable available. More... | |
void | setDatablock (HlmsDatablock *datablock) override |
Assigns a datablock (i.e. HLMS Material) to this renderable. More... | |
void | setDatablock (IdString datablockName) |
Assigns a datablock (i.e. More... | |
void | setDatablock (IdString datablockName) |
Make every setDatablock method from Renderable available. More... | |
void | setDatablockOrMaterialName (String materialName, String groupName) |
First tries to see if an HLMS datablock exist with the given name, if not, tries to search among low level materials. More... | |
void | setIndexDataEndIndex (size_t end_index) |
Tells this SubEntity to draw a subset of the SubMesh by adjusting the index buffer extents. More... | |
void | setIndexDataStartIndex (size_t start_index) |
Tells this SubEntity to draw a subset of the SubMesh by adjusting the index buffer extents. More... | |
void | setMaterial (const MaterialPtr &material) override |
Sets a Material to be used. More... | |
void | setMaterialName (const String &name, const String &groupName) |
Sets the name of the Material to be used. Prefer using HLMS @See setHlms. More... | |
virtual void | setPolygonModeOverrideable (bool override) |
Sets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting. More... | |
void | setPoseWeight (size_t index, float w) |
void | setRenderQueueSubGroup (uint8 subGroup) |
Sets the render queue sub group. More... | |
void | setUseIdentityProjection (bool useIdentityProjection) |
Sets whether or not to use an 'identity' projection. More... | |
void | setUseIdentityView (bool useIdentityView) |
Sets whether or not to use an 'identity' view. More... | |
virtual OGRE_DEPRECATED void | setUserAny (const Any &anything) |
Static Public Member Functions | |
static uint8 | getDefaultRenderQueueSubGroup () |
static void | setDefaultRenderQueueSubGroup (uint8 subGroup) |
Sets the default render queue sub group for all future Renderable instances. More... | |
Public Attributes | |
uint8 | mCustomParameter |
Only valid when using low level materials. More... | |
uint32 | mHlmsGlobalIndex |
Index in the vector holding this Rendrable reference in the HLMS datablock. More... | |
bool | mRenderableVisible |
Control visibility at Renderable (e.g. More... | |
Friends | |
class | Entity |
class | SceneManager |
Utility class which defines the sub-parts of an Entity.
|
inherited |
|
virtual |
Destructor.
|
inline |
Are buffers already marked as vertex animated?
VertexData* Ogre::v1::SubEntity::_getHardwareVertexAnimVertexData | ( | ) |
Advanced method to get the hardware morph vertex information.
TempBlendedBufferInfo* Ogre::v1::SubEntity::_getSkelAnimTempBufferInfo | ( | ) |
Advanced method to get the temp buffer information for software skeletal animation.
VertexData* Ogre::v1::SubEntity::_getSkelAnimVertexData | ( | ) |
Advanced method to get the temporarily blended vertex information for entities which are software skinned.
VertexData* Ogre::v1::SubEntity::_getSoftwareVertexAnimVertexData | ( | ) |
Advanced method to get the temporarily blended software morph vertex information.
TempBlendedBufferInfo* Ogre::v1::SubEntity::_getVertexAnimTempBufferInfo | ( | ) |
Advanced method to get the temp buffer information for software morph animation.
const TempBlendedBufferInfo* Ogre::v1::SubEntity::_getVertexAnimTempBufferInfo | ( | ) | const |
void Ogre::v1::SubEntity::_markBuffersUnusedForAnimation | ( | ) |
Mark all vertex data as so far unanimated.
void Ogre::v1::SubEntity::_markBuffersUsedForAnimation | ( | ) |
Mark all vertex data as animated.
void Ogre::v1::SubEntity::_restoreBuffersForUnusedAnimation | ( | bool | hardwareAnimation | ) |
Internal method to copy original vertex data to the morph structures should there be no active animation in use.
Manually sets the hlms hashes. Don't call this directly.
Reimplemented in Ogre::SubItem.
|
overridevirtual |
Sets the datablock to a null pointer.
Use case: If you will be destroying an HlmsDatablock and all Renderables associated by it; it makes no sense to change the Renderable's datablock to a default one, only to be destroyed immediately after (you pay an unnecessary performance price).
Reimplemented from Ogre::Renderable.
|
overridevirtual |
Overridden from Renderable to provide some custom behaviour.
Reimplemented from Ogre::Renderable.
|
inherited |
|
overridevirtual |
Method which reports whether this renderable would normally cast a shadow.
Reimplemented from Ogre::Renderable.
|
inlineinherited |
|
inlineinherited |
Gets the custom value associated with this Renderable at the given index.
index | Index of the parameter to retrieve. |
References Ogre::Exception::ERR_ITEM_NOT_FOUND, and OGRE_EXCEPT.
|
inlineinherited |
|
inlineinherited |
|
inherited |
|
inlinestaticinherited |
|
inlineinherited |
|
inlineinherited |
size_t Ogre::v1::SubEntity::getIndexDataEndIndex | ( | ) | const |
Returns the current value of the start index used for drawing.
size_t Ogre::v1::SubEntity::getIndexDataStartIndex | ( | ) | const |
Returns the current value of the start index used for drawing.
|
overridevirtual |
Gets a list of lights, ordered relative to how close they are to this renderable.
Implements Ogre::Renderable.
|
inherited |
Retrieves the material this renderable object uses.
It may be null if it's using the HLMS. @See getDatablock
|
inherited |
|
overridevirtual |
Overridden - see Renderable.
Reimplemented from Ogre::Renderable.
|
inlinevirtualinherited |
Gets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting.
Reimplemented in Ogre::v1::BorderRenderable.
Referenced by Ogre::v1::BorderRenderable::getPolygonModeOverrideable().
|
inherited |
|
inherited |
|
inherited |
|
inherited |
|
inherited |
|
overridevirtual |
Overridden - see Renderable.
Implements Ogre::Renderable.
|
inlineinherited |
Overridden, see Renderable.
SubMesh* Ogre::v1::SubEntity::getSubMesh | ( | ) | const |
Accessor method to read mesh data.
|
inlineinherited |
Returns whether or not to use an 'identity' projection.
|
inlineinherited |
Returns whether or not to use an 'identity' view.
|
inlinevirtualinherited |
Returns whether the Hlms implementation should evaluate getUseIdentityProjection per object at runtime, or if it can assume the Renderable will remain with the same setting until the datablock is flushed (performance optimization)
|
inlinevirtualinherited |
Returns whether the world matrix is an identity matrix.
Reimplemented in Ogre::v1::BillboardSet.
|
inlinevirtualinherited |
Retrieves the custom user value associated with this object.
|
inlineinherited |
Return an instance of user objects binding associated with this class.
You can use it to associate one or more custom objects with this class instance.
|
inlineinherited |
Return an instance of user objects binding associated with this class.
You can use it to associate one or more custom objects with this class instance.
|
inlineinherited |
VertexData* Ogre::v1::SubEntity::getVertexDataForBinding | ( | bool | casterPass | ) |
Retrieve the VertexData which should be used for GPU binding.
|
overridevirtual |
Overridden - see Renderable.
Implements Ogre::Renderable.
|
inlineinherited |
Checks whether a custom value is associated with this Renderable at the given index.
index | Index of the parameter to check for existence. |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
operator new, with debug line info
|
inlineinherited |
placement operator new
|
inlineinherited |
|
inlineinherited |
array operator new, with debug line info
|
inlinevirtualinherited |
Called immediately after the Renderable has been rendered.
|
inlinevirtualinherited |
Called just prior to the Renderable being rendered.
Reimplemented in Ogre::v1::BillboardChain.
|
inlineinherited |
Removes a custom value which is associated with this Renderable at the given index.
index | Index of the parameter to remove. |
void Ogre::v1::SubEntity::resetIndexDataStartEndIndex | ( | ) |
Reset the custom start/end index to the default values.
|
inlineinherited |
Sets a custom parameter for this Renderable, which may be used to drive calculations for this specific Renderable, like GPU program 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. |
virtual void Ogre::Renderable::setDatablock |
Make every setDatablock method from Renderable available.
See http://www.research.att.com/~bs/bs_faq2.html#overloadderived
|
overridevirtual |
Assigns a datablock (i.e. HLMS Material) to this renderable.
Reimplemented from Ogre::Renderable.
|
inherited |
Assigns a datablock (i.e.
HLMS material) based on its unique name.
void Ogre::Renderable::setDatablock |
Make every setDatablock method from Renderable available.
See http://www.research.att.com/~bs/bs_faq2.html#overloadderived
|
inherited |
First tries to see if an HLMS datablock exist with the given name, if not, tries to search among low level materials.
|
inlinestaticinherited |
Sets the default render queue sub group for all future Renderable instances.
void Ogre::v1::SubEntity::setIndexDataEndIndex | ( | size_t | end_index | ) |
void Ogre::v1::SubEntity::setIndexDataStartIndex | ( | size_t | start_index | ) |
Tells this SubEntity to draw a subset of the SubMesh by adjusting the index buffer extents.
Default value is zero so that the entire index buffer is used when drawing. Valid values are zero to getIndexDataEndIndex()
|
overridevirtual |
Sets the name of the Material to be used. Prefer using HLMS @See setHlms.
|
inlinevirtualinherited |
Sets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting.
override | true means that a lower camera detail will override this renderables detail level, false means it won't. |
|
inherited |
|
inlineinherited |
Sets the render queue sub group.
subGroup | The sub group. This value can't exceed OGRE_MAKE_MASK( SubRqIdBits ) @See RenderQueue |
|
inlineinherited |
Sets whether or not to use an 'identity' projection.
|
inlineinherited |
Sets whether or not to use an 'identity' view.
|
inlinevirtualinherited |
Sets any kind of user value on this object.
|
friend |
|
friend |
|
inherited |
Only valid when using low level materials.
|
inherited |
Index in the vector holding this Rendrable reference in the HLMS datablock.
Used for O(1) removals.
|
inherited |
Control visibility at Renderable (e.g.
SubMesh) level
Note that if our MovableObject owner called MovableObject::setVisible( false ) we won't get rendered. Both must be true in order to render.