update geometry
This commit is contained in:
+22
-2
@@ -25,6 +25,21 @@ bool absinthe_toplevel_is_unmanaged(struct absinthe_toplevel *toplevel)
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void absinthe_toplevel_update_geometry(struct absinthe_toplevel *toplevel)
|
||||||
|
{
|
||||||
|
#ifdef XWAYLAND
|
||||||
|
if (absinthe_toplevel_is_x11(toplevel)) {
|
||||||
|
toplevel->geometry.x = toplevel->toplevel.x11->x;
|
||||||
|
toplevel->geometry.y = toplevel->toplevel.x11->y;
|
||||||
|
toplevel->geometry.width = toplevel->toplevel.x11->width;
|
||||||
|
toplevel->geometry.height = toplevel->toplevel.x11->height;
|
||||||
|
} else
|
||||||
|
#endif
|
||||||
|
{
|
||||||
|
toplevel->geometry = toplevel->toplevel.xdg->base->geometry;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
struct wlr_surface *absinthe_toplevel_surface(struct absinthe_toplevel *toplevel)
|
struct wlr_surface *absinthe_toplevel_surface(struct absinthe_toplevel *toplevel)
|
||||||
{
|
{
|
||||||
#ifdef XWAYLAND
|
#ifdef XWAYLAND
|
||||||
@@ -40,6 +55,7 @@ void absinthe_toplevel_map(struct wl_listener *listener, void *data)
|
|||||||
|
|
||||||
toplevel->scene_tree = wlr_scene_tree_create(&toplevel->server->scene->tree);
|
toplevel->scene_tree = wlr_scene_tree_create(&toplevel->server->scene->tree);
|
||||||
toplevel->scene_tree->node.data = toplevel;
|
toplevel->scene_tree->node.data = toplevel;
|
||||||
|
wlr_scene_node_set_enabled(&toplevel->scene_tree->node, false);
|
||||||
|
|
||||||
toplevel->border_width = absinthe_toplevel_is_unmanaged(toplevel)
|
toplevel->border_width = absinthe_toplevel_is_unmanaged(toplevel)
|
||||||
? 0
|
? 0
|
||||||
@@ -55,13 +71,17 @@ void absinthe_toplevel_map(struct wl_listener *listener, void *data)
|
|||||||
}
|
}
|
||||||
toplevel->scene_surface->node.data = toplevel;
|
toplevel->scene_surface->node.data = toplevel;
|
||||||
|
|
||||||
|
absinthe_toplevel_update_geometry(toplevel);
|
||||||
|
toplevel->border_width = ABSINTHE_TOPLEVEL_BORDER_WIDTH;
|
||||||
|
int32_t borders_width = ABSINTHE_TOPLEVEL_BORDER_WIDTH * 2;
|
||||||
|
toplevel->geometry.width += borders_width;
|
||||||
|
toplevel->geometry.height += borders_width;
|
||||||
|
|
||||||
for (int i = 0; i < 4; ++i) {
|
for (int i = 0; i < 4; ++i) {
|
||||||
toplevel->border[i] = wlr_scene_rect_create(toplevel->scene_tree, 0, 0, unfocused_border_color);
|
toplevel->border[i] = wlr_scene_rect_create(toplevel->scene_tree, 0, 0, unfocused_border_color);
|
||||||
toplevel->border[i]->node.data = toplevel;
|
toplevel->border[i]->node.data = toplevel;
|
||||||
}
|
}
|
||||||
|
|
||||||
toplevel->border_width = ABSINTHE_TOPLEVEL_BORDER_WIDTH;
|
|
||||||
|
|
||||||
update_focused_output(toplevel->server);
|
update_focused_output(toplevel->server);
|
||||||
toplevel->output = toplevel->server->focused_output;
|
toplevel->output = toplevel->server->focused_output;
|
||||||
toplevel->fullscreen = false;
|
toplevel->fullscreen = false;
|
||||||
|
|||||||
@@ -10,6 +10,7 @@ void layout_arrange(struct absinthe_output *output)
|
|||||||
size_t toplevels_count = 0;
|
size_t toplevels_count = 0;
|
||||||
wl_list_for_each(toplevel, &output->server->toplevels, link) {
|
wl_list_for_each(toplevel, &output->server->toplevels, link) {
|
||||||
if (toplevel->output == output)
|
if (toplevel->output == output)
|
||||||
|
wlr_scene_node_set_enabled(&toplevel->scene_tree->node, true);
|
||||||
toplevels_count++;
|
toplevels_count++;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
+9
-5
@@ -14,19 +14,23 @@ void xdg_toplevel_commit(struct wl_listener *listener, void *data)
|
|||||||
{
|
{
|
||||||
struct absinthe_toplevel *toplevel = wl_container_of(listener, toplevel, commit);
|
struct absinthe_toplevel *toplevel = wl_container_of(listener, toplevel, commit);
|
||||||
|
|
||||||
|
int32_t borders_width = 2 * toplevel->border_width;
|
||||||
|
|
||||||
if (toplevel->toplevel.xdg->base->initial_commit) {
|
if (toplevel->toplevel.xdg->base->initial_commit) {
|
||||||
// Forse server side decoration mode
|
/* Forse server side decoration mode */
|
||||||
if (toplevel->decoration)
|
if (toplevel->decoration)
|
||||||
xdg_decoration_request_mode(&toplevel->decoration_request_mode, toplevel->decoration);
|
xdg_decoration_request_mode(&toplevel->decoration_request_mode, toplevel->decoration);
|
||||||
|
|
||||||
// Let toplevel set preferred size
|
/* Let toplevel set preferred size */
|
||||||
// wlr_xdg_toplevel_set_size(toplevel->xdg_toplevel, 0, 0);
|
wlr_xdg_toplevel_set_size(toplevel->toplevel.xdg, 0, 0);
|
||||||
|
toplevel->geometry.width = toplevel->toplevel.xdg->base->geometry.width + borders_width;
|
||||||
|
toplevel->geometry.height = toplevel->toplevel.xdg->base->geometry.height + borders_width;
|
||||||
} else {
|
} else {
|
||||||
// Check for size because we did't set it on initial commit
|
/* Check for size because we did't set it on initial commit */
|
||||||
int32_t borders_width = 2 * toplevel->border_width;
|
|
||||||
toplevel->geometry.width = toplevel->toplevel.xdg->base->geometry.width + borders_width;
|
toplevel->geometry.width = toplevel->toplevel.xdg->base->geometry.width + borders_width;
|
||||||
toplevel->geometry.height = toplevel->toplevel.xdg->base->geometry.height + borders_width;
|
toplevel->geometry.height = toplevel->toplevel.xdg->base->geometry.height + borders_width;
|
||||||
|
|
||||||
|
/* Update borders and position only after client prepared new buffer */
|
||||||
absinthe_toplevel_set_position(toplevel, toplevel->geometry.x, toplevel->geometry.y);
|
absinthe_toplevel_set_position(toplevel, toplevel->geometry.x, toplevel->geometry.y);
|
||||||
absinthe_toplevel_update_borders_geometry(toplevel);
|
absinthe_toplevel_update_borders_geometry(toplevel);
|
||||||
toplevel->performing_resize = false;
|
toplevel->performing_resize = false;
|
||||||
|
|||||||
+2
-2
@@ -26,8 +26,8 @@ void xwayland_dissociate(struct wl_listener *listener, void *data)
|
|||||||
{
|
{
|
||||||
struct absinthe_toplevel *toplevel = wl_container_of(listener, toplevel, xwayland_dissociate);
|
struct absinthe_toplevel *toplevel = wl_container_of(listener, toplevel, xwayland_dissociate);
|
||||||
|
|
||||||
wl_list_remove(&toplevel->map.link);
|
// wl_list_remove(&toplevel->map.link);
|
||||||
wl_list_remove(&toplevel->unmap.link);
|
// wl_list_remove(&toplevel->unmap.link);
|
||||||
}
|
}
|
||||||
|
|
||||||
void xwayland_configure(struct wl_listener *listener, void *data)
|
void xwayland_configure(struct wl_listener *listener, void *data)
|
||||||
|
|||||||
Reference in New Issue
Block a user