From b757b7e17d8bddd94a3dfd081f8dfc74279370c1 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Martin=20Gr=C3=A4=C3=9Flin?= Date: Thu, 26 Nov 2015 16:22:01 +0100 Subject: [PATCH] [effects] Switch ShowFPS to ShaderTraits based rendering --- effects/showfps/showfps.cpp | 15 ++++++++------- effects/showfps/showfps.h | 2 +- 2 files changed, 9 insertions(+), 8 deletions(-) diff --git a/effects/showfps/showfps.cpp b/effects/showfps/showfps.cpp index 74b3ffba30..5342f20e85 100644 --- a/effects/showfps/showfps.cpp +++ b/effects/showfps/showfps.cpp @@ -158,7 +158,7 @@ void ShowFpsEffect::paintScreen(int mask, QRegion region, ScreenPaintData& data) if (fps > MAX_TIME) fps = MAX_TIME; // keep it the same height if (effects->isOpenGLCompositing()) { - paintGL(fps); + paintGL(fps, data.projectionMatrix()); glFinish(); // make sure all rendering is done } #ifdef KWIN_HAVE_XRENDER_COMPOSITING @@ -173,7 +173,7 @@ void ShowFpsEffect::paintScreen(int mask, QRegion region, ScreenPaintData& data) m_noBenchmark->render(infiniteRegion(), 1.0, alpha); } -void ShowFpsEffect::paintGL(int fps) +void ShowFpsEffect::paintGL(int fps, const QMatrix4x4 &projectionMatrix) { int x = this->x; int y = this->y; @@ -181,7 +181,8 @@ void ShowFpsEffect::paintGL(int fps) glBlendFunc(GL_SRC_ALPHA, GL_ONE_MINUS_SRC_ALPHA); // TODO painting first the background white and then the contents // means that the contents also blend with the background, I guess - ShaderBinder binder(ShaderManager::ColorShader); + ShaderBinder binder(ShaderTrait::UniformColor); + binder.shader()->setUniform(GLShader::ModelViewProjectionMatrix, projectionMatrix); GLVertexBuffer *vbo = GLVertexBuffer::streamingBuffer(); vbo->reset(); QColor color(255, 255, 255); @@ -236,10 +237,10 @@ void ShowFpsEffect::paintGL(int fps) if (fpsTextRect.isValid()) { fpsText.reset(new GLTexture(fpsTextImage(fps))); fpsText->bind(); - ShaderBinder binder(ShaderManager::SimpleShader); - if (effects->compositingType() == OpenGL2Compositing) { - binder.shader()->setUniform("offset", QVector2D(0, 0)); - } + ShaderBinder binder(ShaderTrait::MapTexture); + QMatrix4x4 mvp = projectionMatrix; + mvp.translate(fpsTextRect.x(), fpsTextRect.y()); + binder.shader()->setUniform(GLShader::ModelViewProjectionMatrix, mvp); fpsText->render(QRegion(fpsTextRect), fpsTextRect); fpsText->unbind(); effects->addRepaint(fpsTextRect); diff --git a/effects/showfps/showfps.h b/effects/showfps/showfps.h index 8a50f7402a..3f8909a05e 100644 --- a/effects/showfps/showfps.h +++ b/effects/showfps/showfps.h @@ -73,7 +73,7 @@ public: return textColor; } private: - void paintGL(int fps); + void paintGL(int fps, const QMatrix4x4 &projectionMatrix); #ifdef KWIN_HAVE_XRENDER_COMPOSITING void paintXrender(int fps); #endif