From 3d0676a588770542d0c62cc732b935756ba2801c Mon Sep 17 00:00:00 2001 From: Yuri Sizov Date: Thu, 2 Dec 2021 19:03:31 +0300 Subject: [PATCH] Allow scrolling theme preview when the control picker is active (cherry picked from commit eb98210be416e9c247c5b447e58a5c8724a04cbe) --- editor/plugins/theme_editor_preview.cpp | 6 +++++- editor/plugins/theme_editor_preview.h | 1 + 2 files changed, 6 insertions(+), 1 deletion(-) diff --git a/editor/plugins/theme_editor_preview.cpp b/editor/plugins/theme_editor_preview.cpp index 5f7e5a87483..912d0f3a764 100644 --- a/editor/plugins/theme_editor_preview.cpp +++ b/editor/plugins/theme_editor_preview.cpp @@ -150,6 +150,7 @@ void ThemeEditorPreview::_gui_input_picker_overlay(const Ref &p_even emit_signal("control_picked", theme_type); picker_button->set_pressed(false); picker_overlay->set_visible(false); + return; } } @@ -160,6 +161,9 @@ void ThemeEditorPreview::_gui_input_picker_overlay(const Ref &p_even hovered_control = _find_hovered_control(preview_content, mp); picker_overlay->update(); } + + // Forward input to the scroll container underneath to allow scrolling. + preview_container->call("_gui_input", p_event); } void ThemeEditorPreview::_reset_picker_overlay() { @@ -223,7 +227,7 @@ ThemeEditorPreview::ThemeEditorPreview() { preview_body->set_v_size_flags(SIZE_EXPAND_FILL); add_child(preview_body); - ScrollContainer *preview_container = memnew(ScrollContainer); + preview_container = memnew(ScrollContainer); preview_container->set_enable_v_scroll(true); preview_container->set_enable_h_scroll(true); preview_body->add_child(preview_container); diff --git a/editor/plugins/theme_editor_preview.h b/editor/plugins/theme_editor_preview.h index 4e1b149e701..e0f8e645e2e 100644 --- a/editor/plugins/theme_editor_preview.h +++ b/editor/plugins/theme_editor_preview.h @@ -55,6 +55,7 @@ class ThemeEditorPreview : public VBoxContainer { GDCLASS(ThemeEditorPreview, VBoxContainer); + ScrollContainer *preview_container; ColorRect *preview_bg; MarginContainer *preview_overlay; Control *picker_overlay;