diff options
author | emersion <contact@emersion.fr> | 2017-12-12 21:09:51 +0100 |
---|---|---|
committer | emersion <contact@emersion.fr> | 2017-12-12 21:09:51 +0100 |
commit | d293c429424a9f96c3fc8143af457645326e7a0e (patch) | |
tree | 530509af18e72af36a52e9fd3970a706695919be /sway/desktop/output.c | |
parent | Listen to output layout change (diff) | |
download | sway-d293c429424a9f96c3fc8143af457645326e7a0e.tar.gz sway-d293c429424a9f96c3fc8143af457645326e7a0e.tar.zst sway-d293c429424a9f96c3fc8143af457645326e7a0e.zip |
Update output container box in event handler
Diffstat (limited to 'sway/desktop/output.c')
-rw-r--r-- | sway/desktop/output.c | 23 |
1 files changed, 17 insertions, 6 deletions
diff --git a/sway/desktop/output.c b/sway/desktop/output.c index bcdaa7d2..3fd49846 100644 --- a/sway/desktop/output.c +++ b/sway/desktop/output.c | |||
@@ -91,19 +91,30 @@ static void output_frame_notify(struct wl_listener *listener, void *data) { | |||
91 | soutput->last_frame = now; | 91 | soutput->last_frame = now; |
92 | } | 92 | } |
93 | 93 | ||
94 | static void output_update_size(struct sway_output *output) { | ||
95 | struct wlr_box *output_layout_box = wlr_output_layout_get_box( | ||
96 | root_container.sway_root->output_layout, output->wlr_output); | ||
97 | output->swayc->x = output_layout_box->x; | ||
98 | output->swayc->y = output_layout_box->y; | ||
99 | output->swayc->width = output_layout_box->width; | ||
100 | output->swayc->height = output_layout_box->height; | ||
101 | |||
102 | arrange_windows(output->swayc, -1, -1); | ||
103 | } | ||
104 | |||
94 | static void output_resolution_notify(struct wl_listener *listener, void *data) { | 105 | static void output_resolution_notify(struct wl_listener *listener, void *data) { |
95 | struct sway_output *soutput = wl_container_of(listener, soutput, resolution); | 106 | struct sway_output *output = wl_container_of(listener, output, resolution); |
96 | arrange_windows(soutput->swayc, -1, -1); | 107 | output_update_size(output); |
97 | } | 108 | } |
98 | 109 | ||
99 | static void output_scale_notify(struct wl_listener *listener, void *data) { | 110 | static void output_scale_notify(struct wl_listener *listener, void *data) { |
100 | struct sway_output *soutput = wl_container_of(listener, soutput, scale); | 111 | struct sway_output *output = wl_container_of(listener, output, scale); |
101 | arrange_windows(soutput->swayc, -1, -1); | 112 | output_update_size(output); |
102 | } | 113 | } |
103 | 114 | ||
104 | static void output_transform_notify(struct wl_listener *listener, void *data) { | 115 | static void output_transform_notify(struct wl_listener *listener, void *data) { |
105 | struct sway_output *soutput = wl_container_of(listener, soutput, transform); | 116 | struct sway_output *output = wl_container_of(listener, output, transform); |
106 | arrange_windows(soutput->swayc, -1, -1); | 117 | output_update_size(output); |
107 | } | 118 | } |
108 | 119 | ||
109 | void output_add_notify(struct wl_listener *listener, void *data) { | 120 | void output_add_notify(struct wl_listener *listener, void *data) { |