diff options
| -rw-r--r-- | scene/gui/rich_text_label.cpp | 14 | 
1 files changed, 5 insertions, 9 deletions
| diff --git a/scene/gui/rich_text_label.cpp b/scene/gui/rich_text_label.cpp index a92c3c326d..5bc5d8e690 100644 --- a/scene/gui/rich_text_label.cpp +++ b/scene/gui/rich_text_label.cpp @@ -247,6 +247,7 @@ int RichTextLabel::_process_line(ItemFrame *p_frame, const Vector2 &p_ofs, int &  	int rchar = 0;  	int lh = 0;  	bool line_is_blank = true; +	int fh = 0;  	while (it) { @@ -262,14 +263,9 @@ int RichTextLabel::_process_line(ItemFrame *p_frame, const Vector2 &p_ofs, int &  				const CharType *c = text->text.c_str();  				const CharType *cf = c; -				int fh = font->get_height();  				int ascent = font->get_ascent();  				int descent = font->get_descent(); -				line_ascent = MAX(line_ascent, ascent); -				line_descent = MAX(line_descent, descent); -				fh = MAX(fh, line_ascent + line_descent); // various fonts! -  				Color color;  				bool underline = false; @@ -317,12 +313,12 @@ int RichTextLabel::_process_line(ItemFrame *p_frame, const Vector2 &p_ofs, int &  						end++;  					} +					CHECK_HEIGHT(fh);  					ENSURE_WIDTH(w); -					if (p_mode == PROCESS_CACHE) { -						line_ascent = ascent; -						line_descent = descent; -					} +					line_ascent = MAX(line_ascent, ascent); +					line_descent = MAX(line_descent, descent); +					fh = line_ascent + line_descent;  					if (end && c[end - 1] == ' ') {  						if (p_mode == PROCESS_CACHE) { |