diff options
author | Simon Ser <contact@emersion.fr> | 2023-02-10 18:07:26 +0100 |
---|---|---|
committer | Kenny Levinsen <kl@kl.wtf> | 2023-02-10 20:36:15 +0100 |
commit | 9162b536f69cb69466fb4fcfa24d282fa54b122b (patch) | |
tree | 57b2f8552fd626abce2e1e443e297cc97a09841e | |
parent | 1cab17ada243385798b3340f88144f64ac33ee63 (diff) | |
download | sway-9162b536f69cb69466fb4fcfa24d282fa54b122b.tar.xz |
Add support for fractional-scale-v1
References: https://gitlab.freedesktop.org/wlroots/wlroots/-/merge_requests/3511
-rw-r--r-- | sway/desktop/surface.c | 14 | ||||
-rw-r--r-- | sway/server.c | 2 |
2 files changed, 16 insertions, 0 deletions
diff --git a/sway/desktop/surface.c b/sway/desktop/surface.c index a5a18917..949cfdc2 100644 --- a/sway/desktop/surface.c +++ b/sway/desktop/surface.c @@ -2,6 +2,7 @@ #include <stdlib.h> #include <time.h> #include <wlr/types/wlr_compositor.h> +#include <wlr/types/wlr_fractional_scale_v1.h> #include "sway/server.h" #include "sway/surface.h" #include "sway/output.h" @@ -46,12 +47,25 @@ void handle_compositor_new_surface(struct wl_listener *listener, void *data) { } } +static void surface_update_outputs(struct wlr_surface *surface) { + float scale = 1; + struct wlr_surface_output *surface_output; + wl_list_for_each(surface_output, &surface->current_outputs, link) { + if (surface_output->output->scale > scale) { + scale = surface_output->output->scale; + } + } + wlr_fractional_scale_v1_notify_scale(surface, scale); +} + void surface_enter_output(struct wlr_surface *surface, struct sway_output *output) { wlr_surface_send_enter(surface, output->wlr_output); + surface_update_outputs(surface); } void surface_leave_output(struct wlr_surface *surface, struct sway_output *output) { wlr_surface_send_leave(surface, output->wlr_output); + surface_update_outputs(surface); } diff --git a/sway/server.c b/sway/server.c index 1ff0b461..244c7aec 100644 --- a/sway/server.c +++ b/sway/server.c @@ -14,6 +14,7 @@ #include <wlr/types/wlr_data_control_v1.h> #include <wlr/types/wlr_drm.h> #include <wlr/types/wlr_export_dmabuf_v1.h> +#include <wlr/types/wlr_fractional_scale_v1.h> #include <wlr/types/wlr_gamma_control_v1.h> #include <wlr/types/wlr_idle.h> #include <wlr/types/wlr_idle_notify_v1.h> @@ -214,6 +215,7 @@ bool server_init(struct sway_server *server) { wlr_single_pixel_buffer_manager_v1_create(server->wl_display); server->content_type_manager_v1 = wlr_content_type_manager_v1_create(server->wl_display, 1); + wlr_fractional_scale_manager_v1_create(server->wl_display, 1); struct wlr_xdg_foreign_registry *foreign_registry = wlr_xdg_foreign_registry_create(server->wl_display); |