QOpenGLShaderProgram¶
The QOpenGLShaderProgram
class allows OpenGL shader programs to be linked and used. More…
New in version 5.0.
Synopsis¶
Functions¶
def
addCacheableShaderFromSourceCode
(type, source)def
addCacheableShaderFromSourceCode
(type, source)def
addCacheableShaderFromSourceCode
(type, source)def
addCacheableShaderFromSourceFile
(type, fileName)def
addShader
(shader)def
addShaderFromSourceCode
(type, source)def
addShaderFromSourceCode
(type, source)def
addShaderFromSourceCode
(type, source)def
addShaderFromSourceFile
(type, fileName)def
attributeLocation
(name)def
attributeLocation
(name)def
attributeLocation
(name)def
bind
()def
bindAttributeLocation
(name, location)def
bindAttributeLocation
(name, location)def
bindAttributeLocation
(name, location)def
create
()def
disableAttributeArray
(location)def
disableAttributeArray
(name)def
enableAttributeArray
(location)def
enableAttributeArray
(name)def
isLinked
()def
log
()def
maxGeometryOutputVertices
()def
patchVertexCount
()def
programId
()def
release
()def
removeAllShaders
()def
removeShader
(shader)def
setAttributeArray
(location, type, values, tupleSize[, stride=0])def
setAttributeArray
(location, values, tupleSize[, stride=0])def
setAttributeArray
(name, type, values, tupleSize[, stride=0])def
setAttributeArray
(name, values, tupleSize[, stride=0])def
setAttributeBuffer
(location, type, offset, tupleSize[, stride=0])def
setAttributeBuffer
(name, type, offset, tupleSize[, stride=0])def
setAttributeValue
(location, value)def
setAttributeValue
(location, value)def
setAttributeValue
(location, value)def
setAttributeValue
(location, value)def
setAttributeValue
(location, value)def
setAttributeValue
(location, values, columns, rows)def
setAttributeValue
(location, x, y)def
setAttributeValue
(location, x, y, z)def
setAttributeValue
(location, x, y, z, w)def
setAttributeValue
(name, value)def
setAttributeValue
(name, value)def
setAttributeValue
(name, value)def
setAttributeValue
(name, value)def
setAttributeValue
(name, value)def
setAttributeValue
(name, values, columns, rows)def
setAttributeValue
(name, x, y)def
setAttributeValue
(name, x, y, z)def
setAttributeValue
(name, x, y, z, w)def
setDefaultInnerTessellationLevels
(levels)def
setDefaultOuterTessellationLevels
(levels)def
setPatchVertexCount
(count)def
setUniformValue1f
(arg__1, arg__2)def
setUniformValue1f
(arg__1, arg__2)def
setUniformValue1i
(arg__1, arg__2)def
setUniformValue1i
(arg__1, arg__2)def
setUniformValue
(location, color)def
setUniformValue
(location, point)def
setUniformValue
(location, point)def
setUniformValue
(location, size)def
setUniformValue
(location, size)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, value)def
setUniformValue
(location, x, y)def
setUniformValue
(location, x, y, z)def
setUniformValue
(location, x, y, z, w)def
setUniformValue
(name, color)def
setUniformValue
(name, point)def
setUniformValue
(name, point)def
setUniformValue
(name, size)def
setUniformValue
(name, size)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, value)def
setUniformValue
(name, x, y)def
setUniformValue
(name, x, y, z)def
setUniformValue
(name, x, y, z, w)def
setUniformValueArray
(location, values, count)def
setUniformValueArray
(location, values, count)def
setUniformValueArray
(location, values, count, tupleSize)def
setUniformValueArray
(name, values, count)def
setUniformValueArray
(name, values, count)def
setUniformValueArray
(name, values, count, tupleSize)def
shaders
()def
uniformLocation
(name)def
uniformLocation
(name)def
uniformLocation
(name)
Virtual functions¶
def
link
()
Static functions¶
def
hasOpenGLShaderPrograms
([context=None])
Detailed Description¶
Introduction¶
This class supports shader programs written in the OpenGL Shading Language (GLSL) and in the OpenGL/ES Shading Language (GLSL/ES).
QOpenGLShader
and QOpenGLShaderProgram
shelter the programmer from the details of compiling and linking vertex and fragment shaders.
The following example creates a vertex shader program using the supplied source code
. Once compiled and linked, the shader program is activated in the current QOpenGLContext
by calling bind()
:
shader = QOpenGLShader(QOpenGLShader.Vertex) shader.compileSourceCode(code) program = QOpenGLShaderProgram(context) program.addShader(shader) program.link() program.bind()
Writing Portable Shaders¶
Shader programs can be difficult to reuse across OpenGL implementations because of varying levels of support for standard vertex attributes and uniform variables. In particular, GLSL/ES lacks all of the standard variables that are present on desktop OpenGL systems: gl_Vertex
, gl_Normal
, gl_Color
, and so on. Desktop OpenGL lacks the variable qualifiers highp
, mediump
, and lowp
.
The QOpenGLShaderProgram
class makes the process of writing portable shaders easier by prefixing all shader programs with the following lines on desktop OpenGL:
#define highp #define mediump #define lowp
This makes it possible to run most GLSL/ES shader programs on desktop systems. The programmer should restrict themselves to just features that are present in GLSL/ES, and avoid standard variable names that only work on the desktop.
Simple Shader Example¶
program.addShaderFromSourceCode(QOpenGLShader.Vertex, "attribute highp vec4 vertex;\n" "uniform highp mat4 matrix;\n" "void main(void)\n" "{\n" " gl_Position = matrix * vertex;\n" "}") program.addShaderFromSourceCode(QOpenGLShader.Fragment, "uniform mediump vec4 color;\n" "void main(void)\n" "{\n" " gl_FragColor = color;\n" "}") program.link() program.bind() vertexLocation = program.attributeLocation("vertex") matrixLocation = program.uniformLocation("matrix") colorLocation = program.uniformLocation("color")
With the above shader program active, we can draw a green triangle as follows:
triangleVertices = { 60.0f, 10.0f, 0.0f, 110.0f, 110.0f, 0.0f, 10.0f, 110.0f, 0.0f color = QColor(0, 255, 0, 255) pmvMatrix = QMatrix4x4() pmvMatrix.ortho(rect()) program.enableAttributeArray(vertexLocation) program.setAttributeArray(vertexLocation, triangleVertices, 3) program.setUniformValue(matrixLocation, pmvMatrix) program.setUniformValue(colorLocation, color) glDrawArrays(GL_TRIANGLES, 0, 3) program.disableAttributeArray(vertexLocation)
Binary Shaders and Programs¶
Binary shaders may be specified using glShaderBinary()
on the return value from shaderId()
. The QOpenGLShader
instance containing the binary can then be added to the shader program with addShader()
and linked in the usual fashion with link()
.
Binary programs may be specified using glProgramBinaryOES()
on the return value from programId()
. Then the application should call link()
, which will notice that the program has already been specified and linked, allowing other operations to be performed on the shader program. The shader program’s id can be explicitly created using the create()
function.
Caching Program Binaries¶
As of Qt 5.9, support for caching program binaries on disk is built in. To enable this, switch to using addCacheableShaderFromSourceCode()
and addCacheableShaderFromSourceFile()
. With an OpenGL ES 3.x context or support for GL_ARB_get_program_binary
, this will transparently cache program binaries under GenericCacheLocation
or CacheLocation
. When support is not available, calling the cacheable function variants is equivalent to the normal ones.
Note
Some drivers do not have any binary formats available, even though they advertise the extension or offer OpenGL ES 3.0. In this case program binary support will be disabled.
See also
- class PySide6.QtOpenGL.QOpenGLShaderProgram([parent=None])¶
- Parameters
parent –
PySide6.QtCore.QObject
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.addCacheableShaderFromSourceCode(type, source)¶
- Parameters
type –
ShaderType
source –
PySide6.QtCore.QByteArray
- Return type
bool
This is an overloaded function.
Registers the shader of the specified type
and source
to this program. Unlike addShaderFromSourceCode()
, this function does not perform compilation. Compilation is deferred to link()
, and may not happen at all, because link()
may potentially use a program binary from Qt’s shader disk cache. This will typically lead to a significant increase in performance.
Returns true if the shader has been registered or, in the non-cached case, compiled successfully; false if there was an error. The compilation error messages can be retrieved via log()
.
When the disk cache is disabled, via AA_DisableShaderDiskCache
for example, or the OpenGL context has no support for context binaries, calling this function is equivalent to addShaderFromSourceCode()
.
- PySide6.QtOpenGL.QOpenGLShaderProgram.addCacheableShaderFromSourceCode(type, source)
- Parameters
type –
ShaderType
source – str
- Return type
bool
Registers the shader of the specified type
and source
to this program. Unlike addShaderFromSourceCode()
, this function does not perform compilation. Compilation is deferred to link()
, and may not happen at all, because link()
may potentially use a program binary from Qt’s shader disk cache. This will typically lead to a significant increase in performance.
Returns true if the shader has been registered or, in the non-cached case, compiled successfully; false if there was an error. The compilation error messages can be retrieved via log()
.
When the disk cache is disabled, via AA_DisableShaderDiskCache
for example, or the OpenGL context has no support for context binaries, calling this function is equivalent to addShaderFromSourceCode()
.
- PySide6.QtOpenGL.QOpenGLShaderProgram.addCacheableShaderFromSourceCode(type, source)
- Parameters
type –
ShaderType
source – str
- Return type
bool
This is an overloaded function.
Registers the shader of the specified type
and source
to this program. Unlike addShaderFromSourceCode()
, this function does not perform compilation. Compilation is deferred to link()
, and may not happen at all, because link()
may potentially use a program binary from Qt’s shader disk cache. This will typically lead to a significant increase in performance.
When the disk cache is disabled, via AA_DisableShaderDiskCache
for example, or the OpenGL context has no support for context binaries, calling this function is equivalent to addShaderFromSourceCode()
.
- PySide6.QtOpenGL.QOpenGLShaderProgram.addCacheableShaderFromSourceFile(type, fileName)¶
- Parameters
type –
ShaderType
fileName – str
- Return type
bool
Registers the shader of the specified type
and fileName
to this program. Unlike addShaderFromSourceFile()
, this function does not perform compilation. Compilation is deferred to link()
, and may not happen at all, because link()
may potentially use a program binary from Qt’s shader disk cache. This will typically lead to a significant increase in performance.
Returns true if the file has been read successfully, false if the file could not be opened or the normal, non-cached compilation of the shader has failed. The compilation error messages can be retrieved via log()
.
When the disk cache is disabled, via AA_DisableShaderDiskCache
for example, or the OpenGL context has no support for context binaries, calling this function is equivalent to addShaderFromSourceFile()
.
- PySide6.QtOpenGL.QOpenGLShaderProgram.addShader(shader)¶
- Parameters
shader –
PySide6.QtOpenGL.QOpenGLShader
- Return type
bool
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.
- PySide6.QtOpenGL.QOpenGLShaderProgram.addShaderFromSourceCode(type, source)¶
- Parameters
type –
ShaderType
source –
PySide6.QtCore.QByteArray
- Return type
bool
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.
- PySide6.QtOpenGL.QOpenGLShaderProgram.addShaderFromSourceCode(type, source)
- Parameters
type –
ShaderType
source – str
- Return type
bool
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.
- PySide6.QtOpenGL.QOpenGLShaderProgram.addShaderFromSourceCode(type, source)
- Parameters
type –
ShaderType
source – str
- Return type
bool
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.
- PySide6.QtOpenGL.QOpenGLShaderProgram.addShaderFromSourceFile(type, fileName)¶
- Parameters
type –
ShaderType
fileName – str
- Return type
bool
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.attributeLocation(name)¶
- Parameters
name –
PySide6.QtCore.QByteArray
- Return type
int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.attributeLocation(name)
- Parameters
name – str
- Return type
int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.attributeLocation(name)
- Parameters
name – str
- Return type
int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.bind()¶
- Return type
bool
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()
.
- PySide6.QtOpenGL.QOpenGLShaderProgram.bindAttributeLocation(name, location)¶
- Parameters
name –
PySide6.QtCore.QByteArray
location – int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.bindAttributeLocation(name, location)
- Parameters
name – str
location – int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.bindAttributeLocation(name, location)
- Parameters
name – str
location – int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.create()¶
- Return type
bool
Requests the shader program’s id to be created immediately. Returns true
if successful; false
otherwise.
This function is primarily useful when combining QOpenGLShaderProgram
with other OpenGL functions that operate directly on the shader program id, like GL_OES_get_program_binary
.
When the shader program is used normally, the shader program’s id will be created on demand.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.defaultInnerTessellationLevels()¶
- Return type
Returns the default inner tessellation levels to be used by the tessellation primitive generator in the event that the tessellation control shader does not output them. For more details on OpenGL and Tessellation shaders see OpenGL Tessellation Shaders .
Returns a QList
of floats describing the inner tessellation levels. The vector will always have two elements but not all of them make sense for every mode of tessellation.
Note
This returns the global OpenGL state value. It is not specific to this QOpenGLShaderProgram
instance.
Note
This function is only supported with OpenGL >= 4.0 and will not return valid results with OpenGL ES 3.2.
- PySide6.QtOpenGL.QOpenGLShaderProgram.defaultOuterTessellationLevels()¶
- Return type
Returns the default outer tessellation levels to be used by the tessellation primitive generator in the event that the tessellation control shader does not output them. For more details on OpenGL and Tessellation shaders see OpenGL Tessellation Shaders .
Returns a QList
of floats describing the outer tessellation levels. The vector will always have four elements but not all of them make sense for every mode of tessellation.
Note
This returns the global OpenGL state value. It is not specific to this QOpenGLShaderProgram
instance.
Note
This function is only supported with OpenGL >= 4.0 and will not return valid results with OpenGL ES 3.2.
- PySide6.QtOpenGL.QOpenGLShaderProgram.disableAttributeArray(name)¶
- Parameters
name – str
This is an overloaded function.
Disables the vertex array called name
in this shader program that was enabled by a previous call to enableAttributeArray()
.
- PySide6.QtOpenGL.QOpenGLShaderProgram.disableAttributeArray(location)
- Parameters
location – int
Disables the vertex array at location
in this shader program that was enabled by a previous call to enableAttributeArray()
.
- PySide6.QtOpenGL.QOpenGLShaderProgram.enableAttributeArray(name)¶
- Parameters
name – str
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.
- PySide6.QtOpenGL.QOpenGLShaderProgram.enableAttributeArray(location)
- Parameters
location – int
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.
- static PySide6.QtOpenGL.QOpenGLShaderProgram.hasOpenGLShaderPrograms([context=None])¶
- Parameters
context –
PySide6.QtGui.QOpenGLContext
- Return type
bool
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 None
, then currentContext()
is used.
- PySide6.QtOpenGL.QOpenGLShaderProgram.isLinked()¶
- Return type
bool
Returns true
if this shader program has been linked; false otherwise.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.link()¶
- Return type
bool
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.
When shaders were added to this program via addCacheableShaderFromSourceCode()
or addCacheableShaderFromSourceFile()
, program binaries are supported, and a cached binary is available on disk, actual compilation and linking are skipped. Instead, will initialize the program with the binary blob via glProgramBinary(). If there is no cached version of the program or it was generated with a different driver version, the shaders will be compiled from source and the program will get linked normally. This allows seamless upgrading of the graphics drivers, without having to worry about potentially incompatible binary formats.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.log()¶
- Return type
str
Returns the errors and warnings that occurred during the last link()
or addShader()
with explicitly specified source code.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.maxGeometryOutputVertices()¶
- Return type
int
Returns the hardware limit for how many vertices a geometry shader can output.
- PySide6.QtOpenGL.QOpenGLShaderProgram.patchVertexCount()¶
- Return type
int
Returns the number of vertices per-patch to be used when rendering.
Note
This returns the global OpenGL state value. It is not specific to this QOpenGLShaderProgram
instance.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.programId()¶
- Return type
int
Returns the OpenGL identifier associated with this shader program.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.release()¶
Releases the active shader program from the current QOpenGLContext
. This is equivalent to calling glUseProgram(0)
.
See also
- PySide6.QtOpenGL.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
- PySide6.QtOpenGL.QOpenGLShaderProgram.removeShader(shader)¶
- Parameters
shader –
PySide6.QtOpenGL.QOpenGLShader
Removes shader
from this shader program. The object is not deleted.
The shader program must be valid in the current QOpenGLContext
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeArray(name, values, tupleSize[, stride=0])¶
- Parameters
name – str
values – float
tupleSize – int
stride – int
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.
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeArray(name, type, values, tupleSize[, stride=0])
- Parameters
name – str
type – int
values –
void
tupleSize – int
stride – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeArray(location, values, tupleSize[, stride=0])
- Parameters
location – int
values – float
tupleSize – int
stride – int
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.
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeArray(location, type, values, tupleSize[, stride=0])
- Parameters
location – int
type – int
values –
void
tupleSize – int
stride – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeBuffer(location, type, offset, tupleSize[, stride=0])¶
- Parameters
location – int
type – int
offset – int
tupleSize – int
stride – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeBuffer(name, type, offset, tupleSize[, stride=0])
- Parameters
name – str
type – int
offset – int
tupleSize – int
stride – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(location, x, y, z, w)¶
- Parameters
location – int
x – float
y – float
z – float
w – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(location, x, y, z)
- Parameters
location – int
x – float
y – float
z – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(location, x, y)
- Parameters
location – int
x – float
y – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(location, value)
- Parameters
location – int
value – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(location, values, columns, rows)
- Parameters
location – int
values – float
columns – int
rows – int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QVector4D
Sets the attribute at location
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QVector3D
Sets the attribute at location
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QVector2D
Sets the attribute at location
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QColor
Sets the attribute at location
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(name, x, y, z)
- Parameters
name – str
x – float
y – float
z – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(name, x, y)
- Parameters
name – str
x – float
y – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(name, value)
- Parameters
name – str
value – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(name, values, columns, rows)
- Parameters
name – str
values – float
columns – int
rows – int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QVector4D
This is an overloaded function.
Sets the attribute called name
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QVector3D
This is an overloaded function.
Sets the attribute called name
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QVector2D
This is an overloaded function.
Sets the attribute called name
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QColor
This is an overloaded function.
Sets the attribute called name
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setAttributeValue(name, x, y, z, w)
- Parameters
name – str
x – float
y – float
z – float
w – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setDefaultInnerTessellationLevels(levels)¶
- Parameters
levels –
Sets the default outer tessellation levels to be used by the tessellation primitive generator in the event that the tessellation control shader does not output them to levels
. For more details on OpenGL and Tessellation shaders see OpenGL Tessellation Shaders .
The levels
argument should be a QList
consisting of 2 floats. Not all of the values make sense for all tessellation modes. If you specify a vector with fewer than 2 elements, the remaining elements will be given a default value of 1.
Note
This modifies global OpenGL state and is not specific to this QOpenGLShaderProgram
instance. You should call this in your render function when needed, as QOpenGLShaderProgram
will not apply this for you. This is purely a convenience function.
Note
This function is only available with OpenGL >= 4.0 and is not supported with OpenGL ES 3.2.
- PySide6.QtOpenGL.QOpenGLShaderProgram.setDefaultOuterTessellationLevels(levels)¶
- Parameters
levels –
Sets the default outer tessellation levels to be used by the tessellation primitive generator in the event that the tessellation control shader does not output them to levels
. For more details on OpenGL and Tessellation shaders see OpenGL Tessellation Shaders .
The levels
argument should be a QList
consisting of 4 floats. Not all of the values make sense for all tessellation modes. If you specify a vector with fewer than 4 elements, the remaining elements will be given a default value of 1.
Note
This modifies global OpenGL state and is not specific to this QOpenGLShaderProgram
instance. You should call this in your render function when needed, as QOpenGLShaderProgram
will not apply this for you. This is purely a convenience function.
Note
This function is only available with OpenGL >= 4.0 and is not supported with OpenGL ES 3.2.
- PySide6.QtOpenGL.QOpenGLShaderProgram.setPatchVertexCount(count)¶
- Parameters
count – int
Use this function to specify to OpenGL the number of vertices in a patch to count
. A patch is a custom OpenGL primitive whose interpretation is entirely defined by the tessellation shader stages. Therefore, calling this function only makes sense when using a QOpenGLShaderProgram
containing tessellation stage shaders. When using OpenGL tessellation, the only primitive that can be rendered with glDraw*()
functions is GL_PATCHES
.
This is equivalent to calling glPatchParameteri(GL_PATCH_VERTICES, count).
Note
This modifies global OpenGL state and is not specific to this QOpenGLShaderProgram
instance. You should call this in your render function when needed, as QOpenGLShaderProgram
will not apply this for you. This is purely a convenience function.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)¶
- Parameters
location – int
value –
PySide6.QtGui.QMatrix2x3
Sets the uniform variable at location
in the current context to a 2x3 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat2x3, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec3.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QMatrix2x2
Sets the uniform variable at location
in the current context to a 2x2 matrix value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, color)
- Parameters
location – int
color –
PySide6.QtGui.QColor
Sets the uniform variable at location
in the current context to the red, green, blue, and alpha components of color
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QMatrix2x4
Sets the uniform variable at location
in the current context to a 2x4 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat2x4, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec4.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QMatrix3x2
Sets the uniform variable at location
in the current context to a 3x2 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat3x2, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec2.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QMatrix3x3
Sets the uniform variable at location
in the current context to a 3x3 matrix value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QMatrix3x4
Sets the uniform variable at location
in the current context to a 3x4 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat3x4, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec4.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QMatrix4x2
Sets the uniform variable at location
in the current context to a 4x2 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat4x2, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec2.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QMatrix4x3
Sets the uniform variable at location
in the current context to a 4x3 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat4x3, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec3.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QMatrix4x4
Sets the uniform variable at location
in the current context to a 4x4 matrix value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, point)
- Parameters
location – int
point –
PySide6.QtCore.QPoint
Sets the uniform variable at location
in the current context to the x and y coordinates of point
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, point)
- Parameters
location – int
point –
PySide6.QtCore.QPointF
Sets the uniform variable at location
in the current context to the x and y coordinates of point
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, size)
- Parameters
location – int
size –
PySide6.QtCore.QSize
Sets the uniform variable at location
in the current context to the width and height of the given size
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, size)
- Parameters
location – int
size –
PySide6.QtCore.QSizeF
Sets the uniform variable at location
in the current context to the width and height of the given size
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QTransform
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))
.
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QVector2D
Sets the uniform variable at location
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QVector3D
Sets the uniform variable at location
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
PySide6.QtGui.QVector4D
Sets the uniform variable at location
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
float[][]
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
float[][]
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value –
float[][]
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, x, y)
- Parameters
location – int
x – float
y – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, x, y, z)
- Parameters
location – int
x – float
y – float
z – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, x, y, z, w)
- Parameters
location – int
x – float
y – float
z – float
w – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(location, value)
- Parameters
location – int
value – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, color)
- Parameters
name – str
color –
PySide6.QtGui.QColor
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QMatrix2x2
This is an overloaded function.
Sets the uniform variable called name
in the current context to a 2x2 matrix value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QMatrix2x3
This is an overloaded function.
Sets the uniform variable called name
in the current context to a 2x3 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat2x3, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec3.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QMatrix2x4
This is an overloaded function.
Sets the uniform variable called name
in the current context to a 2x4 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat2x4, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec4.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QMatrix3x2
This is an overloaded function.
Sets the uniform variable called name
in the current context to a 3x2 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat3x2, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec2.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QMatrix3x3
This is an overloaded function.
Sets the uniform variable called name
in the current context to a 3x3 matrix value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QMatrix3x4
This is an overloaded function.
Sets the uniform variable called name
in the current context to a 3x4 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat3x4, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec4.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QMatrix4x2
This is an overloaded function.
Sets the uniform variable called name
in the current context to a 4x2 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat4x2, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec2.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QMatrix4x3
This is an overloaded function.
Sets the uniform variable called name
in the current context to a 4x3 matrix value
.
Note
This function is not aware of non square matrix support, that is, GLSL types like mat4x3, that is present in modern OpenGL versions. Instead, it treats the uniform as an array of vec3.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QMatrix4x4
This is an overloaded function.
Sets the uniform variable called name
in the current context to a 4x4 matrix value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, point)
- Parameters
name – str
point –
PySide6.QtCore.QPoint
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, point)
- Parameters
name – str
point –
PySide6.QtCore.QPointF
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, size)
- Parameters
name – str
size –
PySide6.QtCore.QSize
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QTransform
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))
.
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QVector2D
This is an overloaded function.
Sets the uniform variable called name
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QVector3D
This is an overloaded function.
Sets the uniform variable called name
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
PySide6.QtGui.QVector4D
This is an overloaded function.
Sets the uniform variable called name
in the current context to value
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
float[][]
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
float[][]
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, value)
- Parameters
name – str
value –
float[][]
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, x, y)
- Parameters
name – str
x – float
y – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, x, y, z)
- Parameters
name – str
x – float
y – float
z – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, x, y, z, w)
- Parameters
name – str
x – float
y – float
z – float
w – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue(name, size)
- Parameters
name – str
size –
PySide6.QtCore.QSizeF
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue1f(arg__1, arg__2)¶
- Parameters
arg__1 – str
arg__2 – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue1f(arg__1, arg__2)
- Parameters
arg__1 – int
arg__2 – float
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue1i(arg__1, arg__2)¶
- Parameters
arg__1 – int
arg__2 – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValue1i(arg__1, arg__2)
- Parameters
arg__1 – str
arg__2 – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValueArray(name, values, count, tupleSize)¶
- Parameters
name – str
values – float
count – int
tupleSize – int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValueArray(name, values, count)
- Parameters
name – str
values – int
count – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValueArray(name, values, count)
- Parameters
name – str
values – int
count – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValueArray(location, values, count, tupleSize)
- Parameters
location – int
values – float
count – int
tupleSize – int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValueArray(location, values, count)
- Parameters
location – int
values – int
count – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.setUniformValueArray(location, values, count)
- Parameters
location – int
values – int
count – int
- PySide6.QtOpenGL.QOpenGLShaderProgram.shaders()¶
- Return type
Returns a list of all shaders that have been added to this shader program using addShader()
.
See also
- PySide6.QtOpenGL.QOpenGLShaderProgram.uniformLocation(name)¶
- Parameters
name –
PySide6.QtCore.QByteArray
- Return type
int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.uniformLocation(name)
- Parameters
name – str
- Return type
int
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
- PySide6.QtOpenGL.QOpenGLShaderProgram.uniformLocation(name)
- Parameters
name – str
- Return type
int
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
© 2022 The Qt Company Ltd. Documentation contributions included herein are the copyrights of their respective owners. The documentation provided herein is licensed under the terms of the GNU Free Documentation License version 1.3 as published by the Free Software Foundation. Qt and respective logos are trademarks of The Qt Company Ltd. in Finland and/or other countries worldwide. All other trademarks are property of their respective owners.