diff options
author | volzhs <volzhs@gmail.com> | 2020-01-07 04:21:02 +0900 |
---|---|---|
committer | volzhs <volzhs@gmail.com> | 2020-01-07 04:21:02 +0900 |
commit | e5a00186212d895d5a87c8e74b61d1f80748c9cc (patch) | |
tree | 3c523aab662a6aa0116eea46661cb04af13c6559 /scene/gui | |
parent | 61dd7748cafafca08b8f87183ddf42de06b58911 (diff) |
Calculate label size more accurately
Diffstat (limited to 'scene/gui')
-rw-r--r-- | scene/gui/label.cpp | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/scene/gui/label.cpp b/scene/gui/label.cpp index fa795361a8..df88b34f9d 100644 --- a/scene/gui/label.cpp +++ b/scene/gui/label.cpp @@ -103,8 +103,7 @@ void Label::_notification(int p_what) { int lines_visible = (size.y + line_spacing) / font_h; - // ceiling to ensure autowrapping does not cut text - int space_w = Math::ceil(font->get_char_size(' ').width); + real_t space_w = font->get_char_size(' ').width; int chars_total = 0; int vbegin = 0, vsep = 0; @@ -390,10 +389,9 @@ void Label::regenerate_word_cache() { real_t current_word_size = 0; int word_pos = 0; - int line_width = 0; + real_t line_width = 0; int space_count = 0; - // ceiling to ensure autowrapping does not cut text - int space_width = Math::ceil(font->get_char_size(' ').width); + real_t space_width = font->get_char_size(' ').width; int line_spacing = get_constant("line_spacing"); line_count = 1; total_char_cache = 0; @@ -454,10 +452,9 @@ void Label::regenerate_word_cache() { if (current_word_size == 0) { word_pos = i; } - // ceiling to ensure autowrapping does not cut text char_width = font->get_char_size(current, xl_text[i + 1]).width; current_word_size += char_width; - line_width += Math::ceil(char_width); + line_width += char_width; total_char_cache++; // allow autowrap to cut words when they exceed line width |