diff options
author | malbach <malbach@free.fr> | 2020-01-13 12:13:00 +0100 |
---|---|---|
committer | malbach <malbach@free.fr> | 2020-01-13 14:37:55 +0100 |
commit | bc8ce836e3585b100df0c4cddf6ef2bdada3460a (patch) | |
tree | b7768878bdb8a0434f76c79e57bb62d39c7f458d /scene | |
parent | 52f44e72b61a8e9e923454bacdcf62de1b1c6309 (diff) |
Fix overlapping scrollbars in ScrollContainer (#33309)
Diffstat (limited to 'scene')
-rw-r--r-- | scene/gui/scroll_container.cpp | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/scene/gui/scroll_container.cpp b/scene/gui/scroll_container.cpp index dc1183df74..4712f4cb9d 100644 --- a/scene/gui/scroll_container.cpp +++ b/scene/gui/scroll_container.cpp @@ -420,6 +420,9 @@ void ScrollContainer::update_scrollbars() { v_scroll->hide(); scroll.y = 0; + + // modify the horizontal scrollbar's right anchor to fill the container's width + h_scroll->set_anchor_and_margin(MARGIN_RIGHT, ANCHOR_END, 0); } else { v_scroll->show(); @@ -431,12 +434,18 @@ void ScrollContainer::update_scrollbars() { } scroll.y = v_scroll->get_value(); + + // modify the horizontal scrollbar's right anchor to stop at the left of the vertical scrollbar + h_scroll->set_anchor_and_margin(MARGIN_RIGHT, ANCHOR_END, -vmin.width); } if (hide_scroll_h) { h_scroll->hide(); scroll.x = 0; + + // modify the vertical scrollbar's bottom anchor to fill the container's height + v_scroll->set_anchor_and_margin(MARGIN_BOTTOM, ANCHOR_END, 0); } else { h_scroll->show(); @@ -448,6 +457,9 @@ void ScrollContainer::update_scrollbars() { } scroll.x = h_scroll->get_value(); + + // modify the vertical scrollbar's bottom anchor to stop at the top of the horizontal scrollbar + v_scroll->set_anchor_and_margin(MARGIN_BOTTOM, ANCHOR_END, -hmin.height); } } |