summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorRui Matos <tiagomatos@gmail.com>2016-11-02 19:00:34 +0100
committerMatthias Clasen <mclasen@redhat.com>2016-11-04 12:10:43 -0400
commitb8fc4c246ac6ef5cd7eccd477e2b64ea9efffff6 (patch)
tree6538540398361201f9b8be26bbe3f75742a49a3d
parent2c26f0cae4c06336832f4efd0e32e4ae1f8e84fa (diff)
downloadgtk+-b8fc4c246ac6ef5cd7eccd477e2b64ea9efffff6.tar.gz
gdkwindow-x11: Add support for gdk_window_fullscreen_on_monitor
This way we can recommend that applications use the fullscreen_on_monitor() API on both X and Wayland otherwise they'd have to keep a path for each backend to achieve this functionality. https://bugzilla.gnome.org/show_bug.cgi?id=773857
-rw-r--r--gdk/x11/gdkwindow-x11.c18
1 files changed, 18 insertions, 0 deletions
diff --git a/gdk/x11/gdkwindow-x11.c b/gdk/x11/gdkwindow-x11.c
index 4c0eddb2d6..9d37eb140e 100644
--- a/gdk/x11/gdkwindow-x11.c
+++ b/gdk/x11/gdkwindow-x11.c
@@ -3957,6 +3957,23 @@ gdk_x11_window_fullscreen (GdkWindow *window)
}
static void
+gdk_x11_window_fullscreen_on_monitor (GdkWindow *window,
+ gint monitor)
+{
+ GdkRectangle monitor_geom;
+
+ if (GDK_WINDOW_DESTROYED (window) ||
+ !WINDOW_IS_TOPLEVEL_OR_FOREIGN (window))
+ return;
+
+ gdk_screen_get_monitor_geometry (GDK_WINDOW_SCREEN (window), monitor, &monitor_geom);
+ gdk_window_move (window, monitor_geom.x, monitor_geom.y);
+
+ gdk_window_set_fullscreen_mode (window, GDK_FULLSCREEN_ON_CURRENT_MONITOR);
+ gdk_x11_window_fullscreen (window);
+}
+
+static void
gdk_x11_window_unfullscreen (GdkWindow *window)
{
if (GDK_WINDOW_DESTROYED (window) ||
@@ -5412,6 +5429,7 @@ gdk_window_impl_x11_class_init (GdkWindowImplX11Class *klass)
impl_class->maximize = gdk_x11_window_maximize;
impl_class->unmaximize = gdk_x11_window_unmaximize;
impl_class->fullscreen = gdk_x11_window_fullscreen;
+ impl_class->fullscreen_on_monitor = gdk_x11_window_fullscreen_on_monitor;
impl_class->apply_fullscreen_mode = gdk_x11_window_apply_fullscreen_mode;
impl_class->unfullscreen = gdk_x11_window_unfullscreen;
impl_class->set_keep_above = gdk_x11_window_set_keep_above;