Urho3D::Material Class Reference
Public Member Functions |
Static Public Member Functions |
Private Member Functions |
Private Attributes |
List of all members
Urho3D::Material Class Reference
Describes how to render 3D geometries. More...
#include <Urho3D/Graphics/Material.h>
Inheritance diagram for Urho3D::Material:
Collaboration diagram for Urho3D::Material:
Public Member Functions | |
Material (Context *context) | |
Construct. | |
~Material () | |
Destruct. | |
virtual bool | BeginLoad (Deserializer &source) |
Load resource from stream. May be called from a worker thread. Return true if successful. | |
virtual bool | EndLoad () |
Finish resource loading. Always called from the main thread. Return true if successful. | |
virtual bool | Save (Serializer &dest) const |
Save resource. Return true if successful. | |
bool | Load (const XMLElement &source) |
Load from an XML element. Return true if successful. | |
bool | Save (XMLElement &dest) const |
Save to an XML element. Return true if successful. | |
bool | Load (const JSONValue &source) |
Load from a JSON value. Return true if successful. | |
bool | Save (JSONValue &dest) const |
Save to a JSON value. Return true if successful. | |
void | SetNumTechniques (unsigned num) |
Set number of techniques. | |
void | SetTechnique (unsigned index, Technique *tech, unsigned qualityLevel=0, float lodDistance=0.0f) |
Set technique. | |
void | SetShaderParameter (const String &name, const Variant &value) |
Set shader parameter. | |
void | SetShaderParameterAnimation (const String &name, ValueAnimation *animation, WrapMode wrapMode=WM_LOOP, float speed=1.0f) |
Set shader parameter animation. | |
void | SetShaderParameterAnimationWrapMode (const String &name, WrapMode wrapMode) |
Set shader parameter animation wrap mode. | |
void | SetShaderParameterAnimationSpeed (const String &name, float speed) |
Set shader parameter animation speed. | |
void | SetTexture (TextureUnit unit, Texture *texture) |
Set texture. | |
void | SetUVTransform (const Vector2 &offset, float rotation, const Vector2 &repeat) |
Set texture coordinate transform. | |
void | SetUVTransform (const Vector2 &offset, float rotation, float repeat) |
Set texture coordinate transform. | |
void | SetCullMode (CullMode mode) |
Set culling mode. | |
void | SetShadowCullMode (CullMode mode) |
Set culling mode for shadows. | |
void | SetFillMode (FillMode mode) |
Set polygon fill mode. Interacts with the camera's fill mode setting so that the "least filled" mode will be used. | |
void | SetDepthBias (const BiasParameters ¶meters) |
Set depth bias. | |
void | SetRenderOrder (unsigned char order) |
Set 8-bit render order within pass. Default 128. Lower values will render earlier and higher values later, taking precedence over e.g. state and distance sorting. | |
void | SetScene (Scene *scene) |
Associate the material with a scene to ensure that shader parameter animation happens in sync with scene update, respecting the scene time scale. If no scene is set, the global update events will be used. | |
void | RemoveShaderParameter (const String &name) |
Remove shader parameter. | |
void | ReleaseShaders () |
Reset all shader pointers. | |
SharedPtr< Material > | Clone (const String &cloneName=String::EMPTY) const |
Clone the material. | |
void | SortTechniques () |
Ensure that material techniques are listed in correct order. | |
void | MarkForAuxView (unsigned frameNumber) |
Mark material for auxiliary view rendering. | |
unsigned | GetNumTechniques () const |
Return number of techniques. | |
const Vector< TechniqueEntry > & | GetTechniques () const |
Return all techniques. | |
const TechniqueEntry & | GetTechniqueEntry (unsigned index) const |
Return technique entry by index. | |
Technique * | GetTechnique (unsigned index) const |
Return technique by index. | |
Pass * | GetPass (unsigned index, const String &passName) const |
Return pass by technique index and pass name. | |
Texture * | GetTexture (TextureUnit unit) const |
Return texture by unit. | |
const HashMap< TextureUnit, SharedPtr< Texture > > & | GetTextures () const |
Return all textures. | |
const Variant & | GetShaderParameter (const String &name) const |
Return shader parameter. | |
ValueAnimation * | GetShaderParameterAnimation (const String &name) const |
Return shader parameter animation. | |
WrapMode | GetShaderParameterAnimationWrapMode (const String &name) const |
Return shader parameter animation wrap mode. | |
float | GetShaderParameterAnimationSpeed (const String &name) const |
Return shader parameter animation speed. | |
const HashMap< StringHash, MaterialShaderParameter > & | GetShaderParameters () const |
Return all shader parameters. | |
CullMode | GetCullMode () const |
Return normal culling mode. | |
CullMode | GetShadowCullMode () const |
Return culling mode for shadows. | |
FillMode | GetFillMode () const |
Return polygon fill mode. | |
const BiasParameters & | GetDepthBias () const |
Return depth bias. | |
unsigned char | GetRenderOrder () const |
Return render order. | |
unsigned | GetAuxViewFrameNumber () const |
Return last auxiliary view rendered frame number. | |
bool | GetOcclusion () const |
Return whether should render occlusion. | |
bool | GetSpecular () const |
Return whether should render specular. | |
Scene * | GetScene () const |
Return the scene associated with the material for shader parameter animation updates. | |
unsigned | GetShaderParameterHash () const |
Return shader parameter hash value. Used as an optimization to avoid setting shader parameters unnecessarily. | |
Public Member Functions inherited from Urho3D::Resource | |
Resource (Context *context) | |
Construct. | |
bool | Load (Deserializer &source) |
Load resource synchronously. Call both BeginLoad() & EndLoad() and return true if both succeeded. | |
void | SetName (const String &name) |
Set name. | |
void | SetMemoryUse (unsigned size) |
Set memory use in bytes, possibly approximate. | |
void | ResetUseTimer () |
Reset last used timer. | |
void | SetAsyncLoadState (AsyncLoadState newState) |
Set the asynchronous loading state. Called by ResourceCache. Resources in the middle of asynchronous loading are not normally returned to user. | |
const String & | GetName () const |
Return name. | |
StringHash | GetNameHash () const |
Return name hash. | |
unsigned | GetMemoryUse () const |
Return memory use in bytes, possibly approximate. | |
unsigned | GetUseTimer () |
Return time since last use in milliseconds. If referred to elsewhere than in the resource cache, returns always zero. | |
AsyncLoadState | GetAsyncLoadState () const |
Return the asynchronous loading state. | |
Public Member Functions inherited from Urho3D::Object | |
Object (Context *context) | |
Construct. | |
virtual | ~Object () |
Destruct. Clean up self from event sender & receiver structures. | |
virtual StringHash | GetType () const =0 |
Return type hash. | |
virtual const String & | GetTypeName () const =0 |
Return type name. | |
virtual const TypeInfo * | GetTypeInfo () const =0 |
Return type info. | |
virtual void | OnEvent (Object *sender, StringHash eventType, VariantMap &eventData) |
Handle event. | |
bool | IsInstanceOf (StringHash type) const |
Check current instance is type of specified type. | |
bool | IsInstanceOf (const TypeInfo *typeInfo) const |
Check current instance is type of specified type. | |
template<typename T > | |
bool | IsInstanceOf () const |
Check current instance is type of specified class. | |
void | SubscribeToEvent (StringHash eventType, EventHandler *handler) |
Subscribe to an event that can be sent by any sender. | |
void | SubscribeToEvent (Object *sender, StringHash eventType, EventHandler *handler) |
Subscribe to a specific sender's event. | |
void | UnsubscribeFromEvent (StringHash eventType) |
Unsubscribe from an event. | |
void | UnsubscribeFromEvent (Object *sender, StringHash eventType) |
Unsubscribe from a specific sender's event. | |
void | UnsubscribeFromEvents (Object *sender) |
Unsubscribe from a specific sender's events. | |
void | UnsubscribeFromAllEvents () |
Unsubscribe from all events. | |
void | UnsubscribeFromAllEventsExcept (const PODVector< StringHash > &exceptions, bool onlyUserData) |
Unsubscribe from all events except those listed, and optionally only those with userdata (script registered events.) | |
void | SendEvent (StringHash eventType) |
Send event to all subscribers. | |
void | SendEvent (StringHash eventType, VariantMap &eventData) |
Send event with parameters to all subscribers. More... | |
VariantMap & | GetEventDataMap () const |
Return a preallocated map for event data. Used for optimization to avoid constant re-allocation of event data maps. | |
Context * | GetContext () const |
Return execution context. | |
const Variant & | GetGlobalVar (StringHash key) const |
Return global variable based on key. | |
const VariantMap & | GetGlobalVars () const |
Return all global variables. | |
void | SetGlobalVar (StringHash key, const Variant &value) |
Set global variable with the respective key and value. | |
Object * | GetSubsystem (StringHash type) const |
Return subsystem by type. | |
Object * | GetEventSender () const |
Return active event sender. Null outside event handling. | |
EventHandler * | GetEventHandler () const |
Return active event handler. Null outside event handling. | |
bool | HasSubscribedToEvent (StringHash eventType) const |
Return whether has subscribed to an event without specific sender. | |
bool | HasSubscribedToEvent (Object *sender, StringHash eventType) const |
Return whether has subscribed to a specific sender's event. | |
bool | HasEventHandlers () const |
Return whether has subscribed to any event. | |
template<class T > | |
T * | GetSubsystem () const |
Template version of returning a subsystem. | |
const String & | GetCategory () const |
Return object category. Categories are (optionally) registered along with the object factory. Return an empty string if the object category is not registered. | |
Public Member Functions inherited from Urho3D::RefCounted | |
RefCounted () | |
Construct. Allocate the reference count structure and set an initial self weak reference. | |
virtual | ~RefCounted () |
Destruct. Mark as expired and also delete the reference count structure if no outside weak references exist. | |
void | AddRef () |
Increment reference count. Can also be called outside of a SharedPtr for traditional reference counting. | |
void | ReleaseRef () |
Decrement reference count and delete self if no more references. Can also be called outside of a SharedPtr for traditional reference counting. | |
int | Refs () const |
Return reference count. | |
int | WeakRefs () const |
Return weak reference count. | |
RefCount * | RefCountPtr () |
Return pointer to the reference count structure. | |
Static Public Member Functions | |
static void | RegisterObject (Context *context) |
Register object factory. | |
static String | GetTextureUnitName (TextureUnit unit) |
Return name for texture unit. | |
static Variant | ParseShaderParameterValue (const String &value) |
Parse a shader parameter value from a string. Retunrs either a bool, a float, or a 2 to 4-component vector. | |
Private Member Functions | |
URHO3D_OBJECT (Material, Resource) | |
bool | BeginLoadJSON (Deserializer &source) |
Helper function for loading JSON files. | |
bool | BeginLoadXML (Deserializer &source) |
Helper function for loading XML files. | |
void | CheckOcclusion () |
Re-evaluate occlusion rendering. | |
void | ResetToDefaults () |
Reset to defaults. | |
void | RefreshShaderParameterHash () |
Recalculate shader parameter hash. | |
void | RefreshMemoryUse () |
Recalculate the memory used by the material. | |
ShaderParameterAnimationInfo * | GetShaderParameterAnimationInfo (const String &name) const |
Return shader parameter animation info. | |
void | UpdateEventSubscription () |
Update whether should be subscribed to scene or global update events for shader parameter animation. | |
void | HandleAttributeAnimationUpdate (StringHash eventType, VariantMap &eventData) |
Update shader parameter animations. | |
Private Attributes | |
Vector< TechniqueEntry > | techniques_ |
Techniques. | |
HashMap< TextureUnit, SharedPtr< Texture > > | textures_ |
Textures. | |
HashMap< StringHash, MaterialShaderParameter > | shaderParameters_ |
Shader parameters. | |
HashMap< StringHash, SharedPtr < ShaderParameterAnimationInfo > > | shaderParameterAnimationInfos_ |
Shader parameters animation infos. | |
CullMode | cullMode_ |
Normal culling mode. | |
CullMode | shadowCullMode_ |
Culling mode for shadow rendering. | |
FillMode | fillMode_ |
Polygon fill mode. | |
BiasParameters | depthBias_ |
Depth bias parameters. | |
unsigned char | renderOrder_ |
Render order value. | |
unsigned | auxViewFrameNumber_ |
Last auxiliary view rendered frame number. | |
unsigned | shaderParameterHash_ |
Shader parameter hash value. | |
bool | occlusion_ |
Render occlusion flag. | |
bool | specular_ |
Specular lighting flag. | |
bool | subscribed_ |
Flag for whether is subscribed to animation updates. | |
bool | batchedParameterUpdate_ |
Flag to suppress parameter hash and memory use recalculation when setting multiple shader parameters (loading or resetting the material.) | |
SharedPtr< XMLFile > | loadXMLFile_ |
XML file used while loading. | |
SharedPtr< JSONFile > | loadJSONFile_ |
JSON file used while loading. | |
WeakPtr< Scene > | scene_ |
Associated scene for shader parameter animation updates. | |
Additional Inherited Members | |
Protected Attributes inherited from Urho3D::Object | |
Context * | context_ |
Execution context. | |
Detailed Description
Describes how to render 3D geometries.
The documentation for this class was generated from the following files:
- Source/Urho3D/Graphics/Material.h
- Source/Urho3D/Graphics/Material.cpp