Blame SOURCES/0014-Translate-opaque-area-with-frame-margins.patch

429548
From a3e3ac1c86a956b25b1dc24f14518b6e6c96bcfc Mon Sep 17 00:00:00 2001
89d4c9
From: Jan Grulich <jgrulich@redhat.com>
89d4c9
Date: Wed, 10 Feb 2021 17:11:27 +0100
429548
Subject: [PATCH 14/36] Translate opaque area with frame margins
89d4c9
89d4c9
The opaque area doesn't take window decorations into account, which may
89d4c9
result into possible graphical artefacts.
89d4c9
429548
Pick-to: 5.15 6.0 6.1
89d4c9
Change-Id: I1606e8256e7e204dad927931eb1221b576e227fd
429548
Reviewed-by: David Edmundson <davidedmundson@kde.org>
89d4c9
---
429548
 src/client/qwaylandwindow.cpp | 8 +++++---
429548
 1 file changed, 5 insertions(+), 3 deletions(-)
89d4c9
89d4c9
diff --git a/src/client/qwaylandwindow.cpp b/src/client/qwaylandwindow.cpp
429548
index e875af3a..2af39977 100644
89d4c9
--- a/src/client/qwaylandwindow.cpp
89d4c9
+++ b/src/client/qwaylandwindow.cpp
429548
@@ -1234,12 +1234,14 @@ bool QWaylandWindow::isOpaque() const
89d4c9
 
89d4c9
 void QWaylandWindow::setOpaqueArea(const QRegion &opaqueArea)
89d4c9
 {
89d4c9
-    if (opaqueArea == mOpaqueArea || !mSurface)
89d4c9
+    const QRegion translatedOpaqueArea = opaqueArea.translated(frameMargins().left(), frameMargins().top());
89d4c9
+
89d4c9
+    if (translatedOpaqueArea == mOpaqueArea || !mSurface)
89d4c9
         return;
89d4c9
 
89d4c9
-    mOpaqueArea = opaqueArea;
89d4c9
+    mOpaqueArea = translatedOpaqueArea;
89d4c9
 
89d4c9
-    struct ::wl_region *region = mDisplay->createRegion(opaqueArea);
89d4c9
+    struct ::wl_region *region = mDisplay->createRegion(translatedOpaqueArea);
89d4c9
     mSurface->set_opaque_region(region);
89d4c9
     wl_region_destroy(region);
89d4c9
 }
429548
-- 
429548
2.33.1
429548