From b40dba18c642fa959c4bad59fea99416a31f0825 Mon Sep 17 00:00:00 2001 From: Harrison Gieraltowski Date: Wed, 8 Feb 2023 03:35:44 -0500 Subject: [PATCH] DragValue: when keyboard editing, only update the value on focus lost (#2688) * test * moved some accesskit stuff * reverted accesskit change * Add explanatory comment * fmt --------- Co-authored-by: Emil Ernerfeldt --- crates/egui/src/widgets/drag_value.rs | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) diff --git a/crates/egui/src/widgets/drag_value.rs b/crates/egui/src/widgets/drag_value.rs index 59507be2690..0d33978f2a6 100644 --- a/crates/egui/src/widgets/drag_value.rs +++ b/crates/egui/src/widgets/drag_value.rs @@ -475,13 +475,17 @@ impl<'a> Widget for DragValue<'a> { .desired_width(ui.spacing().interact_size.x) .font(text_style), ); - let parsed_value = match custom_parser { - Some(parser) => parser(&value_text), - None => value_text.parse().ok(), - }; - if let Some(parsed_value) = parsed_value { - let parsed_value = clamp_to_range(parsed_value, clamp_range.clone()); - set(&mut get_set_value, parsed_value); + // Only update the value when the user presses enter, or clicks elsewhere. NOT every frame. + // See https://github.com/emilk/egui/issues/2687 + if response.lost_focus() { + let parsed_value = match custom_parser { + Some(parser) => parser(&value_text), + None => value_text.parse().ok(), + }; + if let Some(parsed_value) = parsed_value { + let parsed_value = clamp_to_range(parsed_value, clamp_range.clone()); + set(&mut get_set_value, parsed_value); + } } ui.memory_mut(|mem| mem.drag_value.edit_string = Some(value_text)); response