diff options
author | MrCdK <contact@mrcdk.com> | 2019-10-02 12:34:04 +0200 |
---|---|---|
committer | MrCdK <contact@mrcdk.com> | 2019-10-02 12:34:04 +0200 |
commit | 03d6291aafd2b05b5f4d5d75688bb61ecbe91e61 (patch) | |
tree | 9047309edbf680c79693d61d7b8e68cb30bc8c76 /scene/gui | |
parent | a737bceb4e40d8472762630566716c19ab89d0ec (diff) |
Handle scrolling correctly in Tree controls inside ScrollContainers
Diffstat (limited to 'scene/gui')
-rw-r--r-- | scene/gui/tree.cpp | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/scene/gui/tree.cpp b/scene/gui/tree.cpp index 2fc4be6900..50b0b12029 100644 --- a/scene/gui/tree.cpp +++ b/scene/gui/tree.cpp @@ -2677,11 +2677,21 @@ void Tree::_gui_input(Ref<InputEvent> p_event) { } break; case BUTTON_WHEEL_UP: { + double prev_value = v_scroll->get_value(); v_scroll->set_value(v_scroll->get_value() - v_scroll->get_page() * b->get_factor() / 8); + if (v_scroll->get_value() != prev_value) { + accept_event(); + } + } break; case BUTTON_WHEEL_DOWN: { + double prev_value = v_scroll->get_value(); v_scroll->set_value(v_scroll->get_value() + v_scroll->get_page() * b->get_factor() / 8); + if (v_scroll->get_value() != prev_value) { + accept_event(); + } + } break; } } @@ -2689,7 +2699,11 @@ void Tree::_gui_input(Ref<InputEvent> p_event) { Ref<InputEventPanGesture> pan_gesture = p_event; if (pan_gesture.is_valid()) { + double prev_value = v_scroll->get_value(); v_scroll->set_value(v_scroll->get_value() + v_scroll->get_page() * pan_gesture->get_delta().y / 8); + if (v_scroll->get_value() != prev_value) { + accept_event(); + } } } |