mirror of https://github.com/encounter/objdiff.git
Fix some hotkeys stealing input from focused widgets
e.g. The symbol list was stealing the W/S key presses when typing into the symbol filter text edit. If the user actually wants to use these shortcuts while a widget is focused, they can simply press the escape key to unfocus all widgets and then press the shortcut.
This commit is contained in:
parent
046f3d6999
commit
77c104c67b
|
@ -1,20 +1,34 @@
|
||||||
use egui::{style::ScrollAnimation, vec2, Context, Key, Modifiers, PointerButton};
|
use egui::{style::ScrollAnimation, vec2, Context, Key, Modifiers, PointerButton};
|
||||||
|
|
||||||
|
fn any_widget_focused(ctx: &Context) -> bool { ctx.memory(|mem| mem.focused().is_some()) }
|
||||||
|
|
||||||
pub fn enter_pressed(ctx: &Context) -> bool {
|
pub fn enter_pressed(ctx: &Context) -> bool {
|
||||||
|
if any_widget_focused(ctx) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
ctx.input_mut(|i| i.key_pressed(Key::Enter) || i.pointer.button_pressed(PointerButton::Extra2))
|
ctx.input_mut(|i| i.key_pressed(Key::Enter) || i.pointer.button_pressed(PointerButton::Extra2))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn back_pressed(ctx: &Context) -> bool {
|
pub fn back_pressed(ctx: &Context) -> bool {
|
||||||
|
if any_widget_focused(ctx) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
ctx.input_mut(|i| {
|
ctx.input_mut(|i| {
|
||||||
i.key_pressed(Key::Backspace) || i.pointer.button_pressed(PointerButton::Extra1)
|
i.key_pressed(Key::Backspace) || i.pointer.button_pressed(PointerButton::Extra1)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn up_pressed(ctx: &Context) -> bool {
|
pub fn up_pressed(ctx: &Context) -> bool {
|
||||||
|
if any_widget_focused(ctx) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
ctx.input_mut(|i| i.key_pressed(Key::ArrowUp) || i.key_pressed(Key::W))
|
ctx.input_mut(|i| i.key_pressed(Key::ArrowUp) || i.key_pressed(Key::W))
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn down_pressed(ctx: &Context) -> bool {
|
pub fn down_pressed(ctx: &Context) -> bool {
|
||||||
|
if any_widget_focused(ctx) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
ctx.input_mut(|i| i.key_pressed(Key::ArrowDown) || i.key_pressed(Key::S))
|
ctx.input_mut(|i| i.key_pressed(Key::ArrowDown) || i.key_pressed(Key::S))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -44,12 +58,18 @@ pub fn check_scroll_hotkeys(ui: &mut egui::Ui, include_small_increments: bool) {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn consume_up_key(ctx: &Context) -> bool {
|
pub fn consume_up_key(ctx: &Context) -> bool {
|
||||||
|
if any_widget_focused(ctx) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
ctx.input_mut(|i| {
|
ctx.input_mut(|i| {
|
||||||
i.consume_key(Modifiers::NONE, Key::ArrowUp) || i.consume_key(Modifiers::NONE, Key::W)
|
i.consume_key(Modifiers::NONE, Key::ArrowUp) || i.consume_key(Modifiers::NONE, Key::W)
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn consume_down_key(ctx: &Context) -> bool {
|
pub fn consume_down_key(ctx: &Context) -> bool {
|
||||||
|
if any_widget_focused(ctx) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
ctx.input_mut(|i| {
|
ctx.input_mut(|i| {
|
||||||
i.consume_key(Modifiers::NONE, Key::ArrowDown) || i.consume_key(Modifiers::NONE, Key::S)
|
i.consume_key(Modifiers::NONE, Key::ArrowDown) || i.consume_key(Modifiers::NONE, Key::S)
|
||||||
})
|
})
|
||||||
|
|
Loading…
Reference in New Issue