From aeec46ecc9ed5acb358a31db2566dd568534de6f Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Marc-Andr=C3=A9=20Lureau?= <marcandre.lureau@gmail.com>
Date: Mon, 15 Jul 2013 20:50:55 +0200
Subject: [PATCH] kiosk: teach a window to become kiosk-mode
Remove the toolbar, disable modifiers.
(cherry picked from commit b7e153950ed473251c8ec67816fd8fcd0b0cdd0d)
https://bugzilla.redhat.com/show_bug.cgi?id=1040926
---
src/virt-viewer-window.c | 25 +++++++++++++++++++++++++
1 file changed, 25 insertions(+)
diff --git a/src/virt-viewer-window.c b/src/virt-viewer-window.c
index 45d1a35..9ab6cc4 100644
--- a/src/virt-viewer-window.c
+++ b/src/virt-viewer-window.c
@@ -1260,6 +1260,23 @@ virt_viewer_window_set_display(VirtViewerWindow *self, VirtViewerDisplay *displa
}
}
+static void
+virt_viewer_window_enable_kiosk(VirtViewerWindow *self)
+{
+ VirtViewerWindowPrivate *priv;
+
+ g_return_if_fail(VIRT_VIEWER_IS_WINDOW(self));
+ priv = self->priv;
+
+ ViewOvBox_SetOver(VIEW_OV_BOX(priv->layout), gtk_drawing_area_new());
+ ViewAutoDrawer_SetActive(VIEW_AUTODRAWER(priv->layout), FALSE);
+ ViewAutoDrawer_SetOverlapPixels(VIEW_AUTODRAWER(priv->layout), 0);
+
+ /* You probably also want X11 Option "DontVTSwitch" "true" */
+ /* and perhaps more distro/desktop-specific options */
+ virt_viewer_window_disable_modifiers(self);
+}
+
void
virt_viewer_window_show(VirtViewerWindow *self)
{
@@ -1273,6 +1290,9 @@ virt_viewer_window_show(VirtViewerWindow *self)
self->priv->desktop_resize_pending = FALSE;
}
+ if (self->priv->kiosk)
+ virt_viewer_window_enable_kiosk(self);
+
virt_viewer_window_move_to_monitor(self);
}
@@ -1349,6 +1369,11 @@ virt_viewer_window_set_kiosk(VirtViewerWindow *self, gboolean enabled)
return;
self->priv->kiosk = enabled;
+
+ if (enabled)
+ virt_viewer_window_enable_kiosk(self);
+ else
+ g_debug("disabling kiosk not implemented yet");
}
/*