fullscreen
This commit is contained in:
+10
-3
@@ -12,13 +12,16 @@ void xdg_toplevel_commit(struct wl_listener *listener, void *data)
|
||||
struct absinthe_toplevel *toplevel = wl_container_of(listener, toplevel, commit);
|
||||
|
||||
if (toplevel->xdg_toplevel->base->initial_commit) {
|
||||
// Let client set the preferred size
|
||||
wlr_xdg_toplevel_set_size(toplevel->xdg_toplevel, 0, 0);
|
||||
|
||||
// Forse server side decoration mode
|
||||
if (toplevel->decoration)
|
||||
xdg_decoration_request_mode(&toplevel->decoration_request_mode, toplevel->decoration);
|
||||
} else {
|
||||
// Check for size because we did't set it on initial commit
|
||||
if (toplevel->geometry.width == 0 || toplevel->geometry.height == 0) {
|
||||
int bw = ABSINTHE_WINDOW_BORDER_WIDTH;
|
||||
int32_t bw = toplevel->border_width;
|
||||
toplevel->geometry.width = toplevel->xdg_toplevel->base->geometry.width + 2 * bw;
|
||||
toplevel->geometry.height = toplevel->xdg_toplevel->base->geometry.height + 2 * bw;
|
||||
}
|
||||
@@ -38,9 +41,14 @@ void xdg_toplevel_map(struct wl_listener *listener, void *data)
|
||||
toplevel->border[i]->node.data = toplevel;
|
||||
}
|
||||
|
||||
toplevel->border_width = ABSINTHE_WINDOW_BORDER_WIDTH;
|
||||
|
||||
absinthe_toplevel_set_border_color(toplevel, bordercolor);
|
||||
absinthe_toplevel_update_borders_geometry(toplevel);
|
||||
|
||||
toplevel->output = toplevel->server->focused_output;
|
||||
toplevel->fullscreen = false;
|
||||
|
||||
wl_list_insert(&toplevel->server->toplevels, &toplevel->link);
|
||||
}
|
||||
|
||||
@@ -93,6 +101,5 @@ void xdg_toplevel_request_maximize(struct wl_listener *listener, void *data)
|
||||
void xdg_toplevel_request_fullscreen(struct wl_listener *listener, void *data)
|
||||
{
|
||||
struct absinthe_toplevel *toplevel = wl_container_of(listener, toplevel, request_fullscreen);
|
||||
if (toplevel->xdg_toplevel->base->initialized)
|
||||
wlr_xdg_surface_schedule_configure(toplevel->xdg_toplevel->base);
|
||||
absinthe_toplevel_set_fullscreen(toplevel, toplevel->xdg_toplevel->requested.fullscreen);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user