Correctly use fallback Theme values as last resort

This commit is contained in:
Yuri Sizov 2021-12-31 18:53:43 +03:00
parent 91b97dac03
commit fe283fd07a
7 changed files with 149 additions and 114 deletions

View file

@ -273,8 +273,8 @@ void editor_register_fonts(Ref<Theme> p_theme) {
// Default font // Default font
MAKE_DEFAULT_FONT(df, String()); MAKE_DEFAULT_FONT(df, String());
p_theme->set_default_theme_font(df); // Default theme font p_theme->set_default_font(df); // Default theme font
p_theme->set_default_theme_font_size(default_font_size); p_theme->set_default_font_size(default_font_size);
p_theme->set_font_size("main_size", "EditorFonts", default_font_size); p_theme->set_font_size("main_size", "EditorFonts", default_font_size);
p_theme->set_font("main", "EditorFonts", df); p_theme->set_font("main", "EditorFonts", df);

View file

@ -294,7 +294,7 @@ Ref<Theme> create_editor_theme(const Ref<Theme> p_theme) {
Ref<Theme> theme = Ref<Theme>(memnew(Theme)); Ref<Theme> theme = Ref<Theme>(memnew(Theme));
// Controls may rely on the scale for their internal drawing logic. // Controls may rely on the scale for their internal drawing logic.
theme->set_default_theme_base_scale(EDSCALE); theme->set_default_base_scale(EDSCALE);
// Theme settings // Theme settings
Color accent_color = EDITOR_GET("interface/theme/accent_color"); Color accent_color = EDITOR_GET("interface/theme/accent_color");

View file

@ -1148,12 +1148,12 @@ float Control::fetch_theme_default_base_scale(Control *p_theme_owner, Window *p_
Window *theme_owner_window = p_theme_owner_window; Window *theme_owner_window = p_theme_owner_window;
while (theme_owner || theme_owner_window) { while (theme_owner || theme_owner_window) {
if (theme_owner && theme_owner->data.theme->has_default_theme_base_scale()) { if (theme_owner && theme_owner->data.theme->has_default_base_scale()) {
return theme_owner->data.theme->get_default_theme_base_scale(); return theme_owner->data.theme->get_default_base_scale();
} }
if (theme_owner_window && theme_owner_window->theme->has_default_theme_base_scale()) { if (theme_owner_window && theme_owner_window->theme->has_default_base_scale()) {
return theme_owner_window->theme->get_default_theme_base_scale(); return theme_owner_window->theme->get_default_base_scale();
} }
Node *parent = theme_owner ? theme_owner->get_parent() : theme_owner_window->get_parent(); Node *parent = theme_owner ? theme_owner->get_parent() : theme_owner_window->get_parent();
@ -1175,13 +1175,16 @@ float Control::fetch_theme_default_base_scale(Control *p_theme_owner, Window *p_
// Secondly, check the project-defined Theme resource. // Secondly, check the project-defined Theme resource.
if (Theme::get_project_default().is_valid()) { if (Theme::get_project_default().is_valid()) {
if (Theme::get_project_default()->has_default_theme_base_scale()) { if (Theme::get_project_default()->has_default_base_scale()) {
return Theme::get_project_default()->get_default_theme_base_scale(); return Theme::get_project_default()->get_default_base_scale();
} }
} }
// Lastly, fall back on the default Theme. // Lastly, fall back on the default Theme.
return Theme::get_default()->get_default_theme_base_scale(); if (Theme::get_default()->has_default_base_scale()) {
return Theme::get_default()->get_default_base_scale();
}
return Theme::get_fallback_base_scale();
} }
float Control::get_theme_default_base_scale() const { float Control::get_theme_default_base_scale() const {
@ -1196,12 +1199,12 @@ Ref<Font> Control::fetch_theme_default_font(Control *p_theme_owner, Window *p_th
Window *theme_owner_window = p_theme_owner_window; Window *theme_owner_window = p_theme_owner_window;
while (theme_owner || theme_owner_window) { while (theme_owner || theme_owner_window) {
if (theme_owner && theme_owner->data.theme->has_default_theme_font()) { if (theme_owner && theme_owner->data.theme->has_default_font()) {
return theme_owner->data.theme->get_default_theme_font(); return theme_owner->data.theme->get_default_font();
} }
if (theme_owner_window && theme_owner_window->theme->has_default_theme_font()) { if (theme_owner_window && theme_owner_window->theme->has_default_font()) {
return theme_owner_window->theme->get_default_theme_font(); return theme_owner_window->theme->get_default_font();
} }
Node *parent = theme_owner ? theme_owner->get_parent() : theme_owner_window->get_parent(); Node *parent = theme_owner ? theme_owner->get_parent() : theme_owner_window->get_parent();
@ -1223,13 +1226,16 @@ Ref<Font> Control::fetch_theme_default_font(Control *p_theme_owner, Window *p_th
// Secondly, check the project-defined Theme resource. // Secondly, check the project-defined Theme resource.
if (Theme::get_project_default().is_valid()) { if (Theme::get_project_default().is_valid()) {
if (Theme::get_project_default()->has_default_theme_font()) { if (Theme::get_project_default()->has_default_font()) {
return Theme::get_project_default()->get_default_theme_font(); return Theme::get_project_default()->get_default_font();
} }
} }
// Lastly, fall back on the default Theme. // Lastly, fall back on the default Theme.
return Theme::get_default()->get_default_theme_font(); if (Theme::get_default()->has_default_font()) {
return Theme::get_default()->get_default_font();
}
return Theme::get_fallback_font();
} }
Ref<Font> Control::get_theme_default_font() const { Ref<Font> Control::get_theme_default_font() const {
@ -1244,12 +1250,12 @@ int Control::fetch_theme_default_font_size(Control *p_theme_owner, Window *p_the
Window *theme_owner_window = p_theme_owner_window; Window *theme_owner_window = p_theme_owner_window;
while (theme_owner || theme_owner_window) { while (theme_owner || theme_owner_window) {
if (theme_owner && theme_owner->data.theme->has_default_theme_font_size()) { if (theme_owner && theme_owner->data.theme->has_default_font_size()) {
return theme_owner->data.theme->get_default_theme_font_size(); return theme_owner->data.theme->get_default_font_size();
} }
if (theme_owner_window && theme_owner_window->theme->has_default_theme_font_size()) { if (theme_owner_window && theme_owner_window->theme->has_default_font_size()) {
return theme_owner_window->theme->get_default_theme_font_size(); return theme_owner_window->theme->get_default_font_size();
} }
Node *parent = theme_owner ? theme_owner->get_parent() : theme_owner_window->get_parent(); Node *parent = theme_owner ? theme_owner->get_parent() : theme_owner_window->get_parent();
@ -1271,13 +1277,16 @@ int Control::fetch_theme_default_font_size(Control *p_theme_owner, Window *p_the
// Secondly, check the project-defined Theme resource. // Secondly, check the project-defined Theme resource.
if (Theme::get_project_default().is_valid()) { if (Theme::get_project_default().is_valid()) {
if (Theme::get_project_default()->has_default_theme_font_size()) { if (Theme::get_project_default()->has_default_font_size()) {
return Theme::get_project_default()->get_default_theme_font_size(); return Theme::get_project_default()->get_default_font_size();
} }
} }
// Lastly, fall back on the default Theme. // Lastly, fall back on the default Theme.
return Theme::get_default()->get_default_theme_font_size(); if (Theme::get_default()->has_default_font_size()) {
return Theme::get_default()->get_default_font_size();
}
return Theme::get_fallback_font_size();
} }
int Control::get_theme_default_font_size() const { int Control::get_theme_default_font_size() const {

View file

@ -1071,7 +1071,7 @@ void initialize_theme() {
if (theme.is_valid()) { if (theme.is_valid()) {
Theme::set_project_default(theme); Theme::set_project_default(theme);
if (font.is_valid()) { if (font.is_valid()) {
Theme::set_default_font(font); Theme::set_fallback_font(font);
} }
} else { } else {
ERR_PRINT("Error loading custom theme '" + theme_path + "'"); ERR_PRINT("Error loading custom theme '" + theme_path + "'");

View file

@ -1053,17 +1053,17 @@ void make_default_theme(bool p_hidpi, Ref<Font> p_font) {
fill_default_theme(t, default_font, large_font, default_icon, default_style, default_scale); fill_default_theme(t, default_font, large_font, default_icon, default_style, default_scale);
Theme::set_default(t); Theme::set_default(t);
Theme::set_default_base_scale(default_scale); Theme::set_fallback_base_scale(default_scale);
Theme::set_default_icon(default_icon); Theme::set_fallback_icon(default_icon);
Theme::set_default_style(default_style); Theme::set_fallback_style(default_style);
Theme::set_default_font(default_font); Theme::set_fallback_font(default_font);
Theme::set_default_font_size(default_font_size); Theme::set_fallback_font_size(default_font_size);
} }
void clear_default_theme() { void clear_default_theme() {
Theme::set_project_default(nullptr); Theme::set_project_default(nullptr);
Theme::set_default(nullptr); Theme::set_default(nullptr);
Theme::set_default_icon(nullptr); Theme::set_fallback_icon(nullptr);
Theme::set_default_style(nullptr); Theme::set_fallback_style(nullptr);
Theme::set_default_font(nullptr); Theme::set_fallback_font(nullptr);
} }

View file

@ -36,11 +36,11 @@ Ref<Theme> Theme::default_theme;
Ref<Theme> Theme::project_default_theme; Ref<Theme> Theme::project_default_theme;
// Universal default values, final fallback for every theme. // Universal default values, final fallback for every theme.
float Theme::default_base_scale = 1.0; float Theme::fallback_base_scale = 1.0;
Ref<Texture2D> Theme::default_icon; Ref<Texture2D> Theme::fallback_icon;
Ref<StyleBox> Theme::default_style; Ref<StyleBox> Theme::fallback_style;
Ref<Font> Theme::default_font; Ref<Font> Theme::fallback_font;
int Theme::default_font_size = 16; int Theme::fallback_font_size = 16;
// Dynamic properties. // Dynamic properties.
bool Theme::_set(const StringName &p_name, const Variant &p_value) { bool Theme::_set(const StringName &p_name, const Variant &p_value) {
@ -220,87 +220,107 @@ void Theme::set_project_default(const Ref<Theme> &p_project_default) {
} }
// Universal fallback values for theme item types. // Universal fallback values for theme item types.
void Theme::set_default_base_scale(float p_base_scale) { void Theme::set_fallback_base_scale(float p_base_scale) {
default_base_scale = p_base_scale; fallback_base_scale = p_base_scale;
} }
void Theme::set_default_icon(const Ref<Texture2D> &p_icon) { void Theme::set_fallback_icon(const Ref<Texture2D> &p_icon) {
default_icon = p_icon; fallback_icon = p_icon;
} }
void Theme::set_default_style(const Ref<StyleBox> &p_style) { void Theme::set_fallback_style(const Ref<StyleBox> &p_style) {
default_style = p_style; fallback_style = p_style;
} }
void Theme::set_default_font(const Ref<Font> &p_font) { void Theme::set_fallback_font(const Ref<Font> &p_font) {
default_font = p_font; fallback_font = p_font;
} }
void Theme::set_default_font_size(int p_font_size) { void Theme::set_fallback_font_size(int p_font_size) {
default_font_size = p_font_size; fallback_font_size = p_font_size;
}
float Theme::get_fallback_base_scale() {
return fallback_base_scale;
}
Ref<Texture2D> Theme::get_fallback_icon() {
return fallback_icon;
}
Ref<StyleBox> Theme::get_fallback_style() {
return fallback_style;
}
Ref<Font> Theme::get_fallback_font() {
return fallback_font;
}
int Theme::get_fallback_font_size() {
return fallback_font_size;
} }
// Fallback values for theme item types, configurable per theme. // Fallback values for theme item types, configurable per theme.
void Theme::set_default_theme_base_scale(float p_base_scale) { void Theme::set_default_base_scale(float p_base_scale) {
if (default_theme_base_scale == p_base_scale) { if (default_base_scale == p_base_scale) {
return; return;
} }
default_theme_base_scale = p_base_scale; default_base_scale = p_base_scale;
_emit_theme_changed(); _emit_theme_changed();
} }
float Theme::get_default_theme_base_scale() const { float Theme::get_default_base_scale() const {
return default_theme_base_scale; return default_base_scale;
} }
bool Theme::has_default_theme_base_scale() const { bool Theme::has_default_base_scale() const {
return default_theme_base_scale > 0.0; return default_base_scale > 0.0;
} }
void Theme::set_default_theme_font(const Ref<Font> &p_default_font) { void Theme::set_default_font(const Ref<Font> &p_default_font) {
if (default_theme_font == p_default_font) { if (default_font == p_default_font) {
return; return;
} }
if (default_theme_font.is_valid()) { if (default_font.is_valid()) {
default_theme_font->disconnect("changed", callable_mp(this, &Theme::_emit_theme_changed)); default_font->disconnect("changed", callable_mp(this, &Theme::_emit_theme_changed));
} }
default_theme_font = p_default_font; default_font = p_default_font;
if (default_theme_font.is_valid()) { if (default_font.is_valid()) {
default_theme_font->connect("changed", callable_mp(this, &Theme::_emit_theme_changed), varray(false), CONNECT_REFERENCE_COUNTED); default_font->connect("changed", callable_mp(this, &Theme::_emit_theme_changed), varray(false), CONNECT_REFERENCE_COUNTED);
} }
_emit_theme_changed(); _emit_theme_changed();
} }
Ref<Font> Theme::get_default_theme_font() const { Ref<Font> Theme::get_default_font() const {
return default_theme_font; return default_font;
} }
bool Theme::has_default_theme_font() const { bool Theme::has_default_font() const {
return default_theme_font.is_valid(); return default_font.is_valid();
} }
void Theme::set_default_theme_font_size(int p_font_size) { void Theme::set_default_font_size(int p_font_size) {
if (default_theme_font_size == p_font_size) { if (default_font_size == p_font_size) {
return; return;
} }
default_theme_font_size = p_font_size; default_font_size = p_font_size;
_emit_theme_changed(); _emit_theme_changed();
} }
int Theme::get_default_theme_font_size() const { int Theme::get_default_font_size() const {
return default_theme_font_size; return default_font_size;
} }
bool Theme::has_default_theme_font_size() const { bool Theme::has_default_font_size() const {
return default_theme_font_size > 0; return default_font_size > 0;
} }
// Icons. // Icons.
@ -324,7 +344,7 @@ Ref<Texture2D> Theme::get_icon(const StringName &p_name, const StringName &p_the
if (icon_map.has(p_theme_type) && icon_map[p_theme_type].has(p_name) && icon_map[p_theme_type][p_name].is_valid()) { if (icon_map.has(p_theme_type) && icon_map[p_theme_type].has(p_name) && icon_map[p_theme_type][p_name].is_valid()) {
return icon_map[p_theme_type][p_name]; return icon_map[p_theme_type][p_name];
} else { } else {
return default_icon; return fallback_icon;
} }
} }
@ -411,7 +431,7 @@ Ref<StyleBox> Theme::get_stylebox(const StringName &p_name, const StringName &p_
if (style_map.has(p_theme_type) && style_map[p_theme_type].has(p_name) && style_map[p_theme_type][p_name].is_valid()) { if (style_map.has(p_theme_type) && style_map[p_theme_type].has(p_name) && style_map[p_theme_type][p_name].is_valid()) {
return style_map[p_theme_type][p_name]; return style_map[p_theme_type][p_name];
} else { } else {
return default_style; return fallback_style;
} }
} }
@ -497,15 +517,15 @@ void Theme::set_font(const StringName &p_name, const StringName &p_theme_type, c
Ref<Font> Theme::get_font(const StringName &p_name, const StringName &p_theme_type) const { Ref<Font> Theme::get_font(const StringName &p_name, const StringName &p_theme_type) const {
if (font_map.has(p_theme_type) && font_map[p_theme_type].has(p_name) && font_map[p_theme_type][p_name].is_valid()) { if (font_map.has(p_theme_type) && font_map[p_theme_type].has(p_name) && font_map[p_theme_type][p_name].is_valid()) {
return font_map[p_theme_type][p_name]; return font_map[p_theme_type][p_name];
} else if (has_default_theme_font()) { } else if (has_default_font()) {
return default_theme_font;
} else {
return default_font; return default_font;
} else {
return fallback_font;
} }
} }
bool Theme::has_font(const StringName &p_name, const StringName &p_theme_type) const { bool Theme::has_font(const StringName &p_name, const StringName &p_theme_type) const {
return ((font_map.has(p_theme_type) && font_map[p_theme_type].has(p_name) && font_map[p_theme_type][p_name].is_valid()) || has_default_theme_font()); return ((font_map.has(p_theme_type) && font_map[p_theme_type].has(p_name) && font_map[p_theme_type][p_name].is_valid()) || has_default_font());
} }
bool Theme::has_font_nocheck(const StringName &p_name, const StringName &p_theme_type) const { bool Theme::has_font_nocheck(const StringName &p_name, const StringName &p_theme_type) const {
@ -577,15 +597,15 @@ void Theme::set_font_size(const StringName &p_name, const StringName &p_theme_ty
int Theme::get_font_size(const StringName &p_name, const StringName &p_theme_type) const { int Theme::get_font_size(const StringName &p_name, const StringName &p_theme_type) const {
if (font_size_map.has(p_theme_type) && font_size_map[p_theme_type].has(p_name) && (font_size_map[p_theme_type][p_name] > 0)) { if (font_size_map.has(p_theme_type) && font_size_map[p_theme_type].has(p_name) && (font_size_map[p_theme_type][p_name] > 0)) {
return font_size_map[p_theme_type][p_name]; return font_size_map[p_theme_type][p_name];
} else if (has_default_theme_font_size()) { } else if (has_default_font_size()) {
return default_theme_font_size;
} else {
return default_font_size; return default_font_size;
} else {
return fallback_font_size;
} }
} }
bool Theme::has_font_size(const StringName &p_name, const StringName &p_theme_type) const { bool Theme::has_font_size(const StringName &p_name, const StringName &p_theme_type) const {
return ((font_size_map.has(p_theme_type) && font_size_map[p_theme_type].has(p_name) && (font_size_map[p_theme_type][p_name] > 0)) || has_default_theme_font_size()); return ((font_size_map.has(p_theme_type) && font_size_map[p_theme_type].has(p_name) && (font_size_map[p_theme_type][p_name] > 0)) || has_default_font_size());
} }
bool Theme::has_font_size_nocheck(const StringName &p_name, const StringName &p_theme_type) const { bool Theme::has_font_size_nocheck(const StringName &p_name, const StringName &p_theme_type) const {
@ -1622,17 +1642,17 @@ void Theme::_bind_methods() {
ClassDB::bind_method(D_METHOD("get_constant_list", "theme_type"), &Theme::_get_constant_list); ClassDB::bind_method(D_METHOD("get_constant_list", "theme_type"), &Theme::_get_constant_list);
ClassDB::bind_method(D_METHOD("get_constant_type_list"), &Theme::_get_constant_type_list); ClassDB::bind_method(D_METHOD("get_constant_type_list"), &Theme::_get_constant_type_list);
ClassDB::bind_method(D_METHOD("set_default_base_scale", "font_size"), &Theme::set_default_theme_base_scale); ClassDB::bind_method(D_METHOD("set_default_base_scale", "base_scale"), &Theme::set_default_base_scale);
ClassDB::bind_method(D_METHOD("get_default_base_scale"), &Theme::get_default_theme_base_scale); ClassDB::bind_method(D_METHOD("get_default_base_scale"), &Theme::get_default_base_scale);
ClassDB::bind_method(D_METHOD("has_default_base_scale"), &Theme::has_default_theme_base_scale); ClassDB::bind_method(D_METHOD("has_default_base_scale"), &Theme::has_default_base_scale);
ClassDB::bind_method(D_METHOD("set_default_font", "font"), &Theme::set_default_theme_font); ClassDB::bind_method(D_METHOD("set_default_font", "font"), &Theme::set_default_font);
ClassDB::bind_method(D_METHOD("get_default_font"), &Theme::get_default_theme_font); ClassDB::bind_method(D_METHOD("get_default_font"), &Theme::get_default_font);
ClassDB::bind_method(D_METHOD("has_default_font"), &Theme::has_default_theme_font); ClassDB::bind_method(D_METHOD("has_default_font"), &Theme::has_default_font);
ClassDB::bind_method(D_METHOD("set_default_font_size", "font_size"), &Theme::set_default_theme_font_size); ClassDB::bind_method(D_METHOD("set_default_font_size", "font_size"), &Theme::set_default_font_size);
ClassDB::bind_method(D_METHOD("get_default_font_size"), &Theme::get_default_theme_font_size); ClassDB::bind_method(D_METHOD("get_default_font_size"), &Theme::get_default_font_size);
ClassDB::bind_method(D_METHOD("has_default_font_size"), &Theme::has_default_theme_font_size); ClassDB::bind_method(D_METHOD("has_default_font_size"), &Theme::has_default_font_size);
ClassDB::bind_method(D_METHOD("set_theme_item", "data_type", "name", "theme_type", "value"), &Theme::set_theme_item); ClassDB::bind_method(D_METHOD("set_theme_item", "data_type", "name", "theme_type", "value"), &Theme::set_theme_item);
ClassDB::bind_method(D_METHOD("get_theme_item", "data_type", "name", "theme_type"), &Theme::get_theme_item); ClassDB::bind_method(D_METHOD("get_theme_item", "data_type", "name", "theme_type"), &Theme::get_theme_item);

View file

@ -101,16 +101,16 @@ protected:
static Ref<Theme> project_default_theme; static Ref<Theme> project_default_theme;
// Universal default values, final fallback for every theme. // Universal default values, final fallback for every theme.
static float default_base_scale; static float fallback_base_scale;
static Ref<Texture2D> default_icon; static Ref<Texture2D> fallback_icon;
static Ref<StyleBox> default_style; static Ref<StyleBox> fallback_style;
static Ref<Font> default_font; static Ref<Font> fallback_font;
static int default_font_size; static int fallback_font_size;
// Default values configurable for each individual theme. // Default values configurable for each individual theme.
float default_theme_base_scale = 0.0; float default_base_scale = 0.0;
Ref<Font> default_theme_font; Ref<Font> default_font;
int default_theme_font_size = -1; int default_font_size = -1;
static void _bind_methods(); static void _bind_methods();
@ -126,23 +126,29 @@ public:
static Ref<Theme> get_project_default(); static Ref<Theme> get_project_default();
static void set_project_default(const Ref<Theme> &p_project_default); static void set_project_default(const Ref<Theme> &p_project_default);
static void set_default_base_scale(float p_base_scale); static void set_fallback_base_scale(float p_base_scale);
static void set_default_icon(const Ref<Texture2D> &p_icon); static void set_fallback_icon(const Ref<Texture2D> &p_icon);
static void set_default_style(const Ref<StyleBox> &p_style); static void set_fallback_style(const Ref<StyleBox> &p_style);
static void set_default_font(const Ref<Font> &p_font); static void set_fallback_font(const Ref<Font> &p_font);
static void set_default_font_size(int p_font_size); static void set_fallback_font_size(int p_font_size);
void set_default_theme_base_scale(float p_base_scale); static float get_fallback_base_scale();
float get_default_theme_base_scale() const; static Ref<Texture2D> get_fallback_icon();
bool has_default_theme_base_scale() const; static Ref<StyleBox> get_fallback_style();
static Ref<Font> get_fallback_font();
static int get_fallback_font_size();
void set_default_theme_font(const Ref<Font> &p_default_font); void set_default_base_scale(float p_base_scale);
Ref<Font> get_default_theme_font() const; float get_default_base_scale() const;
bool has_default_theme_font() const; bool has_default_base_scale() const;
void set_default_theme_font_size(int p_font_size); void set_default_font(const Ref<Font> &p_default_font);
int get_default_theme_font_size() const; Ref<Font> get_default_font() const;
bool has_default_theme_font_size() const; bool has_default_font() const;
void set_default_font_size(int p_font_size);
int get_default_font_size() const;
bool has_default_font_size() const;
void set_icon(const StringName &p_name, const StringName &p_theme_type, const Ref<Texture2D> &p_icon); void set_icon(const StringName &p_name, const StringName &p_theme_type, const Ref<Texture2D> &p_icon);
Ref<Texture2D> get_icon(const StringName &p_name, const StringName &p_theme_type) const; Ref<Texture2D> get_icon(const StringName &p_name, const StringName &p_theme_type) const;