fix flicker with fullscreen effects
BUG: 304375 FIXED-IN: 4.9.1 REVIEW: 106142
This commit is contained in:
parent
0d6cee6ccc
commit
f82fffdd71
3 changed files with 16 additions and 3 deletions
|
@ -393,14 +393,22 @@ void Workspace::timerEvent(QTimerEvent *te)
|
|||
QObject::timerEvent(te);
|
||||
}
|
||||
|
||||
static bool s_pending = false;
|
||||
static int s_pendingFlushes = 0;
|
||||
|
||||
void Workspace::performCompositing()
|
||||
{
|
||||
if (!scene->overlayWindow()->isVisible())
|
||||
return; // nothing is visible anyway
|
||||
|
||||
bool pending = !repaints_region.isEmpty() || windowRepaintsPending();
|
||||
if (!(pending || s_pending)) {
|
||||
if (pending)
|
||||
s_pendingFlushes = 3;
|
||||
else if (scene->hasPendingFlush())
|
||||
--s_pendingFlushes;
|
||||
else
|
||||
s_pendingFlushes = 0;
|
||||
if (s_pendingFlushes < 1) {
|
||||
s_pendingFlushes = 0;
|
||||
scene->idle();
|
||||
// Note: It would seem here we should undo suspended unredirect, but when scenes need
|
||||
// it for some reason, e.g. transformations or translucency, the next pass that does not
|
||||
|
@ -408,7 +416,7 @@ void Workspace::performCompositing()
|
|||
// Otherwise the window would not be painted normally anyway.
|
||||
return;
|
||||
}
|
||||
s_pending = pending;
|
||||
|
||||
// create a list of all windows in the stacking order
|
||||
ToplevelList windows = xStackingOrder();
|
||||
foreach (EffectWindow *c, static_cast< EffectsHandlerImpl* >(effects)->elevatedWindows()) {
|
||||
|
@ -430,6 +438,7 @@ void Workspace::performCompositing()
|
|||
repaints_region = QRegion();
|
||||
|
||||
m_timeSinceLastVBlank = scene->paint(repaints, windows);
|
||||
|
||||
// Trigger at least one more pass even if there would be nothing to paint, so that scene->idle()
|
||||
// is called the next time. If there would be nothing pending, it will not restart the timer and
|
||||
// checkCompositeTime() would restart it again somewhen later, called from functions that
|
||||
|
|
3
scene.h
3
scene.h
|
@ -49,6 +49,9 @@ public:
|
|||
// Returns true if the ctor failed to properly initialize.
|
||||
virtual bool initFailed() const = 0;
|
||||
virtual CompositingType compositingType() const = 0;
|
||||
|
||||
virtual bool hasPendingFlush() const { return false; }
|
||||
|
||||
// Repaints the given screen areas, windows provides the stacking order.
|
||||
// The entry point for the main part of the painting pass.
|
||||
// returns the time since the last vblank signal - if there's one
|
||||
|
|
|
@ -46,6 +46,7 @@ public:
|
|||
virtual CompositingType compositingType() const {
|
||||
return OpenGLCompositing;
|
||||
}
|
||||
virtual bool hasPendingFlush() const { return !m_lastDamage.isEmpty(); }
|
||||
virtual int paint(QRegion damage, ToplevelList windows);
|
||||
virtual void windowAdded(Toplevel*);
|
||||
virtual void windowDeleted(Deleted*);
|
||||
|
|
Loading…
Reference in a new issue