Z index shenanigans (#4089)

Release Notes:

- Fixed a bug allowing certain UI elements to render incorrectly when
overlapping.
This commit is contained in:
Julia 2024-01-17 09:48:08 -05:00 committed by GitHub
commit 2fbf42d7df
No known key found for this signature in database
GPG key ID: B5690EEEBB952194
4 changed files with 13 additions and 3 deletions

View file

@ -339,6 +339,7 @@ fn show_hover(
this.hover_state.info_popover = hover_popover; this.hover_state.info_popover = hover_popover;
cx.notify(); cx.notify();
cx.refresh();
})?; })?;
Ok::<_, anyhow::Error>(()) Ok::<_, anyhow::Error>(())

View file

@ -386,7 +386,7 @@ impl Style {
let background_color = self.background.as_ref().and_then(Fill::color); let background_color = self.background.as_ref().and_then(Fill::color);
if background_color.map_or(false, |color| !color.is_transparent()) { if background_color.map_or(false, |color| !color.is_transparent()) {
cx.with_z_index(1, |cx| { cx.with_z_index(0, |cx| {
let mut border_color = background_color.unwrap_or_default(); let mut border_color = background_color.unwrap_or_default();
border_color.a = 0.; border_color.a = 0.;
cx.paint_quad(quad( cx.paint_quad(quad(
@ -399,12 +399,12 @@ impl Style {
}); });
} }
cx.with_z_index(2, |cx| { cx.with_z_index(0, |cx| {
continuation(cx); continuation(cx);
}); });
if self.is_border_visible() { if self.is_border_visible() {
cx.with_z_index(3, |cx| { cx.with_z_index(0, |cx| {
let corner_radii = self.corner_radii.to_pixels(bounds.size, rem_size); let corner_radii = self.corner_radii.to_pixels(bounds.size, rem_size);
let border_widths = self.border_widths.to_pixels(rem_size); let border_widths = self.border_widths.to_pixels(rem_size);
let max_border_width = border_widths.max(); let max_border_width = border_widths.max();

View file

@ -315,6 +315,7 @@ pub(crate) struct Frame {
pub(crate) depth_map: Vec<(StackingOrder, EntityId, Bounds<Pixels>)>, pub(crate) depth_map: Vec<(StackingOrder, EntityId, Bounds<Pixels>)>,
pub(crate) z_index_stack: StackingOrder, pub(crate) z_index_stack: StackingOrder,
pub(crate) next_stacking_order_id: u32, pub(crate) next_stacking_order_id: u32,
next_root_z_index: u8,
content_mask_stack: Vec<ContentMask<Pixels>>, content_mask_stack: Vec<ContentMask<Pixels>>,
element_offset_stack: Vec<Point<Pixels>>, element_offset_stack: Vec<Point<Pixels>>,
requested_input_handler: Option<RequestedInputHandler>, requested_input_handler: Option<RequestedInputHandler>,
@ -337,6 +338,7 @@ impl Frame {
depth_map: Vec::new(), depth_map: Vec::new(),
z_index_stack: StackingOrder::default(), z_index_stack: StackingOrder::default(),
next_stacking_order_id: 0, next_stacking_order_id: 0,
next_root_z_index: 0,
content_mask_stack: Vec::new(), content_mask_stack: Vec::new(),
element_offset_stack: Vec::new(), element_offset_stack: Vec::new(),
requested_input_handler: None, requested_input_handler: None,
@ -354,6 +356,7 @@ impl Frame {
self.dispatch_tree.clear(); self.dispatch_tree.clear();
self.depth_map.clear(); self.depth_map.clear();
self.next_stacking_order_id = 0; self.next_stacking_order_id = 0;
self.next_root_z_index = 0;
self.reused_views.clear(); self.reused_views.clear();
self.scene.clear(); self.scene.clear();
self.requested_input_handler.take(); self.requested_input_handler.take();
@ -2450,8 +2453,13 @@ pub trait BorrowWindow: BorrowMut<Window> + BorrowMut<AppContext> {
}; };
let new_stacking_order_id = let new_stacking_order_id =
post_inc(&mut self.window_mut().next_frame.next_stacking_order_id); post_inc(&mut self.window_mut().next_frame.next_stacking_order_id);
let new_root_z_index = post_inc(&mut self.window_mut().next_frame.next_root_z_index);
let old_stacking_order = mem::take(&mut self.window_mut().next_frame.z_index_stack); let old_stacking_order = mem::take(&mut self.window_mut().next_frame.z_index_stack);
self.window_mut().next_frame.z_index_stack.id = new_stacking_order_id; self.window_mut().next_frame.z_index_stack.id = new_stacking_order_id;
self.window_mut()
.next_frame
.z_index_stack
.push(new_root_z_index);
self.window_mut().next_frame.content_mask_stack.push(mask); self.window_mut().next_frame.content_mask_stack.push(mask);
let result = f(self); let result = f(self);
self.window_mut().next_frame.content_mask_stack.pop(); self.window_mut().next_frame.content_mask_stack.pop();

View file

@ -51,6 +51,7 @@ impl ContextMenu {
let _on_blur_subscription = cx.on_blur(&focus_handle, |this: &mut ContextMenu, cx| { let _on_blur_subscription = cx.on_blur(&focus_handle, |this: &mut ContextMenu, cx| {
this.cancel(&menu::Cancel, cx) this.cancel(&menu::Cancel, cx)
}); });
cx.refresh();
f( f(
Self { Self {
items: Default::default(), items: Default::default(),