From e10bd8cc11bd52252b1ba107490ebe958f755213 Mon Sep 17 00:00:00 2001 From: Michael Zanetti Date: Tue, 19 May 2009 12:31:29 +0000 Subject: [PATCH] Use PaintClipper in prePaintWindow instead of paintWindow svn path=/trunk/KDE/kdebase/workspace/; revision=969982 --- effects/slideback/slideback.cpp | 51 ++++++++++++++++----------------- 1 file changed, 24 insertions(+), 27 deletions(-) diff --git a/effects/slideback/slideback.cpp b/effects/slideback/slideback.cpp index 8ead3df909..fa1648837d 100644 --- a/effects/slideback/slideback.cpp +++ b/effects/slideback/slideback.cpp @@ -182,6 +182,26 @@ void SlideBackEffect::postPaintScreen() void SlideBackEffect::prePaintWindow( EffectWindow *w, WindowPrePaintData &data, int time ) { + if( stackingOrderChanged() && ( w == newTopWindow() ) ) + { + /* This can happen because of two reasons: + - a window has received the focus earlier without beeing raised and is raised now. -> call windowActivated() now + - paintWindow() is called with a new stackingOrder before activateWindow(). Bug? -> don't draw the overlapping content;*/ + foreach( EffectWindow *tmp, oldStackingOrder ) + { + if( oldStackingOrder.lastIndexOf( tmp ) > oldStackingOrder.lastIndexOf( w ) && isWindowUsable( tmp ) ) + { +// kDebug() << "screw detected." << "clip:" << data.paint << " clipping:" << tmp->geometry() ; + PaintClipper::push( data.paint.subtracted( tmp->geometry() ) ); + clippedRegions.prepend( data.paint.subtracted( tmp->geometry() ) ); + } + } + // Finally call windowActivated in case a already active window is raised. + if( !disabled ) + { + windowActivated( w ); + } + } if( motionManager.isManaging( w ) ) { data.setTransformed(); @@ -192,34 +212,15 @@ void SlideBackEffect::prePaintWindow( EffectWindow *w, WindowPrePaintData &data, void SlideBackEffect::paintWindow( EffectWindow *w, int mask, QRegion region, WindowPaintData &data ) { - if( stackingOrderChanged() && ( w == newTopWindow() ) ) - { - /* This can happen because of two reasons: - - a window has received the focus earlier without beeing raised and is raised now. -> call windowActivated() now - - paintWindow() is called with a new stackingOrder before activateWindow(). Bug? -> don't draw the overlapping content;*/ - foreach( EffectWindow *tmp, oldStackingOrder ) - { - if( oldStackingOrder.lastIndexOf( tmp ) > oldStackingOrder.lastIndexOf( w ) && isWindowUsable( tmp ) ) - { - kDebug() << "screw detected. region:" << region << "clipping:" << tmp->geometry() ; - PaintClipper::push( region.subtracted( tmp->geometry() ) ); - clippedRegions.prepend( region.subtracted( tmp->geometry() ) ); -// region = region.subtracted( tmp->geometry() ); - } - } - // Add a full repaint to make sure the not painted area is repainted soon - effects->addRepaintFull(); - // Finally call windowActivated in case a already active window is raised. - if( !disabled ) - { - windowActivated( w ); - } - } if( motionManager.isManaging( w ) ) { motionManager.apply( w, data ); } effects->paintWindow( w, mask, region, data ); + } + +void SlideBackEffect::postPaintWindow( EffectWindow* w ) + { if( !clippedRegions.isEmpty() ) { foreach( const QRegion ®ion, clippedRegions ) @@ -228,10 +229,6 @@ void SlideBackEffect::paintWindow( EffectWindow *w, int mask, QRegion region, Wi } clippedRegions.clear(); } - } - -void SlideBackEffect::postPaintWindow( EffectWindow* w ) - { if( motionManager.isManaging( w ) ) { if( destinationList.contains( w ) )