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

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