OGRE-Next
2.3
Object-Oriented Graphics Rendering Engine
|
An hlms datablock contains individual information about a specific material. More...
#include <OgreHlmsDatablock.h>
Public Member Functions | |
HlmsDatablock (IdString name, Hlms *creator, const HlmsMacroblock *macroblock, const HlmsBlendblock *blendblock, const HlmsParamVec ¶ms) | |
virtual | ~HlmsDatablock () |
void | _linkRenderable (Renderable *renderable) |
void | _unlinkRenderable (Renderable *renderable) |
virtual void | calculateHash () |
Calculates the hashes needed for sorting by the RenderQueue (i.e. mTextureHash) More... | |
HlmsDatablock * | clone (String name) const |
Creates a copy of this datablock with the same settings, but a different name. More... | |
CompareFunction | getAlphaTest () const |
bool | getAlphaTestShadowCasterOnly () const |
float | getAlphaTestThreshold () const |
const HlmsBlendblock * | getBlendblock (bool casterBlock=false) const |
Hlms * | getCreator () const |
virtual ColourValue | getDiffuseColour () const |
Returns the closest match for a diffuse colour, if applicable by the actual implementation. More... | |
virtual TextureGpu * | getDiffuseTexture () const |
Returns the closest match for a diffuse texture, if applicable by the actual implementation. More... | |
virtual ColourValue | getEmissiveColour () const |
Returns the closest match for a emissive colour, if applicable by the actual implementation. More... | |
virtual TextureGpu * | getEmissiveTexture () const |
Returns the closest match for a emissive texture, if applicable by the actual implementation. More... | |
void | getFilenameAndResourceGroup (String const **outFilename, String const **outResourceGroup) const |
const vector< Renderable * >::type & | getLinkedRenderables () const |
const HlmsMacroblock * | getMacroblock (bool casterBlock=false) const |
IdString | getName () const |
const String * | getNameStr () const |
virtual bool | hasCustomShadowMacroblock () 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 | saveTextures (const String &folderPath, set< String >::type &savedTextures, bool saveOitd, bool saveOriginal, HlmsTextureExportListener *listener) |
virtual void | setAlphaTest (CompareFunction compareFunction, bool shadowCasterOnly=false, bool useAlphaFromTextures=true) |
Sets the alpha test to the given compare function. More... | |
virtual void | setAlphaTestThreshold (float threshold) |
Alpha test's threshold. More... | |
void | setBlendblock (const HlmsBlendblock &blendblock, bool casterBlock=false) |
Sets a new blendblock that matches the same parameter as the input. More... | |
void | setBlendblock (const HlmsBlendblock *blendblock, bool casterBlock=false) |
Sets the blendblock from the given pointer that was already retrieved from the HlmsManager. More... | |
void | setMacroblock (const HlmsMacroblock ¯oblock, bool casterBlock=false) |
Sets a new macroblock that matches the same parameter as the input. More... | |
void | setMacroblock (const HlmsMacroblock *macroblock, bool casterBlock=false) |
Sets the macroblock from the given pointer that was already retrieved from the HlmsManager. More... | |
Static Public Member Functions | |
static const char * | getCmpString (CompareFunction compareFunction) |
Public Attributes | |
bool | mAllowTextureResidencyChange |
When false, we won't try to have Textures become resident. More... | |
uint16 | mMacroblockHash [2] |
float | mShadowConstantBias |
uint32 | mTextureHash |
uint8 | mType |
Friends | |
class | RenderQueue |
An hlms datablock contains individual information about a specific material.
It consists of: A const pointer to an @HlmsMacroblock we do not own and may be shared by other datablocks. A const pointer to an @HlmsBlendblock we do not own and may be shared by other datablocks. The original properties from which this datablock was constructed. This type may be derived to contain additional information. Derived types can cache information present in mOriginalProperties as strings, like diffuse colour values, etc.
A datablock is the internal representation of the surface parameters (depth settings, textures to be used, diffuse colour, specular colour, etc). The notion of a datablock is the closest you'll get to a "material"
Ogre::HlmsDatablock::HlmsDatablock | ( | IdString | name, |
Hlms * | creator, | ||
const HlmsMacroblock * | macroblock, | ||
const HlmsBlendblock * | blendblock, | ||
const HlmsParamVec & | params | ||
) |
|
virtual |
void Ogre::HlmsDatablock::_linkRenderable | ( | Renderable * | renderable | ) |
void Ogre::HlmsDatablock::_unlinkRenderable | ( | Renderable * | renderable | ) |
|
inlinevirtual |
Calculates the hashes needed for sorting by the RenderQueue (i.e. mTextureHash)
HlmsDatablock* Ogre::HlmsDatablock::clone | ( | String | name | ) | const |
Creates a copy of this datablock with the same settings, but a different name.
name | Name of the cloned datablock. |
CompareFunction Ogre::HlmsDatablock::getAlphaTest | ( | ) | const |
bool Ogre::HlmsDatablock::getAlphaTestShadowCasterOnly | ( | ) | const |
|
inline |
|
inline |
|
static |
|
inline |
|
virtual |
Returns the closest match for a diffuse colour, if applicable by the actual implementation.
Note that Unlit implementation returns 0 as diffuse, since it's considered emissive instead due to being bright even in the absence lights.
|
virtual |
Returns the closest match for a diffuse texture, if applicable by the actual implementation.
|
virtual |
Returns the closest match for a emissive colour, if applicable by the actual implementation.
|
virtual |
Returns the closest match for a emissive texture, if applicable by the actual implementation.
void Ogre::HlmsDatablock::getFilenameAndResourceGroup | ( | String const ** | outFilename, |
String const ** | outResourceGroup | ||
) | const |
|
inline |
|
inline |
|
inline |
const String* Ogre::HlmsDatablock::getNameStr | ( | ) | const |
|
virtual |
|
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
|
virtual |
folderPath | Folder where to dump the textures. |
savedTextures | [in/out] Set of texture names. Textures whose name is already in the set won't be saved again. Textures that were saved will be inserted into the set. |
saveOitd | When true, we will download the texture from GPU and save it in OITD format. OITD is faster to load as it's stored in Ogre's native format it understands, but it cannot be opened by traditional image editors; also OITD is not backwards compatible with older versions of Ogre. |
saveOriginal | When true, we will attempt to read the raw filestream of the original texture and save it (i.e. copy the original png/dds/etc file). |
Reimplemented in Ogre::OGRE_HLMS_TEXTURE_BASE_CLASS.
|
virtual |
Sets the alpha test to the given compare function.
CMPF_ALWAYS_PASS means disabled.
compareFunction | Compare function to use. Default is CMPF_ALWAYS_PASS, which means disabled. Note: CMPF_ALWAYS_FAIL is not supported. Set a negative threshold to workaround this issue. |
shadowCasterOnly | When true, only the caster should use alpha testing. Useful if you want alpha blending (i.e. transparency) while rendering normally, but want semi-transparent shadows. |
useAlphaFromTextures | Whether you want the diffuse texture's alpha to influence the alpha test Most likely you want this to be true, unless you're customizing the shader and have special use for alpha testing |
|
virtual |
Alpha test's threshold.
threshold | Value typically in the range [0; 1) |
void Ogre::HlmsDatablock::setBlendblock | ( | const HlmsBlendblock & | blendblock, |
bool | casterBlock = false |
||
) |
Sets a new blendblock that matches the same parameter as the input.
Decreases the reference count of the previous mBlendblock. Runs an O(N) search to get the right block. Calling this function triggers a HlmsDatablock::flushRenderables
blendblock | @See HlmsManager::getBlendblock |
casterBlock | True to directly set the blendblock to be used during the shadow mapping's caster pass. Note that when false, it will reset the caster block to the same as the regular one. |
void Ogre::HlmsDatablock::setBlendblock | ( | const HlmsBlendblock * | blendblock, |
bool | casterBlock = false |
||
) |
Sets the blendblock from the given pointer that was already retrieved from the HlmsManager.
Unlike the other overload, this operation is O(1). Calling this function triggers a HlmsDatablock::flushRenderables
blendblock | A valid block. The reference count is increased inside this function. |
casterBlock | True to directly set the blendblock to be used during the shadow mapping's caster pass. Note that when false, it will reset the caster block to the same as the regular one. |
void Ogre::HlmsDatablock::setMacroblock | ( | const HlmsMacroblock & | macroblock, |
bool | casterBlock = false |
||
) |
Sets a new macroblock that matches the same parameter as the input.
Decreases the reference count of the previously set one. Runs an O(N) search to get the right block. Calling this function triggers a HlmsDatablock::flushRenderables
macroblock | @See HlmsManager::getMacroblock |
casterBlock | True to directly set the macroblock to be used during the shadow mapping's caster pass. Note that when false, it will automatically reset the caster's block according to HlmsManager::setShadowMappingUseBackFaces setting. |
void Ogre::HlmsDatablock::setMacroblock | ( | const HlmsMacroblock * | macroblock, |
bool | casterBlock = false |
||
) |
Sets the macroblock from the given pointer that was already retrieved from the HlmsManager.
Unlike the other overload, this operation is O(1). Calling this function triggers a HlmsDatablock::flushRenderables
macroblock | A valid block. The reference count is increased inside this function. |
casterBlock | True to directly set the macroblock to be used during the shadow mapping's caster pass. Note that when false, it will automatically reset the caster's block according to HlmsManager::setShadowMappingUseBackFaces setting. |
|
friend |
bool Ogre::HlmsDatablock::mAllowTextureResidencyChange |
When false, we won't try to have Textures become resident.
uint16 Ogre::HlmsDatablock::mMacroblockHash[2] |
float Ogre::HlmsDatablock::mShadowConstantBias |
uint32 Ogre::HlmsDatablock::mTextureHash |
uint8 Ogre::HlmsDatablock::mType |