From e0ed5d5f3f8979d10dbe894b21be26486fc1d390 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Lubo=C5=A1=20Lu=C5=88=C3=A1k?= Date: Fri, 26 Jan 2007 22:50:31 +0000 Subject: [PATCH] Move raster position relatively using glBitmap() rather than using glRasterPos2f() - the latter causes drawing artefacts at the bottom screen edge with some gfx cards svn path=/branches/work/kwin_composite/; revision=627525 --- scene_opengl.cpp | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/scene_opengl.cpp b/scene_opengl.cpp index f7e10c860d..a3e8954032 100644 --- a/scene_opengl.cpp +++ b/scene_opengl.cpp @@ -495,14 +495,23 @@ void SceneOpenGL::flushBuffer( int mask, QRegion damage ) { // no idea why glScissor() is used, but Compiz has it and it doesn't seem to hurt glEnable( GL_SCISSOR_TEST ); glDrawBuffer( GL_FRONT ); + int xpos = 0; + int ypos = 0; foreach( QRect r, damage.rects()) { // convert to OpenGL coordinates int y = displayHeight() - r.y() - r.height(); - glRasterPos2f( r.x(), r.y() + r.height()); + // Move raster position relatively using glBitmap() rather + // than using glRasterPos2f() - the latter causes drawing + // artefacts at the bottom screen edge with some gfx cards +// glRasterPos2f( r.x(), r.y() + r.height()); + glBitmap( 0, 0, 0, 0, r.x() - xpos, y - ypos, NULL ); + xpos = r.x(); + ypos = y; glScissor( r.x(), y, r.width(), r.height()); glCopyPixels( r.x(), y, r.width(), r.height(), GL_COLOR ); } + glBitmap( 0, 0, 0, 0, -xpos, -ypos, NULL ); // move position back to 0,0 glDrawBuffer( GL_BACK ); glDisable( GL_SCISSOR_TEST ); }