aboutsummaryrefslogtreecommitdiff
path: root/sway/tree/view.c
diff options
context:
space:
mode:
authorKenny Levinsen <kl@kl.wtf>2021-02-08 01:03:44 +0100
committerSimon Ser <contact@emersion.fr>2021-02-09 09:37:10 +0100
commit50205ade9d7b3d4c014fce5364db329c29acfa86 (patch)
tree5bb5f51f6fd9caf58be821b534682afa51217c68 /sway/tree/view.c
parentcf1e3be22813d343ec177d48a926d7d9104230dd (diff)
transaction: Move centering to view_center_surface
This will allow us to reuse it for centering elsewhere.
Diffstat (limited to 'sway/tree/view.c')
-rw-r--r--sway/tree/view.c10
1 files changed, 10 insertions, 0 deletions
diff --git a/sway/tree/view.c b/sway/tree/view.c
index 3b1e67ea..f4ae8171 100644
--- a/sway/tree/view.c
+++ b/sway/tree/view.c
@@ -887,6 +887,16 @@ void view_update_size(struct sway_view *view, int width, int height) {
}
}
+void view_center_surface(struct sway_view *view) {
+ struct sway_container *con = view->container;
+ // We always center the current coordinates rather than the next, as the
+ // geometry immediately affects the currently active rendering.
+ con->surface_x = fmax(con->current.content_x, con->current.content_x +
+ (con->current.content_width - view->geometry.width) / 2);
+ con->surface_y = fmax(con->current.content_y, con->current.content_y +
+ (con->current.content_height - view->geometry.height) / 2);
+}
+
static const struct sway_view_child_impl subsurface_impl;
static void subsurface_get_root_coords(struct sway_view_child *child,