diff options
author | mvl <marnicq_the_best@hotmail.com> | 2020-07-24 01:42:40 +0200 |
---|---|---|
committer | mvl <marnicq_the_best@hotmail.com> | 2020-08-31 20:09:28 +0200 |
commit | 4318ad94acb2f1f3dabfed1d5159da6fe013b529 (patch) | |
tree | 50f17cb7362429c21e3453524e294a8bce62829b /scene/gui | |
parent | 2cfc5b8680bf7c1f75b02f83f7ecc26d1e49021f (diff) |
Fix bug where leading and trailing spaces werent taken into account with center and right allignment.
Diffstat (limited to 'scene/gui')
-rw-r--r-- | scene/gui/label.cpp | 18 |
1 files changed, 17 insertions, 1 deletions
diff --git a/scene/gui/label.cpp b/scene/gui/label.cpp index f49acc1b96..321f907cc7 100644 --- a/scene/gui/label.cpp +++ b/scene/gui/label.cpp @@ -188,7 +188,7 @@ void Label::_notification(int p_what) { int spaces = 0; while (to && to->char_pos >= 0) { taken += to->pixel_width; - if (to != from && to->space_count) { + if (to->space_count) { spaces += to->space_count; } to = to->next; @@ -420,6 +420,22 @@ void Label::regenerate_word_cache() { wc->space_count = space_count; current_word_size = 0; space_count = 0; + } else if ((i == xl_text.length() || current == '\n') && last != nullptr && space_count != 0) { + //in case there are trailing white spaces we add a placeholder word cache with just the spaces + WordCache *wc = memnew(WordCache); + if (word_cache) { + last->next = wc; + } else { + word_cache = wc; + } + last = wc; + + wc->pixel_width = 0; + wc->char_pos = 0; + wc->word_len = 0; + wc->space_count = space_count; + current_word_size = 0; + space_count = 0; } if (current == '\n') { |