![]() |
OGRE 2.1
Object-Oriented Graphics Rendering Engine
|
Specialisation of GLSLProgram to provide support for separable programs via the OpenGL program pipeline. More...
#include <OgreGLSLSeparableProgram.h>
Public Member Functions | |
GLSLSeparableProgram (GLSLShader *vertexShader, GLSLShader *hullShader, GLSLShader *domainShader, GLSLShader *geometryShader, GLSLShader *fragmentShader, GLSLShader *computeShader) | |
Constructor should only be used by GLSLSeparableProgramManager. | |
~GLSLSeparableProgram () | |
void | activate (void) |
Makes a program pipeline object active by making sure it is linked and then putting it in use. | |
virtual void | extractLayoutQualifiers (void) |
Finds layout qualifiers in the shader source and sets attribute indices appropriately. | |
GLint | getAttributeIndex (VertexElementSemantic semantic, uint index) |
Get the index of a non-standard attribute bound in the linked code. | |
GLSLShader * | getComputeShader () const |
GLSLShader * | getDomainShader () const |
GLSLShader * | getFragmentShader () const |
GLSLShader * | getGeometryShader () const |
GLuint | getGLProgramHandle (void) const |
Get the GL Handle for the program object. | |
GLuint | getGLProgramPipelineHandle () const |
GL Program Pipeline Handle. | |
GLSLShader * | getHullShader () const |
GL3PlusOldVertexArrayObject * | getVertexArrayObject () |
GLSLShader * | getVertexShader () const |
bool | isAttributeValid (VertexElementSemantic semantic, uint index) |
Is a non-standard attribute bound in the linked code? | |
bool | isSkeletalAnimationIncluded (void) const |
Returns whether the linked program includes the required instructions to perform skeletal animation. | |
void | setSkeletalAnimationIncluded (bool included) |
Sets whether the linked program includes the required instructions to perform skeletal animation. | |
void | updateAtomicCounters (GpuProgramParametersSharedPtr params, uint16 mask, GpuProgramType fromProgType) |
Updates program object atomic counter buffers using data from GpuProgramParameters. | |
void | updatePassIterationUniforms (GpuProgramParametersSharedPtr params) |
Updates program pipeline object uniforms using data from pass iteration GpuProgramParameters. | |
void | updateUniformBlocks (GpuProgramParametersSharedPtr params, uint16 mask, GpuProgramType fromProgType) |
Updates program object uniform blocks using shared parameter data from GpuProgramParameters. | |
void | updateUniforms (GpuProgramParametersSharedPtr params, uint16 mask, GpuProgramType fromProgType) |
Updates program pipeline object uniforms using named and indexed parameter data from GpuProgramParameters. | |
Public Attributes | |
GLint | mBaseInstanceLocation |
Specialisation of GLSLProgram to provide support for separable programs via the OpenGL program pipeline.
Separable programs consist of shader objects which have been individually linked. This allows for invidual shaders in a program pipeline to be swapped without recompiling the program object, as would be necessary with monolithic programs. This is especially useful in the common case of only entities which change only a few of the shaders in the pipeline while leaving the rest the same.
GLSL also does not provide assembler low level output after compiling. The GL Render system assumes that the Gpu program is a GL Gpu program so GLSLSeparableProgram will create a GL3PlusShader for the low level implementation. The GLProgram class will create a shader and program object and compile the source but will not create a pipeline object. It's up to GLGpuProgram class to request a program pipeline object to link the program object to.
Ogre::GLSLSeparableProgram::GLSLSeparableProgram | ( | GLSLShader * | vertexShader, |
GLSLShader * | hullShader, | ||
GLSLShader * | domainShader, | ||
GLSLShader * | geometryShader, | ||
GLSLShader * | fragmentShader, | ||
GLSLShader * | computeShader | ||
) |
Constructor should only be used by GLSLSeparableProgramManager.
Ogre::GLSLSeparableProgram::~GLSLSeparableProgram | ( | ) |
Makes a program pipeline object active by making sure it is linked and then putting it in use.
Implements Ogre::GLSLProgram.
Finds layout qualifiers in the shader source and sets attribute indices appropriately.
|
virtual |
Get the index of a non-standard attribute bound in the linked code.
Reimplemented from Ogre::GLSLProgram.
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
Get the GL Handle for the program object.
|
inline |
GL Program Pipeline Handle.
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inherited |
Is a non-standard attribute bound in the linked code?
Returns whether the linked program includes the required instructions to perform skeletal animation.
Sets whether the linked program includes the required instructions to perform skeletal animation.
void Ogre::GLSLSeparableProgram::updateAtomicCounters | ( | GpuProgramParametersSharedPtr | params, |
uint16 | mask, | ||
GpuProgramType | fromProgType | ||
) |
Updates program object atomic counter buffers using data from GpuProgramParameters.
Normally called by GLSLShader::bindProgramAtomicCounterParameters() just before rendering occurs.
|
virtual |
Updates program pipeline object uniforms using data from pass iteration GpuProgramParameters.
Normally called by GLSLShader::bindProgramPassIterationParameters() just before multi pass rendering occurs.
Implements Ogre::GLSLProgram.
|
virtual |
Updates program object uniform blocks using shared parameter data from GpuProgramParameters.
Normally called by GLSLShader::bindProgramSharedParameters() just before rendering occurs.
Implements Ogre::GLSLProgram.
|
virtual |
Updates program pipeline object uniforms using named and indexed parameter data from GpuProgramParameters.
normally called by GLSLShader::bindProgramParameters() just before rendering occurs.
Implements Ogre::GLSLProgram.
|
inherited |