summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRay Strode <[email protected]>2017-02-25 20:10:44 +0300
committerAlexei Sorokin <[email protected]>2017-02-25 20:10:44 +0300
commitfc3de40af9363642ab65929a17250f3ba4477239 (patch)
tree31630658d2d411a233e40ba092cc7b3e7a595cec
parentfb9787630278dd23a6900cfc28c84be5761bc885 (diff)
downloadmate-desktop-fc3de40af9363642ab65929a17250f3ba4477239.tar.bz2
mate-desktop-fc3de40af9363642ab65929a17250f3ba4477239.tar.xz
mate-bg: force property update when doing new crossfade frame
marco needs to get notified about animation updates. This commit frobs the property to wake marco up. https://bugzilla.gnome.org/show_bug.cgi?id=641526
-rw-r--r--libmate-desktop/mate-bg-crossfade.c15
1 files changed, 15 insertions, 0 deletions
diff --git a/libmate-desktop/mate-bg-crossfade.c b/libmate-desktop/mate-bg-crossfade.c
index a399c1c..37fddd8 100644
--- a/libmate-desktop/mate-bg-crossfade.c
+++ b/libmate-desktop/mate-bg-crossfade.c
@@ -382,6 +382,20 @@ animations_are_disabled (MateBGCrossfade *fade)
}
static void
+send_root_property_change_notification (MateBGCrossfade *fade)
+{
+ long zero_length_pixmap = 0;
+
+ /* We do a zero length append to force a change notification,
+ * without changing the value */
+ XChangeProperty (GDK_WINDOW_XDISPLAY (fade->priv->window),
+ GDK_WINDOW_XID (fade->priv->window),
+ gdk_x11_get_xatom_by_name ("_XROOTPMAP_ID"),
+ XA_PIXMAP, 32, PropModeAppend,
+ (unsigned char *) &zero_length_pixmap, 0);
+}
+
+static void
draw_background (MateBGCrossfade *fade)
{
if (gdk_window_get_window_type (fade->priv->window) == GDK_WINDOW_ROOT) {
@@ -391,6 +405,7 @@ draw_background (MateBGCrossfade *fade)
gdk_window_get_width (fade->priv->window),
gdk_window_get_height (fade->priv->window),
False);
+ send_root_property_change_notification (fade);
gdk_flush ();
} else {
gdk_window_invalidate_rect (fade->priv->window, NULL, FALSE);