Don't use GL Matrix Stack on OpenGL 2 backend
Currently the GL Matrix Stack is also used with OpenGL 2. That is pushMatrix, multMatrix and popMatrix are executed although this does not influence the rendering at all. The OpenGL 1 matrices are not passed to the shaders. With this change the calls to the matrix stack are no longer executed if the Shader based backend is used. This means we have a few less matrix multiplications in the rendering. Mostly affects a few effects which have not yet completely be ported over to OpenGL 2. BUG: 303093 FIXED-IN: 4.10 REVIEW: 105455
This commit is contained in:
parent
b734c03346
commit
f775229a80
1 changed files with 12 additions and 0 deletions
|
@ -191,6 +191,9 @@ int nearestPowerOfTwo(int x)
|
||||||
void pushMatrix()
|
void pushMatrix()
|
||||||
{
|
{
|
||||||
#ifndef KWIN_HAVE_OPENGLES
|
#ifndef KWIN_HAVE_OPENGLES
|
||||||
|
if (ShaderManager::instance()->isValid()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
glPushMatrix();
|
glPushMatrix();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
@ -200,6 +203,9 @@ void pushMatrix(const QMatrix4x4 &matrix)
|
||||||
#ifdef KWIN_HAVE_OPENGLES
|
#ifdef KWIN_HAVE_OPENGLES
|
||||||
Q_UNUSED(matrix)
|
Q_UNUSED(matrix)
|
||||||
#else
|
#else
|
||||||
|
if (ShaderManager::instance()->isValid()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
glPushMatrix();
|
glPushMatrix();
|
||||||
multiplyMatrix(matrix);
|
multiplyMatrix(matrix);
|
||||||
#endif
|
#endif
|
||||||
|
@ -210,6 +216,9 @@ void multiplyMatrix(const QMatrix4x4 &matrix)
|
||||||
#ifdef KWIN_HAVE_OPENGLES
|
#ifdef KWIN_HAVE_OPENGLES
|
||||||
Q_UNUSED(matrix)
|
Q_UNUSED(matrix)
|
||||||
#else
|
#else
|
||||||
|
if (ShaderManager::instance()->isValid()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
GLfloat m[16];
|
GLfloat m[16];
|
||||||
const qreal *data = matrix.constData();
|
const qreal *data = matrix.constData();
|
||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
|
@ -243,6 +252,9 @@ void loadMatrix(const QMatrix4x4 &matrix)
|
||||||
void popMatrix()
|
void popMatrix()
|
||||||
{
|
{
|
||||||
#ifndef KWIN_HAVE_OPENGLES
|
#ifndef KWIN_HAVE_OPENGLES
|
||||||
|
if (ShaderManager::instance()->isValid()) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
glPopMatrix();
|
glPopMatrix();
|
||||||
#endif
|
#endif
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue