From 93da082d32ce3a4892fcd88f460ceab9186fa1ef Mon Sep 17 00:00:00 2001 From: dec05eba Date: Fri, 2 Aug 2024 06:19:34 +0200 Subject: Always use transparent background, only take screenshot if no compositor --- src/main.cpp | 23 +++++++++++------------ 1 file changed, 11 insertions(+), 12 deletions(-) (limited to 'src/main.cpp') diff --git a/src/main.cpp b/src/main.cpp index 45f8693..581d656 100644 --- a/src/main.cpp +++ b/src/main.cpp @@ -223,7 +223,7 @@ int main(int argc, char **argv) { window_create_params.hidden = true; //window_create_params.override_redirect = true; window_create_params.background_color = bg_color; - window_create_params.support_alpha = is_compositor_running(display, 0); + window_create_params.support_alpha = true; window_create_params.window_type = MGL_WINDOW_TYPE_DIALOG; mgl::Window window; @@ -268,19 +268,18 @@ int main(int argc, char **argv) { if(!stream_button_texture.load_from_file((program_root_dir + "images/stream.png").c_str())) startup_error("failed to load texture: images/stream.png"); - // TODO: Only do these things if no compositor (with argb support) is running. // TODO: Get size from monitor, get region specific to the monitor - XImage *img = XGetImage(display, DefaultRootWindow(display), window_pos.x, window_pos.y, window_size.x, window_size.y, AllPlanes, ZPixmap); - if(!img) { - fprintf(stderr, "Error: failed to take a screenshot\n"); - exit(1); - } - mgl::Texture screenshot_texture; - if(!window_create_params.support_alpha) { - screenshot_texture = texture_from_ximage(img); - XDestroyImage(img); - img = NULL; + if(!is_compositor_running(display, 0)) { + XImage *img = XGetImage(display, DefaultRootWindow(display), window_pos.x, window_pos.y, window_size.x, window_size.y, AllPlanes, ZPixmap); + if(!img) + fprintf(stderr, "Error: failed to take a screenshot\n"); + + if(img) { + screenshot_texture = texture_from_ximage(img); + XDestroyImage(img); + img = NULL; + } } mgl::Sprite screenshot_sprite; -- cgit v1.2.3