Member Function Documentation
QOpenGLShaderProgram::QOpenGLShaderProgram(QObject * parent = 0)
Constructs a new shader program and attaches it to parent. The program will be invalid until addShader() is called.
The shader program will be associated with the current QOpenGLContext.
See also addShader().
QOpenGLShaderProgram::~QOpenGLShaderProgram() [virtual]
Deletes this shader program.
bool QOpenGLShaderProgram::addShader(QOpenGLShader * shader)
Adds a compiled shader to this shader program. Returns true if the shader could be added, or false otherwise.
Ownership of the shader object remains with the caller. It will not be deleted when this QOpenGLShaderProgram instance is deleted. This allows the caller to add the same shader to multiple shader programs.
See also addShaderFromSourceCode(), addShaderFromSourceFile(), removeShader(), link(), and removeAllShaders().
bool QOpenGLShaderProgram::addShaderFromSourceCode(QOpenGLShader::ShaderType type, const char * source)
Compiles source as a shader of the specified type and adds it to this shader program. Returns true if compilation was successful, false otherwise. The compilation errors and warnings will be made available via log().
This function is intended to be a short-cut for quickly adding vertex and fragment shaders to a shader program without creating an instance of QOpenGLShader first.
See also addShader(), addShaderFromSourceFile(), removeShader(), link(), log(), and removeAllShaders().
bool QOpenGLShaderProgram::addShaderFromSourceCode(QOpenGLShader::ShaderType type, const QByteArray & source)
This is an overloaded function.
Compiles source as a shader of the specified type and adds it to this shader program. Returns true if compilation was successful, false otherwise. The compilation errors and warnings will be made available via log().
This function is intended to be a short-cut for quickly adding vertex and fragment shaders to a shader program without creating an instance of QOpenGLShader first.
See also addShader(), addShaderFromSourceFile(), removeShader(), link(), log(), and removeAllShaders().
bool QOpenGLShaderProgram::addShaderFromSourceCode(QOpenGLShader::ShaderType type, const QString & source)
This is an overloaded function.
Compiles source as a shader of the specified type and adds it to this shader program. Returns true if compilation was successful, false otherwise. The compilation errors and warnings will be made available via log().
This function is intended to be a short-cut for quickly adding vertex and fragment shaders to a shader program without creating an instance of QOpenGLShader first.
See also addShader(), addShaderFromSourceFile(), removeShader(), link(), log(), and removeAllShaders().
bool QOpenGLShaderProgram::addShaderFromSourceFile(QOpenGLShader::ShaderType type, const QString & fileName)
Compiles the contents of fileName as a shader of the specified type and adds it to this shader program. Returns true if compilation was successful, false otherwise. The compilation errors and warnings will be made available via log().
This function is intended to be a short-cut for quickly adding vertex and fragment shaders to a shader program without creating an instance of QOpenGLShader first.
See also addShader() and addShaderFromSourceCode().
int QOpenGLShaderProgram::attributeLocation(const char * name) const
Returns the location of the attribute name within this shader program's parameter list. Returns -1 if name is not a valid attribute for this shader program.
See also uniformLocation() and bindAttributeLocation().
int QOpenGLShaderProgram::attributeLocation(const QByteArray & name) const
This is an overloaded function.
Returns the location of the attribute name within this shader program's parameter list. Returns -1 if name is not a valid attribute for this shader program.
See also uniformLocation() and bindAttributeLocation().
int QOpenGLShaderProgram::attributeLocation(const QString & name) const
This is an overloaded function.
Returns the location of the attribute name within this shader program's parameter list. Returns -1 if name is not a valid attribute for this shader program.
See also uniformLocation() and bindAttributeLocation().
bool QOpenGLShaderProgram::bind()
Binds this shader program to the active QOpenGLContext and makes it the current shader program. Any previously bound shader program is released. This is equivalent to calling glUseProgram() on programId(). Returns true if the program was successfully bound; false otherwise. If the shader program has not yet been linked, or it needs to be re-linked, this function will call link().
See also link() and release().
void QOpenGLShaderProgram::bindAttributeLocation(const char * name, int location)
Binds the attribute name to the specified location. This function can be called before or after the program has been linked. Any attributes that have not been explicitly bound when the program is linked will be assigned locations automatically.
When this function is called after the program has been linked, the program will need to be relinked for the change to take effect.
See also attributeLocation().
void QOpenGLShaderProgram::bindAttributeLocation(const QByteArray & name, int location)
This is an overloaded function.
Binds the attribute name to the specified location. This function can be called before or after the program has been linked. Any attributes that have not been explicitly bound when the program is linked will be assigned locations automatically.
When this function is called after the program has been linked, the program will need to be relinked for the change to take effect.
See also attributeLocation().
void QOpenGLShaderProgram::bindAttributeLocation(const QString & name, int location)
This is an overloaded function.
Binds the attribute name to the specified location. This function can be called before or after the program has been linked. Any attributes that have not been explicitly bound when the program is linked will be assigned locations automatically.
When this function is called after the program has been linked, the program will need to be relinked for the change to take effect.
See also attributeLocation().
void QOpenGLShaderProgram::disableAttributeArray(int location)
Disables the vertex array at location in this shader program that was enabled by a previous call to enableAttributeArray().
See also enableAttributeArray(), setAttributeArray(), setAttributeValue(), and setUniformValue().
void QOpenGLShaderProgram::disableAttributeArray(const char * name)
This is an overloaded function.
Disables the vertex array called name in this shader program that was enabled by a previous call to enableAttributeArray().
See also enableAttributeArray(), setAttributeArray(), setAttributeValue(), and setUniformValue().
void QOpenGLShaderProgram::enableAttributeArray(int location)
Enables the vertex array at location in this shader program so that the value set by setAttributeArray() on location will be used by the shader program.
See also disableAttributeArray(), setAttributeArray(), setAttributeValue(), and setUniformValue().
void QOpenGLShaderProgram::enableAttributeArray(const char * name)
This is an overloaded function.
Enables the vertex array called name in this shader program so that the value set by setAttributeArray() on name will be used by the shader program.
See also disableAttributeArray(), setAttributeArray(), setAttributeValue(), and setUniformValue().
GLenum QOpenGLShaderProgram::geometryInputType() const
Returns the geometry shader input type, if active.
This parameter takes effect the next time the program is linked.
See also setGeometryInputType().
GLenum QOpenGLShaderProgram::geometryOutputType() const
Returns the geometry shader output type, if active.
This parameter takes effect the next time the program is linked.
See also setGeometryOutputType().
int QOpenGLShaderProgram::geometryOutputVertexCount() const
Returns the maximum number of vertices the current geometry shader program will produce, if active.
This parameter takes effect the ntext time the program is linked.
See also setGeometryOutputVertexCount().
bool QOpenGLShaderProgram::hasOpenGLShaderPrograms(QOpenGLContext * context = 0) [static]
Returns true if shader programs written in the OpenGL Shading Language (GLSL) are supported on this system; false otherwise.
The context is used to resolve the GLSL extensions. If context is null, then QOpenGLContext::currentContext() is used.
bool QOpenGLShaderProgram::isLinked() const
Returns true if this shader program has been linked; false otherwise.
See also link().
bool QOpenGLShaderProgram::link() [virtual]
Links together the shaders that were added to this program with addShader(). Returns true if the link was successful or false otherwise. If the link failed, the error messages can be retrieved with log().
Subclasses can override this function to initialize attributes and uniform variables for use in specific shader programs.
If the shader program was already linked, calling this function again will force it to be re-linked.
See also addShader() and log().
QString QOpenGLShaderProgram::log() const
Returns the errors and warnings that occurred during the last link() or addShader() with explicitly specified source code.
See also link().
int QOpenGLShaderProgram::maxGeometryOutputVertices() const
Returns the hardware limit for how many vertices a geometry shader can output.
See also setGeometryOutputVertexCount().
GLuint QOpenGLShaderProgram::programId() const
Returns the OpenGL identifier associated with this shader program.
See also QOpenGLShader::shaderId().
void QOpenGLShaderProgram::release()
Releases the active shader program from the current QOpenGLContext. This is equivalent to calling glUseProgram(0).
See also bind().
void QOpenGLShaderProgram::removeAllShaders()
Removes all of the shaders that were added to this program previously. The QOpenGLShader objects for the shaders will not be deleted if they were constructed externally. QOpenGLShader objects that are constructed internally by QOpenGLShaderProgram will be deleted.
See also addShader() and removeShader().
void QOpenGLShaderProgram::removeShader(QOpenGLShader * shader)
Removes shader from this shader program. The object is not deleted.
The shader program must be valid in the current QOpenGLContext.
See also addShader(), link(), and removeAllShaders().
void QOpenGLShaderProgram::setAttributeArray(int location, const GLfloat * values, int tupleSize, int stride = 0)
Sets an array of vertex values on the attribute at location in this shader program. The tupleSize indicates the number of components per vertex (1, 2, 3, or 4), and the stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in values.
The array will become active when enableAttributeArray() is called on the location. Otherwise the value specified with setAttributeValue() for location will be used.
See also setAttributeValue(), setUniformValue(), enableAttributeArray(), and disableAttributeArray().
void QOpenGLShaderProgram::setAttributeArray(int location, const QVector2D * values, int stride = 0)
Sets an array of 2D vertex values on the attribute at location in this shader program. The stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in values.
The array will become active when enableAttributeArray() is called on the location. Otherwise the value specified with setAttributeValue() for location will be used.
See also setAttributeValue(), setUniformValue(), enableAttributeArray(), and disableAttributeArray().
void QOpenGLShaderProgram::setAttributeArray(int location, const QVector3D * values, int stride = 0)
Sets an array of 3D vertex values on the attribute at location in this shader program. The stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in values.
The array will become active when enableAttributeArray() is called on the location. Otherwise the value specified with setAttributeValue() for location will be used.
See also setAttributeValue(), setUniformValue(), enableAttributeArray(), and disableAttributeArray().
void QOpenGLShaderProgram::setAttributeArray(int location, const QVector4D * values, int stride = 0)
Sets an array of 4D vertex values on the attribute at location in this shader program. The stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in values.
The array will become active when enableAttributeArray() is called on the location. Otherwise the value specified with setAttributeValue() for location will be used.
See also setAttributeValue(), setUniformValue(), enableAttributeArray(), and disableAttributeArray().
void QOpenGLShaderProgram::setAttributeArray(int location, GLenum type, const void * values, int tupleSize, int stride = 0)
Sets an array of vertex values on the attribute at location in this shader program. The stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in values.
The type indicates the type of elements in the values array, usually GL_FLOAT, GL_UNSIGNED_BYTE, etc. The tupleSize indicates the number of components per vertex: 1, 2, 3, or 4.
The array will become active when enableAttributeArray() is called on the location. Otherwise the value specified with setAttributeValue() for location will be used.
The setAttributeBuffer() function can be used to set the attribute array to an offset within a vertex buffer.
See also setAttributeValue(), setUniformValue(), enableAttributeArray(), disableAttributeArray(), and setAttributeBuffer().
void QOpenGLShaderProgram::setAttributeArray(const char * name, const GLfloat * values, int tupleSize, int stride = 0)
This is an overloaded function.
Sets an array of vertex values on the attribute called name in this shader program. The tupleSize indicates the number of components per vertex (1, 2, 3, or 4), and the stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in values.
The array will become active when enableAttributeArray() is called on name. Otherwise the value specified with setAttributeValue() for name will be used.
See also setAttributeValue(), setUniformValue(), enableAttributeArray(), and disableAttributeArray().
void QOpenGLShaderProgram::setAttributeArray(const char * name, const QVector2D * values, int stride = 0)
This is an overloaded function.
Sets an array of 2D vertex values on the attribute called name in this shader program. The stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in values.
The array will become active when enableAttributeArray() is called on name. Otherwise the value specified with setAttributeValue() for name will be used.
See also setAttributeValue(), setUniformValue(), enableAttributeArray(), and disableAttributeArray().
void QOpenGLShaderProgram::setAttributeArray(const char * name, const QVector3D * values, int stride = 0)
This is an overloaded function.
Sets an array of 3D vertex values on the attribute called name in this shader program. The stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in values.
The array will become active when enableAttributeArray() is called on name. Otherwise the value specified with setAttributeValue() for name will be used.
See also setAttributeValue(), setUniformValue(), enableAttributeArray(), and disableAttributeArray().
void QOpenGLShaderProgram::setAttributeArray(const char * name, const QVector4D * values, int stride = 0)
This is an overloaded function.
Sets an array of 4D vertex values on the attribute called name in this shader program. The stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in values.
The array will become active when enableAttributeArray() is called on name. Otherwise the value specified with setAttributeValue() for name will be used.
See also setAttributeValue(), setUniformValue(), enableAttributeArray(), and disableAttributeArray().
void QOpenGLShaderProgram::setAttributeArray(const char * name, GLenum type, const void * values, int tupleSize, int stride = 0)
This is an overloaded function.
Sets an array of vertex values on the attribute called name in this shader program. The stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in values.
The type indicates the type of elements in the values array, usually GL_FLOAT, GL_UNSIGNED_BYTE, etc. The tupleSize indicates the number of components per vertex: 1, 2, 3, or 4.
The array will become active when enableAttributeArray() is called on the name. Otherwise the value specified with setAttributeValue() for name will be used.
The setAttributeBuffer() function can be used to set the attribute array to an offset within a vertex buffer.
See also setAttributeValue(), setUniformValue(), enableAttributeArray(), disableAttributeArray(), and setAttributeBuffer().
void QOpenGLShaderProgram::setAttributeBuffer(int location, GLenum type, int offset, int tupleSize, int stride = 0)
Sets an array of vertex values on the attribute at location in this shader program, starting at a specific offset in the currently bound vertex buffer. The stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in the value array.
The type indicates the type of elements in the vertex value array, usually GL_FLOAT, GL_UNSIGNED_BYTE, etc. The tupleSize indicates the number of components per vertex: 1, 2, 3, or 4.
The array will become active when enableAttributeArray() is called on the location. Otherwise the value specified with setAttributeValue() for location will be used.
See also setAttributeArray().
void QOpenGLShaderProgram::setAttributeBuffer(const char * name, GLenum type, int offset, int tupleSize, int stride = 0)
This is an overloaded function.
Sets an array of vertex values on the attribute called name in this shader program, starting at a specific offset in the currently bound vertex buffer. The stride indicates the number of bytes between vertices. A default stride value of zero indicates that the vertices are densely packed in the value array.
The type indicates the type of elements in the vertex value array, usually GL_FLOAT, GL_UNSIGNED_BYTE, etc. The tupleSize indicates the number of components per vertex: 1, 2, 3, or 4.
The array will become active when enableAttributeArray() is called on the name. Otherwise the value specified with setAttributeValue() for name will be used.
See also setAttributeArray().
void QOpenGLShaderProgram::setAttributeValue(int location, GLfloat value)
Sets the attribute at location in the current context to value.
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(int location, GLfloat x, GLfloat y)
Sets the attribute at location in the current context to the 2D vector (x, y).
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(int location, GLfloat x, GLfloat y, GLfloat z)
Sets the attribute at location in the current context to the 3D vector (x, y, z).
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(int location, GLfloat x, GLfloat y, GLfloat z, GLfloat w)
Sets the attribute at location in the current context to the 4D vector (x, y, z, w).
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(int location, const QVector2D & value)
Sets the attribute at location in the current context to value.
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(int location, const QVector3D & value)
Sets the attribute at location in the current context to value.
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(int location, const QVector4D & value)
Sets the attribute at location in the current context to value.
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(int location, const QColor & value)
Sets the attribute at location in the current context to value.
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(int location, const GLfloat * values, int columns, int rows)
Sets the attribute at location in the current context to the contents of values, which contains columns elements, each consisting of rows elements. The rows value should be 1, 2, 3, or 4. This function is typically used to set matrix values and column vectors.
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(const char * name, GLfloat value)
This is an overloaded function.
Sets the attribute called name in the current context to value.
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(const char * name, GLfloat x, GLfloat y)
This is an overloaded function.
Sets the attribute called name in the current context to the 2D vector (x, y).
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(const char * name, GLfloat x, GLfloat y, GLfloat z)
This is an overloaded function.
Sets the attribute called name in the current context to the 3D vector (x, y, z).
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(const char * name, GLfloat x, GLfloat y, GLfloat z, GLfloat w)
This is an overloaded function.
Sets the attribute called name in the current context to the 4D vector (x, y, z, w).
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(const char * name, const QVector2D & value)
This is an overloaded function.
Sets the attribute called name in the current context to value.
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(const char * name, const QVector3D & value)
This is an overloaded function.
Sets the attribute called name in the current context to value.
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(const char * name, const QVector4D & value)
This is an overloaded function.
Sets the attribute called name in the current context to value.
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(const char * name, const QColor & value)
This is an overloaded function.
Sets the attribute called name in the current context to value.
See also setUniformValue().
void QOpenGLShaderProgram::setAttributeValue(const char * name, const GLfloat * values, int columns, int rows)
This is an overloaded function.
Sets the attribute called name in the current context to the contents of values, which contains columns elements, each consisting of rows elements. The rows value should be 1, 2, 3, or 4. This function is typically used to set matrix values and column vectors.
See also setUniformValue().
void QOpenGLShaderProgram::setGeometryInputType(GLenum inputType)
Sets the input type from inputType.
This parameter takes effect the next time the program is linked.
See also geometryInputType().
void QOpenGLShaderProgram::setGeometryOutputType(GLenum outputType)
Sets the output type from the geometry shader, if active, to outputType.
This parameter takes effect the next time the program is linked.
See also geometryOutputType().
void QOpenGLShaderProgram::setGeometryOutputVertexCount(int count)
Sets the maximum number of vertices the current geometry shader program will produce, if active, to count.
This parameter takes effect the next time the program is linked.
See also geometryOutputVertexCount().
void QOpenGLShaderProgram::setUniformValue(int location, GLfloat value)
Sets the uniform variable at location in the current context to value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QPointF & point)
This is an overloaded function.
Sets the uniform variable associated with name in the current context to the x and y coordinates of point.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QSize & size)
This is an overloaded function.
Sets the uniform variable associated with name in the current context to the width and height of the given size.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QSizeF & size)
This is an overloaded function.
Sets the uniform variable associated with name in the current context to the width and height of the given size.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QMatrix2x2 & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 2x2 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QMatrix2x3 & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 2x3 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QMatrix2x4 & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 2x4 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QMatrix3x2 & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 3x2 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QMatrix3x3 & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 3x3 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QMatrix3x4 & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 3x4 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QMatrix4x2 & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 4x2 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QMatrix4x3 & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 4x3 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QMatrix4x4 & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 4x4 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const GLfloat[2][2] value)
This is an overloaded function.
Sets the uniform variable at location in the current context to a 2x2 matrix value. The matrix elements must be specified in column-major order.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const GLfloat[3][3] value)
This is an overloaded function.
Sets the uniform variable at location in the current context to a 3x3 matrix value. The matrix elements must be specified in column-major order.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const GLfloat[4][4] value)
This is an overloaded function.
Sets the uniform variable at location in the current context to a 4x4 matrix value. The matrix elements must be specified in column-major order.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const GLfloat[2][2] value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 2x2 matrix value. The matrix elements must be specified in column-major order.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const GLfloat[3][3] value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 3x3 matrix value. The matrix elements must be specified in column-major order.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const GLfloat[4][4] value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 4x4 matrix value. The matrix elements must be specified in column-major order.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QTransform & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to a 3x3 transformation matrix value that is specified as a QTransform value.
To set a QTransform value as a 4x4 matrix in a shader, use setUniformValue(name, QMatrix4x4(value)).
void QOpenGLShaderProgram::setUniformValue(int location, GLint value)
Sets the uniform variable at location in the current context to value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, GLuint value)
Sets the uniform variable at location in the current context to value. This function should be used when setting sampler values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, GLfloat x, GLfloat y)
Sets the uniform variable at location in the current context to the 2D vector (x, y).
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, GLfloat x, GLfloat y, GLfloat z)
Sets the uniform variable at location in the current context to the 3D vector (x, y, z).
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, GLfloat x, GLfloat y, GLfloat z, GLfloat w)
Sets the uniform variable at location in the current context to the 4D vector (x, y, z, w).
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QVector2D & value)
Sets the uniform variable at location in the current context to value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QVector3D & value)
Sets the uniform variable at location in the current context to value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QVector4D & value)
Sets the uniform variable at location in the current context to value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QColor & color)
Sets the uniform variable at location in the current context to the red, green, blue, and alpha components of color.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QPoint & point)
Sets the uniform variable at location in the current context to the x and y coordinates of point.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QPointF & point)
Sets the uniform variable at location in the current context to the x and y coordinates of point.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QSize & size)
Sets the uniform variable at location in the current context to the width and height of the given size.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QSizeF & size)
Sets the uniform variable at location in the current context to the width and height of the given size.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QMatrix2x2 & value)
Sets the uniform variable at location in the current context to a 2x2 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QMatrix2x3 & value)
Sets the uniform variable at location in the current context to a 2x3 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QMatrix2x4 & value)
Sets the uniform variable at location in the current context to a 2x4 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QMatrix3x2 & value)
Sets the uniform variable at location in the current context to a 3x2 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QMatrix3x3 & value)
Sets the uniform variable at location in the current context to a 3x3 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QMatrix3x4 & value)
Sets the uniform variable at location in the current context to a 3x4 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QMatrix4x2 & value)
Sets the uniform variable at location in the current context to a 4x2 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QMatrix4x3 & value)
Sets the uniform variable at location in the current context to a 4x3 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QMatrix4x4 & value)
Sets the uniform variable at location in the current context to a 4x4 matrix value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(int location, const QTransform & value)
Sets the uniform variable at location in the current context to a 3x3 transformation matrix value that is specified as a QTransform value.
To set a QTransform value as a 4x4 matrix in a shader, use setUniformValue(location, QMatrix4x4(value)).
void QOpenGLShaderProgram::setUniformValue(const char * name, GLfloat value)
This is an overloaded function.
Sets the uniform variable called name in the current context to value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, GLint value)
This is an overloaded function.
Sets the uniform variable called name in the current context to value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, GLuint value)
This is an overloaded function.
Sets the uniform variable called name in the current context to value. This function should be used when setting sampler values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, GLfloat x, GLfloat y)
This is an overloaded function.
Sets the uniform variable called name in the current context to the 2D vector (x, y).
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, GLfloat x, GLfloat y, GLfloat z)
This is an overloaded function.
Sets the uniform variable called name in the current context to the 3D vector (x, y, z).
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, GLfloat x, GLfloat y, GLfloat z, GLfloat w)
This is an overloaded function.
Sets the uniform variable called name in the current context to the 4D vector (x, y, z, w).
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QVector2D & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QVector3D & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QVector4D & value)
This is an overloaded function.
Sets the uniform variable called name in the current context to value.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QColor & color)
This is an overloaded function.
Sets the uniform variable called name in the current context to the red, green, blue, and alpha components of color.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValue(const char * name, const QPoint & point)
This is an overloaded function.
Sets the uniform variable associated with name in the current context to the x and y coordinates of point.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const GLfloat * values, int count, int tupleSize)
Sets the uniform variable array at location in the current context to the count elements of values. Each element has tupleSize components. The tupleSize must be 1, 2, 3, or 4.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const GLint * values, int count)
Sets the uniform variable array at location in the current context to the count elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const GLuint * values, int count)
Sets the uniform variable array at location in the current context to the count elements of values. This overload should be used when setting an array of sampler values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QVector2D * values, int count)
Sets the uniform variable array at location in the current context to the count 2D vector elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QVector3D * values, int count)
Sets the uniform variable array at location in the current context to the count 3D vector elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QVector4D * values, int count)
Sets the uniform variable array at location in the current context to the count 4D vector elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QMatrix2x2 * values, int count)
Sets the uniform variable array at location in the current context to the count 2x2 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QMatrix2x3 * values, int count)
Sets the uniform variable array at location in the current context to the count 2x3 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QMatrix2x4 * values, int count)
Sets the uniform variable array at location in the current context to the count 2x4 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QMatrix3x2 * values, int count)
Sets the uniform variable array at location in the current context to the count 3x2 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QMatrix3x3 * values, int count)
Sets the uniform variable array at location in the current context to the count 3x3 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QMatrix3x4 * values, int count)
Sets the uniform variable array at location in the current context to the count 3x4 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QMatrix4x2 * values, int count)
Sets the uniform variable array at location in the current context to the count 4x2 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QMatrix4x3 * values, int count)
Sets the uniform variable array at location in the current context to the count 4x3 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(int location, const QMatrix4x4 * values, int count)
Sets the uniform variable array at location in the current context to the count 4x4 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const GLint * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const GLuint * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count elements of values. This overload should be used when setting an array of sampler values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const GLfloat * values, int count, int tupleSize)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count elements of values. Each element has tupleSize components. The tupleSize must be 1, 2, 3, or 4.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QVector2D * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 2D vector elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QVector3D * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 3D vector elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QVector4D * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 4D vector elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QMatrix2x2 * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 2x2 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QMatrix2x3 * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 2x3 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QMatrix2x4 * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 2x4 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QMatrix3x2 * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 3x2 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QMatrix3x3 * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 3x3 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QMatrix3x4 * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 3x4 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QMatrix4x2 * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 4x2 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QMatrix4x3 * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 4x3 matrix elements of values.
See also setAttributeValue().
void QOpenGLShaderProgram::setUniformValueArray(const char * name, const QMatrix4x4 * values, int count)
This is an overloaded function.
Sets the uniform variable array called name in the current context to the count 4x4 matrix elements of values.
See also setAttributeValue().
QList<QOpenGLShader *> QOpenGLShaderProgram::shaders() const
Returns a list of all shaders that have been added to this shader program using addShader().
See also addShader() and removeShader().
int QOpenGLShaderProgram::uniformLocation(const char * name) const
Returns the location of the uniform variable name within this shader program's parameter list. Returns -1 if name is not a valid uniform variable for this shader program.
See also attributeLocation().
int QOpenGLShaderProgram::uniformLocation(const QByteArray & name) const
This is an overloaded function.
Returns the location of the uniform variable name within this shader program's parameter list. Returns -1 if name is not a valid uniform variable for this shader program.
See also attributeLocation().
int QOpenGLShaderProgram::uniformLocation(const QString & name) const
This is an overloaded function.
Returns the location of the uniform variable name within this shader program's parameter list. Returns -1 if name is not a valid uniform variable for this shader program.
See also attributeLocation().