Web   ·   Wiki   ·   Activities   ·   Blog   ·   Lists   ·   Chat   ·   Meeting   ·   Bugs   ·   Git   ·   Translate   ·   Archive   ·   People   ·   Donate
summaryrefslogtreecommitdiffstats
path: root/shell
diff options
context:
space:
mode:
authorCarlos Garcia Campos <carlosgc@gnome.org>2008-07-20 17:54:20 (GMT)
committer Carlos Garcia Campos <carlosgc@src.gnome.org>2008-07-20 17:54:20 (GMT)
commitc083c103325b83d290d9c4a6ea42d74251154e21 (patch)
treec03efd5aa09a577b6b65d0191bf427904efb7f1f /shell
parentd8f0b1595b755a8bcd1b11fb8b1c64c9f4b7caba (diff)
Intercept window manager's fullscreen request in order to run/stop
2008-07-20 Carlos Garcia Campos <carlosgc@gnome.org> * shell/ev-window.c: (ev_window_state_event), (ev_window_class_init): Intercept window manager's fullscreen request in order to run/stop fullscreen mode. Fixes bug #493541. svn path=/trunk/; revision=3078
Diffstat (limited to 'shell')
-rw-r--r--shell/ev-window.c30
1 files changed, 30 insertions, 0 deletions
diff --git a/shell/ev-window.c b/shell/ev-window.c
index ec23937..7d08ebf 100644
--- a/shell/ev-window.c
+++ b/shell/ev-window.c
@@ -3118,6 +3118,35 @@ ev_window_screen_changed (GtkWidget *widget,
}
}
+static gboolean
+ev_window_state_event (GtkWidget *widget,
+ GdkEventWindowState *event)
+{
+ EvWindow *window = EV_WINDOW (widget);
+ EvView *view = EV_VIEW (window->priv->view);
+
+ if (GTK_WIDGET_CLASS (ev_window_parent_class)->window_state_event) {
+ GTK_WIDGET_CLASS (ev_window_parent_class)->window_state_event (widget, event);
+ }
+
+ if ((event->changed_mask & GDK_WINDOW_STATE_FULLSCREEN) == 0)
+ return FALSE;
+
+ if (event->new_window_state & GDK_WINDOW_STATE_FULLSCREEN) {
+ if (ev_view_get_fullscreen (view) || ev_view_get_presentation (view))
+ return FALSE;
+
+ ev_window_run_fullscreen (window);
+ } else {
+ if (ev_view_get_fullscreen (view))
+ ev_window_stop_fullscreen (window, FALSE);
+ else if (ev_view_get_presentation (view))
+ ev_window_stop_presentation (window, FALSE);
+ }
+
+ return FALSE;
+}
+
static void
ev_window_set_page_mode (EvWindow *window,
EvWindowPageMode page_mode)
@@ -4320,6 +4349,7 @@ ev_window_class_init (EvWindowClass *ev_window_class)
g_object_class->finalize = ev_window_finalize;
widget_class->screen_changed = ev_window_screen_changed;
+ widget_class->window_state_event = ev_window_state_event;
g_type_class_add_private (g_object_class, sizeof (EvWindowPrivate));
}