summaryrefslogtreecommitdiffstats
path: root/editor/editor_about.cpp
diff options
context:
space:
mode:
authorYuri Sizov <yuris@humnom.net>2023-12-04 13:18:48 +0100
committerYuri Sizov <yuris@humnom.net>2023-12-04 13:18:48 +0100
commit01888ae7ab2d8989b6e25cb2edbe7b3d27cf4e4e (patch)
tree4e1bfbf8a8a6eb05279582dd5fe527a427f3cbeb /editor/editor_about.cpp
parentd76c1d0e516fedc535a2e394ab780cac79203477 (diff)
downloadredot-engine-01888ae7ab2d8989b6e25cb2edbe7b3d27cf4e4e.tar.gz
Fix theme application in various editor dialogs
99% of the time we shouldn't rely on the signal, we should use the notification instead. I left some comments in places where I couldn't quickly improve the code.
Diffstat (limited to 'editor/editor_about.cpp')
-rw-r--r--editor/editor_about.cpp42
1 files changed, 19 insertions, 23 deletions
diff --git a/editor/editor_about.cpp b/editor/editor_about.cpp
index f6360db569..672697bab0 100644
--- a/editor/editor_about.cpp
+++ b/editor/editor_about.cpp
@@ -39,29 +39,25 @@
// The metadata key used to store and retrieve the version text to copy to the clipboard.
const String EditorAbout::META_TEXT_TO_COPY = "text_to_copy";
-void EditorAbout::_theme_changed() {
- const Ref<Font> font = get_theme_font(SNAME("source"), EditorStringName(EditorFonts));
- const int font_size = get_theme_font_size(SNAME("source_size"), EditorStringName(EditorFonts));
-
- _tpl_text->begin_bulk_theme_override();
- _tpl_text->add_theme_font_override("normal_font", font);
- _tpl_text->add_theme_font_size_override("normal_font_size", font_size);
- _tpl_text->add_theme_constant_override("line_separation", 4 * EDSCALE);
- _tpl_text->end_bulk_theme_override();
-
- _license_text->begin_bulk_theme_override();
- _license_text->add_theme_font_override("normal_font", font);
- _license_text->add_theme_font_size_override("normal_font_size", font_size);
- _license_text->add_theme_constant_override("line_separation", 4 * EDSCALE);
- _license_text->end_bulk_theme_override();
-
- _logo->set_texture(get_editor_theme_icon(SNAME("Logo")));
-}
-
void EditorAbout::_notification(int p_what) {
switch (p_what) {
- case NOTIFICATION_ENTER_TREE: {
- _theme_changed();
+ case NOTIFICATION_THEME_CHANGED: {
+ const Ref<Font> font = get_theme_font(SNAME("source"), EditorStringName(EditorFonts));
+ const int font_size = get_theme_font_size(SNAME("source_size"), EditorStringName(EditorFonts));
+
+ _tpl_text->begin_bulk_theme_override();
+ _tpl_text->add_theme_font_override("normal_font", font);
+ _tpl_text->add_theme_font_size_override("normal_font_size", font_size);
+ _tpl_text->add_theme_constant_override("line_separation", 4 * EDSCALE);
+ _tpl_text->end_bulk_theme_override();
+
+ _license_text->begin_bulk_theme_override();
+ _license_text->add_theme_font_override("normal_font", font);
+ _license_text->add_theme_font_size_override("normal_font_size", font_size);
+ _license_text->add_theme_constant_override("line_separation", 4 * EDSCALE);
+ _license_text->end_bulk_theme_override();
+
+ _logo->set_texture(get_editor_theme_icon(SNAME("Logo")));
} break;
}
}
@@ -128,12 +124,12 @@ EditorAbout::EditorAbout() {
set_hide_on_ok(true);
VBoxContainer *vbc = memnew(VBoxContainer);
- vbc->connect("theme_changed", callable_mp(this, &EditorAbout::_theme_changed));
+ add_child(vbc);
+
HBoxContainer *hbc = memnew(HBoxContainer);
hbc->set_h_size_flags(Control::SIZE_EXPAND_FILL);
hbc->set_alignment(BoxContainer::ALIGNMENT_CENTER);
hbc->add_theme_constant_override("separation", 30 * EDSCALE);
- add_child(vbc);
vbc->add_child(hbc);
_logo = memnew(TextureRect);