OGRE
1.12.13
Object-Oriented Graphics Rendering Engine
|
Collects together the program parameters used for a GpuProgram. More...
#include <OgreGpuProgramParams.h>
Classes | |
struct | AutoConstantDefinition |
Structure defining an auto constant that's available for use in a parameters object. More... | |
class | AutoConstantEntry |
Structure recording the use of an automatic parameter. More... | |
Public Member Functions | |
GpuProgramParameters () | |
GpuProgramParameters (const GpuProgramParameters &oth) | |
Copy constructor. More... | |
~GpuProgramParameters () | |
const GpuConstantDefinition * | _findNamedConstantDefinition (const String &name, bool throwExceptionIfMissing=false) const |
Find a constant definition for a named parameter. More... | |
size_t | _getDoubleConstantPhysicalIndex (size_t logicalIndex, size_t requestedSize, uint16 variability) |
Gets the physical buffer index associated with a logical double constant index. More... | |
size_t | _getFloatConstantPhysicalIndex (size_t logicalIndex, size_t requestedSize, uint16 variability) |
Gets the physical buffer index associated with a logical float constant index. More... | |
size_t | _getIntConstantPhysicalIndex (size_t logicalIndex, size_t requestedSize, uint16 variability) |
Gets the physical buffer index associated with a logical int constant index. More... | |
const Any & | _getRenderSystemData () const |
Internal method that the RenderSystem might use to store optional data. More... | |
void | _readRawConstants (size_t physicalIndex, size_t count, float *dest) |
Read a series of floating point values from the underlying float constant buffer at the given physical index. More... | |
void | _readRawConstants (size_t physicalIndex, size_t count, int *dest) |
Read a series of integer values from the underlying integer constant buffer at the given physical index. More... | |
void | _setLogicalIndexes (const GpuLogicalBufferStructPtr &floatIndexMap, const GpuLogicalBufferStructPtr &doubleIndexMap, const GpuLogicalBufferStructPtr &intIndexMap) |
Internal method for providing a link to a logical index->physical index map for parameters. More... | |
void | _setNamedConstants (const GpuNamedConstantsPtr &constantmap) |
Internal method for providing a link to a name->definition map for parameters. More... | |
void | _setRenderSystemData (const Any &data) const |
Internal method that the RenderSystem might use to store optional data. More... | |
void | _updateAutoParams (const AutoParamDataSource *source, uint16 variabilityMask) |
Update automatic parameters. More... | |
size_t | calculateSize (void) const |
void | copyConstantsFrom (const GpuProgramParameters &source) |
Copies the values of all constants (including auto constants) from another GpuProgramParameters object. More... | |
void | copyMatchingNamedConstantsFrom (const GpuProgramParameters &source) |
Copies the values of all matching named constants (including auto constants) from another GpuProgramParameters object. More... | |
const GpuConstantDefinition & | getConstantDefinition (const String &name) const |
Get a specific GpuConstantDefinition for a named parameter. More... | |
GpuConstantDefinitionIterator | getConstantDefinitionIterator (void) const |
const GpuNamedConstants & | getConstantDefinitions () const |
Get the full list of GpuConstantDefinition instances. More... | |
const DoubleConstantList & | getDoubleConstantList () const |
Get a reference to the list of double constants. More... | |
const GpuLogicalBufferStructPtr & | getDoubleLogicalBufferStruct () const |
Get the current list of mappings from low-level logical param indexes to physical buffer locations in the double buffer. More... | |
size_t | getDoubleLogicalIndexForPhysicalIndex (size_t physicalIndex) |
Retrieves the logical index relating to a physical index in the buffer, for programs which support that (low-level programs and high-level programs which use logical parameter indexes). More... | |
double * | getDoublePointer (size_t pos) |
Get a pointer to the 'nth' item in the double buffer. More... | |
const double * | getDoublePointer (size_t pos) const |
Get a pointer to the 'nth' item in the double buffer. More... | |
const FloatConstantList & | getFloatConstantList () const |
Get a reference to the list of float constants. More... | |
const GpuLogicalBufferStructPtr & | getFloatLogicalBufferStruct () const |
Get the current list of mappings from low-level logical param indexes to physical buffer locations in the float buffer. More... | |
size_t | getFloatLogicalIndexForPhysicalIndex (size_t physicalIndex) |
Retrieves the logical index relating to a physical index in the buffer, for programs which support that (low-level programs and high-level programs which use logical parameter indexes). More... | |
float * | getFloatPointer (size_t pos) |
Get a pointer to the 'nth' item in the float buffer. More... | |
const float * | getFloatPointer (size_t pos) const |
Get a pointer to the 'nth' item in the float buffer. More... | |
const IntConstantList & | getIntConstantList () const |
Get a reference to the list of int constants. More... | |
const GpuLogicalBufferStructPtr & | getIntLogicalBufferStruct () const |
Get the current list of mappings from low-level logical param indexes to physical buffer locations in the integer buffer. More... | |
size_t | getIntLogicalIndexForPhysicalIndex (size_t physicalIndex) |
Retrieves the logical index relating to a physical index in the buffer, for programs which support that (low-level programs and high-level programs which use logical parameter indexes). More... | |
int * | getIntPointer (size_t pos) |
Get a pointer to the 'nth' item in the int buffer. More... | |
const int * | getIntPointer (size_t pos) const |
Get a pointer to the 'nth' item in the int buffer. More... | |
size_t | getPassIterationNumberIndex () const |
const SubroutineMap & | getSubroutineMap () const |
Get map with. More... | |
bool | getTransposeMatrices (void) const |
Gets whether or not matrices are to be transposed when set. More... | |
uint * | getUnsignedIntPointer (size_t pos) |
Get a pointer to the 'nth' item in the uint buffer. More... | |
const uint * | getUnsignedIntPointer (size_t pos) const |
Get a pointer to the 'nth' item in the uint buffer. More... | |
bool | hasLogicalIndexedParameters () const |
Does this parameter set include logically indexed parameters? More... | |
bool | hasNamedParameters () const |
Does this parameter set include named parameters? More... | |
bool | hasPassIterationNumber () const |
void | incPassIterationNumber (void) |
increments the multipass number entry by 1 if it exists More... | |
GpuProgramParameters & | operator= (const GpuProgramParameters &oth) |
Operator = overload. More... | |
void | setIgnoreMissingParams (bool state) |
Tells the program whether to ignore missing parameters or not. More... | |
void | setNamedSubroutine (const String &subroutineSlot, const String &subroutine) |
Set subroutine name by slot name. More... | |
void | setSubroutine (size_t index, const String &subroutine) |
Set subroutine name by slot index. More... | |
void | setTransposeMatrices (bool val) |
Sets whether or not we need to transpose the matrices passed in from the rest of OGRE. More... | |
Set constant by logical index | |
void | setConstant (size_t index, const Vector4 &vec) |
Sets a 4-element floating-point parameter to the program. More... | |
void | setConstant (size_t index, Real val) |
Sets a single floating-point parameter to the program. More... | |
void | setConstant (size_t index, const Vector3 &vec) |
Sets a 4-element floating-point parameter to the program via Vector3. More... | |
void | setConstant (size_t index, const Vector2 &vec) |
Sets a 4-element floating-point parameter to the program via Vector2. More... | |
void | setConstant (size_t index, const Matrix4 &m) |
Sets a Matrix4 parameter to the program. More... | |
void | setConstant (size_t index, const Matrix4 *m, size_t numEntries) |
Sets a list of Matrix4 parameters to the program. More... | |
void | setConstant (size_t index, const ColourValue &colour) |
Sets a ColourValue parameter to the program. More... | |
void | setConstant (size_t index, const float *val, size_t count) |
Sets a multiple value constant floating-point parameter to the program. More... | |
void | setConstant (size_t index, const double *val, size_t count) |
Sets a multiple value constant floating-point parameter to the program. More... | |
void | setConstant (size_t index, const int *val, size_t count) |
Sets a multiple value constant integer parameter to the program. More... | |
void | setConstant (size_t index, const uint *val, size_t count) |
Sets a multiple value constant unsigned integer parameter to the program. More... | |
Set constant by physical index | |
You can use these methods if you have already derived the physical constant buffer location, for a slight speed improvement over using the named / logical index versions. | |
void | _writeRawConstants (size_t physicalIndex, const float *val, size_t count) |
Write a series of floating point values into the underlying float constant buffer at the given physical index. More... | |
void | _writeRawConstants (size_t physicalIndex, const double *val, size_t count) |
Write a series of floating point values into the underlying float constant buffer at the given physical index. More... | |
void | _writeRawConstants (size_t physicalIndex, const int *val, size_t count) |
Write a series of integer values into the underlying integer constant buffer at the given physical index. More... | |
void | _writeRawConstants (size_t physicalIndex, const uint *val, size_t count) |
Write a series of unsigned integer values into the underlying integer constant buffer at the given physical index. More... | |
template<int dims, typename T > | |
void | _writeRawConstant (size_t physicalIndex, const Vector< dims, T > &vec, size_t count=dims) |
Write a Vector parameter to the program directly to the underlying constants buffer. More... | |
template<typename T > | |
void | _writeRawConstant (size_t physicalIndex, T val) |
Write a single parameter to the program. More... | |
void | _writeRawConstant (size_t physicalIndex, Real val, size_t count) |
void | _writeRawConstant (size_t physicalIndex, const Matrix4 &m, size_t elementCount) |
Write a Matrix4 parameter to the program. More... | |
void | _writeRawConstant (size_t physicalIndex, const Matrix3 &m, size_t elementCount) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | _writeRawConstant (size_t physicalIndex, const TransformBaseReal *m, size_t numEntries) |
Write a list of Matrix4 parameters to the program. More... | |
void | _writeRawConstant (size_t physicalIndex, const ColourValue &colour, size_t count=4) |
Write a ColourValue parameter to the program. More... | |
Automatically derived constants | |
const AutoConstantList & | getAutoConstantList () const |
Get a reference to the list of auto constant bindings. More... | |
void | setAutoConstant (size_t index, AutoConstantType acType, uint32 extraInfo=0) |
Sets up a constant which will automatically be updated by the system. More... | |
void | setAutoConstantReal (size_t index, AutoConstantType acType, float rData) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setAutoConstant (size_t index, AutoConstantType acType, uint16 extraInfo1, uint16 extraInfo2) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | _setRawAutoConstant (size_t physicalIndex, AutoConstantType acType, uint32 extraInfo, uint16 variability, uint8 elementSize=4) |
As setAutoConstant, but sets up the auto constant directly against a physical buffer index. More... | |
void | _setRawAutoConstantReal (size_t physicalIndex, AutoConstantType acType, float rData, uint16 variability, uint8 elementSize=4) |
As setAutoConstantReal, but sets up the auto constant directly against a physical buffer index. More... | |
void | clearAutoConstant (size_t index) |
Unbind an auto constant so that the constant is manually controlled again. More... | |
void | setConstantFromTime (size_t index, Real factor) |
void | clearAutoConstants (void) |
Clears all the existing automatic constants. More... | |
const AutoConstantList & | getAutoConstants () const |
Gets the automatic constant bindings currently in place. More... | |
size_t | getAutoConstantCount (void) const |
Gets the number of int constants that have been set. More... | |
AutoConstantEntry * | getAutoConstantEntry (const size_t index) |
Gets a specific Auto Constant entry if index is in valid range otherwise returns a NULL. More... | |
bool | hasAutoConstants (void) const |
Returns true if this instance has any automatic constants. More... | |
const AutoConstantEntry * | findFloatAutoConstantEntry (size_t logicalIndex) |
Finds an auto constant that's affecting a given logical parameter index for floating-point values. More... | |
const AutoConstantEntry * | findDoubleAutoConstantEntry (size_t logicalIndex) |
Finds an auto constant that's affecting a given logical parameter index for double-point values. More... | |
const AutoConstantEntry * | findIntAutoConstantEntry (size_t logicalIndex) |
Finds an auto constant that's affecting a given logical parameter index for integer values. More... | |
const AutoConstantEntry * | findUnsignedIntAutoConstantEntry (size_t logicalIndex) |
Finds an auto constant that's affecting a given logical parameter index for unsigned integer values. More... | |
const AutoConstantEntry * | findAutoConstantEntry (const String ¶mName) const |
Finds an auto constant that's affecting a given named parameter index. More... | |
const AutoConstantEntry * | _findRawAutoConstantEntryFloat (size_t physicalIndex) const |
Finds an auto constant that's affecting a given physical position in the floating-point buffer. More... | |
const AutoConstantEntry * | _findRawAutoConstantEntryDouble (size_t physicalIndex) const |
Finds an auto constant that's affecting a given physical position in the double-point buffer. More... | |
const AutoConstantEntry * | _findRawAutoConstantEntryInt (size_t physicalIndex) const |
Finds an auto constant that's affecting a given physical position in the integer buffer. More... | |
const AutoConstantEntry * | _findRawAutoConstantEntryUnsignedInt (size_t physicalIndex) const |
Finds an auto constant that's affecting a given physical position in the unsigned integer buffer. More... | |
const AutoConstantEntry * | _findRawAutoConstantEntryBool (size_t physicalIndex) const |
Finds an auto constant that's affecting a given physical position in the boolean buffer. More... | |
void | setNamedAutoConstant (const String &name, AutoConstantType acType, size_t extraInfo=0) |
Sets up a constant which will automatically be updated by the system. More... | |
void | setNamedAutoConstantReal (const String &name, AutoConstantType acType, Real rData) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setNamedAutoConstant (const String &name, AutoConstantType acType, uint16 extraInfo1, uint16 extraInfo2) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setNamedConstantFromTime (const String &name, Real factor) |
void | clearNamedAutoConstant (const String &name) |
Unbind an auto constant so that the constant is manually controlled again. More... | |
Set constant by name | |
void | setNamedConstant (const String &name, Real val) |
Sets a single value constant parameter to the program. More... | |
void | setNamedConstant (const String &name, int val) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setNamedConstant (const String &name, uint val) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setNamedConstant (const String &name, const Vector4 &val) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setNamedConstant (const String &name, const Vector3 &val) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setNamedConstant (const String &name, const Vector2 &val) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setNamedConstant (const String &name, const Matrix4 &val) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setNamedConstant (const String &name, const ColourValue &colour) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setNamedConstant (const String &name, const Matrix4 *m, size_t numEntries) |
Sets a list of Matrix4 parameters to the program. More... | |
void | setNamedConstant (const String &name, const float *val, size_t count, size_t multiple=4) |
Sets a multiple value constant parameter to the program. More... | |
void | setNamedConstant (const String &name, const double *val, size_t count, size_t multiple=4) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setNamedConstant (const String &name, const int *val, size_t count, size_t multiple=4) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
void | setNamedConstant (const String &name, const uint *val, size_t count, size_t multiple=4) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
Shared Parameters | |
void | addSharedParameters (GpuSharedParametersPtr sharedParams) |
Use a set of shared parameters in this parameters object. More... | |
void | addSharedParameters (const String &sharedParamsName) |
Use a set of shared parameters in this parameters object. More... | |
bool | isUsingSharedParameters (const String &sharedParamsName) const |
Returns whether this parameter set is using the named shared parameter set. More... | |
void | removeSharedParameters (const String &sharedParamsName) |
Stop using the named shared parameter set. More... | |
void | removeAllSharedParameters () |
Stop using all shared parameter sets. More... | |
const GpuSharedParamUsageList & | getSharedParameters () const |
Get the list of shared parameter sets. More... | |
void | _copySharedParams () |
Update the parameters by copying the data from the shared parameters. More... | |
void | _updateSharedParams () |
Update the HardwareBuffer based backing of referenced shared parameters. More... | |
Static Public Member Functions | |
static const AutoConstantDefinition * | getAutoConstantDefinition (const size_t idx) |
gets the auto constant definition using an index into the auto constant definition array. More... | |
static const AutoConstantDefinition * | getAutoConstantDefinition (const String &name) |
gets the auto constant definition associated with name if found else returns NULL More... | |
static size_t | getNumAutoConstantDefinitions (void) |
Returns the number of auto constant definitions. More... | |
Collects together the program parameters used for a GpuProgram.
typedef std::vector<AutoConstantEntry> Ogre::GpuProgramParameters::AutoConstantList |
typedef std::vector<GpuSharedParametersUsage> Ogre::GpuProgramParameters::GpuSharedParamUsageList |
typedef std::unordered_map<size_t, String> Ogre::GpuProgramParameters::SubroutineMap |
typedef std::unordered_map<size_t, String>::const_iterator Ogre::GpuProgramParameters::SubroutineIterator |
Defines the types of automatically updated values that may be bound to GpuProgram parameters, or used to modify parameters on a per-object basis.
For use in Parameter specification, drop the ACT_
prefix. E.g. ACT_WORLD_MATRIX
becomes world_matrix
.
Enumerator | |
---|---|
ACT_WORLD_MATRIX | The current world matrix. |
ACT_INVERSE_WORLD_MATRIX | The current world matrix, inverted. |
ACT_TRANSPOSE_WORLD_MATRIX | Provides transpose of world matrix. Equivalent to RenderMonkey's "WorldTranspose". |
ACT_INVERSE_TRANSPOSE_WORLD_MATRIX | The current world matrix, inverted & transposed. |
ACT_WORLD_MATRIX_ARRAY_3x4 | An array of world matrices, each represented as only a 3x4 matrix (3 rows of 4columns) usually for doing hardware skinning. You should make enough entries available in your vertex program for the number of bones in use, i.e. an array of numBones*3 float4’s. |
ACT_WORLD_MATRIX_ARRAY | The current array of world matrices, used for blending. |
ACT_WORLD_DUALQUATERNION_ARRAY_2x4 | The current array of world matrices transformed to an array of dual quaternions, represented as a 2x4 matrix. |
ACT_WORLD_SCALE_SHEAR_MATRIX_ARRAY_3x4 | The scale and shear components of the current array of world matrices. |
ACT_VIEW_MATRIX | The current view matrix. |
ACT_INVERSE_VIEW_MATRIX | The current view matrix, inverted. |
ACT_TRANSPOSE_VIEW_MATRIX | Provides transpose of view matrix. Equivalent to RenderMonkey's "ViewTranspose". |
ACT_INVERSE_TRANSPOSE_VIEW_MATRIX | Provides inverse transpose of view matrix. Equivalent to RenderMonkey's "ViewInverseTranspose". |
ACT_PROJECTION_MATRIX | The current projection matrix. |
ACT_INVERSE_PROJECTION_MATRIX | Provides inverse of projection matrix. Equivalent to RenderMonkey's "ProjectionInverse". |
ACT_TRANSPOSE_PROJECTION_MATRIX | Provides transpose of projection matrix. Equivalent to RenderMonkey's "ProjectionTranspose". |
ACT_INVERSE_TRANSPOSE_PROJECTION_MATRIX | Provides inverse transpose of projection matrix. Equivalent to RenderMonkey's "ProjectionInverseTranspose". |
ACT_VIEWPROJ_MATRIX | The current view & projection matrices concatenated. |
ACT_INVERSE_VIEWPROJ_MATRIX | Provides inverse of concatenated view and projection matrices. Equivalent to RenderMonkey's "ViewProjectionInverse". |
ACT_TRANSPOSE_VIEWPROJ_MATRIX | Provides transpose of concatenated view and projection matrices. Equivalent to RenderMonkey's "ViewProjectionTranspose". |
ACT_INVERSE_TRANSPOSE_VIEWPROJ_MATRIX | Provides inverse transpose of concatenated view and projection matrices. Equivalent to RenderMonkey's "ViewProjectionInverseTranspose". |
ACT_WORLDVIEW_MATRIX | The current world & view matrices concatenated. |
ACT_INVERSE_WORLDVIEW_MATRIX | The current world & view matrices concatenated, then inverted. |
ACT_TRANSPOSE_WORLDVIEW_MATRIX | Provides transpose of concatenated world and view matrices. Equivalent to RenderMonkey's "WorldViewTranspose". |
ACT_INVERSE_TRANSPOSE_WORLDVIEW_MATRIX | The current world & view matrices concatenated, then inverted & transposed. |
ACT_NORMAL_MATRIX | Provides inverse transpose of the upper 3x3 of the worldview matrix. Equivalent to "gl_NormalMatrix". |
ACT_WORLDVIEWPROJ_MATRIX | The current world, view & projection matrices concatenated. |
ACT_INVERSE_WORLDVIEWPROJ_MATRIX | Provides inverse of concatenated world, view and projection matrices. Equivalent to RenderMonkey's "WorldViewProjectionInverse". |
ACT_TRANSPOSE_WORLDVIEWPROJ_MATRIX | Provides transpose of concatenated world, view and projection matrices. Equivalent to RenderMonkey's "WorldViewProjectionTranspose". |
ACT_INVERSE_TRANSPOSE_WORLDVIEWPROJ_MATRIX | Provides inverse transpose of concatenated world, view and projection matrices. Equivalent to RenderMonkey's "WorldViewProjectionInverseTranspose". |
ACT_RENDER_TARGET_FLIPPING | -1 if requires texture flipping, +1 otherwise. It's useful when you bypassed projection matrix transform, still able use this value to adjust transformed y position. |
ACT_VERTEX_WINDING | -1 if the winding has been inverted (e.g. for reflections), +1 otherwise. |
ACT_FOG_COLOUR | Fog colour. |
ACT_FOG_PARAMS | Fog params: density, linear start, linear end, 1/(end-start) |
ACT_SURFACE_AMBIENT_COLOUR | Surface ambient colour, as set in Pass::setAmbient. |
ACT_SURFACE_DIFFUSE_COLOUR | Surface diffuse colour, as set in Pass::setDiffuse. |
ACT_SURFACE_SPECULAR_COLOUR | Surface specular colour, as set in Pass::setSpecular. |
ACT_SURFACE_EMISSIVE_COLOUR | Surface emissive colour, as set in Pass::setSelfIllumination. |
ACT_SURFACE_SHININESS | Surface shininess, as set in Pass::setShininess. |
ACT_SURFACE_ALPHA_REJECTION_VALUE | Surface alpha rejection value, not as set in Pass::setAlphaRejectValue, but a floating number between 0.0f and 1.0f instead (255.0f / Pass::getAlphaRejectValue()) |
ACT_LIGHT_COUNT | The number of active light sources (better than gl_MaxLights) |
ACT_AMBIENT_LIGHT_COLOUR | The ambient light colour set in the scene. |
ACT_LIGHT_DIFFUSE_COLOUR | Light diffuse colour (index determined by setAutoConstant call) this requires an index in the ’extra_params’ field, and relates to the ’nth’ closest light which could affect this object (i.e. 0 refers to the closest light - note that directional lights are always first in the list and always present). NB if there are no lights this close, then the parameter will be set to black. |
ACT_LIGHT_SPECULAR_COLOUR | Light specular colour (index determined by setAutoConstant call) |
ACT_LIGHT_ATTENUATION | Light attenuation parameters, Vector4(range, constant, linear, quadric) |
ACT_SPOTLIGHT_PARAMS | Spotlight parameters, Vector4(innerFactor, outerFactor, falloff, isSpot) innerFactor and outerFactor are cos(angle/2) The isSpot parameter is 0.0f for non-spotlights, 1.0f for spotlights. Also for non-spotlights the inner and outer factors are 1 and nearly 1 respectively |
ACT_LIGHT_POSITION | A light position in world space (index determined by setAutoConstant call) This requires an index in the ’extra_params’ field, and relates to the ’nth’ closest light which could affect this object (i.e. 0 refers to the closest light). NB if there are no lights this close, then the parameter will be set to all zeroes. Note that this property will work with all kinds of lights, even directional lights, since the parameter is set as a 4D vector. Point lights will be (pos.x, pos.y, pos.z, 1.0f) whilst directional lights will be (-dir.x, -dir.y, -dir.z, 0.0f). Operations like dot products will work consistently on both. |
ACT_LIGHT_POSITION_OBJECT_SPACE | A light position in object space (index determined by setAutoConstant call) |
ACT_LIGHT_POSITION_VIEW_SPACE | A light position in view space (index determined by setAutoConstant call) |
ACT_LIGHT_DIRECTION | A light direction in world space (index determined by setAutoConstant call)
|
ACT_LIGHT_DIRECTION_OBJECT_SPACE | A light direction in object space (index determined by setAutoConstant call) |
ACT_LIGHT_DIRECTION_VIEW_SPACE | A light direction in view space (index determined by setAutoConstant call) |
ACT_LIGHT_DISTANCE_OBJECT_SPACE | The distance of the light from the center of the object a useful approximation as an alternative to per-vertex distance calculations. |
ACT_LIGHT_POWER_SCALE | Light power level, a single scalar as set in Light::setPowerScale (index determined by setAutoConstant call) |
ACT_LIGHT_DIFFUSE_COLOUR_POWER_SCALED | Light diffuse colour pre-scaled by Light::setPowerScale (index determined by setAutoConstant call) |
ACT_LIGHT_SPECULAR_COLOUR_POWER_SCALED | Light specular colour pre-scaled by Light::setPowerScale (index determined by setAutoConstant call) |
ACT_LIGHT_DIFFUSE_COLOUR_ARRAY | Array of light diffuse colours (count set by extra param) |
ACT_LIGHT_SPECULAR_COLOUR_ARRAY | Array of light specular colours (count set by extra param) |
ACT_LIGHT_DIFFUSE_COLOUR_POWER_SCALED_ARRAY | Array of light diffuse colours scaled by light power (count set by extra param) |
ACT_LIGHT_SPECULAR_COLOUR_POWER_SCALED_ARRAY | Array of light specular colours scaled by light power (count set by extra param) |
ACT_LIGHT_ATTENUATION_ARRAY | Array of light attenuation parameters, Vector4(range, constant, linear, quadric) (count set by extra param) |
ACT_LIGHT_POSITION_ARRAY | Array of light positions in world space (count set by extra param) |
ACT_LIGHT_POSITION_OBJECT_SPACE_ARRAY | Array of light positions in object space (count set by extra param) |
ACT_LIGHT_POSITION_VIEW_SPACE_ARRAY | Array of light positions in view space (count set by extra param) |
ACT_LIGHT_DIRECTION_ARRAY | Array of light directions in world space (count set by extra param) |
ACT_LIGHT_DIRECTION_OBJECT_SPACE_ARRAY | Array of light directions in object space (count set by extra param) |
ACT_LIGHT_DIRECTION_VIEW_SPACE_ARRAY | Array of light directions in view space (count set by extra param) |
ACT_LIGHT_DISTANCE_OBJECT_SPACE_ARRAY | Array of distances of the lights from the center of the object a useful approximation as an alternative to per-vertex distance calculations. (count set by extra param) |
ACT_LIGHT_POWER_SCALE_ARRAY | Array of light power levels, a single scalar as set in Light::setPowerScale (count set by extra param) |
ACT_SPOTLIGHT_PARAMS_ARRAY | Spotlight parameters array of Vector4(innerFactor, outerFactor, falloff, isSpot) innerFactor and outerFactor are cos(angle/2) The isSpot parameter is 0.0f for non-spotlights, 1.0f for spotlights. Also for non-spotlights the inner and outer factors are 1 and nearly 1 respectively. (count set by extra param) |
ACT_DERIVED_AMBIENT_LIGHT_COLOUR | The derived ambient light colour, with 'r', 'g', 'b' components filled with product of surface ambient colour and ambient light colour, respectively, and 'a' component filled with surface ambient alpha component. |
ACT_DERIVED_SCENE_COLOUR | The derived scene colour, with 'r', 'g' and 'b' components filled with sum of derived ambient light colour and surface emissive colour, respectively, and 'a' component filled with surface diffuse alpha component. |
ACT_DERIVED_LIGHT_DIFFUSE_COLOUR | The derived light diffuse colour (index determined by setAutoConstant call), with 'r', 'g' and 'b' components filled with product of surface diffuse colour, light power scale and light diffuse colour, respectively, and 'a' component filled with surface diffuse alpha component. |
ACT_DERIVED_LIGHT_SPECULAR_COLOUR | The derived light specular colour (index determined by setAutoConstant call), with 'r', 'g' and 'b' components filled with product of surface specular colour and light specular colour, respectively, and 'a' component filled with surface specular alpha component. |
ACT_DERIVED_LIGHT_DIFFUSE_COLOUR_ARRAY | Array of derived light diffuse colours (count set by extra param) |
ACT_DERIVED_LIGHT_SPECULAR_COLOUR_ARRAY | Array of derived light specular colours (count set by extra param) |
ACT_LIGHT_NUMBER | The absolute light number of a local light index. Each pass may have a number of lights passed to it, and each of these lights will have an index in the overall light list, which will differ from the local light index due to factors like setStartLight and setIteratePerLight. This binding provides the global light index for a local index. |
ACT_LIGHT_CASTS_SHADOWS | Returns (int) 1 if the given light casts shadows, 0 otherwise (index set in extra param) |
ACT_LIGHT_CASTS_SHADOWS_ARRAY | Returns (int) 1 if the given light casts shadows, 0 otherwise (index set in extra param) |
ACT_SHADOW_EXTRUSION_DISTANCE | The distance a shadow volume should be extruded when using finite extrusion programs. |
ACT_CAMERA_POSITION | The current camera's position in world space. |
ACT_CAMERA_POSITION_OBJECT_SPACE | The current camera's position in object space. |
ACT_CAMERA_RELATIVE_POSITION | The current camera's position in world space even when camera relative rendering is enabled. |
ACT_TEXTURE_VIEWPROJ_MATRIX | The view/projection matrix of the assigned texture projection frustum. Applicable to vertex programs which have been specified as the ’shadow receiver’ vertex program alternative, or where a texture unit is marked as content_type shadow; this provides details of the view/projection matrix for the current shadow projector. The optional ’extra_params’ entry specifies which light the projector refers to (for the case of content_type shadow where more than one shadow texture may be present in a single pass), where 0 is the default and refers to the first light referenced in this pass. |
ACT_TEXTURE_VIEWPROJ_MATRIX_ARRAY | Array of view/projection matrices of the first n texture projection frustums. |
ACT_TEXTURE_WORLDVIEWPROJ_MATRIX | The view/projection matrix of the assigned texture projection frustum, combined with the current world matrix. |
ACT_TEXTURE_WORLDVIEWPROJ_MATRIX_ARRAY | Array of world/view/projection matrices of the first n texture projection frustums. |
ACT_SPOTLIGHT_VIEWPROJ_MATRIX | The view/projection matrix of a given spotlight. |
ACT_SPOTLIGHT_VIEWPROJ_MATRIX_ARRAY | Array of view/projection matrix of a given spotlight. |
ACT_SPOTLIGHT_WORLDVIEWPROJ_MATRIX | The view/projection matrix of a given spotlight projection frustum, combined with the current world matrix. |
ACT_SPOTLIGHT_WORLDVIEWPROJ_MATRIX_ARRAY | An array of the view/projection matrix of a given spotlight projection frustum, combined with the current world matrix. |
ACT_CUSTOM | A custom parameter which will come from the renderable, using 'data' as the identifier. This allows you to map a custom parameter on an individual Renderable (see Renderable::setCustomParameter) to a parameter on a GPU program. It requires that you complete the ’extra_params’ field with the index that was used in the Renderable::setCustomParameter call, and this will ensure that whenever this Renderable is used, it will have it’s custom parameter mapped in. It’s very important that this parameter has been defined on all Renderables that are assigned the material that contains this automatic mapping, otherwise the process will fail. |
ACT_TIME | provides current elapsed time |
ACT_TIME_0_X | Single float value, which repeats itself based on given as parameter "cycle time". Equivalent to RenderMonkey's "Time0_X". |
ACT_COSTIME_0_X | Cosine of "Time0_X". Equivalent to RenderMonkey's "CosTime0_X". |
ACT_SINTIME_0_X | Sine of "Time0_X". Equivalent to RenderMonkey's "SinTime0_X". |
ACT_TANTIME_0_X | Tangent of "Time0_X". Equivalent to RenderMonkey's "TanTime0_X". |
ACT_TIME_0_X_PACKED | Vector of "Time0_X", "SinTime0_X", "CosTime0_X", "TanTime0_X". Equivalent to RenderMonkey's "Time0_X_Packed". |
ACT_TIME_0_1 | Single float value, which represents scaled time value [0..1], which repeats itself based on given as parameter "cycle time". Equivalent to RenderMonkey's "Time0_1". |
ACT_COSTIME_0_1 | Cosine of "Time0_1". Equivalent to RenderMonkey's "CosTime0_1". |
ACT_SINTIME_0_1 | Sine of "Time0_1". Equivalent to RenderMonkey's "SinTime0_1". |
ACT_TANTIME_0_1 | Tangent of "Time0_1". Equivalent to RenderMonkey's "TanTime0_1". |
ACT_TIME_0_1_PACKED | Vector of "Time0_1", "SinTime0_1", "CosTime0_1", "TanTime0_1". Equivalent to RenderMonkey's "Time0_1_Packed". |
ACT_TIME_0_2PI | Single float value, which represents scaled time value [0..2*Pi], which repeats itself based on given as parameter "cycle time". Equivalent to RenderMonkey's "Time0_2PI". |
ACT_COSTIME_0_2PI | Cosine of "Time0_2PI". Equivalent to RenderMonkey's "CosTime0_2PI". |
ACT_SINTIME_0_2PI | Sine of "Time0_2PI". Equivalent to RenderMonkey's "SinTime0_2PI". |
ACT_TANTIME_0_2PI | Tangent of "Time0_2PI". Equivalent to RenderMonkey's "TanTime0_2PI". |
ACT_TIME_0_2PI_PACKED | Vector of "Time0_2PI", "SinTime0_2PI", "CosTime0_2PI", "TanTime0_2PI". Equivalent to RenderMonkey's "Time0_2PI_Packed". |
ACT_FRAME_TIME | provides the scaled frame time, returned as a floating point value. |
ACT_FPS | provides the calculated frames per second, returned as a floating point value. |
ACT_VIEWPORT_WIDTH | Current viewport width (in pixels) as floating point value. Equivalent to RenderMonkey's "ViewportWidth". |
ACT_VIEWPORT_HEIGHT | Current viewport height (in pixels) as floating point value. Equivalent to RenderMonkey's "ViewportHeight". |
ACT_INVERSE_VIEWPORT_WIDTH | This variable represents 1.0/ViewportWidth. Equivalent to RenderMonkey's "ViewportWidthInverse". |
ACT_INVERSE_VIEWPORT_HEIGHT | This variable represents 1.0/ViewportHeight. Equivalent to RenderMonkey's "ViewportHeightInverse". |
ACT_VIEWPORT_SIZE | Packed of "ViewportWidth", "ViewportHeight", "ViewportWidthInverse", "ViewportHeightInverse". |
ACT_VIEW_DIRECTION | This variable provides the view direction vector (world space). Equivalent to RenderMonkey's "ViewDirection". |
ACT_VIEW_SIDE_VECTOR | This variable provides the view side vector (world space). Equivalent to RenderMonkey's "ViewSideVector". |
ACT_VIEW_UP_VECTOR | This variable provides the view up vector (world space). Equivalent to RenderMonkey's "ViewUpVector". |
ACT_FOV | This variable provides the field of view as a floating point value. Equivalent to RenderMonkey's "FOV". |
ACT_NEAR_CLIP_DISTANCE | This variable provides the near clip distance as a floating point value. Equivalent to RenderMonkey's "NearClipPlane". |
ACT_FAR_CLIP_DISTANCE | This variable provides the far clip distance as a floating point value. Equivalent to RenderMonkey's "FarClipPlane". |
ACT_PASS_NUMBER | provides the pass index number within the technique of the active materil. |
ACT_PASS_ITERATION_NUMBER | provides the current iteration number of the pass. The iteration number is the number of times the current render operation has been drawn for the active pass. |
ACT_ANIMATION_PARAMETRIC | Provides a parametric animation value [0..1], only available where the renderable specifically implements it. For morph animation, sets the parametric value (0..1) representing the distance between the first position keyframe (bound to positions) and the second position keyframe (bound to the first free texture coordinate) so that the vertex program can interpolate between them. For pose animation, indicates a group of up to 4 parametric weight values applying to a sequence of up to 4 poses (each one bound to x, y, z and w of the constant), one for each pose. The original positions are held in the usual position buffer, and the offsets to take those positions to the pose where weight == 1.0 are in the first ’n’ free texture coordinates; ’n’ being determined by the value passed to includes_pose_animation. If more than 4 simultaneous poses are required, then you’ll need more than 1 shader constant to hold the parametric values, in which case you should use this binding more than once, referencing a different constant entry; the second one will contain the parametrics for poses 5-8, the third for poses 9-12, and so on. |
ACT_TEXEL_OFFSETS | Provides the texel offsets required by this rendersystem to map texels to pixels. Packed as float4(absoluteHorizontalOffset, absoluteVerticalOffset, horizontalOffset / viewportWidth, verticalOffset / viewportHeight) |
ACT_SCENE_DEPTH_RANGE | Provides information about the depth range of the scene as viewed from the current camera. Passed as float4(minDepth, maxDepth, depthRange, 1 / depthRange) |
ACT_SHADOW_SCENE_DEPTH_RANGE | Provides information about the depth range of the scene as viewed from a given shadow camera. Requires an index parameter which maps to a light index relative to the current light list. Passed as float4(minDepth, maxDepth, depthRange, 1 / depthRange) |
ACT_SHADOW_SCENE_DEPTH_RANGE_ARRAY | Provides an array of information about the depth range of the scene as viewed from a given shadow camera. Requires an index parameter which maps to a light index relative to the current light list. Passed as float4(minDepth, maxDepth, depthRange, 1 / depthRange) |
ACT_SHADOW_COLOUR | Provides the fixed shadow colour as configured via SceneManager::setShadowColour; useful for integrated modulative shadows. |
ACT_TEXTURE_SIZE | Provides texture size of the texture unit (index determined by setAutoConstant call). Packed as float4(width, height, depth, 1) |
ACT_INVERSE_TEXTURE_SIZE | Provides inverse texture size of the texture unit (index determined by setAutoConstant call). Packed as float4(1 / width, 1 / height, 1 / depth, 1) |
ACT_PACKED_TEXTURE_SIZE | Provides packed texture size of the texture unit (index determined by setAutoConstant call). Packed as float4(width, height, 1 / width, 1 / height) |
ACT_TEXTURE_MATRIX | Provides the current transform matrix of the texture unit (index determined by setAutoConstant call), as seen by the fixed-function pipeline. This requires an index in the ’extra_params’ field, and relates to the ’nth’ texture unit of the pass in question. NB if the given index exceeds the number of texture units available for this pass, then the parameter will be set to Matrix4::IDENTITY. |
ACT_LOD_CAMERA_POSITION | Provides the position of the LOD camera in world space, allowing you to perform separate LOD calculations in shaders independent of the rendering camera. If there is no separate LOD camera then this is the real camera position. See Camera::setLodCamera. |
ACT_LOD_CAMERA_POSITION_OBJECT_SPACE | Provides the position of the LOD camera in object space, allowing you to perform separate LOD calculations in shaders independent of the rendering camera. If there is no separate LOD camera then this is the real camera position. See Camera::setLodCamera. |
ACT_LIGHT_CUSTOM | Binds custom per-light constants to the shaders. |
ACT_POINT_PARAMS | Point params: size; constant, linear, quadratic attenuation. |
ACT_UNKNOWN |
Ogre::GpuProgramParameters::GpuProgramParameters | ( | ) |
Ogre::GpuProgramParameters::~GpuProgramParameters | ( | ) |
Ogre::GpuProgramParameters::GpuProgramParameters | ( | const GpuProgramParameters & | oth | ) |
Copy constructor.
GpuProgramParameters& Ogre::GpuProgramParameters::operator= | ( | const GpuProgramParameters & | oth | ) |
Operator = overload.
void Ogre::GpuProgramParameters::_setNamedConstants | ( | const GpuNamedConstantsPtr & | constantmap | ) |
Internal method for providing a link to a name->definition map for parameters.
void Ogre::GpuProgramParameters::_setLogicalIndexes | ( | const GpuLogicalBufferStructPtr & | floatIndexMap, |
const GpuLogicalBufferStructPtr & | doubleIndexMap, | ||
const GpuLogicalBufferStructPtr & | intIndexMap | ||
) |
Internal method for providing a link to a logical index->physical index map for parameters.
|
inline |
Does this parameter set include named parameters?
|
inline |
Does this parameter set include logically indexed parameters?
void Ogre::GpuProgramParameters::setConstant | ( | size_t | index, |
const Vector4 & | vec | ||
) |
Sets a 4-element floating-point parameter to the program.
index | The logical constant index at which to place the parameter (each constant is a 4D float) |
vec | The value to set |
void Ogre::GpuProgramParameters::setConstant | ( | size_t | index, |
Real | val | ||
) |
Sets a single floating-point parameter to the program.
index | The logical constant index at which to place the parameter (each constant is a 4D float) |
val | The value to set |
void Ogre::GpuProgramParameters::setConstant | ( | size_t | index, |
const Vector3 & | vec | ||
) |
Sets a 4-element floating-point parameter to the program via Vector3.
index | The logical constant index at which to place the parameter (each constant is a 4D float). Note that since you're passing a Vector3, the last element of the 4-element value will be set to 1 (a homogeneous vector) |
vec | The value to set |
void Ogre::GpuProgramParameters::setConstant | ( | size_t | index, |
const Vector2 & | vec | ||
) |
Sets a 4-element floating-point parameter to the program via Vector2.
index | The logical constant index at which to place the parameter (each constant is a 4D float). Note that since you're passing a Vector2, the last 2 elements of the 4-element value will be set to 1 (a homogeneous vector) |
vec | The value to set |
void Ogre::GpuProgramParameters::setConstant | ( | size_t | index, |
const Matrix4 & | m | ||
) |
void Ogre::GpuProgramParameters::setConstant | ( | size_t | index, |
const Matrix4 * | m, | ||
size_t | numEntries | ||
) |
Sets a list of Matrix4 parameters to the program.
void Ogre::GpuProgramParameters::setConstant | ( | size_t | index, |
const ColourValue & | colour | ||
) |
Sets a ColourValue parameter to the program.
index | The logical constant index at which to place the parameter (each constant is a 4D float) |
colour | The value to set |
void Ogre::GpuProgramParameters::setConstant | ( | size_t | index, |
const float * | val, | ||
size_t | count | ||
) |
Sets a multiple value constant floating-point parameter to the program.
index | The logical constant index at which to start placing parameters (each constant is a 4D float) |
val | Pointer to the values to write, must contain 4*count floats |
count | The number of groups of 4 floats to write |
void Ogre::GpuProgramParameters::setConstant | ( | size_t | index, |
const double * | val, | ||
size_t | count | ||
) |
Sets a multiple value constant floating-point parameter to the program.
index | The logical constant index at which to start placing parameters (each constant is a 4D float) |
val | Pointer to the values to write, must contain 4*count floats |
count | The number of groups of 4 floats to write |
void Ogre::GpuProgramParameters::setConstant | ( | size_t | index, |
const int * | val, | ||
size_t | count | ||
) |
Sets a multiple value constant integer parameter to the program.
index | The logical constant index at which to place the parameter (each constant is a 4D integer) |
val | Pointer to the values to write, must contain 4*count ints |
count | The number of groups of 4 ints to write |
void Ogre::GpuProgramParameters::setConstant | ( | size_t | index, |
const uint * | val, | ||
size_t | count | ||
) |
Sets a multiple value constant unsigned integer parameter to the program.
index | The logical constant index at which to place the parameter (each constant is a 4D integer) |
val | Pointer to the values to write, must contain 4*count ints |
count | The number of groups of 4 ints to write |
void Ogre::GpuProgramParameters::_writeRawConstants | ( | size_t | physicalIndex, |
const float * | val, | ||
size_t | count | ||
) |
Write a series of floating point values into the underlying float constant buffer at the given physical index.
physicalIndex | The buffer position to start writing |
val | Pointer to a list of values to write |
count | The number of floats to write |
void Ogre::GpuProgramParameters::_writeRawConstants | ( | size_t | physicalIndex, |
const double * | val, | ||
size_t | count | ||
) |
Write a series of floating point values into the underlying float constant buffer at the given physical index.
physicalIndex | The buffer position to start writing |
val | Pointer to a list of values to write |
count | The number of floats to write |
void Ogre::GpuProgramParameters::_writeRawConstants | ( | size_t | physicalIndex, |
const int * | val, | ||
size_t | count | ||
) |
Write a series of integer values into the underlying integer constant buffer at the given physical index.
physicalIndex | The buffer position to start writing |
val | Pointer to a list of values to write |
count | The number of ints to write |
void Ogre::GpuProgramParameters::_writeRawConstants | ( | size_t | physicalIndex, |
const uint * | val, | ||
size_t | count | ||
) |
Write a series of unsigned integer values into the underlying integer constant buffer at the given physical index.
physicalIndex | The buffer position to start writing |
val | Pointer to a list of values to write |
count | The number of ints to write |
|
inline |
Write a Vector parameter to the program directly to the underlying constants buffer.
physicalIndex | The physical buffer index at which to place the parameter |
vec | The value to set |
count | The number of floats to write; if for example the uniform constant 'slot' is smaller than a Vector4 |
|
inline |
Write a single parameter to the program.
physicalIndex | The physical buffer index at which to place the parameter |
val | The value to set |
void Ogre::GpuProgramParameters::_writeRawConstant | ( | size_t | physicalIndex, |
Real | val, | ||
size_t | count | ||
) |
void Ogre::GpuProgramParameters::_writeRawConstant | ( | size_t | physicalIndex, |
const Matrix4 & | m, | ||
size_t | elementCount | ||
) |
Write a Matrix4 parameter to the program.
physicalIndex | The physical buffer index at which to place the parameter |
m | The value to set |
elementCount | actual element count used with shader |
void Ogre::GpuProgramParameters::_writeRawConstant | ( | size_t | physicalIndex, |
const Matrix3 & | m, | ||
size_t | elementCount | ||
) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
void Ogre::GpuProgramParameters::_writeRawConstant | ( | size_t | physicalIndex, |
const TransformBaseReal * | m, | ||
size_t | numEntries | ||
) |
void Ogre::GpuProgramParameters::_writeRawConstant | ( | size_t | physicalIndex, |
const ColourValue & | colour, | ||
size_t | count = 4 |
||
) |
Write a ColourValue parameter to the program.
physicalIndex | The physical buffer index at which to place the parameter |
colour | The value to set |
count | The number of floats to write; if for example the uniform constant 'slot' is smaller than a Vector4 |
void Ogre::GpuProgramParameters::_readRawConstants | ( | size_t | physicalIndex, |
size_t | count, | ||
float * | dest | ||
) |
Read a series of floating point values from the underlying float constant buffer at the given physical index.
physicalIndex | The buffer position to start reading |
count | The number of floats to read |
dest | Pointer to a buffer to receive the values |
void Ogre::GpuProgramParameters::_readRawConstants | ( | size_t | physicalIndex, |
size_t | count, | ||
int * | dest | ||
) |
Read a series of integer values from the underlying integer constant buffer at the given physical index.
physicalIndex | The buffer position to start reading |
count | The number of ints to read |
dest | Pointer to a buffer to receive the values |
GpuConstantDefinitionIterator Ogre::GpuProgramParameters::getConstantDefinitionIterator | ( | void | ) | const |
const GpuConstantDefinition& Ogre::GpuProgramParameters::getConstantDefinition | ( | const String & | name | ) | const |
Get a specific GpuConstantDefinition for a named parameter.
const GpuNamedConstants& Ogre::GpuProgramParameters::getConstantDefinitions | ( | ) | const |
Get the full list of GpuConstantDefinition instances.
|
inline |
Get the current list of mappings from low-level logical param indexes to physical buffer locations in the float buffer.
|
inline |
Get the current list of mappings from low-level logical param indexes to physical buffer locations in the double buffer.
|
inline |
Get the current list of mappings from low-level logical param indexes to physical buffer locations in the integer buffer.
size_t Ogre::GpuProgramParameters::getFloatLogicalIndexForPhysicalIndex | ( | size_t | physicalIndex | ) |
Retrieves the logical index relating to a physical index in the buffer, for programs which support that (low-level programs and high-level programs which use logical parameter indexes).
size_t Ogre::GpuProgramParameters::getDoubleLogicalIndexForPhysicalIndex | ( | size_t | physicalIndex | ) |
Retrieves the logical index relating to a physical index in the buffer, for programs which support that (low-level programs and high-level programs which use logical parameter indexes).
size_t Ogre::GpuProgramParameters::getIntLogicalIndexForPhysicalIndex | ( | size_t | physicalIndex | ) |
Retrieves the logical index relating to a physical index in the buffer, for programs which support that (low-level programs and high-level programs which use logical parameter indexes).
|
inline |
Get a reference to the list of float constants.
|
inline |
Get a pointer to the 'nth' item in the float buffer.
|
inline |
Get a pointer to the 'nth' item in the float buffer.
|
inline |
Get a reference to the list of double constants.
|
inline |
Get a pointer to the 'nth' item in the double buffer.
|
inline |
Get a pointer to the 'nth' item in the double buffer.
|
inline |
Get a reference to the list of int constants.
|
inline |
Get a pointer to the 'nth' item in the int buffer.
|
inline |
Get a pointer to the 'nth' item in the int buffer.
|
inline |
Get a pointer to the 'nth' item in the uint buffer.
|
inline |
Get a pointer to the 'nth' item in the uint buffer.
|
inline |
Get a reference to the list of auto constant bindings.
void Ogre::GpuProgramParameters::setAutoConstant | ( | size_t | index, |
AutoConstantType | acType, | ||
uint32 | extraInfo = 0 |
||
) |
Sets up a constant which will automatically be updated by the system.
index | The location in the constant list to place this updated constant every time it is changed. Note that because of the nature of the types, we know how big the parameter details will be so you don't need to set that like you do for manual constants. |
acType | The type of automatic constant to set |
extraInfo | If the constant type needs more information (like a light index or array size) put it here. |
void Ogre::GpuProgramParameters::setAutoConstantReal | ( | size_t | index, |
AutoConstantType | acType, | ||
float | rData | ||
) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
|
inline |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
void Ogre::GpuProgramParameters::_setRawAutoConstant | ( | size_t | physicalIndex, |
AutoConstantType | acType, | ||
uint32 | extraInfo, | ||
uint16 | variability, | ||
uint8 | elementSize = 4 |
||
) |
As setAutoConstant, but sets up the auto constant directly against a physical buffer index.
void Ogre::GpuProgramParameters::_setRawAutoConstantReal | ( | size_t | physicalIndex, |
AutoConstantType | acType, | ||
float | rData, | ||
uint16 | variability, | ||
uint8 | elementSize = 4 |
||
) |
As setAutoConstantReal, but sets up the auto constant directly against a physical buffer index.
void Ogre::GpuProgramParameters::clearAutoConstant | ( | size_t | index | ) |
Unbind an auto constant so that the constant is manually controlled again.
|
inline |
void Ogre::GpuProgramParameters::clearAutoConstants | ( | void | ) |
Clears all the existing automatic constants.
|
inline |
Gets the automatic constant bindings currently in place.
|
inline |
Gets the number of int constants that have been set.
AutoConstantEntry* Ogre::GpuProgramParameters::getAutoConstantEntry | ( | const size_t | index | ) |
Gets a specific Auto Constant entry if index is in valid range otherwise returns a NULL.
index | which entry is to be retrieved |
|
inline |
Returns true if this instance has any automatic constants.
const AutoConstantEntry* Ogre::GpuProgramParameters::findFloatAutoConstantEntry | ( | size_t | logicalIndex | ) |
Finds an auto constant that's affecting a given logical parameter index for floating-point values.
const AutoConstantEntry* Ogre::GpuProgramParameters::findDoubleAutoConstantEntry | ( | size_t | logicalIndex | ) |
Finds an auto constant that's affecting a given logical parameter index for double-point values.
const AutoConstantEntry* Ogre::GpuProgramParameters::findIntAutoConstantEntry | ( | size_t | logicalIndex | ) |
Finds an auto constant that's affecting a given logical parameter index for integer values.
const AutoConstantEntry* Ogre::GpuProgramParameters::findUnsignedIntAutoConstantEntry | ( | size_t | logicalIndex | ) |
Finds an auto constant that's affecting a given logical parameter index for unsigned integer values.
const AutoConstantEntry* Ogre::GpuProgramParameters::findAutoConstantEntry | ( | const String & | paramName | ) | const |
Finds an auto constant that's affecting a given named parameter index.
const AutoConstantEntry* Ogre::GpuProgramParameters::_findRawAutoConstantEntryFloat | ( | size_t | physicalIndex | ) | const |
Finds an auto constant that's affecting a given physical position in the floating-point buffer.
const AutoConstantEntry* Ogre::GpuProgramParameters::_findRawAutoConstantEntryDouble | ( | size_t | physicalIndex | ) | const |
Finds an auto constant that's affecting a given physical position in the double-point buffer.
const AutoConstantEntry* Ogre::GpuProgramParameters::_findRawAutoConstantEntryInt | ( | size_t | physicalIndex | ) | const |
Finds an auto constant that's affecting a given physical position in the integer buffer.
const AutoConstantEntry* Ogre::GpuProgramParameters::_findRawAutoConstantEntryUnsignedInt | ( | size_t | physicalIndex | ) | const |
Finds an auto constant that's affecting a given physical position in the unsigned integer buffer.
const AutoConstantEntry* Ogre::GpuProgramParameters::_findRawAutoConstantEntryBool | ( | size_t | physicalIndex | ) | const |
Finds an auto constant that's affecting a given physical position in the boolean buffer.
void Ogre::GpuProgramParameters::setNamedAutoConstant | ( | const String & | name, |
AutoConstantType | acType, | ||
size_t | extraInfo = 0 |
||
) |
Sets up a constant which will automatically be updated by the system.
name | The name of the parameter |
acType | The type of automatic constant to set |
extraInfo | If the constant type needs more information (like a light index) put it here. |
void Ogre::GpuProgramParameters::setNamedAutoConstantReal | ( | const String & | name, |
AutoConstantType | acType, | ||
Real | rData | ||
) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
|
inline |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
|
inline |
void Ogre::GpuProgramParameters::clearNamedAutoConstant | ( | const String & | name | ) |
Unbind an auto constant so that the constant is manually controlled again.
void Ogre::GpuProgramParameters::_updateAutoParams | ( | const AutoParamDataSource * | source, |
uint16 | variabilityMask | ||
) |
Update automatic parameters.
source | The source of the parameters |
variabilityMask | A mask of GpuParamVariability which identifies which autos will need updating |
|
inline |
Tells the program whether to ignore missing parameters or not.
Sets a single value constant parameter to the program.
Different types of GPU programs support different types of constant parameters. For example, it's relatively common to find that vertex programs only support floating point constants, and that fragment programs only support integer (fixed point) parameters. This can vary depending on the program version supported by the graphics card being used. You should consult the documentation for the type of low level program you are using, or alternatively use the methods provided on RenderSystemCapabilities to determine the options.
Another possible limitation is that some systems only allow constants to be set on certain boundaries, e.g. in sets of 4 values for example. Again, see RenderSystemCapabilities for full details.
name | The name of the parameter |
val | The value to set |
void Ogre::GpuProgramParameters::setNamedConstant | ( | const String & | name, |
int | val | ||
) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
void Ogre::GpuProgramParameters::setNamedConstant | ( | const String & | name, |
const ColourValue & | colour | ||
) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
void Ogre::GpuProgramParameters::setNamedConstant | ( | const String & | name, |
const Matrix4 * | m, | ||
size_t | numEntries | ||
) |
Sets a list of Matrix4 parameters to the program.
void Ogre::GpuProgramParameters::setNamedConstant | ( | const String & | name, |
const float * | val, | ||
size_t | count, | ||
size_t | multiple = 4 |
||
) |
Sets a multiple value constant parameter to the program.
Some systems only allow constants to be set on certain boundaries, e.g. in sets of 4 values for example. The 'multiple' parameter allows you to control that although you should only change it if you know your chosen language supports that (at the time of writing, only GLSL allows constants which are not a multiple of 4).
name | The name of the parameter |
val | Pointer to the values to write |
count | The number of 'multiples' of floats to write |
multiple | The number of raw entries in each element to write, the default is 4 so count = 1 would write 4 floats. |
void Ogre::GpuProgramParameters::setNamedConstant | ( | const String & | name, |
const double * | val, | ||
size_t | count, | ||
size_t | multiple = 4 |
||
) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
void Ogre::GpuProgramParameters::setNamedConstant | ( | const String & | name, |
const int * | val, | ||
size_t | count, | ||
size_t | multiple = 4 |
||
) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
void Ogre::GpuProgramParameters::setNamedConstant | ( | const String & | name, |
const uint * | val, | ||
size_t | count, | ||
size_t | multiple = 4 |
||
) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
const GpuConstantDefinition* Ogre::GpuProgramParameters::_findNamedConstantDefinition | ( | const String & | name, |
bool | throwExceptionIfMissing = false |
||
) | const |
Find a constant definition for a named parameter.
name | The name to look up |
throwExceptionIfMissing | If set to true, failure to find an entry will throw an exception. |
size_t Ogre::GpuProgramParameters::_getFloatConstantPhysicalIndex | ( | size_t | logicalIndex, |
size_t | requestedSize, | ||
uint16 | variability | ||
) |
Gets the physical buffer index associated with a logical float constant index.
logicalIndex | The logical parameter index |
requestedSize | The requested size - pass 0 to ignore missing entries and return std::numeric_limits<size_t>::max() |
variability |
size_t Ogre::GpuProgramParameters::_getDoubleConstantPhysicalIndex | ( | size_t | logicalIndex, |
size_t | requestedSize, | ||
uint16 | variability | ||
) |
Gets the physical buffer index associated with a logical double constant index.
logicalIndex | The logical parameter index |
requestedSize | The requested size - pass 0 to ignore missing entries and return std::numeric_limits<size_t>::max() |
variability |
size_t Ogre::GpuProgramParameters::_getIntConstantPhysicalIndex | ( | size_t | logicalIndex, |
size_t | requestedSize, | ||
uint16 | variability | ||
) |
Gets the physical buffer index associated with a logical int constant index.
logicalIndex | The logical parameter index |
requestedSize | The requested size - pass 0 to ignore missing entries and return std::numeric_limits<size_t>::max() |
variability |
|
inline |
Sets whether or not we need to transpose the matrices passed in from the rest of OGRE.
|
inline |
Gets whether or not matrices are to be transposed when set.
void Ogre::GpuProgramParameters::copyConstantsFrom | ( | const GpuProgramParameters & | source | ) |
Copies the values of all constants (including auto constants) from another GpuProgramParameters object.
void Ogre::GpuProgramParameters::copyMatchingNamedConstantsFrom | ( | const GpuProgramParameters & | source | ) |
Copies the values of all matching named constants (including auto constants) from another GpuProgramParameters object.
|
static |
gets the auto constant definition associated with name if found else returns NULL
name | The name of the auto constant |
|
static |
gets the auto constant definition using an index into the auto constant definition array.
If the index is out of bounds then NULL is returned;
idx | The auto constant index |
|
static |
Returns the number of auto constant definitions.
void Ogre::GpuProgramParameters::incPassIterationNumber | ( | void | ) |
increments the multipass number entry by 1 if it exists
|
inline |
|
inline |
void Ogre::GpuProgramParameters::addSharedParameters | ( | GpuSharedParametersPtr | sharedParams | ) |
Use a set of shared parameters in this parameters object.
void Ogre::GpuProgramParameters::addSharedParameters | ( | const String & | sharedParamsName | ) |
Use a set of shared parameters in this parameters object.
sharedParamsName | The name of a shared parameter set as defined in GpuProgramManager |
bool Ogre::GpuProgramParameters::isUsingSharedParameters | ( | const String & | sharedParamsName | ) | const |
Returns whether this parameter set is using the named shared parameter set.
void Ogre::GpuProgramParameters::removeSharedParameters | ( | const String & | sharedParamsName | ) |
Stop using the named shared parameter set.
void Ogre::GpuProgramParameters::removeAllSharedParameters | ( | ) |
Stop using all shared parameter sets.
const GpuSharedParamUsageList& Ogre::GpuProgramParameters::getSharedParameters | ( | ) | const |
Get the list of shared parameter sets.
void Ogre::GpuProgramParameters::_copySharedParams | ( | ) |
Update the parameters by copying the data from the shared parameters.
void Ogre::GpuProgramParameters::_updateSharedParams | ( | ) |
Update the HardwareBuffer based backing of referenced shared parameters.
falls back to _copySharedParams() if a shared parameter is not hardware backed
|
inline |
Internal method that the RenderSystem might use to store optional data.
|
inline |
Internal method that the RenderSystem might use to store optional data.
size_t Ogre::GpuProgramParameters::calculateSize | ( | void | ) | const |
void Ogre::GpuProgramParameters::setNamedSubroutine | ( | const String & | subroutineSlot, |
const String & | subroutine | ||
) |
Set subroutine name by slot name.
void Ogre::GpuProgramParameters::setSubroutine | ( | size_t | index, |
const String & | subroutine | ||
) |
Set subroutine name by slot index.
|
inline |
Get map with.