From a375e77b85700f8da8547f9580296e17b376ae3a Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E9=A3=8E=E9=9D=92=E5=B1=B1?= Date: Wed, 26 Feb 2025 16:25:50 +0800 Subject: [PATCH] Revert "Fix inspector follow focus when child is focused" This reverts commit 286d3ae41595f7bcfc7d0812e861d56215560abd. --- editor/editor_inspector.cpp | 21 +++++++++------------ editor/editor_inspector.h | 1 - scene/gui/scroll_container.h | 2 +- 3 files changed, 10 insertions(+), 14 deletions(-) diff --git a/editor/editor_inspector.cpp b/editor/editor_inspector.cpp index 58b02ed2b8a..2a4ca11e650 100644 --- a/editor/editor_inspector.cpp +++ b/editor/editor_inspector.cpp @@ -4528,14 +4528,6 @@ void EditorInspector::_node_removed(Node *p_node) { } } -void EditorInspector::_gui_focus_changed(Control *p_control) { - if (!is_visible_in_tree() && !is_following_focus()) { - return; - } - // Don't follow focus when the inspector nor any of its children is focused. Prevents potential jumping when gaining focus. - set_follow_focus(has_focus() || child_has_focus()); -} - void EditorInspector::_update_current_favorites() { current_favorites.clear(); if (!can_favorite) { @@ -4733,10 +4725,6 @@ void EditorInspector::_notification(int p_what) { if (!is_sub_inspector()) { get_tree()->connect("node_removed", callable_mp(this, &EditorInspector::_node_removed)); } - - Viewport *viewport = get_viewport(); - ERR_FAIL_NULL(viewport); - viewport->connect("gui_focus_changed", callable_mp(this, &EditorInspector::_gui_focus_changed)); } break; case NOTIFICATION_PREDELETE: { @@ -4819,6 +4807,15 @@ void EditorInspector::_notification(int p_what) { update_tree(); } } break; + + case NOTIFICATION_FOCUS_ENTER: { + set_follow_focus(true); + } break; + + case NOTIFICATION_FOCUS_EXIT: { + // Don't follow focus when the inspector is not focused. Prevents potential jumping when gaining focus. + set_follow_focus(false); + } break; } } diff --git a/editor/editor_inspector.h b/editor/editor_inspector.h index 9baf65444f2..ee82806003b 100644 --- a/editor/editor_inspector.h +++ b/editor/editor_inspector.h @@ -606,7 +606,6 @@ class EditorInspector : public ScrollContainer { void _clear_current_favorites(); void _node_removed(Node *p_node); - void _gui_focus_changed(Control *p_control); HashMap per_array_page; void _page_change_request(int p_new_page, const StringName &p_array_prefix); diff --git a/scene/gui/scroll_container.h b/scene/gui/scroll_container.h index 408f70157df..ea6309f57e8 100644 --- a/scene/gui/scroll_container.h +++ b/scene/gui/scroll_container.h @@ -82,6 +82,7 @@ private: bool draw_focus_border = false; bool focus_border_is_drawn = false; + bool child_has_focus(); protected: Size2 get_minimum_size() const override; @@ -98,7 +99,6 @@ protected: public: virtual void gui_input(const Ref &p_gui_input) override; - bool child_has_focus(); void set_h_scroll(int p_pos); int get_h_scroll() const;