From c0969c336e6528f5b98df0c4bf978de79fe6ee6d Mon Sep 17 00:00:00 2001 From: Juan Campa Date: Fri, 11 Feb 2022 14:35:50 -0500 Subject: [PATCH 1/4] Make non interactable layers not interact --- egui/src/memory.rs | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/egui/src/memory.rs b/egui/src/memory.rs index 4809f2de514..b5cdfe7b420 100644 --- a/egui/src/memory.rs +++ b/egui/src/memory.rs @@ -516,9 +516,9 @@ impl Areas { if state.interactable { // Allow us to resize by dragging just outside the window: rect = rect.expand(resize_interact_radius_side); - } - if rect.contains(pos) { - return Some(*layer); + if rect.contains(pos) { + return Some(*layer); + } } } } From 8992b484a7b7576e97702bb726edb37ccf6138a7 Mon Sep 17 00:00:00 2001 From: Juan Campa Date: Fri, 11 Feb 2022 15:05:10 -0500 Subject: [PATCH 2/4] Update CHANGELOG.md --- CHANGELOG.md | 3 +++ 1 file changed, 3 insertions(+) diff --git a/CHANGELOG.md b/CHANGELOG.md index eeb02be9a55..904e641bd46 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -44,12 +44,15 @@ NOTE: [`epaint`](epaint/CHANGELOG.md), [`eframe`](eframe/CHANGELOG.md), [`egui_w * Replaced Frame's `margin: Vec2` with `margin: Margin`, allowing for different margins on opposing sides ([#1219](https://github.com/emilk/egui/pull/1219)). * `Plot::highlight` now takes a `bool` argument ([#1159](https://github.com/emilk/egui/pull/1159)). * `ScrollArea::show` now returns a `ScrollAreaOutput`, so you might need to add `.inner` after the call to it ([#1166](https://github.com/emilk/egui/pull/1166)). +* Tooltips that don't fit the window don't flicker anymore ([#1240](https://github.com/emilk/egui/pull/1240)). +* `Areas::layer_id_at` ignores non interatable layers (i.e. Tooltips) ([#1240](https://github.com/emilk/egui/pull/1240)). ### Fixed 🐛 * Context menus now respects the theme ([#1043](https://github.com/emilk/egui/pull/1043)). * Plot `Orientation` was not public, although fields using this type were ([#1130](https://github.com/emilk/egui/pull/1130)). * Fixed `enable_drag` for Windows ([#1108](https://github.com/emilk/egui/pull/1108)). * Calling `Context::set_pixels_per_point` before the first frame will now work. +* Tooltips that don't fit the window don't flicker anymore ([#1240](https://github.com/emilk/egui/pull/1240)). ### Contributors 🙏 * [AlexxxRu](https://github.com/alexxxru): [#1108](https://github.com/emilk/egui/pull/1108). From ef7f8c497e8968325fadc5f7edef6c359c86b058 Mon Sep 17 00:00:00 2001 From: Juan Campa Date: Fri, 11 Feb 2022 19:43:54 -0500 Subject: [PATCH 3/4] Make menus interactable --- egui/src/menu.rs | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/egui/src/menu.rs b/egui/src/menu.rs index d2b87216b95..46146821ab2 100644 --- a/egui/src/menu.rs +++ b/egui/src/menu.rs @@ -126,7 +126,7 @@ pub(crate) fn menu_ui<'c, R>( let area = Area::new(menu_id) .order(Order::Foreground) .fixed_pos(pos) - .interactable(false) + .interactable(true) .drag_bounds(Rect::EVERYTHING); let inner_response = area.show(ctx, |ui| { ui.scope(|ui| { From df8bb6cf792c57ce744a1b33d54f16ca79deb59e Mon Sep 17 00:00:00 2001 From: Juan Campa Date: Sun, 13 Feb 2022 08:23:23 -0500 Subject: [PATCH 4/4] Fix area interactable not being updated each frame --- egui/src/containers/area.rs | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/egui/src/containers/area.rs b/egui/src/containers/area.rs index 9ff25d5fbbd..6501a1d780a 100644 --- a/egui/src/containers/area.rs +++ b/egui/src/containers/area.rs @@ -204,7 +204,7 @@ impl Area { let state = ctx.memory().areas.get(id).cloned(); let is_new = state.is_none(); if is_new { - ctx.request_repaint(); // if we don't know the previous size we are likely drawing the area in the wrong place} + ctx.request_repaint(); // if we don't know the previous size we are likely drawing the area in the wrong place } let mut state = state.unwrap_or_else(|| State { pos: default_pos.unwrap_or_else(|| automatic_area_position(ctx)), @@ -212,6 +212,7 @@ impl Area { interactable, }); state.pos = new_pos.unwrap_or(state.pos); + state.interactable = interactable; if let Some((anchor, offset)) = anchor { if is_new {