[cogl/cogl-1.16] wayland: Don't set the surface to toplevel until it is shown
- From: Neil Roberts <nroberts src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [cogl/cogl-1.16] wayland: Don't set the surface to toplevel until it is shown
- Date: Fri, 31 May 2013 13:17:57 +0000 (UTC)
commit 0b2b46ce4ca8ecb4e59ec11f69e12845455a8740
Author: Neil Roberts <neil linux intel com>
Date: Wed May 15 16:34:15 2013 +0100
wayland: Don't set the surface to toplevel until it is shown
If we delay setting the surface to toplevel until it is shown then
that gives the application an opportunity to avoid calling show so
that it can set its own surface type.
Reviewed-by: Robert Bragg <robert linux intel com>
(cherry picked from commit ab59c3a421968d7f159d89ca2f0ba8a9f098cbf6)
cogl/cogl-onscreen.h | 6 +++++
cogl/winsys/cogl-winsys-egl-wayland.c | 40 ++++++++++++++++++++++++++++-----
2 files changed, 40 insertions(+), 6 deletions(-)
---
diff --git a/cogl/cogl-onscreen.h b/cogl/cogl-onscreen.h
index 9e58a3b..23a69e3 100644
--- a/cogl/cogl-onscreen.h
+++ b/cogl/cogl-onscreen.h
@@ -273,6 +273,12 @@ cogl_onscreen_set_swap_throttled (CoglOnscreen *onscreen,
* This function will implicitly allocate the given @onscreen
* framebuffer before showing it if it hasn't already been allocated.
*
+ * When using the Wayland winsys calling this will set the surface to
+ * a toplevel type which will make it appear. If the application wants
+ * to set a different type for the surface, it can avoid calling
+ * cogl_onscreen_show() and set its own type directly with the Wayland
+ * client API via cogl_wayland_onscreen_get_surface().
+ *
* <note>Since Cogl doesn't explicitly track the visibility status of
* onscreen framebuffers it wont try to avoid redundant window system
* requests e.g. to show an already visible window. This also means
diff --git a/cogl/winsys/cogl-winsys-egl-wayland.c b/cogl/winsys/cogl-winsys-egl-wayland.c
index 28e599b..62d449c 100644
--- a/cogl/winsys/cogl-winsys-egl-wayland.c
+++ b/cogl/winsys/cogl-winsys-egl-wayland.c
@@ -74,6 +74,8 @@ typedef struct _CoglOnscreenWayland
int pending_dx;
int pending_dy;
CoglBool has_pending;
+
+ CoglBool shell_surface_type_set;
} CoglOnscreenWayland;
static void
@@ -377,12 +379,9 @@ _cogl_winsys_egl_onscreen_init (CoglOnscreen *onscreen,
NULL);
if (!onscreen->foreign_surface)
- {
- wayland_onscreen->wayland_shell_surface =
- wl_shell_get_shell_surface (wayland_renderer->wayland_shell,
- wayland_onscreen->wayland_surface);
- wl_shell_surface_set_toplevel (wayland_onscreen->wayland_shell_surface);
- }
+ wayland_onscreen->wayland_shell_surface =
+ wl_shell_get_shell_surface (wayland_renderer->wayland_shell,
+ wayland_onscreen->wayland_surface);
return TRUE;
}
@@ -460,6 +459,32 @@ _cogl_winsys_onscreen_swap_buffers_with_damage (CoglOnscreen *onscreen,
wl_display_flush (wayland_renderer->wayland_display);
}
+static void
+_cogl_winsys_onscreen_set_visibility (CoglOnscreen *onscreen,
+ CoglBool visibility)
+{
+ CoglOnscreenEGL *egl_onscreen = onscreen->winsys;
+ CoglOnscreenWayland *wayland_onscreen = egl_onscreen->platform;
+
+ /* The first time the onscreen is shown we will set it to toplevel
+ * so that it will appear on the screen. If the surface is foreign
+ * then we won't have the shell surface and we'll just let the
+ * application deal with setting the surface type. */
+ if (visibility &&
+ wayland_onscreen->wayland_shell_surface &&
+ !wayland_onscreen->shell_surface_type_set)
+ {
+ wl_shell_surface_set_toplevel (wayland_onscreen->wayland_shell_surface);
+ wayland_onscreen->shell_surface_type_set = TRUE;
+ }
+
+ /* FIXME: We should also do something here to hide the surface when
+ * visilibity == FALSE. It sounds like there are currently ongoing
+ * discussions about adding support for hiding surfaces in the
+ * Wayland protocol so we might as well wait until then to add that
+ * here. */
+}
+
void
cogl_wayland_renderer_set_foreign_display (CoglRenderer *renderer,
struct wl_display *display)
@@ -657,6 +682,9 @@ _cogl_winsys_egl_wayland_get_vtable (void)
vtable.onscreen_swap_buffers_with_damage =
_cogl_winsys_onscreen_swap_buffers_with_damage;
+ vtable.onscreen_set_visibility =
+ _cogl_winsys_onscreen_set_visibility;
+
vtable_inited = TRUE;
}
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]