[Label3D, 3.x] Monitor default theme font changes, to prevent use of invalid materials.

This commit is contained in:
bruvzg 2022-05-23 18:01:03 +03:00
parent b2cdc16a1d
commit eb44e23ca3
No known key found for this signature in database
GPG key ID: 7960FCF39844EC38
2 changed files with 24 additions and 3 deletions

View file

@ -866,6 +866,11 @@ Ref<Font> Label3D::get_font() const {
} }
Ref<Font> Label3D::_get_font_or_default() const { Ref<Font> Label3D::_get_font_or_default() const {
if (theme_font.is_valid()) {
theme_font->disconnect(CoreStringNames::get_singleton()->changed, const_cast<Label3D *>(this), "_font_changed");
theme_font.unref();
}
if (font_override.is_valid()) { if (font_override.is_valid()) {
return font_override; return font_override;
} }
@ -877,7 +882,12 @@ Ref<Font> Label3D::_get_font_or_default() const {
for (List<StringName>::Element *E = theme_types.front(); E; E = E->next()) { for (List<StringName>::Element *E = theme_types.front(); E; E = E->next()) {
if (Theme::get_project_default()->has_theme_item(Theme::DATA_TYPE_FONT, "font", E->get())) { if (Theme::get_project_default()->has_theme_item(Theme::DATA_TYPE_FONT, "font", E->get())) {
return Theme::get_project_default()->get_theme_item(Theme::DATA_TYPE_FONT, "font", E->get()); Ref<Font> f = Theme::get_project_default()->get_theme_item(Theme::DATA_TYPE_FONT, "font", E->get());
if (f.is_valid()) {
theme_font = f;
theme_font->connect(CoreStringNames::get_singleton()->changed, const_cast<Label3D *>(this), "_font_changed");
}
return f;
} }
} }
} }
@ -889,13 +899,23 @@ Ref<Font> Label3D::_get_font_or_default() const {
for (List<StringName>::Element *E = theme_types.front(); E; E = E->next()) { for (List<StringName>::Element *E = theme_types.front(); E; E = E->next()) {
if (Theme::get_default()->has_theme_item(Theme::DATA_TYPE_FONT, "font", E->get())) { if (Theme::get_default()->has_theme_item(Theme::DATA_TYPE_FONT, "font", E->get())) {
return Theme::get_default()->get_theme_item(Theme::DATA_TYPE_FONT, "font", E->get()); Ref<Font> f = Theme::get_default()->get_theme_item(Theme::DATA_TYPE_FONT, "font", E->get());
if (f.is_valid()) {
theme_font = f;
theme_font->connect(CoreStringNames::get_singleton()->changed, const_cast<Label3D *>(this), "_font_changed");
}
return f;
} }
} }
} }
// If they don't exist, use any type to return the default/empty value. // If they don't exist, use any type to return the default/empty value.
return Theme::get_default()->get_theme_item(Theme::DATA_TYPE_FONT, "font", StringName()); Ref<Font> f = Theme::get_default()->get_theme_item(Theme::DATA_TYPE_FONT, "font", StringName());
if (f.is_valid()) {
theme_font = f;
theme_font->connect(CoreStringNames::get_singleton()->changed, const_cast<Label3D *>(this), "_font_changed");
}
return f;
} }
void Label3D::set_modulate(const Color &p_color) { void Label3D::set_modulate(const Color &p_color) {

View file

@ -124,6 +124,7 @@ private:
float width = 500.0; float width = 500.0;
Ref<Font> font_override; Ref<Font> font_override;
mutable Ref<Font> theme_font;
Color modulate = Color(1, 1, 1, 1); Color modulate = Color(1, 1, 1, 1);
Point2 lbl_offset; Point2 lbl_offset;
int outline_render_priority = -1; int outline_render_priority = -1;