From 823692abc114824f296e387c2cabe5c3f7c68a3b Mon Sep 17 00:00:00 2001 From: Vlad Zahorodnii Date: Thu, 18 Feb 2021 15:05:31 +0200 Subject: [PATCH] effects/wobblywindows: Refactor the update loop This way, the code is more tidier. --- src/effects/wobblywindows/wobblywindows.cpp | 30 +++++++++------------ src/effects/wobblywindows/wobblywindows.h | 2 +- 2 files changed, 13 insertions(+), 19 deletions(-) diff --git a/src/effects/wobblywindows/wobblywindows.cpp b/src/effects/wobblywindows/wobblywindows.cpp index 2ece00547c..4b7fd8ab1e 100644 --- a/src/effects/wobblywindows/wobblywindows.cpp +++ b/src/effects/wobblywindows/wobblywindows.cpp @@ -239,34 +239,27 @@ void WobblyWindowsEffect::prePaintScreen(ScreenPrePaintData& data, std::chrono:: effects->prePaintScreen(data, presentTime); } -const qreal maxTime = 10.0; + +static const std::chrono::milliseconds integrationStep(10); + void WobblyWindowsEffect::prePaintWindow(EffectWindow* w, WindowPrePaintData& data, std::chrono::milliseconds presentTime) { auto infoIt = windows.find(w); if (infoIt != windows.end()) { data.setTransformed(); data.quads = data.quads.makeRegularGrid(m_xTesselation, m_yTesselation); - bool stop = false; - - qreal updateTime = 0; - if (infoIt->lastPresentTime.count()) { - updateTime = (presentTime - infoIt->lastPresentTime).count(); - } - infoIt->lastPresentTime = presentTime; // We have to reset the clip region in order to render clients below // opaque wobbly windows. data.clip = QRegion(); - while (!stop && (updateTime > maxTime)) { -#if defined VERBOSE_MODE - qCDebug(KWINEFFECTS) << "loop time " << updateTime << " / " << time; -#endif - stop = !updateWindowWobblyDatas(w, maxTime); - updateTime -= maxTime; - } - if (!stop && updateTime > 0) { - updateWindowWobblyDatas(w, updateTime); + while ((presentTime - infoIt->clock).count() > 0) { + const auto delta = std::min(presentTime - infoIt->clock, integrationStep); + infoIt->clock += delta; + + if (!updateWindowWobblyDatas(w, delta.count())) { + break; + } } } @@ -470,7 +463,8 @@ void WobblyWindowsEffect::initWobblyInfo(WindowWobblyInfos& wwi, QRect geometry) wwi.bezierSurface = new Pair[wwi.bezierCount]; wwi.status = Moving; - wwi.lastPresentTime = std::chrono::milliseconds::zero(); + wwi.clock = std::chrono::duration_cast( + std::chrono::steady_clock::now().time_since_epoch()); qreal x = geometry.x(), y = geometry.y(); qreal width = geometry.width(), height = geometry.height(); diff --git a/src/effects/wobblywindows/wobblywindows.h b/src/effects/wobblywindows/wobblywindows.h index 9ebcdfa38f..dc7b3f969f 100644 --- a/src/effects/wobblywindows/wobblywindows.h +++ b/src/effects/wobblywindows/wobblywindows.h @@ -152,7 +152,7 @@ private: bool can_wobble_top, can_wobble_left, can_wobble_right, can_wobble_bottom; QRect resize_original_rect; - std::chrono::milliseconds lastPresentTime; + std::chrono::milliseconds clock; }; QHash< const EffectWindow*, WindowWobblyInfos > windows;