Make debug_draw_opaque_regions work in screencasts again

This commit is contained in:
Ivan Molodetskikh
2026-01-26 06:17:40 +03:00
parent 5ddcf195dd
commit a34ed51586
2 changed files with 42 additions and 48 deletions
+10 -7
View File
@@ -148,7 +148,7 @@ use crate::protocols::mutter_x11_interop::MutterX11InteropManagerState;
use crate::protocols::output_management::OutputManagementManagerState;
use crate::protocols::screencopy::{Screencopy, ScreencopyBuffer, ScreencopyManagerState};
use crate::protocols::virtual_pointer::VirtualPointerManagerState;
use crate::render_helpers::debug::draw_opaque_regions;
use crate::render_helpers::debug::push_opaque_regions;
use crate::render_helpers::primary_gpu_texture::PrimaryGpuTextureRenderElement;
use crate::render_helpers::renderer::NiriRenderer;
use crate::render_helpers::solid_color::{SolidColorBuffer, SolidColorRenderElement};
@@ -4036,12 +4036,6 @@ impl Niri {
self.render_inner(renderer, output, include_pointer, target, &mut |elem| {
elements.push(elem)
});
if self.debug_draw_opaque_regions {
let output_scale = Scale::from(output.current_scale().fractional_scale());
draw_opaque_regions(&mut elements, output_scale);
}
elements
}
@@ -4066,6 +4060,15 @@ impl Niri {
let output_scale = Scale::from(output.current_scale().fractional_scale());
let push = if self.debug_draw_opaque_regions {
&mut move |elem| {
push_opaque_regions(&elem, output_scale, push);
push(elem);
}
} else {
push
};
// The pointer goes on the top.
if include_pointer && self.pointer_visibility.is_visible() {
self.render_pointer(renderer, output, &mut |elem| push(elem.into()));