diff options
author | Dudemanguy <random342@airmail.cc> | 2020-10-01 11:00:58 -0500 |
---|---|---|
committer | Dudemanguy <random342@airmail.cc> | 2020-10-01 11:12:22 -0500 |
commit | 34b8adc4562f38374d8eb981b002f268dc5640d4 (patch) | |
tree | e2bf777aa9dd629e526a2bd0819a4a208f8b8541 /video/out/opengl/context_wayland.c | |
parent | dcec6d9556c6cfca11b865442174479096f55111 (diff) | |
download | mpv-34b8adc4562f38374d8eb981b002f268dc5640d4.tar.bz2 mpv-34b8adc4562f38374d8eb981b002f268dc5640d4.tar.xz |
wayland: set an opaque region
Apparently a part of the wayland spec. A compositor may use a surface
that has set part of itself as opaque for various optimizations. For
mpv, we simply set the entire surface as opaque as long as the user has
not set alpha=yes (note: alpha is technically broken in the wayland EGL
backend at the time of this commit but oh well). wlshm is always opaque.
Fixes #8125.
Diffstat (limited to 'video/out/opengl/context_wayland.c')
-rw-r--r-- | video/out/opengl/context_wayland.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/video/out/opengl/context_wayland.c b/video/out/opengl/context_wayland.c index 13040b54d8..c0a8aee206 100644 --- a/video/out/opengl/context_wayland.c +++ b/video/out/opengl/context_wayland.c @@ -122,6 +122,13 @@ static void resize(struct ra_ctx *ctx) const int32_t width = wl->scaling*mp_rect_w(wl->geometry); const int32_t height = wl->scaling*mp_rect_h(wl->geometry); + if (!ctx->opts.want_alpha) { + struct wl_region *region = wl_compositor_create_region(wl->compositor); + wl_region_add(region, 0, 0, width, height); + wl_surface_set_opaque_region(wl->surface, region); + wl_region_destroy(region); + } + wl_surface_set_buffer_scale(wl->surface, wl->scaling); if (p->egl_window) |