[RTL] Fix font variations / OpenType features of theme default font not updated when default font is changed.
This commit is contained in:
parent
3472bdd6b6
commit
970592274d
3 changed files with 122 additions and 39 deletions
|
@ -3826,20 +3826,12 @@ void TextServerAdvanced::shaped_set_span_update_font(const RID &p_shaped, int64_
|
|||
ERR_FAIL_INDEX(p_index, sd->spans.size());
|
||||
|
||||
ShapedTextDataAdvanced::Span &span = sd->spans.ptrw()[p_index];
|
||||
bool changed = (span.font_size != p_size) || (span.features != p_opentype_features) || (p_fonts.size() != span.fonts.size());
|
||||
if (!changed) {
|
||||
for (int i = 0; i < p_fonts.size(); i++) {
|
||||
changed = changed || (span.fonts[i] != p_fonts[i]);
|
||||
}
|
||||
}
|
||||
if (changed) {
|
||||
span.fonts = p_fonts;
|
||||
span.font_size = p_size;
|
||||
span.features = p_opentype_features;
|
||||
|
||||
invalidate(sd, false);
|
||||
}
|
||||
}
|
||||
|
||||
bool TextServerAdvanced::shaped_text_add_string(const RID &p_shaped, const String &p_text, const TypedArray<RID> &p_fonts, int64_t p_size, const Dictionary &p_opentype_features, const String &p_language, const Variant &p_meta) {
|
||||
ShapedTextDataAdvanced *sd = shaped_owner.get_or_null(p_shaped);
|
||||
|
|
|
@ -2196,24 +2196,69 @@ RichTextLabel::ItemFont *RichTextLabel::_find_font(Item *p_item) {
|
|||
ItemFont *fi = static_cast<ItemFont *>(fontitem);
|
||||
switch (fi->def_font) {
|
||||
case NORMAL_FONT: {
|
||||
if (fi->variation) {
|
||||
Ref<FontVariation> fc = fi->font;
|
||||
if (fc.is_valid()) {
|
||||
fc->set_base_font(theme_cache.normal_font);
|
||||
}
|
||||
} else {
|
||||
fi->font = theme_cache.normal_font;
|
||||
}
|
||||
if (fi->def_size) {
|
||||
fi->font_size = theme_cache.normal_font_size;
|
||||
}
|
||||
} break;
|
||||
case BOLD_FONT: {
|
||||
if (fi->variation) {
|
||||
Ref<FontVariation> fc = fi->font;
|
||||
if (fc.is_valid()) {
|
||||
fc->set_base_font(theme_cache.bold_font);
|
||||
}
|
||||
} else {
|
||||
fi->font = theme_cache.bold_font;
|
||||
}
|
||||
if (fi->def_size) {
|
||||
fi->font_size = theme_cache.bold_font_size;
|
||||
}
|
||||
} break;
|
||||
case ITALICS_FONT: {
|
||||
if (fi->variation) {
|
||||
Ref<FontVariation> fc = fi->font;
|
||||
if (fc.is_valid()) {
|
||||
fc->set_base_font(theme_cache.italics_font);
|
||||
}
|
||||
} else {
|
||||
fi->font = theme_cache.italics_font;
|
||||
}
|
||||
if (fi->def_size) {
|
||||
fi->font_size = theme_cache.italics_font_size;
|
||||
}
|
||||
} break;
|
||||
case BOLD_ITALICS_FONT: {
|
||||
if (fi->variation) {
|
||||
Ref<FontVariation> fc = fi->font;
|
||||
if (fc.is_valid()) {
|
||||
fc->set_base_font(theme_cache.bold_italics_font);
|
||||
}
|
||||
} else {
|
||||
fi->font = theme_cache.bold_italics_font;
|
||||
}
|
||||
if (fi->def_size) {
|
||||
fi->font_size = theme_cache.bold_italics_font_size;
|
||||
}
|
||||
} break;
|
||||
case MONO_FONT: {
|
||||
if (fi->variation) {
|
||||
Ref<FontVariation> fc = fi->font;
|
||||
if (fc.is_valid()) {
|
||||
fc->set_base_font(theme_cache.mono_font);
|
||||
}
|
||||
} else {
|
||||
fi->font = theme_cache.mono_font;
|
||||
}
|
||||
if (fi->def_size) {
|
||||
fi->font_size = theme_cache.mono_font_size;
|
||||
}
|
||||
} break;
|
||||
default: {
|
||||
} break;
|
||||
|
@ -3034,14 +3079,30 @@ void RichTextLabel::push_dropcap(const String &p_string, const Ref<Font> &p_font
|
|||
_add_item(item, false);
|
||||
}
|
||||
|
||||
void RichTextLabel::_push_def_font(DefaultFont p_font) {
|
||||
void RichTextLabel::_push_def_font_var(DefaultFont p_def_font, const Ref<Font> &p_font, int p_size) {
|
||||
_stop_thread();
|
||||
MutexLock data_lock(data_mutex);
|
||||
|
||||
ERR_FAIL_COND(current->type == ITEM_TABLE);
|
||||
ItemFont *item = memnew(ItemFont);
|
||||
|
||||
item->def_font = p_font;
|
||||
item->def_font = p_def_font;
|
||||
item->variation = true;
|
||||
item->font = p_font;
|
||||
item->font_size = p_size;
|
||||
item->def_size = (p_size <= 0);
|
||||
_add_item(item, true);
|
||||
}
|
||||
|
||||
void RichTextLabel::_push_def_font(DefaultFont p_def_font) {
|
||||
_stop_thread();
|
||||
MutexLock data_lock(data_mutex);
|
||||
|
||||
ERR_FAIL_COND(current->type == ITEM_TABLE);
|
||||
ItemFont *item = memnew(ItemFont);
|
||||
|
||||
item->def_font = p_def_font;
|
||||
item->def_size = true;
|
||||
_add_item(item, true);
|
||||
}
|
||||
|
||||
|
@ -4122,24 +4183,21 @@ void RichTextLabel::append_text(const String &p_bbcode) {
|
|||
pos = brk_end + 1;
|
||||
tag_stack.push_front("font_size");
|
||||
|
||||
} else if (tag.begins_with("opentype_features=")) {
|
||||
String fnt_ftr = tag.substr(18, tag.length());
|
||||
} else if (tag.begins_with("opentype_features=") || tag.begins_with("otf=")) {
|
||||
int value_pos = tag.find("=");
|
||||
String fnt_ftr = tag.substr(value_pos + 1);
|
||||
Vector<String> subtag = fnt_ftr.split(",");
|
||||
if (subtag.size() > 0) {
|
||||
Ref<Font> font = theme_cache.normal_font;
|
||||
int font_size = 0;
|
||||
DefaultFont def_font = NORMAL_FONT;
|
||||
|
||||
ItemFont *font_it = _find_font(current);
|
||||
if (font_it) {
|
||||
if (font_it->font.is_valid()) {
|
||||
font = font_it->font;
|
||||
}
|
||||
if (font_it->font_size > 0) {
|
||||
font_size = font_it->font_size;
|
||||
def_font = font_it->def_font;
|
||||
}
|
||||
}
|
||||
Ref<FontVariation> fc;
|
||||
fc.instantiate();
|
||||
fc->set_base_font(font);
|
||||
Dictionary features;
|
||||
for (int i = 0; i < subtag.size(); i++) {
|
||||
Vector<String> subtag_a = subtag[i].split("=");
|
||||
|
@ -4149,11 +4207,21 @@ void RichTextLabel::append_text(const String &p_bbcode) {
|
|||
features[TS->name_to_tag(subtag_a[0])] = 1;
|
||||
}
|
||||
}
|
||||
|
||||
Ref<FontVariation> fc;
|
||||
fc.instantiate();
|
||||
|
||||
fc->set_base_font(font);
|
||||
fc->set_opentype_features(features);
|
||||
push_font(fc, font_size);
|
||||
|
||||
if (def_font != CUSTOM_FONT) {
|
||||
_push_def_font_var(def_font, fc);
|
||||
} else {
|
||||
push_font(fc);
|
||||
}
|
||||
}
|
||||
pos = brk_end + 1;
|
||||
tag_stack.push_front("opentype_features");
|
||||
tag_stack.push_front(tag.substr(0, value_pos));
|
||||
|
||||
} else if (tag.begins_with("font=")) {
|
||||
String fnt = tag.substr(5, tag.length());
|
||||
|
@ -4169,9 +4237,21 @@ void RichTextLabel::append_text(const String &p_bbcode) {
|
|||
} else if (tag.begins_with("font ")) {
|
||||
Vector<String> subtag = tag.substr(2, tag.length()).split(" ");
|
||||
|
||||
Ref<Font> font = theme_cache.normal_font;
|
||||
DefaultFont def_font = NORMAL_FONT;
|
||||
|
||||
ItemFont *font_it = _find_font(current);
|
||||
if (font_it) {
|
||||
if (font_it->font.is_valid()) {
|
||||
font = font_it->font;
|
||||
def_font = font_it->def_font;
|
||||
}
|
||||
}
|
||||
|
||||
Ref<FontVariation> fc;
|
||||
fc.instantiate();
|
||||
int fnt_size = 0;
|
||||
|
||||
int fnt_size = -1;
|
||||
for (int i = 1; i < subtag.size(); i++) {
|
||||
Vector<String> subtag_a = subtag[i].split("=", true, 2);
|
||||
if (subtag_a.size() == 2) {
|
||||
|
@ -4179,7 +4259,8 @@ void RichTextLabel::append_text(const String &p_bbcode) {
|
|||
String fnt = subtag_a[1];
|
||||
Ref<Font> font_data = ResourceLoader::load(fnt, "Font");
|
||||
if (font_data.is_valid()) {
|
||||
fc->set_base_font(font_data);
|
||||
font = font_data;
|
||||
def_font = CUSTOM_FONT;
|
||||
}
|
||||
} else if (subtag_a[0] == "size" || subtag_a[0] == "s") {
|
||||
fnt_size = subtag_a[1].to_int();
|
||||
|
@ -4233,7 +4314,14 @@ void RichTextLabel::append_text(const String &p_bbcode) {
|
|||
}
|
||||
}
|
||||
}
|
||||
fc->set_base_font(font);
|
||||
|
||||
if (def_font != CUSTOM_FONT) {
|
||||
_push_def_font_var(def_font, fc, fnt_size);
|
||||
} else {
|
||||
push_font(fc, fnt_size);
|
||||
}
|
||||
|
||||
pos = brk_end + 1;
|
||||
tag_stack.push_front("font");
|
||||
|
||||
|
|
|
@ -189,6 +189,8 @@ private:
|
|||
struct ItemFont : public Item {
|
||||
DefaultFont def_font = CUSTOM_FONT;
|
||||
Ref<Font> font;
|
||||
bool variation = false;
|
||||
bool def_size = false;
|
||||
int font_size = 0;
|
||||
ItemFont() { type = ITEM_FONT; }
|
||||
};
|
||||
|
@ -571,7 +573,8 @@ public:
|
|||
void add_newline();
|
||||
bool remove_line(const int p_line);
|
||||
void push_dropcap(const String &p_string, const Ref<Font> &p_font, int p_size, const Rect2 &p_dropcap_margins = Rect2(), const Color &p_color = Color(1, 1, 1), int p_ol_size = 0, const Color &p_ol_color = Color(0, 0, 0, 0));
|
||||
void _push_def_font(DefaultFont p_font);
|
||||
void _push_def_font(DefaultFont p_def_font);
|
||||
void _push_def_font_var(DefaultFont p_def_font, const Ref<Font> &p_font, int p_size = -1);
|
||||
void push_font(const Ref<Font> &p_font, int p_size = 0);
|
||||
void push_font_size(int p_font_size);
|
||||
void push_outline_size(int p_font_size);
|
||||
|
|
Loading…
Reference in a new issue