From 5689dbc2090e5479062fb6f5155aa2acf70929e6 Mon Sep 17 00:00:00 2001 From: passivestar <60579014+passivestar@users.noreply.github.com> Date: Tue, 13 Feb 2024 13:38:11 +0400 Subject: [PATCH] Allow to abort `SpinSlider` value changes --- editor/gui/editor_spin_slider.cpp | 78 +++++++++++++++++------- editor/gui/editor_spin_slider.h | 3 + editor/plugins/node_3d_editor_plugin.cpp | 4 ++ 3 files changed, 64 insertions(+), 21 deletions(-) diff --git a/editor/gui/editor_spin_slider.cpp b/editor/gui/editor_spin_slider.cpp index dd1440fe0b2..fab5784f167 100644 --- a/editor/gui/editor_spin_slider.cpp +++ b/editor/gui/editor_spin_slider.cpp @@ -68,27 +68,15 @@ void EditorSpinSlider::gui_input(const Ref &p_event) { } return; } else { - grabbing_spinner_attempt = true; - grabbing_spinner_dist_cache = 0; - pre_grab_value = get_value(); - grabbing_spinner = false; - grabbing_spinner_mouse_pos = get_global_mouse_position(); - emit_signal("grabbed"); + _grab_start(); } } else { - if (grabbing_spinner_attempt) { - if (grabbing_spinner) { - Input::get_singleton()->set_mouse_mode(Input::MOUSE_MODE_VISIBLE); - Input::get_singleton()->warp_mouse(grabbing_spinner_mouse_pos); - queue_redraw(); - emit_signal("ungrabbed"); - } else { - _focus_entered(); - } - - grabbing_spinner = false; - grabbing_spinner_attempt = false; - } + _grab_end(); + } + } else if (mb->get_button_index() == MouseButton::RIGHT) { + if (mb->is_pressed() && is_grabbing()) { + _grab_end(); + set_value(pre_grab_value); } } else if (mb->get_button_index() == MouseButton::WHEEL_UP || mb->get_button_index() == MouseButton::WHEEL_DOWN) { if (grabber->is_visible()) { @@ -142,8 +130,47 @@ void EditorSpinSlider::gui_input(const Ref &p_event) { } Ref k = p_event; - if (k.is_valid() && k->is_pressed() && k->is_action("ui_accept", true)) { - _focus_entered(); + if (k.is_valid() && k->is_pressed()) { + if (k->is_action("ui_accept", true)) { + _focus_entered(); + } else if (is_grabbing()) { + if (k->is_action("ui_cancel", true)) { + _grab_end(); + set_value(pre_grab_value); + } + accept_event(); + } + } +} + +void EditorSpinSlider::_grab_start() { + grabbing_spinner_attempt = true; + grabbing_spinner_dist_cache = 0; + pre_grab_value = get_value(); + grabbing_spinner = false; + grabbing_spinner_mouse_pos = get_global_mouse_position(); + emit_signal("grabbed"); +} + +void EditorSpinSlider::_grab_end() { + if (grabbing_spinner_attempt) { + if (grabbing_spinner) { + Input::get_singleton()->set_mouse_mode(Input::MOUSE_MODE_VISIBLE); + Input::get_singleton()->warp_mouse(grabbing_spinner_mouse_pos); + queue_redraw(); + grabbing_spinner = false; + emit_signal("ungrabbed"); + } else { + _focus_entered(); + } + + grabbing_spinner_attempt = false; + } + + if (grabbing_grabber) { + grabbing_grabber = false; + mousewheel_over_grabber = false; + emit_signal("ungrabbed"); } } @@ -173,16 +200,25 @@ void EditorSpinSlider::_grabber_gui_input(const Ref &p_event) { if (mb.is_valid() && mb->get_button_index() == MouseButton::LEFT) { if (mb->is_pressed()) { grabbing_grabber = true; + pre_grab_value = get_value(); if (!mousewheel_over_grabber) { grabbing_ratio = get_as_ratio(); grabbing_from = grabber->get_transform().xform(mb->get_position()).x; } + grab_focus(); emit_signal("grabbed"); } else { grabbing_grabber = false; mousewheel_over_grabber = false; emit_signal("ungrabbed"); } + } else if (mb.is_valid() && mb->get_button_index() == MouseButton::RIGHT) { + if (mb->is_pressed() && grabbing_grabber) { + grabbing_grabber = false; + mousewheel_over_grabber = false; + set_value(pre_grab_value); + emit_signal("ungrabbed"); + } } Ref mm = p_event; diff --git a/editor/gui/editor_spin_slider.h b/editor/gui/editor_spin_slider.h index 8c643157f12..a999f5c48f1 100644 --- a/editor/gui/editor_spin_slider.h +++ b/editor/gui/editor_spin_slider.h @@ -72,6 +72,9 @@ class EditorSpinSlider : public Range { bool hide_slider = false; bool flat = false; + void _grab_start(); + void _grab_end(); + void _grabber_gui_input(const Ref &p_event); void _value_input_closed(); void _value_input_submitted(const String &); diff --git a/editor/plugins/node_3d_editor_plugin.cpp b/editor/plugins/node_3d_editor_plugin.cpp index 92c1b1be1d5..f0cb2aa3a5c 100644 --- a/editor/plugins/node_3d_editor_plugin.cpp +++ b/editor/plugins/node_3d_editor_plugin.cpp @@ -1488,6 +1488,10 @@ Transform3D Node3DEditorViewport::_compute_transform(TransformMode p_mode, const } void Node3DEditorViewport::_surface_mouse_enter() { + if (Input::get_singleton()->get_mouse_mode() == Input::MOUSE_MODE_CAPTURED) { + return; + } + if (!surface->has_focus() && (!get_viewport()->gui_get_focus_owner() || !get_viewport()->gui_get_focus_owner()->is_text_field())) { surface->grab_focus(); }