summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonas Ådahl <jadahl@gmail.com>2020-12-05 12:22:25 +0100
committerJonas Ådahl <jadahl@gmail.com>2020-12-07 20:37:29 +0100
commit2e5eeb6b925621486328b1410373ec8bd324d78c (patch)
tree82f7f650ebcb9c650c5a16341eb48e951fbdbe69
parenteb0eac0f0316b767dd834b423e89c2d7c0bf1c80 (diff)
downloadgtk+-2e5eeb6b925621486328b1410373ec8bd324d78c.tar.gz
gtk/window: Add 'fullscreen' prop and gtk_window_is_fullscreen()
This makes it possible to set 'fullscreen' to 'true' in a .ui file to start an application in fullscreen mode.
-rw-r--r--gtk/gtkwindow.c63
-rw-r--r--gtk/gtkwindow.h3
2 files changed, 65 insertions, 1 deletions
diff --git a/gtk/gtkwindow.c b/gtk/gtkwindow.c
index 27c9067e37..176ae22bf5 100644
--- a/gtk/gtkwindow.c
+++ b/gtk/gtkwindow.c
@@ -285,6 +285,7 @@ enum {
PROP_FOCUS_VISIBLE,
PROP_MAXIMIZED,
+ PROP_FULLSCREEN,
LAST_ARG
};
@@ -869,6 +870,13 @@ gtk_window_class_init (GtkWindowClass *klass)
FALSE,
GTK_PARAM_READWRITE|G_PARAM_CONSTRUCT|G_PARAM_EXPLICIT_NOTIFY);
+ window_props[PROP_FULLSCREEN] =
+ g_param_spec_boolean ("fullscreen",
+ P_("Is fullscreen"),
+ P_("Whether the window is fullscreen"),
+ FALSE,
+ GTK_PARAM_READWRITE|G_PARAM_CONSTRUCT|G_PARAM_EXPLICIT_NOTIFY);
+
/**
* GtkWindow:application:
*
@@ -1111,6 +1119,36 @@ gtk_window_is_maximized (GtkWindow *window)
return priv->maximize_initially;
}
+/**
+ * gtk_window_is_fullscreen:
+ * @window: a #GtkWindow
+ *
+ * Retrieves the current fullscreen state of @window.
+ *
+ * Note that since fullscreening is ultimately handled by the window
+ * manager and happens asynchronously to an application request, you
+ * shouldn’t assume the return value of this function changing
+ * immediately (or at all), as an effect of calling
+ * gtk_window_fullscreen() or gtk_window_unfullscreen().
+ *
+ * If the window isn't yet mapped, the value returned will whether the
+ * initial requested state is fullscreen.
+ *
+ * Returns: whether the window has a fullscreen state.
+ */
+gboolean
+gtk_window_is_fullscreen (GtkWindow *window)
+{
+ GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
+
+ g_return_val_if_fail (GTK_IS_WINDOW (window), FALSE);
+
+ if (priv->surface && gdk_surface_get_mapped (priv->surface))
+ return priv->fullscreen;
+ else
+ return priv->fullscreen_initially;
+}
+
void
_gtk_window_toggle_maximized (GtkWindow *window)
{
@@ -1625,6 +1663,12 @@ gtk_window_set_property (GObject *object,
else
gtk_window_unmaximize (window);
break;
+ case PROP_FULLSCREEN:
+ if (g_value_get_boolean (value))
+ gtk_window_fullscreen (window);
+ else
+ gtk_window_unfullscreen (window);
+ break;
case PROP_FOCUS_WIDGET:
gtk_window_set_focus (window, g_value_get_object (value));
break;
@@ -1702,6 +1746,9 @@ gtk_window_get_property (GObject *object,
case PROP_MAXIMIZED:
g_value_set_boolean (value, gtk_window_is_maximized (window));
break;
+ case PROP_FULLSCREEN:
+ g_value_set_boolean (value, gtk_window_is_fullscreen (window));
+ break;
case PROP_FOCUS_WIDGET:
g_value_set_object (value, gtk_window_get_focus (window));
break;
@@ -4425,6 +4472,8 @@ surface_state_changed (GtkWidget *widget)
{
priv->fullscreen = (new_surface_state & GDK_TOPLEVEL_STATE_FULLSCREEN) ? TRUE : FALSE;
priv->fullscreen_initially = priv->fullscreen;
+
+ g_object_notify_by_pspec (G_OBJECT (widget), window_props[PROP_FULLSCREEN]);
}
if (changed_mask & GDK_TOPLEVEL_STATE_MAXIMIZED)
@@ -5195,12 +5244,17 @@ void
gtk_window_fullscreen (GtkWindow *window)
{
GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
+ gboolean was_fullscreen_initially;
g_return_if_fail (GTK_IS_WINDOW (window));
+ was_fullscreen_initially = priv->fullscreen_initially;
priv->fullscreen_initially = TRUE;
- gtk_window_update_toplevel (window);
+ if (priv->surface && gdk_surface_get_mapped (priv->surface))
+ gtk_window_update_toplevel (window);
+ else if (!was_fullscreen_initially)
+ g_object_notify_by_pspec (G_OBJECT (window), window_props[PROP_FULLSCREEN]);
}
static void
@@ -5267,13 +5321,20 @@ void
gtk_window_unfullscreen (GtkWindow *window)
{
GtkWindowPrivate *priv = gtk_window_get_instance_private (window);
+ gboolean was_fullscreen_initially;
g_return_if_fail (GTK_IS_WINDOW (window));
+ was_fullscreen_initially = priv->fullscreen_initially;
unset_fullscreen_monitor (window);
priv->fullscreen_initially = FALSE;
gtk_window_update_toplevel (window);
+
+ if (priv->surface && gdk_surface_get_mapped (priv->surface))
+ gtk_window_update_toplevel (window);
+ else if (was_fullscreen_initially)
+ g_object_notify_by_pspec (G_OBJECT (window), window_props[PROP_FULLSCREEN]);
}
/**
diff --git a/gtk/gtkwindow.h b/gtk/gtkwindow.h
index a68937ba67..1c673b4201 100644
--- a/gtk/gtkwindow.h
+++ b/gtk/gtkwindow.h
@@ -248,6 +248,9 @@ GDK_AVAILABLE_IN_ALL
gboolean gtk_window_is_maximized (GtkWindow *window);
GDK_AVAILABLE_IN_ALL
+gboolean gtk_window_is_fullscreen (GtkWindow *window);
+
+GDK_AVAILABLE_IN_ALL
void gtk_window_destroy (GtkWindow *window);
GDK_AVAILABLE_IN_ALL