|
| Decal (IdType id, ObjectMemoryManager *objectMemoryManager, SceneManager *manager) |
|
| ~Decal () override |
|
TextureGpu * | getDiffuseTexture () const |
|
TextureGpu * | getEmissiveTexture () const |
|
bool | getIgnoreAlphaDiffuse () const |
|
float | getMetalness () const |
|
const String & | getMovableType () const override |
| Returns the type name of this object. More...
|
|
TextureGpu * | getNormalTexture () const |
|
float | getRoughness () const |
|
void | notifyTextureChanged (TextureGpu *texture, TextureGpuListener::Reason reason, void *extraData) override |
| Called when a TextureGpu changed in a way that affects how it is displayed: More...
|
|
void | setDiffuseTexture (TextureGpu *diffuseTex) |
| Call this family of functions if the input texture is automatically batched We will listen for residency changes and change the internal slice accordingly. More...
|
|
void | setDiffuseTextureRaw (TextureGpu *diffuseTex, uint32 sliceIdx) |
| Call this family of functions if the input texture is managed by hand by you. More...
|
|
void | setEmissiveTexture (TextureGpu *emissiveTex) |
|
void | setEmissiveTextureRaw (TextureGpu *emissiveTex, uint32 sliceIdx) |
|
void | setIgnoreAlphaDiffuse (bool bIgnore) |
| When diffuse textures are used (globally), the alpha component of the diffuse texture will be used to mask all the other textures (e.g. More...
|
|
void | setMetalness (float value) |
| Value for Metalness. Must be in range [0; 1]. More...
|
|
void | setNormalTexture (TextureGpu *normalTex) |
|
void | setNormalTextureRaw (TextureGpu *normalTex, uint32 sliceIdx) |
|
void | setRectSize (Vector2 planeDimensions, Real depth) |
| Helper function to set width, height and depth of the decal. More...
|
|
void | setRenderQueueGroup (uint8 queueID) override |
| Decals only allow ForwardPlusBase::MinDecalRq <= queueID < ForwardPlusBase::MaxDecalRq. More...
|
|
void | setRoughness (float roughness) |
| Value for Roughness. Valid range depends on the BRDF used. More...
|
|
| MovableObject (IdType id, ObjectMemoryManager *objectMemoryManager, SceneManager *manager, uint8 renderQueueId) |
| Constructor. More...
|
|
| MovableObject (ObjectData *objectDataPtrs) |
| Don't use this constructor unless you know what you're doing. More...
|
|
virtual | ~MovableObject () |
| Virtual destructor - read Scott Meyers if you don't know why this is needed. More...
|
|
LightList * | _getLightList () |
| Returns a pointer to the current list of lights for this object. More...
|
|
SceneManager * | _getManager () const |
| Get the manager of this object, if any (internal use only) More...
|
|
ObjectData & | _getObjectData () |
| Returns a direct access to the ObjectData state. More...
|
|
const Matrix4 & | _getParentNodeFullTransform () const |
| Returns the full transformation of the parent sceneNode or the attachingPoint node. More...
|
|
virtual void | _notifyAttached (Node *parent) |
| Internal method called to notify the object that it has been attached to a node. More...
|
|
void | _notifyManager (SceneManager *man) |
| Notify the object of it's manager (internal use only) More...
|
|
virtual void | _notifyParentNodeMemoryChanged () |
|
virtual void | _notifyStaticDirty () const |
| Called by SceneManager when it is telling we're a static MovableObject being dirty Don't call this directly. More...
|
|
virtual void | _releaseManualHardwareResources () |
| Notifies the movable object that hardware resources were lost. More...
|
|
virtual void | _restoreManualHardwareResources () |
| Notifies the movable object that hardware resources should be restored. More...
|
|
virtual void | _updateRenderQueue (RenderQueue *queue, Camera *camera, const Camera *lodCamera) |
| Internal method by which the movable object must add Renderable subclass instances to the rendering queue. More...
|
|
void | addQueryFlags (uint32 flags) |
| As setQueryFlags, except the flags passed as parameters are appended to the existing flags on this object. More...
|
|
void | addVisibilityFlags (uint32 flags) |
| As setVisibilityFlags, except the flags passed as parameters are appended to the existing flags on this object. More...
|
|
void | detachFromParent () |
| Detaches an object from a parent SceneNode if attached. More...
|
|
RealAsUint | getCachedDistanceToCamera () const |
| Returns the distance to camera as calculated in cullFrustum() More...
|
|
Real | getCachedDistanceToCameraAsReal () const |
| Returns the distance to camera as calculated in cullFrustum() More...
|
|
bool | getCastShadows () const |
| Returns whether shadow casting is enabled for this object. More...
|
|
unsigned char | getCurrentMeshLod () const |
|
uint32 | getLightMask () const |
| Get a bitwise mask which will filter the lights affecting this object. More...
|
|
Listener * | getListener () const |
| Gets the current listener for this object. More...
|
|
Aabb | getLocalAabb () const |
| Retrieves the local axis-aligned bounding box for this object. More...
|
|
float | getLocalRadius () const |
| See getLocalAabb and getWorldRadius. More...
|
|
const String & | getName () const |
| Returns the name of this object. More...
|
|
Node * | getParentNode () const |
| Returns the node to which this object is attached. More...
|
|
SceneNode * | getParentSceneNode () const |
|
uint32 | getQueryFlags () const |
| Returns the query flags relevant for this object. More...
|
|
Real | getRenderingDistance () const |
| Gets the distance at which batches are no longer rendered. More...
|
|
Real | getRenderingMinPixelSize () const |
| Returns the minimum pixel size an object needs to be in both screen axes in order to be rendered. More...
|
|
uint8 | getRenderQueueGroup () const |
| Gets the queue group for this entity, see setRenderQueueGroup for full details. More...
|
|
Real | getShadowRenderingDistance () const |
| Gets the distance at which batches are no longer casting shadows. More...
|
|
SkeletonInstance * | getSkeletonInstance () 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...
|
|
uint32 | getVisibilityFlags () const |
| Returns the visibility flags relevant for this object. More...
|
|
bool | getVisible () const |
| Gets this object whether to be visible or not, if it has a renderable component. More...
|
|
Aabb | getWorldAabb () const |
| Gets the axis aligned box in world space. More...
|
|
Aabb | getWorldAabbUpdated () |
| Gets the axis aligned box in world space. More...
|
|
float | getWorldRadius () const |
| Gets the bounding Radius scaled by max( scale.x, scale.y, scale.z ). More...
|
|
float | getWorldRadiusUpdated () |
| Gets the bounding Radius scaled by max( scale.x, scale.y, scale.z ). More...
|
|
virtual void | instanceBatchCullFrustumThreaded (const Frustum *frustum, const Camera *lodCamera, uint32 combinedVisibilityFlags) |
|
bool | isAttached () const |
| Returns true if this object is attached to a Node. More...
|
|
bool | isStatic () const |
| Checks whether this MovableObject is static. More...
|
|
bool | isVisible () const |
| Returns whether or not this object is supposed to be visible or not. More...
|
|
const LightList & | queryLights () const |
| Gets a list of lights, ordered relative to how close they are to this movable object. More...
|
|
void | removeQueryFlags (uint32 flags) |
| As setQueryFlags, except the flags passed as parameters are removed from the existing flags on this object. More...
|
|
void | removeVisibilityFlags (uint32 flags) |
| As setVisibilityFlags, except the flags passed as parameters are removed from the existing flags on this object. More...
|
|
void | resetMeshLod () |
| Sets mCurrentMeshLod to 0. More...
|
|
void | setCastShadows (bool enabled) |
| Sets whether or not this object will cast shadows. More...
|
|
void | setLightMask (uint32 lightMask) |
| Set a bitwise mask which will filter the lights affecting this object. More...
|
|
void | setListener (Listener *listener) |
| Sets a listener for this object. More...
|
|
void | setLocalAabb (const Aabb box) |
| Sets the local axis-aligned bounding box for this object. More...
|
|
void | setName (const String &name) |
| Sets a custom name for this node. More...
|
|
void | setQueryFlags (uint32 flags) |
| Sets the query flags for this object. More...
|
|
void | setRenderingDistance (Real dist) |
| Sets the distance at which the object is no longer rendered. More...
|
|
void | setRenderingMinPixelSize (Real pixelSize) |
| Sets the minimum pixel size an object needs to be in both screen axes in order to be rendered. More...
|
|
void | setShadowRenderingDistance (Real dist) |
| Sets the distance at which the object is no longer casting shadows. More...
|
|
bool | setStatic (bool bStatic) |
| Turns this Node into static or dynamic. More...
|
|
void | setVisibilityFlags (uint32 flags) |
| Sets the visibility flags for this object. More...
|
|
void | setVisible (bool visible) |
| Tells this object whether to be visible or not, if it has a renderable component. More...
|
|
| AnimableObject () |
|
virtual | ~AnimableObject () |
|
virtual AnimableValuePtr | createAnimableValue (const String &valueName) |
| Create a reference-counted AnimableValuePtr for the named value. More...
|
|
const StringVector & | getAnimableValueNames () const |
| Gets a list of animable value names for this object. More...
|
|
| IdObject (IdType id) |
| We don't call generateNewId() here, to prevent objects in the stack (i.e. More...
|
|
IdType | getId () const |
| Get the unique id of this object. More...
|
|
bool | operator() (const IdObject &left, const IdObject &right) |
|
bool | operator() (const IdObject *left, const IdObject *right) |
|
virtual | ~TextureGpuListener () |
|
virtual bool | shouldStayLoaded (TextureGpu *texture) |
| Return true if this TextureGpu should likely stay loaded or else graphical changes could occur. More...
|
|
Decals can have diffuse, normal map, and emissive on top of regular objects.
You can GLOBALLY disable each of these (diffuse/normal/emissive) by setting a null texture in SceneManager::setDecalsDiffuse and co.
If a nullptr is set on e.g. Normal textures, and a Decal uses normal maps, they won't appear. You need to set a valid pointer to SceneManager::setDecalsNormals.
Likewise, if no Decal actually uses normal textures, but you still set one via SceneManager::setDecalsNormals, then you will be wasting GPU shader performance.
When diffuse is used, the fresnel and specular colours of the material are overwritten as well.
Q: How to disable diffuse/normal/emissive per Decal?
To disable diffuse just point to a diffuse texture slice (mDiffuseIdx) that is a black and call setIgnoreAlphaDiffuse( true )
To disable normals, just point to a normal map that has XY components set both to 0
To disable emissive, just point to a texture that is black.
Q: Why does it use Metalness? What happens when a non-metallic workflow is used?
Metalness is used for performance reasons, as it allows giving enough control over the specular by just using one parameter, rather than having 3 (one per specular channel)
On metallic & fresnel workflows, this "just works" because the metalness parameter will produce a new coloured F0 parameter, which will overwrite the one from the original material.
On specular workflows, if the fresnel is coloured, it will behave the same way as a metallic/fresnel workflow, because the original specular colour will be set to white, and F0 will be overwritten.
If the fresnel is monochrome (specular workflow), then the specular colour will be overwritten instead, and the metalness value of the decal will act as a fresnel value, overwriting the original fresnel.