From 48a5a4690e2bd9df7dcdfeb3cf1018ed563e8efc Mon Sep 17 00:00:00 2001 From: Michail Vourlakos Date: Mon, 11 Mar 2019 16:09:50 +0200 Subject: [PATCH] decrease edge ghost window sensitivity for mouse --this patch fixes the show timer delayer in combination with KWin edges activation even more. The experience now looks almost identical to NONE-KWin edge activation --- app/view/screenedgeghostwindow.cpp | 24 +++++++++++++++++++++--- app/view/screenedgeghostwindow.h | 2 ++ 2 files changed, 23 insertions(+), 3 deletions(-) diff --git a/app/view/screenedgeghostwindow.cpp b/app/view/screenedgeghostwindow.cpp index 60f23e02e..92003e9a9 100644 --- a/app/view/screenedgeghostwindow.cpp +++ b/app/view/screenedgeghostwindow.cpp @@ -55,6 +55,18 @@ ScreenEdgeGhostWindow::ScreenEdgeGhostWindow(Latte::View *view) : m_fixGeometryTimer.setInterval(500); connect(&m_fixGeometryTimer, &QTimer::timeout, this, &ScreenEdgeGhostWindow::fixGeometry); + //! this timer is used in order to avoid fast enter/exit signals during first + //! appearing after edge activation + m_delayedMouseTimer.setSingleShot(true); + m_delayedMouseTimer.setInterval(50); + connect(&m_delayedMouseTimer, &QTimer::timeout, this, [this]() { + if (m_delayedContainsMouse) { + setContainsMouse(true); + } else { + setContainsMouse(false); + } + }); + connect(this, &QQuickView::xChanged, this, &ScreenEdgeGhostWindow::startGeometryTimer); connect(this, &QQuickView::yChanged, this, &ScreenEdgeGhostWindow::startGeometryTimer); connect(this, &QQuickView::widthChanged, this, &ScreenEdgeGhostWindow::startGeometryTimer); @@ -135,7 +147,7 @@ KWayland::Client::PlasmaShellSurface *ScreenEdgeGhostWindow::surface() void ScreenEdgeGhostWindow::updateGeometry() { QRect newGeometry; - int thickness{2}; + int thickness{KWindowSystem::compositingActive() ? 4 : 2}; if (m_latteView->location() == Plasma::Types::BottomEdge) { newGeometry.setX(m_latteView->absGeometry().left()); @@ -234,9 +246,15 @@ void ScreenEdgeGhostWindow::setContainsMouse(bool contains) bool ScreenEdgeGhostWindow::event(QEvent *e) { if (e->type() == QEvent::Enter || e->type() == QEvent::DragEnter) { - setContainsMouse(true); + m_delayedContainsMouse = true; + if (!m_delayedMouseTimer.isActive()) { + m_delayedMouseTimer.start(); + } } else if (e->type() == QEvent::Leave || e->type() == QEvent::DragLeave) { - setContainsMouse(false); + m_delayedContainsMouse = false; + if (!m_delayedMouseTimer.isActive()) { + m_delayedMouseTimer.start(); + } } return QQuickView::event(e); diff --git a/app/view/screenedgeghostwindow.h b/app/view/screenedgeghostwindow.h index 76df91a77..3516d05a6 100644 --- a/app/view/screenedgeghostwindow.h +++ b/app/view/screenedgeghostwindow.h @@ -90,10 +90,12 @@ private: void setupWaylandIntegration(); private: + bool m_delayedContainsMouse{false}; bool m_containsMouse{false}; bool m_inDelete{false}; QRect m_calculatedGeometry; + QTimer m_delayedMouseTimer; QTimer m_fixGeometryTimer; Latte::View *m_latteView{nullptr};