From 34bdf25bb5af5f36568e0af8b6a95f2c93552d07 Mon Sep 17 00:00:00 2001 From: emersion Date: Sat, 2 Jun 2018 20:55:34 +0100 Subject: Only send frame to visible surfaces when fullscreened --- sway/desktop/output.c | 32 +++++++++++++++++++++----------- 1 file changed, 21 insertions(+), 11 deletions(-) diff --git a/sway/desktop/output.c b/sway/desktop/output.c index 964cfe00..a9ff9782 100644 --- a/sway/desktop/output.c +++ b/sway/desktop/output.c @@ -969,20 +969,30 @@ static void send_frame_done(struct sway_output *output, struct timespec *when) { .when = when, }; - send_frame_done_layer(&data, - &output->layers[ZWLR_LAYER_SHELL_V1_LAYER_BACKGROUND]); - send_frame_done_layer(&data, - &output->layers[ZWLR_LAYER_SHELL_V1_LAYER_BOTTOM]); - struct sway_container *workspace = output_get_active_workspace(output); - send_frame_done_container(&data, workspace); - send_frame_done_container(&data, workspace->sway_workspace->floating); + if (workspace->sway_workspace->fullscreen) { + send_frame_done_container_iterator( + workspace->sway_workspace->fullscreen->swayc, &data); + + if (workspace->sway_workspace->fullscreen->type == SWAY_VIEW_XWAYLAND) { + send_frame_done_unmanaged(&data, + &root_container.sway_root->xwayland_unmanaged); + } + } else { + send_frame_done_layer(&data, + &output->layers[ZWLR_LAYER_SHELL_V1_LAYER_BACKGROUND]); + send_frame_done_layer(&data, + &output->layers[ZWLR_LAYER_SHELL_V1_LAYER_BOTTOM]); - send_frame_done_unmanaged(&data, - &root_container.sway_root->xwayland_unmanaged); + send_frame_done_container(&data, workspace); + send_frame_done_container(&data, workspace->sway_workspace->floating); + + send_frame_done_unmanaged(&data, + &root_container.sway_root->xwayland_unmanaged); + send_frame_done_layer(&data, + &output->layers[ZWLR_LAYER_SHELL_V1_LAYER_TOP]); + } - send_frame_done_layer(&data, - &output->layers[ZWLR_LAYER_SHELL_V1_LAYER_TOP]); send_frame_done_layer(&data, &output->layers[ZWLR_LAYER_SHELL_V1_LAYER_OVERLAY]); } -- cgit v1.2.3