mirror of
https://github.com/zed-industries/zed.git
synced 2025-01-11 13:10:54 +00:00
Use visible bounds to determine hit bounds for cursor/mouse regions
This commit is contained in:
parent
5c84f4b92c
commit
a26af194e7
4 changed files with 18 additions and 11 deletions
|
@ -212,12 +212,14 @@ impl Element for Container {
|
|||
});
|
||||
}
|
||||
|
||||
if let Some(hit_bounds) = quad_bounds.intersection(visible_bounds) {
|
||||
if let Some(style) = self.style.cursor {
|
||||
cx.scene.push_cursor_region(CursorRegion {
|
||||
bounds: quad_bounds,
|
||||
bounds: hit_bounds,
|
||||
style,
|
||||
});
|
||||
}
|
||||
}
|
||||
|
||||
let child_origin =
|
||||
quad_bounds.origin() + vec2f(self.style.padding.left, self.style.padding.top);
|
||||
|
|
|
@ -78,13 +78,13 @@ impl Element for EventHandler {
|
|||
if let Some(discriminant) = self.capture_all {
|
||||
cx.scene.push_stacking_context(None);
|
||||
cx.scene.push_cursor_region(CursorRegion {
|
||||
bounds,
|
||||
bounds: visible_bounds,
|
||||
style: Default::default(),
|
||||
});
|
||||
cx.scene.push_mouse_region(MouseRegion {
|
||||
view_id: cx.current_view_id(),
|
||||
discriminant: Some(discriminant),
|
||||
bounds,
|
||||
bounds: visible_bounds,
|
||||
hover: Some(Rc::new(|_, _, _| {})),
|
||||
mouse_down: Some(Rc::new(|_, _| {})),
|
||||
click: Some(Rc::new(|_, _, _| {})),
|
||||
|
|
|
@ -152,9 +152,10 @@ impl Element for MouseEventHandler {
|
|||
_: &mut Self::LayoutState,
|
||||
cx: &mut PaintContext,
|
||||
) -> Self::PaintState {
|
||||
let hit_bounds = self.hit_bounds(visible_bounds);
|
||||
if let Some(style) = self.cursor_style {
|
||||
cx.scene.push_cursor_region(CursorRegion {
|
||||
bounds: self.hit_bounds(bounds),
|
||||
bounds: hit_bounds,
|
||||
style,
|
||||
});
|
||||
}
|
||||
|
@ -162,7 +163,7 @@ impl Element for MouseEventHandler {
|
|||
cx.scene.push_mouse_region(MouseRegion {
|
||||
view_id: cx.current_view_id(),
|
||||
discriminant: Some((self.tag, self.id)),
|
||||
bounds: self.hit_bounds(bounds),
|
||||
bounds: hit_bounds,
|
||||
hover: self.hover.clone(),
|
||||
click: self.click.clone(),
|
||||
mouse_down: self.mouse_down.clone(),
|
||||
|
|
|
@ -250,12 +250,16 @@ impl Scene {
|
|||
}
|
||||
|
||||
pub fn push_cursor_region(&mut self, region: CursorRegion) {
|
||||
if can_draw(region.bounds) {
|
||||
self.active_layer().push_cursor_region(region);
|
||||
}
|
||||
}
|
||||
|
||||
pub fn push_mouse_region(&mut self, region: MouseRegion) {
|
||||
if can_draw(region.bounds) {
|
||||
self.active_layer().push_mouse_region(region);
|
||||
}
|
||||
}
|
||||
|
||||
pub fn push_image(&mut self, image: Image) {
|
||||
self.active_layer().push_image(image)
|
||||
|
|
Loading…
Reference in a new issue