From 3c5c079aa58b8c0cdf8ae2bf9fa8f01d2c53407f Mon Sep 17 00:00:00 2001 From: Ismael Asensio Date: Sun, 3 Jul 2022 00:58:42 +0200 Subject: [PATCH] TabBox: Do not highlight selected window for fullscreen switchers This helps improving performance on those effects, where the highlighted window is not even shown. BUG: 449180 FIXED-IN: 5.25.3 --- src/tabbox/tabboxhandler.cpp | 19 +++++++++++++++---- 1 file changed, 15 insertions(+), 4 deletions(-) diff --git a/src/tabbox/tabboxhandler.cpp b/src/tabbox/tabboxhandler.cpp index 417a842eec..19bd4a45c3 100644 --- a/src/tabbox/tabboxhandler.cpp +++ b/src/tabbox/tabboxhandler.cpp @@ -62,6 +62,8 @@ public: ClientModel *clientModel() const; DesktopModel *desktopModel() const; + bool isHighlightWindows() const; + TabBoxHandler *q; // public pointer // members TabBoxConfig config; @@ -144,6 +146,15 @@ DesktopModel *TabBoxHandlerPrivate::desktopModel() const return m_desktopModel; } +bool TabBoxHandlerPrivate::isHighlightWindows() const +{ + const QQuickWindow *w = window(); + if (w && w->visibility() == QWindow::FullScreen) { + return false; + } + return config.isHighlightWindows(); +} + void TabBoxHandlerPrivate::updateHighlightWindows() { if (!isShown || config.tabBoxMode() != TabBoxConfig::ClientTabBox) { @@ -198,7 +209,7 @@ void TabBoxHandlerPrivate::updateHighlightWindows() void TabBoxHandlerPrivate::endHighlightWindows(bool abort) { TabBoxClient *currentClient = q->client(index); - if (config.isHighlightWindows() && q->isKWinCompositing()) { + if (isHighlightWindows() && q->isKWinCompositing()) { const auto stackingOrder = q->stackingOrder(); for (const QWeakPointer &clientPointer : stackingOrder) { if (QSharedPointer client = clientPointer.toStrongRef()) { @@ -381,7 +392,7 @@ void TabBoxHandler::show() if (d->config.isShowTabBox()) { d->show(); } - if (d->config.isHighlightWindows()) { + if (d->isHighlightWindows()) { if (kwinApp()->x11Connection()) { Xcb::sync(); } @@ -409,7 +420,7 @@ void TabBoxHandler::initHighlightWindows() void TabBoxHandler::hide(bool abort) { d->isShown = false; - if (d->config.isHighlightWindows()) { + if (d->isHighlightWindows()) { d->endHighlightWindows(abort); } #ifndef KWIN_UNIT_TEST @@ -519,7 +530,7 @@ void TabBoxHandler::setCurrentIndex(const QModelIndex &index) } d->index = index; if (d->config.tabBoxMode() == TabBoxConfig::ClientTabBox) { - if (d->config.isHighlightWindows()) { + if (d->isHighlightWindows()) { d->updateHighlightWindows(); } }