diff options
author | Guido Günther <agx@sigxcpu.org> | 2018-04-23 16:49:41 +0200 |
---|---|---|
committer | Guido Günther <agx@sigxcpu.org> | 2018-04-23 18:11:47 +0200 |
commit | 67a10cc1f68c4f8e7b78b1a5b06aceafb4f3f7ca (patch) | |
tree | 36ee8a1e11e05198ab18739cbb9ebb2d665e1424 /examples | |
parent | e2ed7be0baa6fe17d6a4a73c68ac1e8b6dea96f9 (diff) |
examples/layer-shell: take an explicit grab on the popup
This demonstrates popups can be closed by clicking on the area outside
the popup and parent.
Diffstat (limited to 'examples')
-rw-r--r-- | examples/layer-shell.c | 6 |
1 files changed, 4 insertions, 2 deletions
diff --git a/examples/layer-shell.c b/examples/layer-shell.c index 0e1d61ca..d9deb7b0 100644 --- a/examples/layer-shell.c +++ b/examples/layer-shell.c @@ -209,7 +209,7 @@ static const struct xdg_popup_listener xdg_popup_listener = { .popup_done = xdg_popup_done, }; -static void create_popup() { +static void create_popup(uint32_t serial) { if (popup) { return; } @@ -227,6 +227,8 @@ static void create_popup() { xdg_positioner_set_anchor(xdg_positioner, XDG_POSITIONER_ANCHOR_BOTTOM_RIGHT); popup = xdg_surface_get_popup(xdg_surface, NULL, xdg_positioner); + xdg_popup_grab(popup, seat, serial); + assert(popup); zwlr_layer_surface_v1_get_popup(layer_surface, popup); @@ -311,7 +313,7 @@ static void wl_pointer_button(void *data, struct wl_pointer *wl_pointer, if (popup_wl_surface) { popup_destroy(); } else { - create_popup(); + create_popup(serial); } } else { buttons++; |