Blame SOURCES/qtwayland-translate-opaque-area-for-decorations.patch

c54cd9
From 1e0862acdc2e6ccf77bf3a1436b877d3af5e5fe7 Mon Sep 17 00:00:00 2001
c54cd9
From: Jan Grulich <jgrulich@redhat.com>
c54cd9
Date: Wed, 10 Feb 2021 17:11:27 +0100
c54cd9
Subject: [PATCH] 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
c54cd9
Pick-to: 5.15
c54cd9
Change-Id: I1606e8256e7e204dad927931eb1221b576e227fd
c54cd9
---
c54cd9
c54cd9
diff --git a/src/client/qwaylandwindow.cpp b/src/client/qwaylandwindow.cpp
c54cd9
index 04c2dbd..b29edfa 100644
c54cd9
--- a/src/client/qwaylandwindow.cpp
c54cd9
+++ b/src/client/qwaylandwindow.cpp
c54cd9
@@ -1242,12 +1242,14 @@
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
 }