Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
godotengine
GitHub Repository: godotengine/godot
Path: blob/master/editor/themes/theme_modern.cpp
14709 views
1
/**************************************************************************/
2
/* theme_modern.cpp */
3
/**************************************************************************/
4
/* This file is part of: */
5
/* GODOT ENGINE */
6
/* https://godotengine.org */
7
/**************************************************************************/
8
/* Copyright (c) 2014-present Godot Engine contributors (see AUTHORS.md). */
9
/* Copyright (c) 2007-2014 Juan Linietsky, Ariel Manzur. */
10
/* */
11
/* Permission is hereby granted, free of charge, to any person obtaining */
12
/* a copy of this software and associated documentation files (the */
13
/* "Software"), to deal in the Software without restriction, including */
14
/* without limitation the rights to use, copy, modify, merge, publish, */
15
/* distribute, sublicense, and/or sell copies of the Software, and to */
16
/* permit persons to whom the Software is furnished to do so, subject to */
17
/* the following conditions: */
18
/* */
19
/* The above copyright notice and this permission notice shall be */
20
/* included in all copies or substantial portions of the Software. */
21
/* */
22
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
23
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
24
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. */
25
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
26
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
27
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
28
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
29
/**************************************************************************/
30
31
#include "theme_modern.h"
32
33
#include "core/math/math_defs.h"
34
#include "editor/editor_string_names.h"
35
#include "editor/settings/editor_settings.h"
36
#include "editor/themes/editor_scale.h"
37
#include "editor/themes/editor_theme_manager.h"
38
#include "scene/gui/graph_edit.h"
39
#include "scene/resources/dpi_texture.h"
40
#include "scene/resources/image_texture.h"
41
#include "scene/resources/style_box_flat.h"
42
#include "scene/resources/style_box_line.h"
43
44
// Helper.
45
static Color _get_base_color(EditorThemeManager::ThemeConfiguration &p_config, float p_brightness_ofs = 0.0, float p_saturation_mult = 1.0) {
46
const bool is_dark = p_brightness_ofs >= 0.0 ? p_config.dark_theme : !p_config.dark_theme;
47
Color color = p_config.base_color;
48
color.set_v(CLAMP(Math::lerp(color.get_v(), is_dark ? 1 : 0, Math::abs(p_config.contrast * p_brightness_ofs)), 0, 1));
49
color.set_s(color.get_s() * p_saturation_mult);
50
51
return color;
52
}
53
54
void ThemeModern::populate_shared_styles(const Ref<EditorTheme> &p_theme, EditorThemeManager::ThemeConfiguration &p_config) {
55
// Colors.
56
{
57
// Base colors.
58
59
p_theme->set_color("base_color", EditorStringName(Editor), p_config.base_color);
60
p_theme->set_color("accent_color", EditorStringName(Editor), p_config.accent_color);
61
62
// White (dark theme) or black (light theme), will be used to generate the rest of the colors
63
p_config.mono_color = p_config.dark_theme ? Color(1, 1, 1) : Color(0, 0, 0);
64
p_config.mono_color_font = p_config.dark_icon_and_font ? Color(1, 1, 1) : Color(0, 0, 0);
65
p_config.mono_color_inv = p_config.dark_theme ? Color(0, 0, 0) : Color(1, 1, 1);
66
67
// Ensure base colors are in the 0..1 luminance range to avoid 8-bit integer overflow or text rendering issues.
68
// Some places in the editor use 8-bit integer colors.
69
p_config.dark_color_1 = p_config.base_color.lerp(Color(0, 0, 0, 1), p_config.contrast).clamp();
70
p_config.dark_color_2 = p_config.dark_theme ? Color(0, 0, 0, 0.3) : Color(1, 1, 1, 0.3);
71
p_config.dark_color_3 = _get_base_color(p_config, p_config.dark_theme ? -0.95 : -1.8, 0.9);
72
73
p_config.contrast_color_1 = p_config.base_color.lerp(p_config.mono_color, MAX(p_config.contrast, p_config.default_contrast));
74
p_config.contrast_color_2 = p_config.base_color.lerp(p_config.mono_color, MAX(p_config.contrast * 1.5, p_config.default_contrast * 1.5));
75
76
p_config.highlight_color = Color(p_config.accent_color.r, p_config.accent_color.g, p_config.accent_color.b, 0.275);
77
p_config.highlight_disabled_color = p_config.highlight_color.lerp(p_config.dark_theme ? Color(0, 0, 0) : Color(1, 1, 1), 0.5);
78
79
p_config.success_color = Color(0.45, 0.95, 0.5);
80
p_config.warning_color = Color(0.83, 0.78, 0.62);
81
p_config.error_color = Color(1, 0.47, 0.42);
82
83
// Keep dark theme colors accessible for use in the frame time gradient in the 3D editor.
84
// This frame time gradient is used to colorize text for a dark background, so it should keep using bright colors
85
// even when using a light theme.
86
p_theme->set_color("success_color_dark_background", EditorStringName(Editor), p_config.success_color);
87
p_theme->set_color("warning_color_dark_background", EditorStringName(Editor), p_config.warning_color);
88
p_theme->set_color("error_color_dark_background", EditorStringName(Editor), p_config.error_color);
89
90
if (!p_config.dark_icon_and_font) {
91
// Darken some colors to be readable on a light background.
92
p_config.success_color = p_config.success_color.lerp(p_config.mono_color_font, 0.35);
93
p_config.warning_color = Color(0.83, 0.49, 0.01);
94
p_config.error_color = Color(0.8, 0.22, 0.22);
95
}
96
97
p_theme->set_color("mono_color", EditorStringName(Editor), p_config.mono_color);
98
p_theme->set_color("dark_color_1", EditorStringName(Editor), p_config.dark_color_1);
99
p_theme->set_color("dark_color_2", EditorStringName(Editor), p_config.dark_color_2);
100
p_theme->set_color("dark_color_3", EditorStringName(Editor), p_config.dark_color_3);
101
p_theme->set_color("contrast_color_1", EditorStringName(Editor), p_config.contrast_color_1);
102
p_theme->set_color("contrast_color_2", EditorStringName(Editor), p_config.contrast_color_2);
103
p_theme->set_color("highlight_color", EditorStringName(Editor), p_config.highlight_color);
104
p_theme->set_color("highlight_disabled_color", EditorStringName(Editor), p_config.highlight_disabled_color);
105
p_theme->set_color("success_color", EditorStringName(Editor), p_config.success_color);
106
p_theme->set_color("warning_color", EditorStringName(Editor), p_config.warning_color);
107
p_theme->set_color("error_color", EditorStringName(Editor), p_config.error_color);
108
p_theme->set_color("ruler_color", EditorStringName(Editor), p_config.base_color.lerp(p_config.mono_color_inv, 0.3) * Color(1, 1, 1, 0.8));
109
#ifndef DISABLE_DEPRECATED // Used before 4.3.
110
p_theme->set_color("disabled_highlight_color", EditorStringName(Editor), p_config.highlight_disabled_color);
111
#endif
112
113
// Only used when the Draw Extra Borders editor setting is enabled.
114
p_config.extra_border_color_1 = p_config.dark_theme ? Color(1, 1, 1, 0.4) : Color(0, 0, 0, 0.4);
115
p_config.extra_border_color_2 = p_config.dark_theme ? Color(1, 1, 1, 0.2) : Color(0, 0, 0, 0.2);
116
117
p_theme->set_color("extra_border_color_1", EditorStringName(Editor), p_config.extra_border_color_1);
118
p_theme->set_color("extra_border_color_2", EditorStringName(Editor), p_config.extra_border_color_2);
119
120
// Font colors.
121
122
p_config.font_color = p_config.mono_color_font * Color(1, 1, 1, 0.7);
123
p_config.font_secondary_color = p_config.mono_color_font * Color(1, 1, 1, 0.45);
124
p_config.font_focus_color = p_config.mono_color_font;
125
p_config.font_hover_color = p_config.mono_color_font;
126
p_config.font_pressed_color = p_config.mono_color_font;
127
p_config.font_hover_pressed_color = p_config.mono_color_font;
128
p_config.font_disabled_color = p_config.mono_color_font * Color(1, 1, 1, p_config.dark_icon_and_font ? 0.35 : 0.5);
129
p_config.font_readonly_color = Color(p_config.mono_color_font.r, p_config.mono_color_font.g, p_config.mono_color_font.b, 0.65);
130
p_config.font_placeholder_color = p_config.font_disabled_color;
131
p_config.font_outline_color = Color(1, 1, 1, 0);
132
133
// Colors designed for dark backgrounds, even when using a light theme.
134
// This is used for 3D editor overlay texts.
135
if (p_config.dark_theme) {
136
p_config.font_dark_background_color = p_config.font_color;
137
p_config.font_dark_background_focus_color = p_config.font_focus_color;
138
p_config.font_dark_background_hover_color = p_config.font_hover_color;
139
p_config.font_dark_background_pressed_color = p_config.font_pressed_color;
140
p_config.font_dark_background_hover_pressed_color = p_config.font_hover_pressed_color;
141
} else {
142
p_config.font_dark_background_color = p_config.mono_color.inverted().lerp(p_config.base_color, 0.75);
143
p_config.font_dark_background_focus_color = p_config.mono_color.inverted().lerp(p_config.base_color, 0.25);
144
p_config.font_dark_background_hover_color = p_config.mono_color.inverted().lerp(p_config.base_color, 0.25);
145
p_config.font_dark_background_pressed_color = p_config.font_dark_background_color.lerp(p_config.accent_color, 0.74);
146
p_config.font_dark_background_hover_pressed_color = p_config.font_dark_background_color.lerp(p_config.accent_color, 0.5);
147
}
148
149
p_theme->set_color(SceneStringName(font_color), EditorStringName(Editor), p_config.font_color);
150
p_theme->set_color("font_focus_color", EditorStringName(Editor), p_config.font_focus_color);
151
p_theme->set_color("font_hover_color", EditorStringName(Editor), p_config.font_hover_color);
152
p_theme->set_color("font_pressed_color", EditorStringName(Editor), p_config.font_pressed_color);
153
p_theme->set_color("font_hover_pressed_color", EditorStringName(Editor), p_config.font_hover_pressed_color);
154
p_theme->set_color("font_disabled_color", EditorStringName(Editor), p_config.font_disabled_color);
155
p_theme->set_color("font_readonly_color", EditorStringName(Editor), p_config.font_readonly_color);
156
p_theme->set_color("font_placeholder_color", EditorStringName(Editor), p_config.font_placeholder_color);
157
p_theme->set_color("font_outline_color", EditorStringName(Editor), p_config.font_outline_color);
158
159
p_theme->set_color("font_dark_background_color", EditorStringName(Editor), p_config.font_dark_background_color);
160
p_theme->set_color("font_dark_background_focus_color", EditorStringName(Editor), p_config.font_dark_background_focus_color);
161
p_theme->set_color("font_dark_background_hover_color", EditorStringName(Editor), p_config.font_dark_background_hover_color);
162
p_theme->set_color("font_dark_background_pressed_color", EditorStringName(Editor), p_config.font_dark_background_pressed_color);
163
p_theme->set_color("font_dark_background_hover_pressed_color", EditorStringName(Editor), p_config.font_dark_background_hover_pressed_color);
164
165
#ifndef DISABLE_DEPRECATED // Used before 4.3.
166
p_theme->set_color("readonly_font_color", EditorStringName(Editor), p_config.font_readonly_color);
167
p_theme->set_color("disabled_font_color", EditorStringName(Editor), p_config.font_disabled_color);
168
p_theme->set_color("readonly_color", EditorStringName(Editor), p_config.font_readonly_color);
169
p_theme->set_color("highlighted_font_color", EditorStringName(Editor), p_config.font_hover_color); // Closest equivalent.
170
#endif
171
172
// Icon colors.
173
174
p_config.icon_normal_color = Color(1, 1, 1, p_config.dark_icon_and_font ? 0.7 : 0.95);
175
p_config.icon_secondary_color = Color(1, 1, 1, p_config.dark_icon_and_font ? 0.45 : 0.6);
176
p_config.icon_focus_color = Color(1, 1, 1);
177
p_config.icon_hover_color = Color(1, 1, 1);
178
p_config.icon_pressed_color = p_config.accent_color * (p_config.dark_icon_and_font ? 1.15 : 3.5);
179
p_config.icon_pressed_color.a = 1.0;
180
p_config.icon_disabled_color = Color(1, 1, 1, p_config.dark_icon_and_font ? 0.35 : 0.5);
181
182
p_theme->set_color("icon_normal_color", EditorStringName(Editor), p_config.icon_normal_color);
183
p_theme->set_color("icon_focus_color", EditorStringName(Editor), p_config.icon_focus_color);
184
p_theme->set_color("icon_hover_color", EditorStringName(Editor), p_config.icon_hover_color);
185
p_theme->set_color("icon_pressed_color", EditorStringName(Editor), p_config.icon_pressed_color);
186
p_theme->set_color("icon_disabled_color", EditorStringName(Editor), p_config.icon_disabled_color);
187
188
// Additional GUI colors.
189
190
p_config.surface_lowest_color = _get_base_color(p_config, p_config.dark_theme ? -1.3 : -2.2, 0.9);
191
p_config.surface_lower_color = p_config.dark_color_3;
192
p_config.surface_low_color = _get_base_color(p_config, p_config.dark_theme ? -0.6 : -0.9);
193
p_config.surface_base_color = _get_base_color(p_config, -0.2);
194
p_config.surface_high_color = _get_base_color(p_config, 0.2, 0.8);
195
p_config.surface_higher_color = _get_base_color(p_config, 0.35, 0.8);
196
p_config.surface_highest_color = _get_base_color(p_config, 0.55, 0.6);
197
198
p_config.button_normal_color = _get_base_color(p_config, 0.35, 0.85);
199
p_config.button_hover_color = _get_base_color(p_config, 0.55, 0.75);
200
p_config.button_pressed_color = _get_base_color(p_config, 0.75, 0.75);
201
p_config.button_disabled_color = _get_base_color(p_config, 0.2, 0.75);
202
p_config.button_border_normal_color = _get_base_color(p_config, 0.45, 0.75);
203
p_config.button_border_hover_color = _get_base_color(p_config, 0.65, 0.75);
204
p_config.button_border_pressed_color = _get_base_color(p_config, 0.85, 0.75);
205
206
p_config.shadow_color = Color(0, 0, 0, p_config.dark_theme ? 0.3 : 0.1);
207
p_config.selection_color = p_config.accent_color * Color(1, 1, 1, 0.4);
208
p_config.disabled_border_color = p_config.mono_color.inverted().lerp(p_config.base_color, 0.7);
209
p_config.disabled_bg_color = p_config.mono_color.inverted().lerp(p_config.base_color, 0.9);
210
p_config.separator_color = p_config.dark_theme ? Color(0, 0, 0, 0.4) : Color(0, 0, 0, 0.2);
211
212
p_theme->set_color("selection_color", EditorStringName(Editor), p_config.selection_color);
213
p_theme->set_color("disabled_border_color", EditorStringName(Editor), p_config.disabled_border_color);
214
p_theme->set_color("disabled_bg_color", EditorStringName(Editor), p_config.disabled_bg_color);
215
p_theme->set_color("separator_color", EditorStringName(Editor), p_config.separator_color);
216
217
// Additional editor colors.
218
219
p_theme->set_color("box_selection_fill_color", EditorStringName(Editor), p_config.mono_color * Color(1, 1, 1, 0.12));
220
p_theme->set_color("box_selection_stroke_color", EditorStringName(Editor), p_config.mono_color * Color(1, 1, 1, 0.4));
221
222
p_theme->set_color("axis_x_color", EditorStringName(Editor), Color(0.96, 0.20, 0.32));
223
p_theme->set_color("axis_y_color", EditorStringName(Editor), Color(0.53, 0.84, 0.01));
224
p_theme->set_color("axis_z_color", EditorStringName(Editor), Color(0.16, 0.55, 0.96));
225
p_theme->set_color("axis_w_color", EditorStringName(Editor), Color(0.55, 0.55, 0.55));
226
227
p_theme->set_color("property_color_x", EditorStringName(Editor), p_config.dark_icon_and_font ? Color(0.88, 0.38, 0.47) : Color(0.40, 0.04, 0.09));
228
p_theme->set_color("property_color_y", EditorStringName(Editor), p_config.dark_icon_and_font ? Color(0.76, 0.93, 0.40) : Color(0.27, 0.37, 0.06));
229
p_theme->set_color("property_color_z", EditorStringName(Editor), p_config.dark_icon_and_font ? Color(0.42, 0.67, 0.96) : Color(0.08, 0.22, 0.38));
230
p_theme->set_color("property_color_w", EditorStringName(Editor), p_config.font_color);
231
232
// Special colors for rendering methods.
233
234
p_theme->set_color("forward_plus_color", EditorStringName(Editor), Color::hex(0x5d8c3fff));
235
p_theme->set_color("mobile_color", EditorStringName(Editor), Color::hex(0xa5557dff));
236
p_theme->set_color("gl_compatibility_color", EditorStringName(Editor), Color::hex(0x5586a4ff));
237
}
238
239
// Constants.
240
{
241
// Can't save single float in theme, so using Color.
242
p_theme->set_color("icon_saturation", EditorStringName(Editor), Color(p_config.icon_saturation, p_config.icon_saturation, p_config.icon_saturation));
243
244
// Controls may rely on the scale for their internal drawing logic.
245
p_theme->set_default_base_scale(EDSCALE);
246
p_theme->set_constant("scale", EditorStringName(Editor), EDSCALE);
247
248
p_theme->set_constant("thumb_size", EditorStringName(Editor), p_config.thumb_size);
249
p_theme->set_constant("class_icon_size", EditorStringName(Editor), p_config.class_icon_size);
250
p_theme->set_constant("gizmo_handle_scale", EditorStringName(Editor), p_config.gizmo_handle_scale);
251
252
p_theme->set_constant("base_margin", EditorStringName(Editor), p_config.base_margin);
253
p_theme->set_constant("increased_margin", EditorStringName(Editor), p_config.increased_margin);
254
p_theme->set_constant("window_border_margin", EditorStringName(Editor), p_config.window_border_margin);
255
p_theme->set_constant("top_bar_separation", EditorStringName(Editor), p_config.top_bar_separation);
256
257
p_theme->set_constant("dark_theme", EditorStringName(Editor), p_config.dark_theme);
258
}
259
260
// Styleboxes.
261
{
262
// This is the basic stylebox, used as a base for most other styleboxes (through `duplicate()`).
263
p_config.base_style = EditorThemeManager::make_flat_stylebox(p_config.base_color, p_config.increased_margin * 1.5, p_config.increased_margin * 1.5, p_config.increased_margin * 1.5, p_config.increased_margin * 1.5, p_config.corner_radius);
264
265
p_config.focus_style = p_config.base_style->duplicate();
266
p_config.focus_style->set_draw_center(false);
267
p_config.focus_style->set_border_color(p_config.accent_color * Color(1, 1, 1, 0.8));
268
p_config.focus_style->set_border_width_all(2);
269
270
p_config.base_empty_style = EditorThemeManager::make_empty_stylebox();
271
272
p_config.base_empty_wide_style = EditorThemeManager::make_empty_stylebox();
273
// Ensure minimum margin for wide flat buttons otherwise the topbar looks broken.
274
float base_empty_wide_margin = MAX(p_config.base_margin, 3.0);
275
p_config.base_empty_wide_style->set_content_margin_individual(base_empty_wide_margin * 1.5 * EDSCALE, base_empty_wide_margin * EDSCALE, base_empty_wide_margin * 1.5 * EDSCALE, base_empty_wide_margin * EDSCALE);
276
277
// Button styles.
278
{
279
p_config.widget_margin = Vector2(p_config.increased_margin + 2, p_config.increased_margin + 1) * EDSCALE;
280
281
p_config.button_style = p_config.base_style->duplicate();
282
p_config.button_style->set_content_margin_individual(p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.5 * EDSCALE, p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.5 * EDSCALE);
283
p_config.button_style->set_bg_color(p_config.button_normal_color);
284
p_config.button_style->set_border_width_all(Math::round(EDSCALE));
285
p_config.button_style->set_shadow_color(p_config.dark_theme ? Color(0, 0, 0, 0.005) : Color(1, 1, 1, 0.005));
286
p_config.button_style->set_shadow_size(Math::ceil(8 * EDSCALE));
287
p_config.button_style->set_shadow_offset(Vector2(0, 4) * EDSCALE);
288
if (p_config.draw_extra_borders) {
289
p_config.button_style->set_border_color(p_config.extra_border_color_1);
290
} else {
291
p_config.button_style->set_border_color(p_config.button_border_normal_color);
292
}
293
294
p_config.button_style_disabled = p_config.button_style->duplicate();
295
p_config.button_style_disabled->set_bg_color(p_config.button_disabled_color);
296
if (p_config.draw_extra_borders) {
297
p_config.button_style_disabled->set_border_color(p_config.extra_border_color_2 * Color(1, 1, 1, 0.5));
298
} else {
299
p_config.button_style_disabled->set_border_width_all(0);
300
}
301
302
p_config.button_style_pressed = p_config.button_style->duplicate();
303
p_config.button_style_pressed->set_bg_color(p_config.button_pressed_color);
304
if (p_config.draw_extra_borders) {
305
p_config.button_style_pressed->set_border_color(p_config.extra_border_color_1);
306
} else {
307
p_config.button_style_pressed->set_border_color(p_config.button_border_pressed_color);
308
}
309
310
p_config.button_style_hover = p_config.button_style->duplicate();
311
p_config.button_style_hover->set_bg_color(p_config.button_hover_color);
312
if (p_config.draw_extra_borders) {
313
p_config.button_style_pressed->set_border_color(p_config.extra_border_color_1);
314
} else {
315
p_config.button_style_hover->set_border_color(p_config.button_border_hover_color);
316
}
317
318
p_config.flat_button_hover = p_config.base_style->duplicate();
319
// Use the normal variation here and the hover one in the pressed state to lessen contrast.
320
p_config.flat_button_hover->set_bg_color(p_config.button_normal_color);
321
// This affects buttons in Tree so top and bottom margins should be kept low.
322
p_config.flat_button_hover->set_content_margin_individual(p_config.base_margin * 1.5 * EDSCALE, p_config.base_margin * 0.9 * EDSCALE, p_config.base_margin * 1.5 * EDSCALE, p_config.base_margin * 0.9 * EDSCALE);
323
if (p_config.draw_extra_borders) {
324
p_config.button_style_hover->set_border_color(p_config.extra_border_color_1);
325
}
326
327
p_config.flat_button_pressed = p_config.flat_button_hover->duplicate();
328
p_config.flat_button_pressed->set_bg_color(p_config.button_hover_color);
329
if (p_config.draw_extra_borders) {
330
p_config.flat_button_pressed->set_border_color(p_config.extra_border_color_1);
331
}
332
333
p_config.flat_button = p_config.flat_button_hover->duplicate();
334
p_config.flat_button->set_draw_center(false);
335
}
336
337
// Windows and popups.
338
{
339
p_config.popup_panel_style = p_config.base_style->duplicate();
340
p_config.popup_panel_style->set_bg_color(_get_base_color(p_config, -0.8, 0.9));
341
p_config.popup_panel_style->set_shadow_color(Color(0, 0, 0, 0.3));
342
p_config.popup_panel_style->set_shadow_size(p_config.base_margin * 0.75 * EDSCALE);
343
p_config.popup_panel_style->set_content_margin_all(p_config.popup_margin * EDSCALE);
344
p_config.popup_panel_style->set_corner_radius_all(0);
345
if (p_config.draw_extra_borders) {
346
p_config.popup_panel_style->set_border_width_all(Math::round(EDSCALE));
347
p_config.popup_panel_style->set_border_color(p_config.extra_border_color_2);
348
}
349
350
p_config.window_style = p_config.base_style->duplicate();
351
p_config.window_style->set_content_margin_all(p_config.popup_margin);
352
p_config.window_style->set_shadow_color(p_config.shadow_color);
353
p_config.window_style->set_shadow_size(4 * EDSCALE);
354
p_config.window_style->set_border_color(p_config.base_color);
355
p_config.window_style->set_border_width(SIDE_TOP, 24 * EDSCALE);
356
p_config.window_style->set_expand_margin(SIDE_TOP, 24 * EDSCALE);
357
p_config.window_style->set_corner_radius_all(0);
358
359
p_config.window_complex_style = p_config.window_style->duplicate();
360
p_config.window_complex_style->set_bg_color(p_config.surface_lowest_color);
361
362
p_config.dialog_style = p_config.base_style->duplicate();
363
p_config.dialog_style->set_content_margin_all(p_config.popup_margin);
364
p_config.dialog_style->set_corner_radius_all(0);
365
}
366
367
// Panels.
368
{
369
p_config.panel_container_style = p_config.button_style->duplicate();
370
p_config.panel_container_style->set_draw_center(false);
371
p_config.panel_container_style->set_border_width_all(0);
372
373
// Content panel for tabs and similar containers.
374
375
// Compensate for the border.
376
const int content_panel_margin = p_config.base_margin * EDSCALE + p_config.border_width;
377
378
p_config.content_panel_style = p_config.base_style->duplicate();
379
p_config.content_panel_style->set_border_color(p_config.dark_color_3);
380
p_config.content_panel_style->set_border_width_all(p_config.border_width);
381
p_config.content_panel_style->set_border_width(Side::SIDE_TOP, 0);
382
p_config.content_panel_style->set_corner_radius(CORNER_TOP_LEFT, 0);
383
p_config.content_panel_style->set_corner_radius(CORNER_TOP_RIGHT, 0);
384
p_config.content_panel_style->set_content_margin_individual(content_panel_margin, 2 * EDSCALE + content_panel_margin, content_panel_margin, content_panel_margin);
385
386
p_config.tab_container_style = p_config.base_style->duplicate();
387
p_config.tab_container_style->set_content_margin_all(p_config.increased_margin * 1.5 * EDSCALE);
388
p_config.tab_container_style->set_corner_radius_individual(0, 0, p_config.corner_radius * EDSCALE, p_config.corner_radius * EDSCALE);
389
390
p_config.foreground_panel = p_config.tab_container_style->duplicate();
391
p_config.foreground_panel->set_corner_radius(CORNER_TOP_LEFT, p_config.tab_container_style->get_corner_radius(CORNER_BOTTOM_LEFT));
392
p_config.foreground_panel->set_corner_radius(CORNER_TOP_RIGHT, p_config.tab_container_style->get_corner_radius(CORNER_BOTTOM_RIGHT));
393
394
// Trees and similarly inset panels.
395
396
p_config.tree_panel_style = p_config.base_style->duplicate();
397
// Make Trees easier to distinguish from other controls by using a darker background color.
398
p_config.tree_panel_style->set_bg_color(p_config.dark_color_1.lerp(p_config.dark_color_2, 0.5));
399
if (p_config.draw_extra_borders) {
400
p_config.tree_panel_style->set_border_width_all(Math::round(EDSCALE));
401
p_config.tree_panel_style->set_border_color(p_config.extra_border_color_2);
402
} else {
403
p_config.tree_panel_style->set_border_color(p_config.dark_color_3);
404
}
405
}
406
}
407
}
408
409
void ThemeModern::populate_standard_styles(const Ref<EditorTheme> &p_theme, EditorThemeManager::ThemeConfiguration &p_config) {
410
// Panels.
411
{
412
// Panel.
413
p_theme->set_stylebox(SceneStringName(panel), "Panel", EditorThemeManager::make_flat_stylebox(p_config.dark_color_1, 6, 4, 6, 4, p_config.corner_radius));
414
415
// PanelContainer.
416
p_theme->set_stylebox(SceneStringName(panel), "PanelContainer", p_config.base_empty_wide_style);
417
418
// TooltipPanel & TooltipLabel.
419
{
420
// TooltipPanel is also used for custom tooltips, while TooltipLabel
421
// is only relevant for default tooltips.
422
423
p_theme->set_color(SceneStringName(font_color), "TooltipLabel", p_config.font_hover_color);
424
p_theme->set_color("font_shadow_color", "TooltipLabel", Color(1, 1, 1, 0));
425
426
Ref<StyleBoxFlat> tooltip_style = p_config.base_style->duplicate();
427
tooltip_style->set_bg_color(p_config.surface_lower_color);
428
tooltip_style->set_content_margin_all(0);
429
tooltip_style->set_corner_radius_all(0);
430
if (p_config.draw_extra_borders) {
431
tooltip_style->set_border_width_all(Math::round(EDSCALE));
432
tooltip_style->set_border_color(p_config.extra_border_color_2);
433
}
434
p_theme->set_stylebox(SceneStringName(panel), "TooltipPanel", tooltip_style);
435
}
436
437
// PopupPanel
438
Ref<StyleBoxFlat> popup_panel_style = p_config.base_style->duplicate();
439
popup_panel_style->set_bg_color(p_config.surface_lower_color);
440
popup_panel_style->set_shadow_color(Color(0, 0, 0, 0.3));
441
popup_panel_style->set_shadow_size(p_config.base_margin * 0.75 * EDSCALE);
442
popup_panel_style->set_content_margin_all(p_config.popup_margin);
443
popup_panel_style->set_corner_radius_all(0);
444
if (p_config.draw_extra_borders) {
445
popup_panel_style->set_border_width_all(Math::round(EDSCALE));
446
popup_panel_style->set_border_color(p_config.extra_border_color_2);
447
}
448
p_theme->set_stylebox(SceneStringName(panel), "PopupPanel", p_config.popup_panel_style);
449
}
450
451
// Buttons.
452
{
453
// Button.
454
455
p_theme->set_stylebox(CoreStringName(normal), "Button", p_config.button_style);
456
p_theme->set_stylebox(SceneStringName(hover), "Button", p_config.button_style_hover);
457
p_theme->set_stylebox(SceneStringName(pressed), "Button", p_config.button_style_pressed);
458
p_theme->set_stylebox("hover_pressed", "Button", p_config.button_style_pressed);
459
p_theme->set_stylebox("focus", "Button", p_config.focus_style);
460
p_theme->set_stylebox("disabled", "Button", p_config.button_style_disabled);
461
462
p_theme->set_color(SceneStringName(font_color), "Button", p_config.font_color);
463
p_theme->set_color("font_hover_color", "Button", p_config.font_hover_color);
464
p_theme->set_color("font_hover_pressed_color", "Button", p_config.font_hover_pressed_color);
465
p_theme->set_color("font_focus_color", "Button", p_config.font_focus_color);
466
p_theme->set_color("font_pressed_color", "Button", p_config.font_pressed_color);
467
p_theme->set_color("font_disabled_color", "Button", p_config.font_disabled_color);
468
p_theme->set_color("font_outline_color", "Button", p_config.font_outline_color);
469
470
p_theme->set_color("icon_normal_color", "Button", p_config.icon_normal_color);
471
p_theme->set_color("icon_hover_color", "Button", p_config.icon_hover_color);
472
p_theme->set_color("icon_focus_color", "Button", p_config.icon_focus_color);
473
p_theme->set_color("icon_hover_pressed_color", "Button", p_config.icon_pressed_color);
474
p_theme->set_color("icon_pressed_color", "Button", p_config.icon_pressed_color);
475
p_theme->set_color("icon_disabled_color", "Button", p_config.icon_disabled_color);
476
477
p_theme->set_constant("h_separation", "Button", 4 * EDSCALE);
478
p_theme->set_constant("outline_size", "Button", 0);
479
480
p_theme->set_constant("outline_size", "Button", 0);
481
p_theme->set_constant("align_to_largest_stylebox", "Button", 1); // Enabled.
482
483
// MenuButton.
484
485
p_theme->set_stylebox(CoreStringName(normal), "MenuButton", p_config.base_empty_wide_style);
486
p_theme->set_stylebox(SceneStringName(hover), "MenuButton", p_config.flat_button_hover);
487
p_theme->set_stylebox(SceneStringName(pressed), "MenuButton", p_config.flat_button_pressed);
488
p_theme->set_stylebox("focus", "MenuButton", p_config.focus_style);
489
p_theme->set_stylebox("disabled", "MenuButton", p_config.base_empty_wide_style);
490
491
p_theme->set_constant("outline_size", "MenuButton", 0);
492
493
// MenuBar.
494
495
p_theme->set_stylebox(CoreStringName(normal), "MenuBar", p_config.button_style);
496
p_theme->set_stylebox(SceneStringName(hover), "MenuBar", p_config.button_style_hover);
497
p_theme->set_stylebox(SceneStringName(pressed), "MenuBar", p_config.button_style_pressed);
498
p_theme->set_stylebox("disabled", "MenuBar", p_config.button_style_disabled);
499
500
p_theme->set_color(SceneStringName(font_color), "MenuBar", p_config.font_color);
501
p_theme->set_color("font_hover_color", "MenuBar", p_config.font_hover_color);
502
p_theme->set_color("font_hover_pressed_color", "MenuBar", p_config.font_hover_pressed_color);
503
p_theme->set_color("font_focus_color", "MenuBar", p_config.font_focus_color);
504
p_theme->set_color("font_pressed_color", "MenuBar", p_config.font_pressed_color);
505
p_theme->set_color("font_disabled_color", "MenuBar", p_config.font_disabled_color);
506
p_theme->set_color("font_outline_color", "MenuBar", p_config.font_outline_color);
507
508
p_theme->set_constant("h_separation", "MenuBar", 4 * EDSCALE);
509
p_theme->set_constant("outline_size", "MenuBar", 0);
510
511
// OptionButton.
512
513
p_theme->set_stylebox("focus", "OptionButton", p_config.focus_style);
514
p_theme->set_stylebox(CoreStringName(normal), "OptionButton", p_config.button_style);
515
p_theme->set_stylebox(SceneStringName(hover), "OptionButton", p_config.button_style_hover);
516
p_theme->set_stylebox(SceneStringName(pressed), "OptionButton", p_config.button_style_pressed);
517
p_theme->set_stylebox("disabled", "OptionButton", p_config.button_style_disabled);
518
519
p_theme->set_icon("arrow", "OptionButton", p_theme->get_icon(SNAME("GuiOptionArrow"), EditorStringName(EditorIcons)));
520
p_theme->set_constant("arrow_margin", "OptionButton", p_config.base_margin * 2 * EDSCALE);
521
p_theme->set_constant("modulate_arrow", "OptionButton", true);
522
p_theme->set_constant("h_separation", "OptionButton", 4 * EDSCALE);
523
p_theme->set_constant("outline_size", "OptionButton", 0);
524
525
// CheckButton.
526
527
p_theme->set_stylebox(CoreStringName(normal), "CheckButton", p_config.panel_container_style);
528
p_theme->set_stylebox(SceneStringName(pressed), "CheckButton", p_config.panel_container_style);
529
p_theme->set_stylebox("disabled", "CheckButton", p_config.panel_container_style);
530
p_theme->set_stylebox(SceneStringName(hover), "CheckButton", p_config.panel_container_style);
531
p_theme->set_stylebox("hover_pressed", "CheckButton", p_config.panel_container_style);
532
533
p_theme->set_icon("checked", "CheckButton", p_theme->get_icon(SNAME("GuiToggleOn"), EditorStringName(EditorIcons)));
534
p_theme->set_icon("checked_disabled", "CheckButton", p_theme->get_icon(SNAME("GuiToggleOnDisabled"), EditorStringName(EditorIcons)));
535
p_theme->set_icon("unchecked", "CheckButton", p_theme->get_icon(SNAME("GuiToggleOff"), EditorStringName(EditorIcons)));
536
p_theme->set_icon("unchecked_disabled", "CheckButton", p_theme->get_icon(SNAME("GuiToggleOffDisabled"), EditorStringName(EditorIcons)));
537
538
p_theme->set_icon("checked_mirrored", "CheckButton", p_theme->get_icon(SNAME("GuiToggleOnMirrored"), EditorStringName(EditorIcons)));
539
p_theme->set_icon("checked_disabled_mirrored", "CheckButton", p_theme->get_icon(SNAME("GuiToggleOnDisabledMirrored"), EditorStringName(EditorIcons)));
540
p_theme->set_icon("unchecked_mirrored", "CheckButton", p_theme->get_icon(SNAME("GuiToggleOffMirrored"), EditorStringName(EditorIcons)));
541
p_theme->set_icon("unchecked_disabled_mirrored", "CheckButton", p_theme->get_icon(SNAME("GuiToggleOffDisabledMirrored"), EditorStringName(EditorIcons)));
542
543
p_theme->set_constant("h_separation", "CheckButton", 8 * EDSCALE);
544
p_theme->set_constant("check_v_offset", "CheckButton", 0);
545
p_theme->set_constant("outline_size", "CheckButton", 0);
546
547
// CheckBox.
548
{
549
Ref<StyleBoxFlat> checkbox_style = p_config.panel_container_style->duplicate();
550
checkbox_style->set_content_margin_individual(p_config.base_margin * 1.5 * EDSCALE, p_config.base_margin * 0.75 * EDSCALE, p_config.base_margin * 1.5 * EDSCALE, p_config.base_margin * 0.75 * EDSCALE);
551
Ref<StyleBoxFlat> checkbox_style_normal = checkbox_style->duplicate();
552
checkbox_style_normal->set_draw_center(false);
553
554
p_theme->set_stylebox(CoreStringName(normal), "CheckBox", checkbox_style_normal);
555
p_theme->set_stylebox(SceneStringName(pressed), "CheckBox", checkbox_style);
556
p_theme->set_stylebox("disabled", "CheckBox", checkbox_style);
557
p_theme->set_stylebox(SceneStringName(hover), "CheckBox", checkbox_style);
558
p_theme->set_stylebox("hover_pressed", "CheckBox", checkbox_style);
559
560
p_theme->set_icon("checked", "CheckBox", p_theme->get_icon(SNAME("GuiChecked"), EditorStringName(EditorIcons)));
561
562
p_theme->set_icon("unchecked", "CheckBox", p_theme->get_icon(SNAME("GuiUnchecked"), EditorStringName(EditorIcons)));
563
p_theme->set_icon("radio_checked", "CheckBox", p_theme->get_icon(SNAME("GuiRadioChecked"), EditorStringName(EditorIcons)));
564
p_theme->set_icon("radio_unchecked", "CheckBox", p_theme->get_icon(SNAME("GuiRadioUnchecked"), EditorStringName(EditorIcons)));
565
p_theme->set_icon("checked_disabled", "CheckBox", p_theme->get_icon(SNAME("GuiCheckedDisabled"), EditorStringName(EditorIcons)));
566
p_theme->set_icon("unchecked_disabled", "CheckBox", p_theme->get_icon(SNAME("GuiUncheckedDisabled"), EditorStringName(EditorIcons)));
567
p_theme->set_icon("radio_checked_disabled", "CheckBox", p_theme->get_icon(SNAME("GuiRadioCheckedDisabled"), EditorStringName(EditorIcons)));
568
p_theme->set_icon("radio_unchecked_disabled", "CheckBox", p_theme->get_icon(SNAME("GuiRadioUncheckedDisabled"), EditorStringName(EditorIcons)));
569
570
p_theme->set_constant("h_separation", "CheckBox", 8 * EDSCALE);
571
p_theme->set_constant("check_v_offset", "CheckBox", 0);
572
p_theme->set_constant("outline_size", "CheckBox", 0);
573
}
574
575
// LinkButton.
576
577
p_theme->set_stylebox("focus", "LinkButton", p_config.base_empty_style);
578
579
p_theme->set_color(SceneStringName(font_color), "LinkButton", p_config.font_color);
580
p_theme->set_color("font_hover_color", "LinkButton", p_config.font_hover_color);
581
p_theme->set_color("font_hover_pressed_color", "LinkButton", p_config.font_hover_pressed_color);
582
p_theme->set_color("font_focus_color", "LinkButton", p_config.font_focus_color);
583
p_theme->set_color("font_pressed_color", "LinkButton", p_config.font_pressed_color);
584
p_theme->set_color("font_disabled_color", "LinkButton", p_config.font_disabled_color);
585
p_theme->set_color("font_outline_color", "LinkButton", p_config.font_outline_color);
586
587
p_theme->set_constant("outline_size", "LinkButton", 0);
588
}
589
590
// Tree & ItemList.
591
{
592
// Tree.
593
{
594
// Use empty stylebox for trees to avoid drawing unnecessary borders in docks.
595
Ref<StyleBoxEmpty> style_tree_panel = p_config.base_empty_style->duplicate();
596
style_tree_panel->set_content_margin_individual(p_config.base_margin * 1.5 * EDSCALE, p_config.base_margin * 2.5 * EDSCALE, p_config.base_margin * 1.5 * EDSCALE, p_config.base_margin * 2.5 * EDSCALE);
597
598
Ref<StyleBoxFlat> style_button_pressed = p_config.flat_button_pressed->duplicate();
599
style_button_pressed->set_content_margin_individual(p_config.base_margin, 0, p_config.base_margin, 0);
600
601
p_theme->set_icon("checked", "Tree", p_theme->get_icon(SNAME("GuiChecked"), EditorStringName(EditorIcons)));
602
p_theme->set_icon("checked_disabled", "Tree", p_theme->get_icon(SNAME("GuiCheckedDisabled"), EditorStringName(EditorIcons)));
603
p_theme->set_icon("indeterminate", "Tree", p_theme->get_icon(SNAME("GuiIndeterminate"), EditorStringName(EditorIcons)));
604
p_theme->set_icon("indeterminate_disabled", "Tree", p_theme->get_icon(SNAME("GuiIndeterminateDisabled"), EditorStringName(EditorIcons)));
605
p_theme->set_icon("unchecked", "Tree", p_theme->get_icon(SNAME("GuiUnchecked"), EditorStringName(EditorIcons)));
606
p_theme->set_icon("unchecked_disabled", "Tree", p_theme->get_icon(SNAME("GuiUncheckedDisabled"), EditorStringName(EditorIcons)));
607
p_theme->set_icon("arrow", "Tree", p_theme->get_icon(SNAME("GuiTreeArrowDown"), EditorStringName(EditorIcons)));
608
p_theme->set_icon("arrow_collapsed", "Tree", p_theme->get_icon(SNAME("GuiTreeArrowRight"), EditorStringName(EditorIcons)));
609
p_theme->set_icon("arrow_collapsed_mirrored", "Tree", p_theme->get_icon(SNAME("GuiTreeArrowLeft"), EditorStringName(EditorIcons)));
610
p_theme->set_icon("updown", "Tree", p_theme->get_icon(SNAME("GuiTreeUpdown"), EditorStringName(EditorIcons)));
611
p_theme->set_icon("select_arrow", "Tree", p_theme->get_icon(SNAME("GuiDropdown"), EditorStringName(EditorIcons)));
612
613
p_theme->set_stylebox(SceneStringName(panel), "Tree", style_tree_panel);
614
p_theme->set_stylebox("focus", "Tree", p_config.focus_style);
615
p_theme->set_stylebox("button_pressed", "Tree", style_button_pressed);
616
p_theme->set_stylebox("custom_button", "Tree", p_config.flat_button);
617
p_theme->set_stylebox("custom_button_pressed", "Tree", style_button_pressed);
618
619
p_theme->set_color("custom_button_font_highlight", "Tree", p_config.font_hover_color);
620
p_theme->set_color(SceneStringName(font_color), "Tree", p_config.font_color);
621
p_theme->set_color("font_hovered_color", "Tree", p_config.font_hover_color);
622
p_theme->set_color("font_hovered_dimmed_color", "Tree", p_config.font_hover_color);
623
p_theme->set_color("font_hovered_selected_color", "Tree", p_config.font_hover_color);
624
p_theme->set_color("font_selected_color", "Tree", p_config.font_pressed_color);
625
p_theme->set_color("font_disabled_color", "Tree", p_config.font_disabled_color);
626
p_theme->set_color("font_outline_color", "Tree", p_config.font_outline_color);
627
p_theme->set_color("title_button_color", "Tree", p_config.font_color);
628
p_theme->set_color("drop_position_color", "Tree", p_config.accent_color);
629
630
int tree_v_sep = p_config.enable_touch_optimizations ? p_config.separation_margin : Math::pow(p_config.base_margin * 0.2 * EDSCALE, 3);
631
p_theme->set_constant("v_separation", "Tree", tree_v_sep);
632
p_theme->set_constant("h_separation", "Tree", (p_config.increased_margin + 2) * EDSCALE);
633
p_theme->set_constant("guide_width", "Tree", p_config.border_width);
634
p_theme->set_constant("item_margin", "Tree", MAX(3 * p_config.increased_margin * EDSCALE, 12 * EDSCALE));
635
p_theme->set_constant("inner_item_margin_top", "Tree", p_config.separation_margin);
636
p_theme->set_constant("inner_item_margin_bottom", "Tree", p_config.separation_margin);
637
p_theme->set_constant("inner_item_margin_left", "Tree", p_config.base_margin * EDSCALE);
638
p_theme->set_constant("inner_item_margin_right", "Tree", p_config.base_margin * EDSCALE);
639
p_theme->set_constant("button_margin", "Tree", p_config.base_margin * EDSCALE);
640
p_theme->set_constant("dragging_unfold_wait_msec", "Tree", p_config.dragging_hover_wait_msec);
641
p_theme->set_constant("scroll_border", "Tree", 40 * EDSCALE);
642
p_theme->set_constant("scroll_speed", "Tree", 12);
643
p_theme->set_constant("outline_size", "Tree", 0);
644
p_theme->set_constant("scrollbar_margin_left", "Tree", 0);
645
p_theme->set_constant("scrollbar_margin_top", "Tree", 0);
646
p_theme->set_constant("scrollbar_margin_right", "Tree", 0);
647
p_theme->set_constant("scrollbar_margin_bottom", "Tree", 0);
648
p_theme->set_constant("scrollbar_h_separation", "Tree", 1 * EDSCALE);
649
p_theme->set_constant("scrollbar_v_separation", "Tree", 1 * EDSCALE);
650
651
Color relationship_line_color = p_config.mono_color * Color(1, 1, 1, p_config.relationship_line_opacity);
652
Color highlight_line_color = p_config.mono_color * Color(1, 1, 1, p_config.relationship_line_opacity * 2);
653
654
int draw_relationship_lines = 0;
655
int relationship_line_width = 0;
656
int highlighted_line_width = Math::ceil(EDSCALE);
657
if (p_config.draw_relationship_lines == EditorThemeManager::RELATIONSHIP_ALL) {
658
draw_relationship_lines = 1;
659
relationship_line_width = 1;
660
} else if (p_config.draw_relationship_lines == EditorThemeManager::RELATIONSHIP_SELECTED_ONLY) {
661
draw_relationship_lines = 1;
662
}
663
664
p_theme->set_constant("draw_guides", "Tree", 0);
665
p_theme->set_constant("draw_relationship_lines", "Tree", draw_relationship_lines && p_config.relationship_line_opacity >= 0.01);
666
p_theme->set_constant("relationship_line_width", "Tree", relationship_line_width);
667
p_theme->set_constant("parent_hl_line_width", "Tree", highlighted_line_width);
668
p_theme->set_constant("children_hl_line_width", "Tree", 1);
669
p_theme->set_constant("parent_hl_line_margin", "Tree", 3);
670
p_theme->set_color("relationship_line_color", "Tree", relationship_line_color);
671
p_theme->set_color("parent_hl_line_color", "Tree", highlight_line_color);
672
p_theme->set_color("children_hl_line_color", "Tree", relationship_line_color);
673
p_theme->set_color("drop_position_color", "Tree", p_config.icon_normal_color);
674
p_theme->set_color("guide_color", "Tree", Color(1, 1, 1, 0));
675
676
Ref<StyleBoxFlat> style_tree_hover = p_config.flat_button_hover->duplicate();
677
style_tree_hover->set_bg_color(p_config.button_disabled_color);
678
style_tree_hover->set_content_margin_all(0);
679
680
p_theme->set_stylebox("button_hover", "Tree", style_tree_hover);
681
p_theme->set_stylebox("hovered", "Tree", style_tree_hover);
682
p_theme->set_stylebox("hovered_dimmed", "Tree", style_tree_hover);
683
p_theme->set_stylebox("custom_button_hover", "Tree", style_tree_hover);
684
p_theme->set_stylebox("selected", "Tree", style_tree_hover);
685
p_theme->set_stylebox("selected_focus", "Tree", p_config.focus_style);
686
687
Ref<StyleBoxFlat> style_tree_hover_selected = style_tree_hover->duplicate();
688
style_tree_hover_selected->set_bg_color(p_config.button_normal_color);
689
690
p_theme->set_stylebox("hovered_selected", "Tree", style_tree_hover_selected);
691
p_theme->set_stylebox("hovered_selected_focus", "Tree", p_config.focus_style);
692
693
// Cursor is drawn on top of the item so it needs to be transparent.
694
Ref<StyleBoxFlat> style_tree_cursor = p_config.base_style->duplicate();
695
style_tree_cursor->set_bg_color(p_config.mono_color * Color(1, 1, 1, 0.04));
696
697
Ref<StyleBoxFlat> style_tree_title = p_config.base_style->duplicate();
698
style_tree_title->set_bg_color(p_config.surface_lowest_color);
699
// Use a transparent border to separate rounded column titles.
700
style_tree_title->set_border_color(Color(p_config.surface_lowest_color, 0));
701
style_tree_title->set_border_width(SIDE_LEFT, Math::ceil(EDSCALE));
702
style_tree_title->set_border_width(SIDE_RIGHT, Math::ceil(EDSCALE));
703
704
p_theme->set_stylebox("cursor", "Tree", style_tree_cursor);
705
p_theme->set_stylebox("cursor_unfocused", "Tree", style_tree_cursor);
706
p_theme->set_stylebox("title_button_normal", "Tree", style_tree_title);
707
p_theme->set_stylebox("title_button_hover", "Tree", style_tree_title);
708
p_theme->set_stylebox("title_button_pressed", "Tree", style_tree_title);
709
}
710
711
// ItemList.
712
{
713
Ref<StyleBoxFlat> style_itemlist_bg = p_config.base_style->duplicate();
714
style_itemlist_bg->set_content_margin_all(p_config.base_margin * 2 * EDSCALE);
715
Ref<StyleBoxFlat> style_itemlist_cursor = p_config.base_style->duplicate();
716
style_itemlist_cursor->set_bg_color(p_config.mono_color * Color(1, 1, 1, 0.04));
717
718
p_theme->set_stylebox(SceneStringName(panel), "ItemList", style_itemlist_bg);
719
p_theme->set_stylebox("focus", "ItemList", p_config.focus_style);
720
p_theme->set_stylebox("cursor", "ItemList", style_itemlist_cursor);
721
p_theme->set_stylebox("cursor_unfocused", "ItemList", style_itemlist_cursor);
722
p_theme->set_stylebox("selected_focus", "ItemList", p_config.focus_style);
723
p_theme->set_stylebox("selected", "ItemList", p_config.flat_button_hover);
724
p_theme->set_stylebox("hovered", "ItemList", p_config.flat_button_hover);
725
p_theme->set_stylebox("hovered_selected", "ItemList", p_config.flat_button_hover);
726
p_theme->set_stylebox("hovered_selected_focus", "ItemList", p_config.focus_style);
727
p_theme->set_color(SceneStringName(font_color), "ItemList", p_config.font_color);
728
p_theme->set_color("font_hovered_color", "ItemList", p_config.font_hover_color);
729
p_theme->set_color("font_hovered_selected_color", "ItemList", p_config.font_hover_pressed_color);
730
p_theme->set_color("font_selected_color", "ItemList", p_config.font_pressed_color);
731
p_theme->set_color("font_outline_color", "ItemList", p_config.font_outline_color);
732
p_theme->set_color("guide_color", "ItemList", Color(1, 1, 1, 0));
733
p_theme->set_constant("v_separation", "ItemList", p_config.base_margin * 1.5 * EDSCALE);
734
p_theme->set_constant("h_separation", "ItemList", (p_config.increased_margin + 2) * EDSCALE);
735
p_theme->set_constant("icon_margin", "ItemList", (p_config.increased_margin + 2) * EDSCALE);
736
p_theme->set_constant(SceneStringName(line_separation), "ItemList", p_config.separation_margin);
737
p_theme->set_constant("outline_size", "ItemList", 0);
738
}
739
}
740
741
// TabBar & TabContainer.
742
{
743
Ref<StyleBoxFlat> style_tab_selected = p_config.base_style->duplicate();
744
style_tab_selected->set_content_margin_individual(p_config.base_margin * 4 * EDSCALE, p_config.base_margin * 2.1 * EDSCALE, p_config.base_margin * 4 * EDSCALE, p_config.base_margin * 2.1 * EDSCALE);
745
style_tab_selected->set_corner_radius_individual(p_config.corner_radius * EDSCALE, p_config.corner_radius * EDSCALE, 0, 0);
746
747
Ref<StyleBoxFlat> style_tab_focus = style_tab_selected->duplicate();
748
style_tab_focus->set_bg_color(p_config.base_color);
749
style_tab_focus->set_border_color(p_config.accent_color);
750
751
Ref<StyleBoxFlat> style_tab_unselected = style_tab_selected->duplicate();
752
style_tab_unselected->set_bg_color(p_config.surface_lowest_color);
753
style_tab_unselected->set_border_width_all(0);
754
755
Ref<StyleBoxFlat> style_tab_hovered = style_tab_unselected->duplicate();
756
style_tab_hovered->set_bg_color(p_config.surface_base_color * Color(1, 1, 1, 0.8));
757
758
Color drop_mark_color = p_config.dark_color_2.lerp(p_config.accent_color, 0.75);
759
760
Ref<StyleBoxFlat> style_tabbar_background = p_config.base_style->duplicate();
761
style_tabbar_background->set_bg_color(p_config.surface_lowest_color);
762
style_tabbar_background->set_corner_radius(CORNER_BOTTOM_LEFT, 0);
763
style_tabbar_background->set_corner_radius(CORNER_BOTTOM_RIGHT, 0);
764
style_tabbar_background->set_content_margin_individual(0, 0, p_config.base_margin * 0.25 * EDSCALE, 0);
765
766
p_theme->set_stylebox("tabbar_background", "TabContainer", style_tabbar_background);
767
p_theme->set_stylebox(SceneStringName(panel), "TabContainer", p_config.tab_container_style);
768
769
p_theme->set_stylebox("tab_selected", "TabContainer", style_tab_selected);
770
p_theme->set_stylebox("tab_hovered", "TabContainer", style_tab_hovered);
771
p_theme->set_stylebox("tab_unselected", "TabContainer", style_tab_unselected);
772
p_theme->set_stylebox("tab_disabled", "TabContainer", style_tab_unselected);
773
p_theme->set_stylebox("tab_focus", "TabContainer", p_config.focus_style);
774
p_theme->set_stylebox("tab_selected", "TabBar", style_tab_selected);
775
p_theme->set_stylebox("tab_hovered", "TabBar", style_tab_hovered);
776
p_theme->set_stylebox("tab_unselected", "TabBar", style_tab_unselected);
777
p_theme->set_stylebox("tab_disabled", "TabBar", style_tab_unselected);
778
p_theme->set_stylebox("tab_focus", "TabBar", p_config.focus_style);
779
p_theme->set_stylebox("button_pressed", "TabBar", p_config.panel_container_style);
780
p_theme->set_stylebox("button_highlight", "TabBar", p_config.panel_container_style);
781
782
p_theme->set_color("font_selected_color", "TabContainer", p_config.font_color);
783
p_theme->set_color("font_hovered_color", "TabContainer", p_config.font_hover_color);
784
p_theme->set_color("font_unselected_color", "TabContainer", p_config.font_secondary_color);
785
p_theme->set_color("font_disabled_color", "TabContainer", p_config.font_disabled_color * Color(1, 1, 1, 0.55));
786
p_theme->set_color("font_outline_color", "TabContainer", p_config.font_outline_color);
787
p_theme->set_color("font_selected_color", "TabBar", p_config.font_color);
788
p_theme->set_color("font_hovered_color", "TabBar", p_config.font_hover_color);
789
p_theme->set_color("font_unselected_color", "TabBar", p_config.font_secondary_color);
790
p_theme->set_color("font_disabled_color", "TabBar", p_config.font_disabled_color * Color(1, 1, 1, 0.55));
791
p_theme->set_color("font_outline_color", "TabBar", p_config.font_outline_color);
792
p_theme->set_color("drop_mark_color", "TabContainer", drop_mark_color);
793
p_theme->set_color("drop_mark_color", "TabBar", drop_mark_color);
794
795
p_theme->set_color("icon_selected_color", "TabContainer", p_config.icon_normal_color);
796
p_theme->set_color("icon_hovered_color", "TabContainer", p_config.icon_hover_color);
797
p_theme->set_color("icon_unselected_color", "TabContainer", p_config.icon_secondary_color);
798
p_theme->set_color("icon_disabled_color", "TabContainer", p_config.icon_disabled_color * Color(1, 1, 1, 0.55));
799
p_theme->set_color("icon_selected_color", "TabBar", p_config.icon_normal_color);
800
p_theme->set_color("icon_hovered_color", "TabBar", p_config.icon_hover_color);
801
p_theme->set_color("icon_unselected_color", "TabBar", p_config.icon_secondary_color);
802
p_theme->set_color("icon_disabled_color", "TabBar", p_config.icon_disabled_color * Color(1, 1, 1, 0.55));
803
804
p_theme->set_icon("menu", "TabContainer", p_theme->get_icon(SNAME("GuiTabMenu"), EditorStringName(EditorIcons)));
805
p_theme->set_icon("menu_highlight", "TabContainer", p_theme->get_icon(SNAME("GuiTabMenuHl"), EditorStringName(EditorIcons)));
806
p_theme->set_icon("close", "TabBar", p_theme->get_icon(SNAME("GuiClose"), EditorStringName(EditorIcons)));
807
p_theme->set_icon("increment", "TabContainer", p_theme->get_icon(SNAME("GuiScrollArrowRight"), EditorStringName(EditorIcons)));
808
p_theme->set_icon("decrement", "TabContainer", p_theme->get_icon(SNAME("GuiScrollArrowLeft"), EditorStringName(EditorIcons)));
809
p_theme->set_icon("increment", "TabBar", p_theme->get_icon(SNAME("GuiScrollArrowRight"), EditorStringName(EditorIcons)));
810
p_theme->set_icon("decrement", "TabBar", p_theme->get_icon(SNAME("GuiScrollArrowLeft"), EditorStringName(EditorIcons)));
811
p_theme->set_icon("increment_highlight", "TabBar", p_theme->get_icon(SNAME("GuiScrollArrowRightHl"), EditorStringName(EditorIcons)));
812
p_theme->set_icon("decrement_highlight", "TabBar", p_theme->get_icon(SNAME("GuiScrollArrowLeftHl"), EditorStringName(EditorIcons)));
813
p_theme->set_icon("increment_highlight", "TabContainer", p_theme->get_icon(SNAME("GuiScrollArrowRightHl"), EditorStringName(EditorIcons)));
814
p_theme->set_icon("decrement_highlight", "TabContainer", p_theme->get_icon(SNAME("GuiScrollArrowLeftHl"), EditorStringName(EditorIcons)));
815
p_theme->set_icon("drop_mark", "TabContainer", p_theme->get_icon(SNAME("GuiTabDropMark"), EditorStringName(EditorIcons)));
816
p_theme->set_icon("drop_mark", "TabBar", p_theme->get_icon(SNAME("GuiTabDropMark"), EditorStringName(EditorIcons)));
817
818
p_theme->set_constant("side_margin", "TabContainer", 0);
819
p_theme->set_constant("outline_size", "TabContainer", 0);
820
p_theme->set_constant("h_separation", "TabBar", 4 * EDSCALE);
821
p_theme->set_constant("outline_size", "TabBar", 0);
822
p_theme->set_constant("hover_switch_wait_msec", "TabBar", p_config.dragging_hover_wait_msec);
823
}
824
825
// Separators.
826
{
827
Ref<StyleBoxLine> style_h_separator = EditorThemeManager::make_line_stylebox(p_config.separator_color, Math::round(2 * EDSCALE), p_config.base_margin * -1 * EDSCALE, p_config.base_margin * -1 * EDSCALE);
828
p_theme->set_stylebox("separator", "HSeparator", style_h_separator);
829
830
Ref<StyleBoxLine> style_v_separator = style_h_separator->duplicate();
831
style_v_separator->set_vertical(true);
832
p_theme->set_stylebox("separator", "VSeparator", style_v_separator);
833
834
p_theme->set_constant("separation", "Separator", p_config.base_margin * 2 * EDSCALE);
835
}
836
837
// LineEdit & TextEdit.
838
{
839
Ref<StyleBoxFlat> text_editor_style = p_config.base_style->duplicate();
840
text_editor_style->set_bg_color(p_config.surface_lower_color);
841
text_editor_style->set_content_margin_individual(p_config.base_margin * 2 * EDSCALE, ((p_config.base_margin * 0.75) + 1) * EDSCALE, p_config.base_margin * 2 * EDSCALE, ((p_config.base_margin * 0.75) + 1) * EDSCALE);
842
if (p_config.draw_extra_borders) {
843
text_editor_style->set_border_width_all(Math::round(EDSCALE));
844
text_editor_style->set_border_color(p_config.extra_border_color_1);
845
}
846
847
Ref<StyleBoxFlat> text_editor_disabled_style = text_editor_style->duplicate();
848
// Using transparent background for readonly otherwise it looks bad in the master audio bus.
849
text_editor_disabled_style->set_bg_color(p_config.dark_theme ? Color(0, 0, 0, 0.2) : Color(1, 1, 1, 0.5));
850
851
// LineEdit.
852
853
p_theme->set_stylebox(CoreStringName(normal), "LineEdit", text_editor_style);
854
p_theme->set_stylebox("focus", "LineEdit", p_config.focus_style);
855
p_theme->set_stylebox("read_only", "LineEdit", text_editor_disabled_style);
856
857
p_theme->set_icon("clear", "LineEdit", p_theme->get_icon(SNAME("GuiClose"), EditorStringName(EditorIcons)));
858
859
p_theme->set_color(SceneStringName(font_color), "LineEdit", p_config.font_color);
860
p_theme->set_color("font_selected_color", "LineEdit", p_config.font_pressed_color);
861
p_theme->set_color("font_uneditable_color", "LineEdit", p_config.font_readonly_color);
862
p_theme->set_color("font_placeholder_color", "LineEdit", p_config.font_placeholder_color);
863
p_theme->set_color("font_outline_color", "LineEdit", p_config.font_outline_color);
864
p_theme->set_color("caret_color", "LineEdit", p_config.font_color);
865
p_theme->set_color("selection_color", "LineEdit", p_config.selection_color);
866
p_theme->set_color("clear_button_color", "LineEdit", p_config.font_color);
867
p_theme->set_color("clear_button_color_pressed", "LineEdit", p_config.accent_color);
868
869
p_theme->set_constant("minimum_character_width", "LineEdit", 4);
870
p_theme->set_constant("outline_size", "LineEdit", 0);
871
p_theme->set_constant("caret_width", "LineEdit", 1);
872
873
// TextEdit.
874
875
p_theme->set_stylebox(CoreStringName(normal), "TextEdit", text_editor_style);
876
p_theme->set_stylebox("focus", "TextEdit", p_config.focus_style);
877
p_theme->set_stylebox("read_only", "TextEdit", text_editor_disabled_style);
878
879
p_theme->set_icon("tab", "TextEdit", p_theme->get_icon(SNAME("GuiTab"), EditorStringName(EditorIcons)));
880
p_theme->set_icon("space", "TextEdit", p_theme->get_icon(SNAME("GuiSpace"), EditorStringName(EditorIcons)));
881
882
p_theme->set_color(SceneStringName(font_color), "TextEdit", p_config.font_color);
883
p_theme->set_color("font_readonly_color", "TextEdit", p_config.font_readonly_color);
884
p_theme->set_color("font_placeholder_color", "TextEdit", p_config.font_placeholder_color);
885
p_theme->set_color("font_outline_color", "TextEdit", p_config.font_outline_color);
886
p_theme->set_color("caret_color", "TextEdit", p_config.font_color);
887
p_theme->set_color("selection_color", "TextEdit", p_config.selection_color);
888
889
p_theme->set_constant("line_spacing", "TextEdit", 4 * EDSCALE);
890
p_theme->set_constant("outline_size", "TextEdit", 0);
891
p_theme->set_constant("caret_width", "TextEdit", 1);
892
}
893
894
// Containers.
895
{
896
p_theme->set_constant("separation", "BoxContainer", p_config.separation_margin);
897
p_theme->set_constant("separation", "HBoxContainer", p_config.separation_margin);
898
p_theme->set_constant("separation", "VBoxContainer", p_config.separation_margin);
899
p_theme->set_constant("margin_left", "MarginContainer", 0);
900
p_theme->set_constant("margin_top", "MarginContainer", 0);
901
p_theme->set_constant("margin_right", "MarginContainer", 0);
902
p_theme->set_constant("margin_bottom", "MarginContainer", 0);
903
p_theme->set_constant("h_separation", "GridContainer", p_config.separation_margin);
904
p_theme->set_constant("v_separation", "GridContainer", p_config.separation_margin);
905
p_theme->set_constant("h_separation", "FlowContainer", p_config.separation_margin);
906
p_theme->set_constant("v_separation", "FlowContainer", p_config.separation_margin);
907
p_theme->set_constant("h_separation", "HFlowContainer", p_config.separation_margin);
908
p_theme->set_constant("v_separation", "HFlowContainer", p_config.separation_margin);
909
p_theme->set_constant("h_separation", "VFlowContainer", p_config.separation_margin);
910
p_theme->set_constant("v_separation", "VFlowContainer", p_config.separation_margin);
911
912
// SplitContainer.
913
914
p_theme->set_icon("h_grabber", "SplitContainer", p_theme->get_icon(SNAME("GuiHsplitter"), EditorStringName(EditorIcons)));
915
p_theme->set_icon("v_grabber", "SplitContainer", p_theme->get_icon(SNAME("GuiVsplitter"), EditorStringName(EditorIcons)));
916
p_theme->set_icon("grabber", "VSplitContainer", p_theme->get_icon(SNAME("GuiVsplitter"), EditorStringName(EditorIcons)));
917
p_theme->set_icon("grabber", "HSplitContainer", p_theme->get_icon(SNAME("GuiHsplitter"), EditorStringName(EditorIcons)));
918
919
p_theme->set_constant("separation", "SplitContainer", p_config.base_margin * 0.75 * EDSCALE);
920
p_theme->set_constant("separation", "HSplitContainer", p_config.base_margin * 0.75 * EDSCALE);
921
p_theme->set_constant("separation", "VSplitContainer", p_config.base_margin * 0.75 * EDSCALE);
922
923
p_theme->set_constant("autohide", "SplitContainer", 1);
924
p_theme->set_constant("autohide", "HSplitContainer", 1);
925
p_theme->set_constant("autohide", "VSplitContainer", 1);
926
927
p_theme->set_constant("minimum_grab_thickness", "SplitContainer", p_config.base_margin * 2 * EDSCALE);
928
p_theme->set_constant("minimum_grab_thickness", "HSplitContainer", p_config.base_margin * 2 * EDSCALE);
929
p_theme->set_constant("minimum_grab_thickness", "VSplitContainer", p_config.base_margin * 2 * EDSCALE);
930
931
// GridContainer.
932
p_theme->set_constant("v_separation", "GridContainer", Math::round(p_config.widget_margin.y - 2 * EDSCALE));
933
934
// FoldableContainer
935
936
Ref<StyleBoxFlat> foldable_container_title = EditorThemeManager::make_flat_stylebox(p_config.dark_color_1.darkened(0.125), p_config.base_margin, p_config.base_margin, p_config.base_margin, p_config.base_margin);
937
foldable_container_title->set_corner_radius(CORNER_BOTTOM_LEFT, 0);
938
foldable_container_title->set_corner_radius(CORNER_BOTTOM_RIGHT, 0);
939
p_theme->set_stylebox("title_panel", "FoldableContainer", foldable_container_title);
940
Ref<StyleBoxFlat> foldable_container_hover = EditorThemeManager::make_flat_stylebox(p_config.dark_color_1.lerp(p_config.base_color, 0.4), p_config.base_margin, p_config.base_margin, p_config.base_margin, p_config.base_margin);
941
foldable_container_hover->set_corner_radius(CORNER_BOTTOM_LEFT, 0);
942
foldable_container_hover->set_corner_radius(CORNER_BOTTOM_RIGHT, 0);
943
p_theme->set_stylebox("title_hover_panel", "FoldableContainer", foldable_container_hover);
944
p_theme->set_stylebox("title_collapsed_panel", "FoldableContainer", EditorThemeManager::make_flat_stylebox(p_config.dark_color_1.darkened(0.125), p_config.base_margin, p_config.base_margin, p_config.base_margin, p_config.base_margin));
945
p_theme->set_stylebox("title_collapsed_hover_panel", "FoldableContainer", EditorThemeManager::make_flat_stylebox(p_config.dark_color_1.lerp(p_config.base_color, 0.4), p_config.base_margin, p_config.base_margin, p_config.base_margin, p_config.base_margin));
946
Ref<StyleBoxFlat> foldable_container_panel = EditorThemeManager::make_flat_stylebox(p_config.dark_color_1, p_config.base_margin, p_config.base_margin, p_config.base_margin, p_config.base_margin);
947
foldable_container_panel->set_corner_radius(CORNER_TOP_LEFT, 0);
948
foldable_container_panel->set_corner_radius(CORNER_TOP_RIGHT, 0);
949
p_theme->set_stylebox(SceneStringName(panel), "FoldableContainer", foldable_container_panel);
950
p_theme->set_stylebox("focus", "FoldableContainer", p_config.focus_style);
951
952
p_theme->set_font(SceneStringName(font), "FoldableContainer", p_theme->get_font(SceneStringName(font), SNAME("HeaderSmall")));
953
p_theme->set_font_size(SceneStringName(font_size), "FoldableContainer", p_theme->get_font_size(SceneStringName(font_size), SNAME("HeaderSmall")));
954
955
p_theme->set_color(SceneStringName(font_color), "FoldableContainer", p_config.font_color);
956
p_theme->set_color("hover_font_color", "FoldableContainer", p_config.font_hover_color);
957
p_theme->set_color("collapsed_font_color", "FoldableContainer", p_config.font_pressed_color);
958
p_theme->set_color("font_outline_color", "FoldableContainer", p_config.font_outline_color);
959
960
p_theme->set_icon("expanded_arrow", "FoldableContainer", p_theme->get_icon(SNAME("GuiTreeArrowDown"), EditorStringName(EditorIcons)));
961
p_theme->set_icon("expanded_arrow_mirrored", "FoldableContainer", p_theme->get_icon(SNAME("GuiArrowUp"), EditorStringName(EditorIcons)));
962
p_theme->set_icon("folded_arrow", "FoldableContainer", p_theme->get_icon(SNAME("GuiTreeArrowRight"), EditorStringName(EditorIcons)));
963
p_theme->set_icon("folded_arrow_mirrored", "FoldableContainer", p_theme->get_icon(SNAME("GuiTreeArrowLeft"), EditorStringName(EditorIcons)));
964
965
p_theme->set_constant("outline_size", "FoldableContainer", 0);
966
p_theme->set_constant("h_separation", "FoldableContainer", p_config.separation_margin);
967
}
968
969
// Window and dialogs.
970
{
971
// Window.
972
973
p_theme->set_stylebox("embedded_border", "Window", p_config.window_style);
974
p_theme->set_stylebox("embedded_unfocused_border", "Window", p_config.window_style);
975
976
p_theme->set_color("title_color", "Window", p_config.font_color);
977
p_theme->set_icon("close", "Window", p_theme->get_icon(SNAME("GuiClose"), EditorStringName(EditorIcons)));
978
p_theme->set_icon("close_pressed", "Window", p_theme->get_icon(SNAME("GuiClose"), EditorStringName(EditorIcons)));
979
p_theme->set_constant("close_h_offset", "Window", 22 * EDSCALE);
980
p_theme->set_constant("close_v_offset", "Window", 20 * EDSCALE);
981
p_theme->set_constant("title_height", "Window", 24 * EDSCALE);
982
p_theme->set_constant("resize_margin", "Window", 4 * EDSCALE);
983
p_theme->set_font("title_font", "Window", p_theme->get_font(SNAME("title"), EditorStringName(EditorFonts)));
984
p_theme->set_font_size("title_font_size", "Window", p_theme->get_font_size(SNAME("title_size"), EditorStringName(EditorFonts)));
985
986
// AcceptDialog.
987
p_theme->set_stylebox(SceneStringName(panel), "AcceptDialog", p_config.dialog_style);
988
p_theme->set_constant("buttons_separation", "AcceptDialog", 8 * EDSCALE);
989
// Make buttons with short texts such as "OK" easier to click/tap.
990
p_theme->set_constant("buttons_min_width", "AcceptDialog", p_config.dialogs_buttons_min_size.x * EDSCALE);
991
p_theme->set_constant("buttons_min_height", "AcceptDialog", p_config.dialogs_buttons_min_size.y * EDSCALE);
992
993
// FileDialog.
994
p_theme->set_icon("folder", "FileDialog", p_theme->get_icon(SNAME("Folder"), EditorStringName(EditorIcons)));
995
p_theme->set_icon("parent_folder", "FileDialog", p_theme->get_icon(SNAME("ArrowUp"), EditorStringName(EditorIcons)));
996
p_theme->set_icon("back_folder", "FileDialog", p_theme->get_icon(SNAME("Back"), EditorStringName(EditorIcons)));
997
p_theme->set_icon("forward_folder", "FileDialog", p_theme->get_icon(SNAME("Forward"), EditorStringName(EditorIcons)));
998
p_theme->set_icon("reload", "FileDialog", p_theme->get_icon(SNAME("Reload"), EditorStringName(EditorIcons)));
999
p_theme->set_icon("toggle_hidden", "FileDialog", p_theme->get_icon(SNAME("GuiVisibilityVisible"), EditorStringName(EditorIcons)));
1000
p_theme->set_icon("create_folder", "FileDialog", p_theme->get_icon(SNAME("FolderCreate"), EditorStringName(EditorIcons)));
1001
// Use a different color for folder icons to make them easier to distinguish from files.
1002
// On a light theme, the icon will be dark, so we need to lighten it before blending it with the accent color.
1003
p_theme->set_color("folder_icon_color", "FileDialog", (p_config.dark_icon_and_font ? Color(1, 1, 1) : Color(4.25, 4.25, 4.25)).lerp(p_config.accent_color, 0.7));
1004
p_theme->set_color("file_disabled_color", "FileDialog", p_config.font_disabled_color);
1005
1006
p_theme->set_constant("thumbnail_size", "EditorFileDialog", p_config.thumb_size);
1007
1008
// PopupDialog.
1009
p_theme->set_stylebox(SceneStringName(panel), "PopupDialog", p_config.dialog_style);
1010
1011
// PopupMenu.
1012
{
1013
Ref<StyleBoxFlat> style_popup_menu = p_config.base_style->duplicate();
1014
style_popup_menu->set_bg_color(p_config.surface_lower_color);
1015
style_popup_menu->set_content_margin_all(p_config.popup_margin);
1016
style_popup_menu->set_corner_radius_all(0);
1017
if (p_config.draw_extra_borders) {
1018
style_popup_menu->set_border_width_all(Math::round(EDSCALE));
1019
style_popup_menu->set_border_color(p_config.extra_border_color_2);
1020
}
1021
p_theme->set_stylebox(SceneStringName(panel), "PopupMenu", style_popup_menu);
1022
1023
p_theme->set_stylebox(SceneStringName(hover), "PopupMenu", p_config.flat_button_hover);
1024
1025
Ref<StyleBoxLine> style_popup_separator = EditorThemeManager::make_line_stylebox(p_config.mono_color * Color(1, 1, 1, p_config.dark_theme ? 0.075 : 0.125), Math::round(2 * EDSCALE), p_config.base_margin * -2 * EDSCALE, p_config.base_margin * -2 * EDSCALE);
1026
1027
p_theme->set_stylebox("separator", "PopupMenu", style_popup_separator);
1028
p_theme->set_stylebox("labeled_separator_left", "PopupMenu", style_popup_separator);
1029
p_theme->set_stylebox("labeled_separator_right", "PopupMenu", style_popup_separator);
1030
1031
p_theme->set_color(SceneStringName(font_color), "PopupMenu", p_config.font_color);
1032
p_theme->set_color("font_hover_color", "PopupMenu", p_config.font_hover_color);
1033
p_theme->set_color("font_accelerator_color", "PopupMenu", p_config.font_disabled_color);
1034
p_theme->set_color("font_disabled_color", "PopupMenu", p_config.font_disabled_color);
1035
p_theme->set_color("font_separator_color", "PopupMenu", p_config.font_disabled_color);
1036
p_theme->set_color("font_outline_color", "PopupMenu", p_config.font_outline_color);
1037
1038
p_theme->set_icon("checked", "PopupMenu", p_theme->get_icon(SNAME("GuiChecked"), EditorStringName(EditorIcons)));
1039
p_theme->set_icon("unchecked", "PopupMenu", p_theme->get_icon(SNAME("GuiUnchecked"), EditorStringName(EditorIcons)));
1040
p_theme->set_icon("radio_checked", "PopupMenu", p_theme->get_icon(SNAME("GuiRadioChecked"), EditorStringName(EditorIcons)));
1041
p_theme->set_icon("radio_unchecked", "PopupMenu", p_theme->get_icon(SNAME("GuiRadioUnchecked"), EditorStringName(EditorIcons)));
1042
p_theme->set_icon("checked_disabled", "PopupMenu", p_theme->get_icon(SNAME("GuiCheckedDisabled"), EditorStringName(EditorIcons)));
1043
p_theme->set_icon("unchecked_disabled", "PopupMenu", p_theme->get_icon(SNAME("GuiUncheckedDisabled"), EditorStringName(EditorIcons)));
1044
p_theme->set_icon("radio_checked_disabled", "PopupMenu", p_theme->get_icon(SNAME("GuiRadioCheckedDisabled"), EditorStringName(EditorIcons)));
1045
p_theme->set_icon("radio_unchecked_disabled", "PopupMenu", p_theme->get_icon(SNAME("GuiRadioUncheckedDisabled"), EditorStringName(EditorIcons)));
1046
p_theme->set_icon("submenu", "PopupMenu", p_theme->get_icon(SNAME("ArrowRight"), EditorStringName(EditorIcons)));
1047
p_theme->set_icon("submenu_mirrored", "PopupMenu", p_theme->get_icon(SNAME("ArrowLeft"), EditorStringName(EditorIcons)));
1048
1049
p_theme->set_constant("h_separation", "PopupMenu", p_config.base_margin * 1.75 * EDSCALE);
1050
int v_sep = (p_config.enable_touch_optimizations ? 12 : p_config.base_margin * 1.75) * EDSCALE;
1051
p_theme->set_constant("v_separation", "PopupMenu", v_sep);
1052
p_theme->set_constant("outline_size", "PopupMenu", 0);
1053
p_theme->set_constant("item_start_padding", "PopupMenu", p_config.popup_margin);
1054
p_theme->set_constant("item_end_padding", "PopupMenu", p_config.popup_margin);
1055
}
1056
}
1057
1058
// Sliders and scrollbars.
1059
{
1060
Ref<Texture2D> empty_icon = memnew(ImageTexture);
1061
1062
Ref<StyleBoxFlat> grabber_style = p_config.base_style->duplicate();
1063
grabber_style->set_bg_color(p_config.mono_color * Color(1, 1, 1, 0.225));
1064
1065
Ref<StyleBoxFlat> grabber_hl_style = p_config.base_style->duplicate();
1066
grabber_hl_style->set_bg_color(p_config.mono_color * Color(1, 1, 1, 0.5));
1067
1068
int scroll_margin = (p_config.enable_touch_optimizations ? 10 : 3) * EDSCALE;
1069
1070
// HScrollBar.
1071
1072
Ref<StyleBoxEmpty> h_scroll_style = p_config.base_empty_style->duplicate();
1073
h_scroll_style->set_content_margin_individual(0, scroll_margin, 0, scroll_margin);
1074
1075
p_theme->set_stylebox("scroll", "HScrollBar", h_scroll_style);
1076
p_theme->set_stylebox("scroll_focus", "HScrollBar", p_config.focus_style);
1077
p_theme->set_stylebox("grabber", "HScrollBar", grabber_style);
1078
p_theme->set_stylebox("grabber_highlight", "HScrollBar", grabber_hl_style);
1079
p_theme->set_stylebox("grabber_pressed", "HScrollBar", grabber_hl_style);
1080
1081
p_theme->set_icon("increment", "HScrollBar", empty_icon);
1082
p_theme->set_icon("increment_highlight", "HScrollBar", empty_icon);
1083
p_theme->set_icon("increment_pressed", "HScrollBar", empty_icon);
1084
p_theme->set_icon("decrement", "HScrollBar", empty_icon);
1085
p_theme->set_icon("decrement_highlight", "HScrollBar", empty_icon);
1086
p_theme->set_icon("decrement_pressed", "HScrollBar", empty_icon);
1087
1088
p_theme->set_constant("padding_top", "HScrollBar", p_config.base_margin * EDSCALE);
1089
p_theme->set_constant("padding_bottom", "HScrollBar", p_config.base_margin * EDSCALE);
1090
1091
// VScrollBar.
1092
1093
Ref<StyleBoxEmpty> v_scroll_style = p_config.base_empty_style->duplicate();
1094
v_scroll_style->set_content_margin_individual(scroll_margin, 0, scroll_margin, 0);
1095
1096
p_theme->set_stylebox("scroll", "VScrollBar", v_scroll_style);
1097
p_theme->set_stylebox("scroll_focus", "VScrollBar", p_config.focus_style);
1098
p_theme->set_stylebox("grabber", "VScrollBar", grabber_style);
1099
p_theme->set_stylebox("grabber_highlight", "VScrollBar", grabber_hl_style);
1100
p_theme->set_stylebox("grabber_pressed", "VScrollBar", grabber_hl_style);
1101
1102
p_theme->set_icon("increment", "VScrollBar", empty_icon);
1103
p_theme->set_icon("increment_highlight", "VScrollBar", empty_icon);
1104
p_theme->set_icon("increment_pressed", "VScrollBar", empty_icon);
1105
p_theme->set_icon("decrement", "VScrollBar", empty_icon);
1106
p_theme->set_icon("decrement_highlight", "VScrollBar", empty_icon);
1107
p_theme->set_icon("decrement_pressed", "VScrollBar", empty_icon);
1108
1109
p_theme->set_constant("padding_left", "VScrollBar", p_config.base_margin * EDSCALE);
1110
p_theme->set_constant("padding_right", "VScrollBar", p_config.base_margin * EDSCALE);
1111
1112
// Slider
1113
const int background_margin = MAX(2, p_config.base_margin / 2);
1114
1115
Ref<StyleBoxFlat> style_h_slider = p_config.base_style->duplicate();
1116
style_h_slider->set_bg_color(p_config.mono_color_inv * Color(1, 1, 1, 0.35));
1117
style_h_slider->set_content_margin_individual(0, 2 * EDSCALE, 0, 2 * EDSCALE);
1118
1119
// HSlider.
1120
p_theme->set_icon("grabber_highlight", "HSlider", p_theme->get_icon(SNAME("GuiSliderGrabberHl"), EditorStringName(EditorIcons)));
1121
p_theme->set_icon("grabber", "HSlider", p_theme->get_icon(SNAME("GuiSliderGrabber"), EditorStringName(EditorIcons)));
1122
p_theme->set_stylebox("slider", "HSlider", style_h_slider);
1123
p_theme->set_stylebox("grabber_area", "HSlider", EditorThemeManager::make_flat_stylebox(p_config.contrast_color_1, 0, background_margin, 0, background_margin, p_config.corner_radius));
1124
p_theme->set_stylebox("grabber_area_highlight", "HSlider", EditorThemeManager::make_flat_stylebox(p_config.contrast_color_1, 0, background_margin, 0, background_margin));
1125
p_theme->set_constant("center_grabber", "HSlider", 0);
1126
p_theme->set_constant("grabber_offset", "HSlider", 0);
1127
1128
Ref<StyleBoxFlat> style_v_slider = style_h_slider->duplicate();
1129
style_v_slider->set_content_margin_individual(2 * EDSCALE, 0, 2 * EDSCALE, 0);
1130
1131
// VSlider.
1132
p_theme->set_icon("grabber", "VSlider", p_theme->get_icon(SNAME("GuiSliderGrabber"), EditorStringName(EditorIcons)));
1133
p_theme->set_icon("grabber_highlight", "VSlider", p_theme->get_icon(SNAME("GuiSliderGrabberHl"), EditorStringName(EditorIcons)));
1134
p_theme->set_stylebox("slider", "VSlider", style_v_slider);
1135
p_theme->set_stylebox("grabber_area", "VSlider", EditorThemeManager::make_flat_stylebox(p_config.contrast_color_1, background_margin, 0, background_margin, 0, p_config.corner_radius));
1136
p_theme->set_stylebox("grabber_area_highlight", "VSlider", EditorThemeManager::make_flat_stylebox(p_config.contrast_color_1, background_margin, 0, background_margin, 0));
1137
p_theme->set_constant("center_grabber", "VSlider", 0);
1138
p_theme->set_constant("grabber_offset", "VSlider", 0);
1139
}
1140
1141
// Labels.
1142
{
1143
// RichTextLabel.
1144
1145
Ref<StyleBoxFlat> rich_text_style = p_config.base_style->duplicate();
1146
rich_text_style->set_bg_color(p_config.surface_low_color);
1147
rich_text_style->set_content_margin_all(p_config.base_margin * 2 * EDSCALE);
1148
1149
p_theme->set_stylebox(CoreStringName(normal), "RichTextLabel", rich_text_style);
1150
p_theme->set_stylebox("focus", "RichTextLabel", EditorThemeManager::make_empty_stylebox());
1151
1152
p_theme->set_color("default_color", "RichTextLabel", p_config.font_color);
1153
p_theme->set_color("font_shadow_color", "RichTextLabel", Color(1, 1, 1, 0));
1154
p_theme->set_color("font_outline_color", "RichTextLabel", p_config.font_outline_color);
1155
p_theme->set_color("selection_color", "RichTextLabel", p_config.selection_color);
1156
1157
p_theme->set_constant("shadow_offset_x", "RichTextLabel", 1 * EDSCALE);
1158
p_theme->set_constant("shadow_offset_y", "RichTextLabel", 1 * EDSCALE);
1159
p_theme->set_constant("shadow_outline_size", "RichTextLabel", 1 * EDSCALE);
1160
p_theme->set_constant("outline_size", "RichTextLabel", 0);
1161
1162
// Label.
1163
1164
Ref<StyleBoxEmpty> label_style = p_config.base_empty_style->duplicate();
1165
label_style->set_content_margin_individual(p_config.base_margin * 2 * EDSCALE, p_config.base_margin * EDSCALE, p_config.base_margin * 2 * EDSCALE, p_config.base_margin * EDSCALE);
1166
1167
p_theme->set_stylebox(CoreStringName(normal), "Label", label_style);
1168
p_theme->set_stylebox("focus", "Label", p_config.focus_style);
1169
1170
p_theme->set_color(SceneStringName(font_color), "Label", p_config.font_color);
1171
p_theme->set_color("font_shadow_color", "Label", Color(1, 1, 1, 0));
1172
p_theme->set_color("font_outline_color", "Label", p_config.font_outline_color);
1173
1174
p_theme->set_constant("shadow_offset_x", "Label", 1 * EDSCALE);
1175
p_theme->set_constant("shadow_offset_y", "Label", 1 * EDSCALE);
1176
p_theme->set_constant("shadow_outline_size", "Label", 1 * EDSCALE);
1177
p_theme->set_constant("line_spacing", "Label", 3 * EDSCALE);
1178
p_theme->set_constant("outline_size", "Label", 0);
1179
}
1180
1181
// SpinBox.
1182
{
1183
Ref<Texture2D> empty_icon = memnew(ImageTexture);
1184
p_theme->set_icon("updown", "SpinBox", empty_icon);
1185
p_theme->set_icon("up", "SpinBox", p_theme->get_icon(SNAME("GuiSpinboxUp"), EditorStringName(EditorIcons)));
1186
p_theme->set_icon("up_hover", "SpinBox", p_theme->get_icon(SNAME("GuiSpinboxUp"), EditorStringName(EditorIcons)));
1187
p_theme->set_icon("up_pressed", "SpinBox", p_theme->get_icon(SNAME("GuiSpinboxUp"), EditorStringName(EditorIcons)));
1188
p_theme->set_icon("up_disabled", "SpinBox", p_theme->get_icon(SNAME("GuiSpinboxUp"), EditorStringName(EditorIcons)));
1189
p_theme->set_icon("down", "SpinBox", p_theme->get_icon(SNAME("GuiSpinboxDown"), EditorStringName(EditorIcons)));
1190
p_theme->set_icon("down_hover", "SpinBox", p_theme->get_icon(SNAME("GuiSpinboxDown"), EditorStringName(EditorIcons)));
1191
p_theme->set_icon("down_pressed", "SpinBox", p_theme->get_icon(SNAME("GuiSpinboxDown"), EditorStringName(EditorIcons)));
1192
p_theme->set_icon("down_disabled", "SpinBox", p_theme->get_icon(SNAME("GuiSpinboxDown"), EditorStringName(EditorIcons)));
1193
1194
p_theme->set_stylebox("up_background", "SpinBox", EditorThemeManager::make_empty_stylebox());
1195
p_theme->set_stylebox("up_background_hovered", "SpinBox", p_config.button_style_hover);
1196
p_theme->set_stylebox("up_background_pressed", "SpinBox", p_config.button_style_pressed);
1197
p_theme->set_stylebox("up_background_disabled", "SpinBox", EditorThemeManager::make_empty_stylebox());
1198
p_theme->set_stylebox("down_background", "SpinBox", EditorThemeManager::make_empty_stylebox());
1199
p_theme->set_stylebox("down_background_hovered", "SpinBox", p_config.button_style_hover);
1200
p_theme->set_stylebox("down_background_pressed", "SpinBox", p_config.button_style_pressed);
1201
p_theme->set_stylebox("down_background_disabled", "SpinBox", EditorThemeManager::make_empty_stylebox());
1202
1203
p_theme->set_color("up_icon_modulate", "SpinBox", p_config.icon_normal_color);
1204
p_theme->set_color("up_hover_icon_modulate", "SpinBox", p_config.icon_hover_color);
1205
p_theme->set_color("up_pressed_icon_modulate", "SpinBox", p_config.icon_pressed_color);
1206
p_theme->set_color("up_disabled_icon_modulate", "SpinBox", p_config.icon_disabled_color);
1207
p_theme->set_color("down_icon_modulate", "SpinBox", p_config.icon_normal_color);
1208
p_theme->set_color("down_hover_icon_modulate", "SpinBox", p_config.icon_hover_color);
1209
p_theme->set_color("down_pressed_icon_modulate", "SpinBox", p_config.icon_pressed_color);
1210
p_theme->set_color("down_disabled_icon_modulate", "SpinBox", p_config.icon_disabled_color);
1211
1212
p_theme->set_stylebox("field_and_buttons_separator", "SpinBox", EditorThemeManager::make_empty_stylebox());
1213
p_theme->set_stylebox("up_down_buttons_separator", "SpinBox", EditorThemeManager::make_empty_stylebox());
1214
1215
p_theme->set_constant("buttons_vertical_separation", "SpinBox", 0);
1216
p_theme->set_constant("field_and_buttons_separation", "SpinBox", 2);
1217
p_theme->set_constant("buttons_width", "SpinBox", 16);
1218
#ifndef DISABLE_DEPRECATED
1219
p_theme->set_constant("set_min_buttons_width_from_icons", "SpinBox", 1);
1220
#endif
1221
}
1222
1223
// ProgressBar.
1224
1225
Ref<StyleBoxFlat> progress_bar_style = p_config.base_style->duplicate();
1226
progress_bar_style->set_bg_color(p_config.surface_lowest_color);
1227
progress_bar_style->set_expand_margin(SIDE_TOP, p_config.base_margin * 0.5 * EDSCALE);
1228
progress_bar_style->set_expand_margin(SIDE_BOTTOM, p_config.base_margin * 0.5 * EDSCALE);
1229
progress_bar_style->set_content_margin_all(p_config.base_margin * EDSCALE);
1230
if (p_config.draw_extra_borders) {
1231
progress_bar_style->set_border_width_all(Math::round(EDSCALE));
1232
progress_bar_style->set_border_color(p_config.extra_border_color_2);
1233
}
1234
1235
Ref<StyleBoxFlat> progress_fill_style = progress_bar_style->duplicate();
1236
progress_fill_style->set_bg_color(p_config.button_normal_color);
1237
if (p_config.draw_extra_borders) {
1238
progress_fill_style->set_border_color(p_config.extra_border_color_1);
1239
}
1240
1241
p_theme->set_stylebox("background", "ProgressBar", progress_bar_style);
1242
p_theme->set_stylebox("fill", "ProgressBar", progress_fill_style);
1243
p_theme->set_color(SceneStringName(font_color), "ProgressBar", p_config.font_color);
1244
p_theme->set_color("font_outline_color", "ProgressBar", p_config.font_outline_color);
1245
p_theme->set_constant("outline_size", "ProgressBar", 0);
1246
1247
// GraphEdit and related nodes.
1248
{
1249
// GraphEdit.
1250
1251
Ref<StyleBoxFlat> ge_panel_style = p_config.base_style->duplicate();
1252
ge_panel_style->set_bg_color(p_config.surface_lowest_color);
1253
1254
p_theme->set_stylebox(SceneStringName(panel), "GraphEdit", ge_panel_style);
1255
p_theme->set_stylebox("panel_focus", "GraphEdit", p_config.focus_style);
1256
p_theme->set_stylebox("menu_panel", "GraphEdit", EditorThemeManager::make_flat_stylebox(p_config.surface_low_color * Color(1, 1, 1, 0.5), 4, 2, 4, 2, 3));
1257
1258
float grid_base_brightness = p_config.dark_theme ? 1.0 : 0.0;
1259
GraphEdit::GridPattern grid_pattern = (GraphEdit::GridPattern) int(EDITOR_GET("editors/visual_editors/grid_pattern"));
1260
switch (grid_pattern) {
1261
case GraphEdit::GRID_PATTERN_LINES:
1262
p_theme->set_color("grid_major", "GraphEdit", Color(grid_base_brightness, grid_base_brightness, grid_base_brightness, 0.10));
1263
p_theme->set_color("grid_minor", "GraphEdit", Color(grid_base_brightness, grid_base_brightness, grid_base_brightness, 0.05));
1264
break;
1265
case GraphEdit::GRID_PATTERN_DOTS:
1266
p_theme->set_color("grid_major", "GraphEdit", Color(grid_base_brightness, grid_base_brightness, grid_base_brightness, 0.07));
1267
p_theme->set_color("grid_minor", "GraphEdit", Color(grid_base_brightness, grid_base_brightness, grid_base_brightness, 0.07));
1268
break;
1269
default:
1270
WARN_PRINT("Unknown grid pattern.");
1271
break;
1272
}
1273
1274
p_theme->set_color("selection_fill", "GraphEdit", p_theme->get_color(SNAME("box_selection_fill_color"), EditorStringName(Editor)));
1275
p_theme->set_color("selection_stroke", "GraphEdit", p_theme->get_color(SNAME("box_selection_stroke_color"), EditorStringName(Editor)));
1276
p_theme->set_color("activity", "GraphEdit", p_config.mono_color);
1277
1278
p_theme->set_color("connection_hover_tint_color", "GraphEdit", p_config.dark_color_2);
1279
p_theme->set_constant("connection_hover_thickness", "GraphEdit", 0);
1280
p_theme->set_color("connection_valid_target_tint_color", "GraphEdit", p_config.extra_border_color_1);
1281
p_theme->set_color("connection_rim_color", "GraphEdit", p_config.tree_panel_style->get_bg_color());
1282
1283
p_theme->set_icon("zoom_out", "GraphEdit", p_theme->get_icon(SNAME("ZoomLess"), EditorStringName(EditorIcons)));
1284
p_theme->set_icon("zoom_in", "GraphEdit", p_theme->get_icon(SNAME("ZoomMore"), EditorStringName(EditorIcons)));
1285
p_theme->set_icon("zoom_reset", "GraphEdit", p_theme->get_icon(SNAME("ZoomReset"), EditorStringName(EditorIcons)));
1286
p_theme->set_icon("grid_toggle", "GraphEdit", p_theme->get_icon(SNAME("GridToggle"), EditorStringName(EditorIcons)));
1287
p_theme->set_icon("minimap_toggle", "GraphEdit", p_theme->get_icon(SNAME("GridMinimap"), EditorStringName(EditorIcons)));
1288
p_theme->set_icon("snapping_toggle", "GraphEdit", p_theme->get_icon(SNAME("SnapGrid"), EditorStringName(EditorIcons)));
1289
p_theme->set_icon("layout", "GraphEdit", p_theme->get_icon(SNAME("GridLayout"), EditorStringName(EditorIcons)));
1290
1291
// GraphEditMinimap.
1292
{
1293
Ref<StyleBoxFlat> style_minimap_bg = EditorThemeManager::make_flat_stylebox(p_config.surface_low_color * Color(1, 1, 1, 0.3), 0, 0, 0, 0);
1294
style_minimap_bg->set_border_color(p_config.dark_color_3);
1295
style_minimap_bg->set_border_width_all(1);
1296
p_theme->set_stylebox(SceneStringName(panel), "GraphEditMinimap", style_minimap_bg);
1297
1298
Ref<StyleBoxFlat> style_minimap_camera;
1299
Ref<StyleBoxFlat> style_minimap_node;
1300
if (p_config.dark_theme) {
1301
style_minimap_camera = EditorThemeManager::make_flat_stylebox(Color(0.65, 0.65, 0.65, 0.2), 0, 0, 0, 0);
1302
style_minimap_camera->set_border_color(Color(0.65, 0.65, 0.65, 0.45));
1303
style_minimap_node = EditorThemeManager::make_flat_stylebox(Color(1, 1, 1), 0, 0, 0, 0);
1304
} else {
1305
style_minimap_camera = EditorThemeManager::make_flat_stylebox(Color(0.38, 0.38, 0.38, 0.1), 0, 0, 0, 0);
1306
style_minimap_camera->set_border_color(Color(0.38, 0.38, 0.38, 0.45));
1307
style_minimap_node = EditorThemeManager::make_flat_stylebox(Color(0, 0, 0), 0, 0, 0, 0);
1308
}
1309
style_minimap_camera->set_border_width_all(1);
1310
style_minimap_node->set_anti_aliased(false);
1311
p_theme->set_stylebox("camera", "GraphEditMinimap", style_minimap_camera);
1312
p_theme->set_stylebox("node", "GraphEditMinimap", style_minimap_node);
1313
1314
const Color minimap_resizer_color = p_config.dark_theme ? Color(1, 1, 1, 0.65) : Color(0, 0, 0, 0.65);
1315
p_theme->set_icon("resizer", "GraphEditMinimap", p_theme->get_icon(SNAME("GuiResizerTopLeft"), EditorStringName(EditorIcons)));
1316
p_theme->set_color("resizer_color", "GraphEditMinimap", minimap_resizer_color);
1317
}
1318
1319
// GraphElement, GraphNode & GraphFrame.
1320
{
1321
const int gn_margin_top = 2;
1322
const int gn_margin_side = 2;
1323
const int gn_margin_bottom = 2;
1324
1325
const int gn_corner_radius = 3;
1326
1327
const Color gn_bg_color = p_config.dark_theme ? p_config.dark_color_3 : p_config.dark_color_1.lerp(p_config.mono_color, 0.09);
1328
const Color gn_frame_bg = _get_base_color(p_config, p_config.dark_theme ? -1.8 : -0.5, 0.9);
1329
1330
const bool high_contrast_borders = p_config.draw_extra_borders && p_config.dark_theme;
1331
1332
Ref<StyleBoxFlat> gn_panel_style = EditorThemeManager::make_flat_stylebox(gn_frame_bg, gn_margin_side, gn_margin_top, gn_margin_side, gn_margin_bottom, p_config.corner_radius);
1333
gn_panel_style->set_border_width(SIDE_BOTTOM, 2 * EDSCALE);
1334
gn_panel_style->set_border_width(SIDE_LEFT, 2 * EDSCALE);
1335
gn_panel_style->set_border_width(SIDE_RIGHT, 2 * EDSCALE);
1336
gn_panel_style->set_border_color(high_contrast_borders ? gn_bg_color.lightened(0.2) : gn_bg_color.darkened(0.3));
1337
gn_panel_style->set_corner_radius_individual(0, 0, gn_corner_radius * EDSCALE, gn_corner_radius * EDSCALE);
1338
gn_panel_style->set_anti_aliased(true);
1339
1340
Ref<StyleBoxFlat> gn_panel_selected_style = gn_panel_style->duplicate();
1341
gn_panel_selected_style->set_bg_color(p_config.dark_theme ? gn_bg_color.lightened(0.15) : gn_bg_color.darkened(0.15));
1342
gn_panel_selected_style->set_border_width(SIDE_TOP, 0);
1343
gn_panel_selected_style->set_border_width(SIDE_BOTTOM, 2 * EDSCALE);
1344
gn_panel_selected_style->set_border_width(SIDE_LEFT, 2 * EDSCALE);
1345
gn_panel_selected_style->set_border_width(SIDE_RIGHT, 2 * EDSCALE);
1346
gn_panel_selected_style->set_border_color(p_config.mono_color);
1347
1348
const int gn_titlebar_margin_top = 8;
1349
const int gn_titlebar_margin_side = 12;
1350
const int gn_titlebar_margin_bottom = 8;
1351
1352
Ref<StyleBoxFlat> gn_titlebar_style = EditorThemeManager::make_flat_stylebox(gn_bg_color, gn_titlebar_margin_side, gn_titlebar_margin_top, gn_titlebar_margin_side, gn_titlebar_margin_bottom, p_config.corner_radius);
1353
gn_titlebar_style->set_border_width(SIDE_TOP, 2 * EDSCALE);
1354
gn_titlebar_style->set_border_width(SIDE_LEFT, 2 * EDSCALE);
1355
gn_titlebar_style->set_border_width(SIDE_RIGHT, 2 * EDSCALE);
1356
gn_titlebar_style->set_border_color(high_contrast_borders ? gn_bg_color.lightened(0.2) : gn_bg_color.darkened(0.3));
1357
gn_titlebar_style->set_expand_margin(SIDE_TOP, 2 * EDSCALE);
1358
gn_titlebar_style->set_corner_radius_individual(gn_corner_radius * EDSCALE, gn_corner_radius * EDSCALE, 0, 0);
1359
gn_titlebar_style->set_anti_aliased(true);
1360
1361
Ref<StyleBoxFlat> gn_titlebar_selected_style = gn_titlebar_style->duplicate();
1362
gn_titlebar_selected_style->set_border_color(p_config.mono_color);
1363
gn_titlebar_selected_style->set_border_width(SIDE_TOP, 2 * EDSCALE);
1364
gn_titlebar_selected_style->set_border_width(SIDE_LEFT, 2 * EDSCALE);
1365
gn_titlebar_selected_style->set_border_width(SIDE_RIGHT, 2 * EDSCALE);
1366
gn_titlebar_selected_style->set_expand_margin(SIDE_TOP, 2 * EDSCALE);
1367
1368
Color gn_decoration_color = p_config.dark_color_1.inverted();
1369
1370
// GraphElement.
1371
1372
p_theme->set_stylebox(SceneStringName(panel), "GraphElement", gn_panel_style);
1373
p_theme->set_stylebox("panel_selected", "GraphElement", gn_panel_selected_style);
1374
p_theme->set_stylebox("titlebar", "GraphElement", gn_titlebar_style);
1375
p_theme->set_stylebox("titlebar_selected", "GraphElement", gn_titlebar_selected_style);
1376
1377
p_theme->set_color("resizer_color", "GraphElement", gn_decoration_color);
1378
p_theme->set_icon("resizer", "GraphElement", p_theme->get_icon(SNAME("GuiResizer"), EditorStringName(EditorIcons)));
1379
1380
// GraphNode.
1381
1382
Ref<StyleBoxEmpty> gn_slot_style = EditorThemeManager::make_empty_stylebox(12, 0, 12, 0);
1383
1384
p_theme->set_stylebox(SceneStringName(panel), "GraphNode", gn_panel_style);
1385
p_theme->set_stylebox("panel_selected", "GraphNode", gn_panel_selected_style);
1386
p_theme->set_stylebox("panel_focus", "GraphNode", p_config.focus_style);
1387
p_theme->set_stylebox("titlebar", "GraphNode", gn_titlebar_style);
1388
p_theme->set_stylebox("titlebar_selected", "GraphNode", gn_titlebar_selected_style);
1389
p_theme->set_stylebox("slot", "GraphNode", gn_slot_style);
1390
p_theme->set_stylebox("slot_selected", "GraphNode", p_config.focus_style);
1391
1392
p_theme->set_color("resizer_color", "GraphNode", gn_decoration_color);
1393
1394
p_theme->set_constant("port_h_offset", "GraphNode", 1);
1395
p_theme->set_constant("separation", "GraphNode", 1 * EDSCALE);
1396
1397
Ref<DPITexture> port_icon = p_theme->get_icon(SNAME("GuiGraphNodePort"), EditorStringName(EditorIcons));
1398
// The true size is 24x24 This is necessary for sharp port icons at high zoom levels in GraphEdit (up to ~200%).
1399
port_icon->set_size_override(Size2(12, 12));
1400
p_theme->set_icon("port", "GraphNode", port_icon);
1401
1402
// GraphNode's title Label.
1403
p_theme->set_type_variation("GraphNodeTitleLabel", "Label");
1404
p_theme->set_stylebox(CoreStringName(normal), "GraphNodeTitleLabel", EditorThemeManager::make_empty_stylebox(0, 0, 0, 0));
1405
p_theme->set_color("font_shadow_color", "GraphNodeTitleLabel", p_config.shadow_color);
1406
p_theme->set_constant("shadow_outline_size", "GraphNodeTitleLabel", 4);
1407
p_theme->set_constant("shadow_offset_x", "GraphNodeTitleLabel", 0);
1408
p_theme->set_constant("shadow_offset_y", "GraphNodeTitleLabel", 1);
1409
p_theme->set_constant("line_spacing", "GraphNodeTitleLabel", 3 * EDSCALE);
1410
1411
// GraphFrame.
1412
1413
const int gf_corner_width = 7 * EDSCALE;
1414
const int gf_border_width = 2 * MAX(1, EDSCALE);
1415
1416
Ref<StyleBoxFlat> graphframe_sb = EditorThemeManager::make_flat_stylebox(Color(0.0, 0.0, 0.0, 0.2), gn_margin_side, gn_margin_side, gn_margin_side, gn_margin_bottom, gf_corner_width);
1417
graphframe_sb->set_expand_margin(SIDE_TOP, 38 * EDSCALE);
1418
graphframe_sb->set_border_width_all(gf_border_width);
1419
graphframe_sb->set_border_color(high_contrast_borders ? gn_bg_color.lightened(0.2) : gn_bg_color.darkened(0.3));
1420
graphframe_sb->set_shadow_size(8 * EDSCALE);
1421
graphframe_sb->set_shadow_color(Color(p_config.shadow_color, p_config.shadow_color.a * 0.25));
1422
graphframe_sb->set_anti_aliased(true);
1423
1424
Ref<StyleBoxFlat> graphframe_sb_selected = graphframe_sb->duplicate();
1425
graphframe_sb_selected->set_border_color(p_config.mono_color);
1426
1427
p_theme->set_stylebox(SceneStringName(panel), "GraphFrame", graphframe_sb);
1428
p_theme->set_stylebox("panel_selected", "GraphFrame", graphframe_sb_selected);
1429
p_theme->set_stylebox("titlebar", "GraphFrame", EditorThemeManager::make_empty_stylebox(4, 4, 4, 4));
1430
p_theme->set_stylebox("titlebar_selected", "GraphFrame", EditorThemeManager::make_empty_stylebox(4, 4, 4, 4));
1431
p_theme->set_color("resizer_color", "GraphFrame", gn_decoration_color);
1432
1433
// GraphFrame's title Label.
1434
p_theme->set_type_variation("GraphFrameTitleLabel", "Label");
1435
p_theme->set_stylebox(CoreStringName(normal), "GraphFrameTitleLabel", memnew(StyleBoxEmpty));
1436
p_theme->set_font_size(SceneStringName(font_size), "GraphFrameTitleLabel", 22 * EDSCALE);
1437
p_theme->set_color(SceneStringName(font_color), "GraphFrameTitleLabel", Color(1, 1, 1));
1438
p_theme->set_color("font_shadow_color", "GraphFrameTitleLabel", Color(1, 1, 1, 0));
1439
p_theme->set_color("font_outline_color", "GraphFrameTitleLabel", Color(1, 1, 1));
1440
p_theme->set_constant("shadow_offset_x", "GraphFrameTitleLabel", 1 * EDSCALE);
1441
p_theme->set_constant("shadow_offset_y", "GraphFrameTitleLabel", 1 * EDSCALE);
1442
p_theme->set_constant("outline_size", "GraphFrameTitleLabel", 0);
1443
p_theme->set_constant("shadow_outline_size", "GraphFrameTitleLabel", 1 * EDSCALE);
1444
p_theme->set_constant("line_spacing", "GraphFrameTitleLabel", 3 * EDSCALE);
1445
}
1446
1447
// VisualShader reroute node.
1448
{
1449
Ref<StyleBox> vs_reroute_panel_style = EditorThemeManager::make_empty_stylebox();
1450
Ref<StyleBox> vs_reroute_titlebar_style = vs_reroute_panel_style->duplicate();
1451
vs_reroute_titlebar_style->set_content_margin_all(16 * EDSCALE);
1452
p_theme->set_stylebox(SceneStringName(panel), "VSRerouteNode", vs_reroute_panel_style);
1453
p_theme->set_stylebox("panel_selected", "VSRerouteNode", vs_reroute_panel_style);
1454
p_theme->set_stylebox("titlebar", "VSRerouteNode", vs_reroute_titlebar_style);
1455
p_theme->set_stylebox("titlebar_selected", "VSRerouteNode", vs_reroute_titlebar_style);
1456
p_theme->set_stylebox("slot", "VSRerouteNode", EditorThemeManager::make_empty_stylebox());
1457
1458
p_theme->set_color("drag_background", "VSRerouteNode", p_config.dark_theme ? Color(0.19, 0.21, 0.24) : Color(0.8, 0.8, 0.8));
1459
p_theme->set_color("selected_rim_color", "VSRerouteNode", p_config.mono_color);
1460
}
1461
}
1462
1463
// ColorPicker and related nodes.
1464
{
1465
// ColorPicker.
1466
Ref<StyleBoxFlat> circle_style_focus = p_config.base_style->duplicate();
1467
circle_style_focus->set_border_color(p_config.mono_color * Color(1, 1, 1, 0.3));
1468
circle_style_focus->set_draw_center(false);
1469
circle_style_focus->set_corner_radius_all(256 * EDSCALE);
1470
circle_style_focus->set_corner_detail(32 * EDSCALE);
1471
1472
p_theme->set_constant("margin", "ColorPicker", p_config.base_margin);
1473
p_theme->set_constant("sv_width", "ColorPicker", 256 * EDSCALE);
1474
p_theme->set_constant("sv_height", "ColorPicker", 256 * EDSCALE);
1475
p_theme->set_constant("h_width", "ColorPicker", 30 * EDSCALE);
1476
p_theme->set_constant("label_width", "ColorPicker", 10 * EDSCALE);
1477
p_theme->set_constant("center_slider_grabbers", "ColorPicker", 1);
1478
1479
p_theme->set_stylebox("sample_focus", "ColorPicker", p_config.focus_style);
1480
p_theme->set_stylebox("picker_focus_rectangle", "ColorPicker", p_config.focus_style);
1481
p_theme->set_stylebox("picker_focus_circle", "ColorPicker", circle_style_focus);
1482
p_theme->set_color("focused_not_editing_cursor_color", "ColorPicker", p_config.highlight_color);
1483
1484
p_theme->set_icon("screen_picker", "ColorPicker", p_theme->get_icon(SNAME("ColorPick"), EditorStringName(EditorIcons)));
1485
p_theme->set_icon("shape_circle", "ColorPicker", p_theme->get_icon(SNAME("PickerShapeCircle"), EditorStringName(EditorIcons)));
1486
p_theme->set_icon("shape_rect", "ColorPicker", p_theme->get_icon(SNAME("PickerShapeRectangle"), EditorStringName(EditorIcons)));
1487
p_theme->set_icon("shape_rect_wheel", "ColorPicker", p_theme->get_icon(SNAME("PickerShapeRectangleWheel"), EditorStringName(EditorIcons)));
1488
p_theme->set_icon("add_preset", "ColorPicker", p_theme->get_icon(SNAME("Add"), EditorStringName(EditorIcons)));
1489
p_theme->set_icon("sample_bg", "ColorPicker", p_theme->get_icon(SNAME("GuiMiniCheckerboard"), EditorStringName(EditorIcons)));
1490
p_theme->set_icon("sample_revert", "ColorPicker", p_theme->get_icon(SNAME("Reload"), EditorStringName(EditorIcons)));
1491
p_theme->set_icon("overbright_indicator", "ColorPicker", p_theme->get_icon(SNAME("OverbrightIndicator"), EditorStringName(EditorIcons)));
1492
p_theme->set_icon("bar_arrow", "ColorPicker", p_theme->get_icon(SNAME("ColorPickerBarArrow"), EditorStringName(EditorIcons)));
1493
p_theme->set_icon("picker_cursor", "ColorPicker", p_theme->get_icon(SNAME("PickerCursor"), EditorStringName(EditorIcons)));
1494
p_theme->set_icon("picker_cursor_bg", "ColorPicker", p_theme->get_icon(SNAME("PickerCursorBg"), EditorStringName(EditorIcons)));
1495
p_theme->set_icon("color_script", "ColorPicker", p_theme->get_icon(SNAME("Script"), EditorStringName(EditorIcons)));
1496
1497
// ColorPickerButton.
1498
p_theme->set_icon("bg", "ColorPickerButton", p_theme->get_icon(SNAME("GuiMiniCheckerboard"), EditorStringName(EditorIcons)));
1499
1500
// ColorPresetButton.
1501
p_theme->set_stylebox("preset_fg", "ColorPresetButton", EditorThemeManager::make_flat_stylebox(Color(1, 1, 1), 2, 2, 2, 2, 2));
1502
p_theme->set_icon("preset_bg", "ColorPresetButton", p_theme->get_icon(SNAME("GuiMiniCheckerboard"), EditorStringName(EditorIcons)));
1503
p_theme->set_icon("overbright_indicator", "ColorPresetButton", p_theme->get_icon(SNAME("OverbrightIndicator"), EditorStringName(EditorIcons)));
1504
}
1505
}
1506
1507
void ThemeModern::populate_editor_styles(const Ref<EditorTheme> &p_theme, EditorThemeManager::ThemeConfiguration &p_config) {
1508
// Project manager.
1509
{
1510
Ref<StyleBoxFlat> style_project_list = p_config.base_style->duplicate();
1511
style_project_list->set_bg_color(p_config.surface_low_color);
1512
1513
p_theme->set_stylebox("panel_container", "ProjectManager", p_config.foreground_panel);
1514
p_theme->set_stylebox("project_list", "ProjectManager", style_project_list);
1515
p_theme->set_stylebox("quick_settings_panel", "ProjectManager", style_project_list);
1516
p_theme->set_constant("sidebar_button_icon_separation", "ProjectManager", int(6 * EDSCALE));
1517
p_theme->set_icon("browse_folder", "ProjectManager", p_theme->get_icon(SNAME("FolderBrowse"), EditorStringName(EditorIcons)));
1518
p_theme->set_icon("browse_file", "ProjectManager", p_theme->get_icon(SNAME("FileBrowse"), EditorStringName(EditorIcons)));
1519
1520
// ProjectTag.
1521
{
1522
p_theme->set_type_variation("ProjectTagButton", "Button");
1523
1524
Ref<StyleBoxFlat> tag = p_config.button_style->duplicate();
1525
tag->set_bg_color(p_config.dark_theme ? tag->get_bg_color().lightened(0.2) : tag->get_bg_color().darkened(0.2));
1526
tag->set_corner_radius(CORNER_TOP_LEFT, 0);
1527
tag->set_corner_radius(CORNER_BOTTOM_LEFT, 0);
1528
tag->set_corner_radius(CORNER_TOP_RIGHT, 4);
1529
tag->set_corner_radius(CORNER_BOTTOM_RIGHT, 4);
1530
p_theme->set_stylebox(CoreStringName(normal), "ProjectTagButton", tag);
1531
1532
tag = p_config.button_style_hover->duplicate();
1533
tag->set_corner_radius(CORNER_TOP_LEFT, 0);
1534
tag->set_corner_radius(CORNER_BOTTOM_LEFT, 0);
1535
tag->set_corner_radius(CORNER_TOP_RIGHT, 4);
1536
tag->set_corner_radius(CORNER_BOTTOM_RIGHT, 4);
1537
p_theme->set_stylebox(SceneStringName(hover), "ProjectTagButton", tag);
1538
1539
tag = p_config.button_style_pressed->duplicate();
1540
tag->set_corner_radius(CORNER_TOP_LEFT, 0);
1541
tag->set_corner_radius(CORNER_BOTTOM_LEFT, 0);
1542
tag->set_corner_radius(CORNER_TOP_RIGHT, 4);
1543
tag->set_corner_radius(CORNER_BOTTOM_RIGHT, 4);
1544
p_theme->set_stylebox(SceneStringName(pressed), "ProjectTagButton", tag);
1545
}
1546
}
1547
1548
// Editor and main screen.
1549
{
1550
// Editor background.
1551
Color background_color = p_config.surface_lowest_color; //_get_base_color(p_config, -1.5);
1552
p_theme->set_color("background", EditorStringName(Editor), background_color);
1553
Ref<StyleBoxFlat> style_bg = p_config.base_style->duplicate();
1554
style_bg->set_bg_color(background_color);
1555
style_bg->set_content_margin_all(0);
1556
style_bg->set_corner_radius_all(0);
1557
p_theme->set_stylebox("Background", EditorStringName(EditorStyles), style_bg);
1558
1559
Ref<StyleBoxFlat> editor_panel_foreground = p_config.base_style->duplicate();
1560
editor_panel_foreground->set_corner_radius_all(0);
1561
p_theme->set_stylebox("PanelForeground", EditorStringName(EditorStyles), editor_panel_foreground);
1562
1563
// Editor focus.
1564
p_theme->set_stylebox("Focus", EditorStringName(EditorStyles), p_config.focus_style);
1565
1566
Ref<StyleBoxFlat> style_widget_focus_viewport = p_config.base_style->duplicate();
1567
style_widget_focus_viewport->set_corner_radius_all(0);
1568
style_widget_focus_viewport->set_border_width_all(2);
1569
style_widget_focus_viewport->set_border_color(p_config.mono_color * Color(1, 1, 1, 0.07));
1570
style_widget_focus_viewport->set_draw_center(false);
1571
p_theme->set_stylebox("FocusViewport", EditorStringName(EditorStyles), style_widget_focus_viewport);
1572
1573
p_theme->set_stylebox(SceneStringName(panel), "ScrollContainer", p_config.base_empty_style);
1574
p_theme->set_stylebox("focus", "ScrollContainer", p_config.focus_style);
1575
1576
// This stylebox is used in 3d and 2d viewports (no borders).
1577
Ref<StyleBoxFlat> style_content_panel_vp = p_config.content_panel_style->duplicate();
1578
style_content_panel_vp->set_content_margin_individual(p_config.border_width * 2, p_config.base_margin * EDSCALE, p_config.border_width * 2, p_config.border_width * 2);
1579
p_theme->set_stylebox("Content", EditorStringName(EditorStyles), style_content_panel_vp);
1580
1581
// 3D/Spatial editor.
1582
Ref<StyleBoxFlat> style_info_3d_viewport = p_config.base_style->duplicate();
1583
Color bg_color = style_info_3d_viewport->get_bg_color() * Color(1, 1, 1, 0.5);
1584
if (!p_config.dark_theme) {
1585
// Always use a dark background for the 3D viewport, even in light themes.
1586
// This is displayed as an overlay of the 3D scene, whose appearance doesn't change with the editor theme.
1587
// On top of that, dark overlays are more readable than light overlays.
1588
bg_color.invert();
1589
}
1590
style_info_3d_viewport->set_bg_color(bg_color);
1591
style_info_3d_viewport->set_content_margin_individual(p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.5 * EDSCALE, p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.5 * EDSCALE);
1592
p_theme->set_stylebox("Information3dViewport", EditorStringName(EditorStyles), style_info_3d_viewport);
1593
1594
// 2D, 3D, and Game toolbar.
1595
p_theme->set_type_variation("MainToolBarMargin", "MarginContainer");
1596
p_theme->set_constant("margin_left", "MainToolBarMargin", 4 * EDSCALE);
1597
p_theme->set_constant("margin_right", "MainToolBarMargin", 4 * EDSCALE);
1598
p_theme->set_constant("margin_top", "MainToolBarMargin", p_config.base_margin * 0.5 * EDSCALE);
1599
p_theme->set_constant("margin_bottom", "MainToolBarMargin", p_config.base_margin * 0.5 * EDSCALE);
1600
1601
// 2D and 3D contextual toolbar.
1602
// Use a custom stylebox to make contextual menu items stand out from the rest.
1603
// This helps with editor usability as contextual menu items change when selecting nodes,
1604
// even though it may not be immediately obvious at first.
1605
Ref<StyleBoxFlat> toolbar_stylebox = p_config.base_style->duplicate();
1606
toolbar_stylebox->set_bg_color(p_config.surface_higher_color);
1607
toolbar_stylebox->set_content_margin_all(0);
1608
p_theme->set_stylebox("ContextualToolbar", EditorStringName(EditorStyles), toolbar_stylebox);
1609
1610
// Script editor.
1611
p_theme->set_stylebox("ScriptEditorPanel", EditorStringName(EditorStyles), EditorThemeManager::make_empty_stylebox(p_config.base_margin, 0, p_config.base_margin, p_config.base_margin));
1612
p_theme->set_stylebox("ScriptEditorPanelFloating", EditorStringName(EditorStyles), EditorThemeManager::make_empty_stylebox(0, 0, 0, 0));
1613
p_theme->set_stylebox("ScriptEditor", EditorStringName(EditorStyles), EditorThemeManager::make_empty_stylebox(0, 0, 0, 0));
1614
1615
// Game view.
1616
p_theme->set_type_variation("GamePanel", "PanelContainer");
1617
Ref<StyleBoxFlat> game_panel = p_theme->get_stylebox(SceneStringName(panel), SNAME("Panel"))->duplicate();
1618
game_panel->set_corner_radius_all(0);
1619
game_panel->set_content_margin_all(0);
1620
game_panel->set_draw_center(true);
1621
p_theme->set_stylebox(SceneStringName(panel), "GamePanel", game_panel);
1622
1623
// Main menu.
1624
p_theme->set_stylebox(CoreStringName(normal), "MainScreenButton", p_config.base_empty_wide_style);
1625
p_theme->set_stylebox("normal_mirrored", "MainScreenButton", p_config.base_empty_wide_style);
1626
p_theme->set_stylebox(SceneStringName(pressed), "MainScreenButton", p_config.base_empty_wide_style);
1627
p_theme->set_stylebox("pressed_mirrored", "MainScreenButton", p_config.base_empty_wide_style);
1628
p_theme->set_stylebox(SceneStringName(hover), "MainScreenButton", p_config.base_empty_wide_style);
1629
p_theme->set_stylebox("hover_mirrored", "MainScreenButton", p_config.base_empty_wide_style);
1630
p_theme->set_stylebox("hover_pressed", "MainScreenButton", p_config.base_empty_wide_style);
1631
p_theme->set_stylebox("hover_pressed_mirrored", "MainScreenButton", p_config.base_empty_wide_style);
1632
1633
p_theme->set_type_variation("MainMenuBar", "FlatMenuButton");
1634
p_theme->set_stylebox(CoreStringName(normal), "MainMenuBar", p_config.flat_button);
1635
p_theme->set_stylebox(SceneStringName(pressed), "MainMenuBar", p_config.flat_button_pressed);
1636
p_theme->set_stylebox(SceneStringName(hover), "MainMenuBar", p_config.flat_button_hover);
1637
p_theme->set_stylebox("hover_pressed", "MainMenuBar", p_config.flat_button_hover);
1638
1639
// Run bar.
1640
Ref<StyleBoxFlat> run_bar_hover = p_config.base_style->duplicate();
1641
run_bar_hover->set_bg_color(p_config.mono_color * Color(1, 1, 1, 0.1));
1642
run_bar_hover->set_content_margin_all(0);
1643
1644
p_theme->set_type_variation("RunBarButton", "FlatMenuButton");
1645
p_theme->set_stylebox("disabled", "RunBarButton", p_config.base_empty_wide_style);
1646
p_theme->set_stylebox(SceneStringName(pressed), "RunBarButton", p_config.base_empty_wide_style);
1647
p_theme->set_stylebox(SceneStringName(hover), "RunBarButton", run_bar_hover);
1648
1649
// Needs to present even if unused.
1650
p_theme->set_type_variation("RunBarButtonMovieMakerDisabled", "RunBarButton");
1651
1652
Ref<StyleBoxFlat> movie_maker_button_enabled_hover = run_bar_hover->duplicate();
1653
movie_maker_button_enabled_hover->set_bg_color(p_config.accent_color.lightened(0.2));
1654
1655
p_theme->set_type_variation("RunBarButtonMovieMakerEnabled", "RunBarButton");
1656
p_theme->set_stylebox("hover_pressed", "RunBarButtonMovieMakerEnabled", movie_maker_button_enabled_hover);
1657
p_theme->set_color("icon_normal_color", "RunBarButtonMovieMakerEnabled", Color(0, 0, 0, 0.7));
1658
p_theme->set_color("icon_pressed_color", "RunBarButtonMovieMakerEnabled", Color(0, 0, 0, 0.84));
1659
p_theme->set_color("icon_hover_color", "RunBarButtonMovieMakerEnabled", Color(0, 0, 0, 0.9));
1660
p_theme->set_color("icon_hover_pressed_color", "RunBarButtonMovieMakerEnabled", Color(0, 0, 0, 0.84));
1661
1662
// Bottom panel.
1663
Ref<StyleBoxFlat> style_bottom_panel = p_config.content_panel_style->duplicate();
1664
style_bottom_panel->set_border_width(SIDE_BOTTOM, 0);
1665
style_bottom_panel->set_corner_radius_all(p_config.corner_radius * EDSCALE);
1666
style_bottom_panel->set_corner_radius(CORNER_BOTTOM_LEFT, 0);
1667
style_bottom_panel->set_corner_radius(CORNER_BOTTOM_RIGHT, 0);
1668
1669
Ref<StyleBoxFlat> style_bottom_panel_hidden = style_bottom_panel->duplicate();
1670
style_bottom_panel_hidden->set_content_margin(SIDE_TOP, 0);
1671
Ref<StyleBoxFlat> style_bottom_panel_tabbar = p_config.content_panel_style->duplicate();
1672
style_bottom_panel_tabbar->set_content_margin(SIDE_TOP, 0);
1673
1674
Ref<StyleBoxEmpty> style_bottom_tab = p_config.base_empty_style->duplicate();
1675
style_bottom_tab->set_content_margin_individual(p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.2 * EDSCALE, p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.2 * EDSCALE);
1676
Ref<StyleBoxFlat> bottom_panel_button_hover = p_config.flat_button_hover->duplicate();
1677
bottom_panel_button_hover->set_content_margin_individual(p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.2 * EDSCALE, p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.2 * EDSCALE);
1678
1679
p_theme->set_stylebox("BottomPanel", EditorStringName(EditorStyles), style_bottom_panel);
1680
p_theme->set_type_variation("BottomPanel", "TabContainer");
1681
p_theme->set_stylebox(SceneStringName(panel), "BottomPanel", style_bottom_panel_hidden);
1682
p_theme->set_stylebox("tabbar_background", "BottomPanel", style_bottom_panel_tabbar);
1683
p_theme->set_stylebox("tab_selected", "BottomPanel", bottom_panel_button_hover);
1684
p_theme->set_stylebox("tab_hovered", "BottomPanel", bottom_panel_button_hover);
1685
p_theme->set_stylebox("tab_focus", "BottomPanel", p_config.base_empty_style);
1686
p_theme->set_stylebox("tab_unselected", "BottomPanel", style_bottom_tab);
1687
p_theme->set_color("font_unselected_color", "BottomPanel", p_config.font_color);
1688
p_theme->set_color("font_hovered_color", "BottomPanel", p_config.font_hover_color);
1689
p_theme->set_color("font_selected_color", "BottomPanel", p_config.font_hover_color);
1690
p_theme->set_constant("tab_separation", "BottomPanel", p_config.separation_margin);
1691
1692
p_theme->set_type_variation("BottomPanelButton", "FlatMenuButton");
1693
1694
// Use bigger margin for buttons in bottom panel to make them easier to press.
1695
Ref<StyleBoxEmpty> bottom_panel_button = p_config.base_empty_style->duplicate();
1696
bottom_panel_button->set_content_margin_individual(p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.2 * EDSCALE, p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.2 * EDSCALE);
1697
p_theme->set_stylebox(CoreStringName(normal), "BottomPanelButton", bottom_panel_button);
1698
1699
p_theme->set_stylebox(SceneStringName(hover), "BottomPanelButton", bottom_panel_button_hover);
1700
p_theme->set_stylebox(SceneStringName(pressed), "BottomPanelButton", bottom_panel_button_hover);
1701
1702
Ref<StyleBoxFlat> bottom_panel_button_pressed = p_config.flat_button_hover->duplicate();
1703
bottom_panel_button_pressed->set_content_margin_individual(p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.2 * EDSCALE, p_config.base_margin * 2 * EDSCALE, p_config.base_margin * 1.2 * EDSCALE);
1704
p_theme->set_stylebox("hover_pressed", "BottomPanelButton", bottom_panel_button_pressed);
1705
1706
// Don't tint the icon even when in "pressed" state.
1707
p_theme->set_color("icon_pressed_color", "BottomPanelButton", Color(1, 1, 1, 1));
1708
Color icon_hover_color = p_config.icon_normal_color * (p_config.dark_icon_and_font ? 1.15 : 1.0);
1709
icon_hover_color.a = 1.0;
1710
p_theme->set_color("icon_hover_color", "BottomPanel", icon_hover_color);
1711
p_theme->set_color("icon_hover_pressed_color", "BottomPanel", icon_hover_color);
1712
p_theme->set_color("icon_hover_color", "BottomPanelButton", icon_hover_color);
1713
p_theme->set_color("icon_hover_pressed_color", "BottomPanelButton", p_config.accent_color);
1714
p_theme->set_color("icon_pressed_color", "BottomPanelButton", p_config.accent_color);
1715
1716
// Audio bus.
1717
Ref<StyleBoxFlat> audio_bus = p_config.base_style->duplicate();
1718
audio_bus->set_bg_color(p_config.surface_high_color);
1719
p_theme->set_stylebox(CoreStringName(normal), "EditorAudioBus", audio_bus);
1720
p_theme->set_stylebox("focus", "EditorAudioBus", p_config.focus_style);
1721
Ref<StyleBoxFlat> audio_bus_master = p_config.base_style->duplicate();
1722
audio_bus_master->set_bg_color(p_config.surface_higher_color);
1723
p_theme->set_stylebox("master", "EditorAudioBus", audio_bus_master);
1724
}
1725
1726
// Editor GUI widgets.
1727
{
1728
// EditorSpinSlider.
1729
p_theme->set_color("label_color", "EditorSpinSlider", p_config.font_color);
1730
p_theme->set_color("read_only_label_color", "EditorSpinSlider", p_config.font_readonly_color);
1731
1732
Ref<StyleBoxFlat> editor_spin_label_bg = p_config.base_style->duplicate();
1733
editor_spin_label_bg->set_bg_color(p_config.surface_lower_color);
1734
editor_spin_label_bg->set_content_margin_all(p_config.base_margin * EDSCALE);
1735
p_theme->set_stylebox("label_bg", "EditorSpinSlider", editor_spin_label_bg);
1736
1737
// TODO Use separate arrows instead like on SpinBox. Planned for a different PR.
1738
p_theme->set_icon("updown", "EditorSpinSlider", p_theme->get_icon(SNAME("GuiSpinboxUpdown"), EditorStringName(EditorIcons)));
1739
p_theme->set_icon("updown_disabled", "EditorSpinSlider", p_theme->get_icon(SNAME("GuiSpinboxUpdownDisabled"), EditorStringName(EditorIcons)));
1740
1741
// Launch Pad and Play buttons.
1742
Ref<StyleBoxFlat> style_launch_pad_movie = p_config.base_style->duplicate();
1743
style_launch_pad_movie->set_bg_color(p_config.accent_color * Color(1, 1, 1, 0.2));
1744
style_launch_pad_movie->set_border_color(p_config.accent_color * Color(1, 1, 1, 0.8));
1745
style_launch_pad_movie->set_border_width_all(Math::round(2 * EDSCALE));
1746
p_theme->set_stylebox("LaunchPadMovieMode", EditorStringName(EditorStyles), style_launch_pad_movie);
1747
1748
int pad_normal_margin = style_launch_pad_movie->get_minimum_size().width / 2;
1749
Ref<StyleBoxEmpty> style_launch_pad = memnew(StyleBoxEmpty);
1750
style_launch_pad->set_content_margin_all(pad_normal_margin);
1751
p_theme->set_stylebox("LaunchPadNormal", EditorStringName(EditorStyles), style_launch_pad);
1752
1753
Ref<StyleBoxFlat> style_launch_pad_recovery_mode = EditorThemeManager::make_flat_stylebox(p_config.dark_color_1, 2 * EDSCALE, 0, 2 * EDSCALE, 0, p_config.corner_radius);
1754
style_launch_pad_recovery_mode->set_bg_color(p_config.accent_color * Color(1, 1, 1, 0.1));
1755
style_launch_pad_recovery_mode->set_border_color(p_config.warning_color);
1756
style_launch_pad_recovery_mode->set_border_width_all(Math::round(2 * EDSCALE));
1757
style_launch_pad_recovery_mode->set_corner_radius_all(p_config.corner_radius * EDSCALE);
1758
p_theme->set_stylebox("LaunchPadRecoveryMode", EditorStringName(EditorStyles), style_launch_pad_recovery_mode);
1759
1760
p_theme->set_stylebox("MovieWriterButtonNormal", EditorStringName(EditorStyles), EditorThemeManager::make_empty_stylebox(0, 0, 0, 0));
1761
Ref<StyleBoxFlat> style_write_movie_button = p_config.base_style->duplicate();
1762
style_write_movie_button->set_bg_color(p_config.accent_color * Color(1, 1, 1, 0.8));
1763
style_write_movie_button->set_content_margin_all(0);
1764
p_theme->set_stylebox("MovieWriterButtonPressed", EditorStringName(EditorStyles), style_write_movie_button);
1765
1766
// Profiler autostart indicator panel.
1767
Ref<StyleBoxFlat> style_profiler_autostart = EditorThemeManager::make_flat_stylebox(p_config.dark_color_1, 2 * EDSCALE, 0, 2 * EDSCALE, 0, p_config.corner_radius);
1768
style_profiler_autostart->set_bg_color(Color(1, 0.867, 0.396));
1769
style_profiler_autostart->set_corner_radius_all(p_config.corner_radius * EDSCALE);
1770
p_theme->set_type_variation("ProfilerAutostartIndicator", "Button");
1771
p_theme->set_stylebox(CoreStringName(normal), "ProfilerAutostartIndicator", style_profiler_autostart);
1772
p_theme->set_stylebox(SceneStringName(pressed), "ProfilerAutostartIndicator", style_profiler_autostart);
1773
p_theme->set_stylebox(SceneStringName(hover), "ProfilerAutostartIndicator", style_profiler_autostart);
1774
1775
// Recovery mode button style
1776
Ref<StyleBoxFlat> style_recovery_mode_button = p_config.button_style_pressed->duplicate();
1777
style_recovery_mode_button->set_bg_color(p_config.warning_color);
1778
style_recovery_mode_button->set_corner_radius_all(p_config.corner_radius * EDSCALE);
1779
style_recovery_mode_button->set_content_margin_all(0);
1780
// Recovery mode button is implicitly styled from the panel's background.
1781
// So, remove any existing borders. (e.g. from draw_extra_borders config)
1782
style_recovery_mode_button->set_border_width_all(0);
1783
style_recovery_mode_button->set_expand_margin(SIDE_RIGHT, 2 * EDSCALE);
1784
p_theme->set_stylebox("RecoveryModeButton", EditorStringName(EditorStyles), style_recovery_mode_button);
1785
}
1786
1787
// Standard GUI variations.
1788
{
1789
// Custom theme type for MarginContainer with 4px margins.
1790
p_theme->set_type_variation("MarginContainer4px", "MarginContainer");
1791
p_theme->set_constant("margin_left", "MarginContainer4px", 4 * EDSCALE);
1792
p_theme->set_constant("margin_top", "MarginContainer4px", 4 * EDSCALE);
1793
p_theme->set_constant("margin_right", "MarginContainer4px", 4 * EDSCALE);
1794
p_theme->set_constant("margin_bottom", "MarginContainer4px", 4 * EDSCALE);
1795
1796
// Header LinkButton variation.
1797
p_theme->set_type_variation("HeaderSmallLink", "LinkButton");
1798
p_theme->set_font(SceneStringName(font), "HeaderSmallLink", p_theme->get_font(SceneStringName(font), SNAME("HeaderSmall")));
1799
p_theme->set_font_size(SceneStringName(font_size), "HeaderSmallLink", p_theme->get_font_size(SceneStringName(font_size), SNAME("HeaderSmall")));
1800
1801
// Flat button variations.
1802
{
1803
p_theme->set_stylebox(CoreStringName(normal), SceneStringName(FlatButton), p_config.base_empty_wide_style);
1804
p_theme->set_stylebox(SceneStringName(hover), SceneStringName(FlatButton), p_config.flat_button_hover);
1805
p_theme->set_stylebox(SceneStringName(pressed), SceneStringName(FlatButton), p_config.flat_button_pressed);
1806
p_theme->set_stylebox("hover_pressed", SceneStringName(FlatButton), p_config.flat_button_pressed);
1807
p_theme->set_stylebox("disabled", SceneStringName(FlatButton), p_config.base_empty_wide_style);
1808
1809
p_theme->set_stylebox(CoreStringName(normal), "FlatMenuButton", p_config.base_empty_wide_style);
1810
p_theme->set_stylebox(SceneStringName(hover), "FlatMenuButton", p_config.flat_button_hover);
1811
p_theme->set_stylebox(SceneStringName(pressed), "FlatMenuButton", p_config.flat_button_pressed);
1812
p_theme->set_stylebox("hover_pressed", "FlatMenuButton", p_config.flat_button_pressed);
1813
p_theme->set_stylebox("disabled", "FlatMenuButton", p_config.base_empty_wide_style);
1814
1815
// Variation for Editor Log filter buttons.
1816
1817
p_theme->set_type_variation("EditorLogFilterButton", "Button");
1818
// When pressed, don't tint the icons with the accent color, just leave them normal.
1819
p_theme->set_color("icon_pressed_color", "EditorLogFilterButton", p_config.icon_normal_color);
1820
// When unpressed, dim the icons.
1821
Color icon_normal_color = Color(p_config.icon_normal_color, (p_config.dark_icon_and_font ? 0.4 : 0.8));
1822
p_theme->set_color("icon_normal_color", "EditorLogFilterButton", icon_normal_color);
1823
Color icon_hover_color = p_config.icon_normal_color * (p_config.dark_icon_and_font ? 1.15 : 1.0);
1824
icon_hover_color.a = 1.0;
1825
p_theme->set_color("icon_hover_color", "EditorLogFilterButton", icon_hover_color);
1826
p_theme->set_color("icon_hover_pressed_color", "EditorLogFilterButton", icon_hover_color);
1827
1828
// Hover and pressed styles are swapped for toggle buttons on purpose.
1829
p_theme->set_stylebox(CoreStringName(normal), "EditorLogFilterButton", p_config.base_empty_style);
1830
p_theme->set_stylebox(SceneStringName(hover), "EditorLogFilterButton", p_config.flat_button_pressed);
1831
p_theme->set_stylebox(SceneStringName(pressed), "EditorLogFilterButton", p_config.flat_button_hover);
1832
}
1833
1834
// Buttons styles that stand out against the panel background (e.g. AssetLib).
1835
{
1836
p_theme->set_type_variation("PanelBackgroundButton", "Button");
1837
1838
Ref<StyleBoxFlat> panel_button_style = p_config.button_style->duplicate();
1839
panel_button_style->set_bg_color(p_config.base_color.lerp(p_config.mono_color, 0.08));
1840
1841
Ref<StyleBoxFlat> panel_button_style_hover = p_config.button_style_hover->duplicate();
1842
panel_button_style_hover->set_bg_color(p_config.base_color.lerp(p_config.mono_color, 0.16));
1843
1844
Ref<StyleBoxFlat> panel_button_style_pressed = p_config.button_style_pressed->duplicate();
1845
panel_button_style_pressed->set_bg_color(p_config.base_color.lerp(p_config.mono_color, 0.20));
1846
1847
Ref<StyleBoxFlat> panel_button_style_disabled = p_config.button_style_disabled->duplicate();
1848
panel_button_style_disabled->set_bg_color(p_config.disabled_bg_color);
1849
1850
p_theme->set_stylebox(CoreStringName(normal), "PanelBackgroundButton", panel_button_style);
1851
p_theme->set_stylebox(SceneStringName(hover), "PanelBackgroundButton", panel_button_style_hover);
1852
p_theme->set_stylebox(SceneStringName(pressed), "PanelBackgroundButton", panel_button_style_pressed);
1853
p_theme->set_stylebox("disabled", "PanelBackgroundButton", panel_button_style_disabled);
1854
}
1855
1856
// Top bar selectors.
1857
p_theme->set_type_variation("TopBarOptionButton", "OptionButton");
1858
p_theme->set_font(SceneStringName(font), "TopBarOptionButton", p_theme->get_font(SNAME("bold"), EditorStringName(EditorFonts)));
1859
p_theme->set_font_size(SceneStringName(font_size), "TopBarOptionButton", p_theme->get_font_size(SNAME("bold_size"), EditorStringName(EditorFonts)));
1860
1861
// Complex editor windows.
1862
p_theme->set_stylebox(SceneStringName(panel), "EditorSettingsDialog", p_config.window_complex_style);
1863
p_theme->set_stylebox(SceneStringName(panel), "ProjectSettingsEditor", p_config.window_complex_style);
1864
p_theme->set_stylebox(SceneStringName(panel), "ProjectExportDialog", p_config.window_complex_style);
1865
p_theme->set_stylebox(SceneStringName(panel), "SceneImportSettingsDialog", p_config.window_complex_style);
1866
p_theme->set_stylebox(SceneStringName(panel), "EditorAbout", p_config.window_complex_style);
1867
p_theme->set_stylebox(SceneStringName(panel), "ThemeItemEditorDialog", p_config.window_complex_style);
1868
1869
// MarginContainers with negative margins, to negate borders. Used with scroll hints.
1870
{
1871
int margin = -p_theme->get_stylebox(SceneStringName(panel), SNAME("PanelContainer"))->get_content_margin(SIDE_LEFT);
1872
1873
p_theme->set_type_variation("NoBorderHorizontal", "MarginContainer");
1874
p_theme->set_constant("margin_left", "NoBorderHorizontal", margin);
1875
p_theme->set_constant("margin_right", "NoBorderHorizontal", margin);
1876
1877
p_theme->set_type_variation("NoBorderHorizontalBottom", "MarginContainer");
1878
p_theme->set_constant("margin_left", "NoBorderHorizontalBottom", margin);
1879
p_theme->set_constant("margin_right", "NoBorderHorizontalBottom", margin);
1880
p_theme->set_constant("margin_bottom", "NoBorderHorizontalBottom", margin);
1881
1882
margin = margin - p_theme->get_stylebox(SNAME("BottomPanel"), EditorStringName(EditorStyles))->get_content_margin(SIDE_LEFT);
1883
1884
// Used in the animation track editor.
1885
p_theme->set_type_variation("NoBorderAnimation", "MarginContainer");
1886
p_theme->set_constant("margin_left", "NoBorderAnimation", margin);
1887
p_theme->set_constant("margin_right", "NoBorderAnimation", margin);
1888
1889
margin = -p_theme->get_stylebox(SceneStringName(panel), SNAME("AcceptDialog"))->get_content_margin(SIDE_LEFT);
1890
1891
p_theme->set_type_variation("NoBorderHorizontalWindow", "MarginContainer");
1892
p_theme->set_constant("margin_left", "NoBorderHorizontalWindow", margin);
1893
p_theme->set_constant("margin_right", "NoBorderHorizontalWindow", margin);
1894
}
1895
1896
// Buttons in material previews.
1897
{
1898
const Color dim_light_color = p_config.icon_normal_color.darkened(0.24);
1899
const Color dim_light_highlighted_color = p_config.icon_normal_color.darkened(0.18);
1900
Ref<StyleBox> sb_empty_borderless = EditorThemeManager::make_empty_stylebox();
1901
1902
p_theme->set_type_variation("PreviewLightButton", "Button");
1903
// When pressed, don't use the accent color tint. When unpressed, dim the icon.
1904
p_theme->set_color("icon_normal_color", "PreviewLightButton", dim_light_color);
1905
p_theme->set_color("icon_focus_color", "PreviewLightButton", dim_light_color);
1906
p_theme->set_color("icon_pressed_color", "PreviewLightButton", p_config.icon_normal_color);
1907
p_theme->set_color("icon_hover_pressed_color", "PreviewLightButton", p_config.icon_normal_color);
1908
// Unpressed icon is dim, so use a dim highlight.
1909
p_theme->set_color("icon_hover_color", "PreviewLightButton", dim_light_highlighted_color);
1910
1911
p_theme->set_stylebox(CoreStringName(normal), "PreviewLightButton", sb_empty_borderless);
1912
p_theme->set_stylebox(SceneStringName(hover), "PreviewLightButton", sb_empty_borderless);
1913
p_theme->set_stylebox("focus", "PreviewLightButton", sb_empty_borderless);
1914
p_theme->set_stylebox(SceneStringName(pressed), "PreviewLightButton", sb_empty_borderless);
1915
}
1916
1917
// TabContainerOdd variation.
1918
{
1919
// Can be used on tabs against the base color background (e.g. nested tabs).
1920
p_theme->set_type_variation("TabContainerOdd", "TabContainer");
1921
1922
Ref<StyleBoxFlat> style_tab_selected_odd = p_theme->get_stylebox(SNAME("tab_selected"), SNAME("TabContainer"))->duplicate();
1923
style_tab_selected_odd->set_bg_color(p_config.surface_base_color);
1924
p_theme->set_stylebox("tab_selected", "TabContainerOdd", style_tab_selected_odd);
1925
1926
Ref<StyleBoxFlat> style_panel_odd = p_theme->get_stylebox(SceneStringName(panel), SNAME("TabContainer"))->duplicate();
1927
style_panel_odd->set_bg_color(p_config.surface_base_color);
1928
p_theme->set_stylebox(SceneStringName(panel), "TabContainerOdd", style_panel_odd);
1929
1930
p_theme->set_stylebox("tabbar_background", "TabContainerOdd", p_theme->get_stylebox(SNAME("tabbar_background"), SNAME("TabContainer")));
1931
}
1932
1933
// EditorValidationPanel.
1934
Ref<StyleBoxFlat> editor_validation_panel = p_config.base_style->duplicate();
1935
editor_validation_panel->set_bg_color(p_config.surface_low_color);
1936
editor_validation_panel->set_content_margin_individual(p_config.base_margin * EDSCALE, p_config.base_margin * 0.5 * EDSCALE, p_config.base_margin * EDSCALE, p_config.base_margin * 0.5 * EDSCALE);
1937
p_theme->set_stylebox(SceneStringName(panel), "EditorValidationPanel", editor_validation_panel);
1938
1939
// Sidebars.
1940
{
1941
p_theme->set_type_variation("ScrollContainerSecondary", "ScrollContainer");
1942
p_theme->set_type_variation("TreeSecondary", "Tree");
1943
p_theme->set_type_variation("ItemListSecondary", "ItemList");
1944
1945
Ref<StyleBoxFlat> style_sidebar = p_config.base_style->duplicate();
1946
style_sidebar->set_bg_color(p_config.surface_low_color);
1947
if (p_config.draw_extra_borders) {
1948
style_sidebar->set_border_width_all(1 * EDSCALE);
1949
style_sidebar->set_border_color(p_config.extra_border_color_2);
1950
}
1951
1952
p_theme->set_stylebox(SceneStringName(panel), "ScrollContainerSecondary", style_sidebar);
1953
p_theme->set_stylebox(SceneStringName(panel), "TreeSecondary", style_sidebar);
1954
p_theme->set_stylebox(SceneStringName(panel), "ItemListSecondary", style_sidebar);
1955
// Use it for EditorDebuggerInspector in StackTrace to keep the default 3-column layout,
1956
// as the debugger inspector is too small to be considered a main area.
1957
p_theme->set_stylebox(SceneStringName(panel), "EditorDebuggerInspector", style_sidebar);
1958
}
1959
1960
// ForegroundPanel.
1961
{
1962
p_theme->set_type_variation("PanelForeground", "Panel");
1963
p_theme->set_type_variation("EditorInspectorForeground", "EditorInspector");
1964
1965
p_theme->set_stylebox(SceneStringName(panel), "PanelForeground", p_config.foreground_panel);
1966
p_theme->set_stylebox(SceneStringName(panel), "EditorInspectorForeground", p_config.foreground_panel);
1967
}
1968
}
1969
1970
// Editor inspector.
1971
{
1972
// Panel.
1973
p_theme->set_stylebox(SceneStringName(panel), "EditorInspector", p_config.base_empty_style);
1974
1975
// Vertical separation between inspector areas.
1976
p_theme->set_type_variation("EditorInspectorContainer", "VBoxContainer");
1977
p_theme->set_constant("separation", "EditorInspectorContainer", Math::ceil(p_config.base_margin * 0.5 * EDSCALE));
1978
1979
// Vertical separation between inspector properties.
1980
p_theme->set_type_variation("EditorPropertyContainer", "VBoxContainer");
1981
p_theme->set_constant("separation", "EditorPropertyContainer", p_config.base_margin * 0.5 * EDSCALE);
1982
1983
// EditorProperty.
1984
1985
Ref<StyleBoxFlat> style_property_bg = p_config.base_style->duplicate();
1986
style_property_bg->set_bg_color(p_config.highlight_color);
1987
style_property_bg->set_border_width_all(0);
1988
1989
Ref<StyleBoxFlat> style_property_bg_selected = p_config.base_style->duplicate();
1990
style_property_bg_selected->set_bg_color(p_config.mono_color * Color(1, 1, 1, 0.03));
1991
1992
Ref<StyleBoxFlat> style_property_child_bg = p_config.base_style->duplicate();
1993
style_property_child_bg->set_bg_color(p_config.surface_lower_color);
1994
style_property_child_bg->set_content_margin_all(p_config.base_margin * EDSCALE);
1995
1996
p_theme->set_stylebox("bg", "EditorProperty", p_config.base_empty_style);
1997
p_theme->set_stylebox("bg_selected", "EditorProperty", style_property_bg_selected);
1998
p_theme->set_stylebox("child_bg", "EditorProperty", style_property_child_bg);
1999
p_theme->set_constant("font_offset", "EditorProperty", 8 * EDSCALE);
2000
2001
const Color property_color = p_config.font_color.lerp(Color(0.5, 0.5, 0.5), 0.5);
2002
const Color readonly_color = property_color.lerp(p_config.dark_icon_and_font ? Color(0, 0, 0) : Color(1, 1, 1), 0.25);
2003
const Color readonly_warning_color = p_config.error_color.lerp(p_config.dark_icon_and_font ? Color(0, 0, 0) : Color(1, 1, 1), 0.25);
2004
2005
p_theme->set_color("property_color", "EditorProperty", p_config.font_color);
2006
p_theme->set_color("readonly_color", "EditorProperty", readonly_color);
2007
p_theme->set_color("warning_color", "EditorProperty", p_config.warning_color);
2008
p_theme->set_color("readonly_warning_color", "EditorProperty", readonly_warning_color);
2009
2010
Ref<StyleBoxFlat> style_property_group_note = p_config.base_style->duplicate();
2011
Color property_group_note_color = p_config.accent_color;
2012
property_group_note_color.a = 0.1;
2013
style_property_group_note->set_bg_color(property_group_note_color);
2014
p_theme->set_stylebox("bg_group_note", "EditorProperty", style_property_group_note);
2015
2016
// EditorInspectorSection.
2017
2018
Color inspector_section_color = p_config.font_color.lerp(Color(0.5, 0.5, 0.5), 0.35);
2019
p_theme->set_color(SceneStringName(font_color), "EditorInspectorSection", inspector_section_color);
2020
2021
Color inspector_indent_color = p_config.accent_color;
2022
inspector_indent_color.a = 0.2;
2023
Ref<StyleBoxFlat> inspector_indent_style = EditorThemeManager::make_flat_stylebox(inspector_indent_color, 2.0 * EDSCALE, 0, 2.0 * EDSCALE, 0);
2024
p_theme->set_stylebox("indent_box", "EditorInspectorSection", inspector_indent_style);
2025
p_theme->set_constant("indent_size", "EditorInspectorSection", 6.0 * EDSCALE);
2026
p_theme->set_constant("h_separation", "EditorInspectorSection", p_config.base_margin * EDSCALE);
2027
2028
Color prop_subsection_stylebox_color = p_config.button_disabled_color.lerp(p_config.base_color, 0.48);
2029
p_theme->set_color("prop_subsection_stylebox_color", EditorStringName(Editor), prop_subsection_stylebox_color);
2030
2031
Ref<StyleBoxFlat> prop_subsection_stylebox = p_config.base_style->duplicate();
2032
prop_subsection_stylebox->set_bg_color(p_theme->get_color("prop_subsection_stylebox_color", EditorStringName(Editor)));
2033
prop_subsection_stylebox->set_corner_radius_all(p_config.corner_radius * EDSCALE);
2034
p_theme->set_stylebox("prop_subsection_stylebox", EditorStringName(Editor), prop_subsection_stylebox);
2035
2036
Ref<StyleBoxFlat> prop_subsection_stylebox_left = prop_subsection_stylebox->duplicate();
2037
prop_subsection_stylebox_left->set_corner_radius(CORNER_TOP_RIGHT, 0);
2038
prop_subsection_stylebox_left->set_corner_radius(CORNER_BOTTOM_RIGHT, 0);
2039
p_theme->set_stylebox("prop_subsection_stylebox_left", EditorStringName(Editor), prop_subsection_stylebox_left);
2040
2041
Ref<StyleBoxFlat> prop_subsection_stylebox_right = prop_subsection_stylebox->duplicate();
2042
prop_subsection_stylebox_right->set_corner_radius(CORNER_TOP_LEFT, 0);
2043
prop_subsection_stylebox_right->set_corner_radius(CORNER_BOTTOM_LEFT, 0);
2044
p_theme->set_stylebox("prop_subsection_stylebox_right", EditorStringName(Editor), prop_subsection_stylebox_right);
2045
2046
p_theme->set_color("prop_subsection", EditorStringName(Editor), Color(1, 1, 1, 0));
2047
#ifndef DISABLE_DEPRECATED // Used before 4.3.
2048
p_theme->set_color("property_color", EditorStringName(Editor), p_config.dark_color_1.lerp(p_config.mono_color_font, 0.12));
2049
#endif
2050
2051
// EditorInspectorCategory.
2052
2053
Ref<StyleBoxFlat> category_bg = p_config.base_style->duplicate();
2054
category_bg->set_bg_color(p_config.surface_high_color);
2055
category_bg->set_content_margin_individual(0, p_config.base_margin * EDSCALE, 0, p_config.base_margin * EDSCALE);
2056
if (p_config.draw_extra_borders) {
2057
category_bg->set_border_width_all(1);
2058
category_bg->set_border_color(p_config.extra_border_color_2);
2059
}
2060
p_theme->set_stylebox("bg", "EditorInspectorCategory", category_bg);
2061
2062
p_theme->set_constant("inspector_margin", EditorStringName(Editor), 12 * EDSCALE);
2063
2064
// Colored EditorProperty.
2065
for (int i = 0; i < 16; i++) {
2066
Color si_base_color = p_config.accent_color;
2067
2068
float hue_rotate = (i * 2 % 16) / 16.0;
2069
si_base_color.set_hsv(Math::fmod(float(si_base_color.get_h() + hue_rotate), float(1.0)), si_base_color.get_s(), si_base_color.get_v());
2070
si_base_color = p_config.accent_color.lerp(si_base_color, p_config.subresource_hue_tint);
2071
2072
// Sub-inspector background.
2073
Ref<StyleBoxFlat> sub_inspector_bg = p_config.base_style->duplicate();
2074
sub_inspector_bg->set_bg_color(p_config.dark_color_1.lerp(si_base_color, 0.08));
2075
sub_inspector_bg->set_border_width_all(2 * EDSCALE);
2076
sub_inspector_bg->set_border_color(si_base_color * Color(0.7, 0.7, 0.7, 0.8));
2077
sub_inspector_bg->set_content_margin_all(4 * EDSCALE);
2078
sub_inspector_bg->set_corner_radius(CORNER_TOP_LEFT, 0);
2079
sub_inspector_bg->set_corner_radius(CORNER_TOP_RIGHT, 0);
2080
2081
p_theme->set_stylebox("sub_inspector_bg" + itos(i + 1), EditorStringName(EditorStyles), sub_inspector_bg);
2082
2083
// EditorProperty background while it has a sub-inspector open.
2084
Ref<StyleBoxFlat> bg_color = EditorThemeManager::make_flat_stylebox(si_base_color * Color(0.7, 0.7, 0.7, 0.8), 0, 0, 0, 0, p_config.corner_radius);
2085
bg_color->set_anti_aliased(false);
2086
bg_color->set_corner_radius(CORNER_BOTTOM_LEFT, 0);
2087
bg_color->set_corner_radius(CORNER_BOTTOM_RIGHT, 0);
2088
2089
p_theme->set_stylebox("sub_inspector_property_bg" + itos(i + 1), EditorStringName(EditorStyles), bg_color);
2090
2091
// Dictionary editor add item.
2092
// Expand to the left and right by 4px to compensate for the dictionary editor margins.
2093
2094
Color style_dictionary_bg_color = p_config.dark_color_3.lerp(si_base_color, 0.08);
2095
Ref<StyleBoxFlat> style_dictionary_add_item = EditorThemeManager::make_flat_stylebox(style_dictionary_bg_color, 0, 4, 0, 4, p_config.corner_radius);
2096
style_dictionary_add_item->set_expand_margin(SIDE_LEFT, 2 * EDSCALE);
2097
style_dictionary_add_item->set_expand_margin(SIDE_RIGHT, 2 * EDSCALE);
2098
p_theme->set_stylebox("DictionaryAddItem" + itos(i + 1), EditorStringName(EditorStyles), style_dictionary_add_item);
2099
}
2100
Color si_base_color = p_config.accent_color;
2101
2102
// Sub-inspector background.
2103
Ref<StyleBoxFlat> sub_inspector_bg = p_config.base_style->duplicate();
2104
sub_inspector_bg->set_bg_color(Color(1, 1, 1, 0));
2105
sub_inspector_bg->set_border_width_all(2 * EDSCALE);
2106
sub_inspector_bg->set_border_color(p_config.dark_color_1.lerp(si_base_color, 0.15));
2107
sub_inspector_bg->set_content_margin_all(4 * EDSCALE);
2108
sub_inspector_bg->set_corner_radius(CORNER_TOP_LEFT, 0);
2109
sub_inspector_bg->set_corner_radius(CORNER_TOP_RIGHT, 0);
2110
2111
p_theme->set_stylebox("sub_inspector_bg0", EditorStringName(EditorStyles), sub_inspector_bg);
2112
2113
// Sub-inspector background no border.
2114
2115
Ref<StyleBoxFlat> sub_inspector_bg_no_border = p_config.base_style->duplicate();
2116
sub_inspector_bg_no_border->set_content_margin_all(2 * EDSCALE);
2117
sub_inspector_bg_no_border->set_bg_color(p_config.dark_color_2.lerp(p_config.dark_color_3, 0.15));
2118
p_theme->set_stylebox("sub_inspector_bg_no_border", EditorStringName(EditorStyles), sub_inspector_bg_no_border);
2119
2120
// EditorProperty background while it has a sub-inspector open.
2121
Ref<StyleBoxFlat> bg_color = EditorThemeManager::make_flat_stylebox(p_config.dark_color_1.lerp(si_base_color, 0.15), 0, 0, 0, 0, p_config.corner_radius);
2122
bg_color->set_anti_aliased(false);
2123
bg_color->set_corner_radius(CORNER_BOTTOM_LEFT, 0);
2124
bg_color->set_corner_radius(CORNER_BOTTOM_RIGHT, 0);
2125
2126
p_theme->set_stylebox("sub_inspector_property_bg0", EditorStringName(EditorStyles), bg_color);
2127
2128
p_theme->set_color("sub_inspector_property_color", EditorStringName(EditorStyles), p_config.dark_icon_and_font ? Color(1, 1, 1, 1) : Color(0, 0, 0, 1));
2129
2130
// Dictionary editor.
2131
// Expand to the left and right by 4px to compensate for the dictionary editor margins.
2132
Ref<StyleBoxEmpty> style_dictionary_add_item = EditorThemeManager::make_empty_stylebox(0, 4, 0, 4);
2133
p_theme->set_stylebox("DictionaryAddItem0", EditorStringName(EditorStyles), style_dictionary_add_item);
2134
2135
// Object selector.
2136
p_theme->set_type_variation("ObjectSelectorMargin", "MarginContainer");
2137
p_theme->set_constant("margin_left", "ObjectSelectorMargin", p_config.base_margin * 2 * EDSCALE);
2138
p_theme->set_constant("margin_right", "ObjectSelectorMargin", p_config.base_margin * 2.5 * EDSCALE);
2139
2140
// EditorInspectorButton.
2141
2142
p_theme->set_type_variation("EditorInspectorButton", "Button");
2143
Ref<StyleBoxFlat> style_line = p_theme->get_stylebox(CoreStringName(normal), SNAME("LineEdit"));
2144
float vertical_margin = style_line->get_content_margin(SIDE_TOP);
2145
2146
Ref<StyleBoxFlat> style_inspector_button = p_config.button_style->duplicate();
2147
style_inspector_button->set_content_margin(SIDE_TOP, vertical_margin);
2148
style_inspector_button->set_content_margin(SIDE_BOTTOM, vertical_margin);
2149
2150
Ref<StyleBoxFlat> style_inspector_button_hover = p_config.button_style_hover->duplicate();
2151
style_inspector_button_hover->set_content_margin(SIDE_TOP, vertical_margin);
2152
style_inspector_button_hover->set_content_margin(SIDE_BOTTOM, vertical_margin);
2153
2154
Ref<StyleBoxFlat> style_inspector_button_pressed = p_config.button_style_pressed->duplicate();
2155
style_inspector_button_pressed->set_content_margin(SIDE_TOP, vertical_margin);
2156
style_inspector_button_pressed->set_content_margin(SIDE_BOTTOM, vertical_margin);
2157
2158
Ref<StyleBoxFlat> style_inspector_button_disabled = p_config.button_style_disabled->duplicate();
2159
style_inspector_button_disabled->set_content_margin(SIDE_TOP, vertical_margin);
2160
style_inspector_button_disabled->set_content_margin(SIDE_BOTTOM, vertical_margin);
2161
2162
p_theme->set_stylebox(CoreStringName(normal), "EditorInspectorButton", style_inspector_button);
2163
p_theme->set_stylebox(SceneStringName(hover), "EditorInspectorButton", style_inspector_button_hover);
2164
p_theme->set_stylebox(SceneStringName(pressed), "EditorInspectorButton", style_inspector_button_pressed);
2165
p_theme->set_stylebox("hover_pressed", "EditorInspectorButton", style_inspector_button_pressed);
2166
p_theme->set_stylebox("disabled", "EditorInspectorButton", style_inspector_button_disabled);
2167
2168
// Make the height for properties uniform.
2169
Ref<StyleBoxFlat> inspector_button_style = p_theme->get_stylebox(CoreStringName(normal), SNAME("EditorInspectorButton"));
2170
Ref<Font> font = p_theme->get_font(SceneStringName(font), SNAME("LineEdit"));
2171
int font_size = p_theme->get_font_size(SceneStringName(font_size), SNAME("LineEdit"));
2172
p_config.inspector_property_height = inspector_button_style->get_minimum_size().height + font->get_height(font_size);
2173
p_theme->set_constant("inspector_property_height", EditorStringName(Editor), p_config.inspector_property_height);
2174
2175
// EditorInspectorFlatButton.
2176
2177
p_theme->set_type_variation("EditorInspectorFlatButton", "FlatButton");
2178
2179
Ref<StyleBoxFlat> inspector_flat_button_hover = p_config.flat_button_hover->duplicate();
2180
inspector_flat_button_hover->set_content_margin(SIDE_TOP, vertical_margin);
2181
inspector_flat_button_hover->set_content_margin(SIDE_BOTTOM, vertical_margin);
2182
2183
Ref<StyleBoxFlat> inspector_flat_button_pressed = p_config.flat_button_pressed->duplicate();
2184
inspector_flat_button_pressed->set_content_margin(SIDE_TOP, vertical_margin);
2185
inspector_flat_button_pressed->set_content_margin(SIDE_BOTTOM, vertical_margin);
2186
2187
p_theme->set_stylebox(CoreStringName(normal), "EditorInspectorFlatButton", p_config.base_empty_wide_style);
2188
p_theme->set_stylebox(SceneStringName(hover), "EditorInspectorFlatButton", p_config.flat_button_hover);
2189
p_theme->set_stylebox(SceneStringName(pressed), "EditorInspectorFlatButton", p_config.flat_button_pressed);
2190
p_theme->set_stylebox("hover_pressed", "EditorInspectorFlatButton", p_config.flat_button_pressed);
2191
p_theme->set_stylebox("disabled", "EditorInspectorFlatButton", p_config.base_empty_wide_style);
2192
2193
// InspectorActionButton.
2194
p_theme->set_type_variation("InspectorActionButton", "Button");
2195
p_theme->set_constant("h_separation", "InspectorActionButton", p_config.base_margin * 2 * EDSCALE);
2196
}
2197
2198
// Animation Editor.
2199
{
2200
// Timeline general.
2201
p_theme->set_constant("timeline_v_separation", "AnimationTrackEditor", 0);
2202
p_theme->set_constant("track_v_separation", "AnimationTrackEditor", 0);
2203
2204
// AnimationTimelineEdit.
2205
// "primary" is used for integer timeline values, "secondary" for decimals.
2206
2207
Ref<StyleBoxFlat> style_time_available = p_config.base_style->duplicate();
2208
style_time_available->set_bg_color(p_config.dark_theme ? p_config.surface_highest_color : p_config.surface_high_color);
2209
if (p_config.draw_extra_borders) {
2210
style_time_available->set_border_width_all(Math::round(EDSCALE));
2211
style_time_available->set_border_color(p_config.extra_border_color_2);
2212
}
2213
2214
Ref<StyleBoxFlat> style_time_unavailable = p_config.base_style->duplicate();
2215
style_time_unavailable->set_bg_color(p_config.dark_theme ? p_config.surface_high_color : p_config.surface_highest_color);
2216
2217
p_theme->set_stylebox("time_available", "AnimationTimelineEdit", style_time_available);
2218
p_theme->set_stylebox("time_unavailable", "AnimationTimelineEdit", style_time_unavailable);
2219
2220
p_theme->set_color("v_line_primary_color", "AnimationTimelineEdit", p_config.mono_color * Color(1, 1, 1, 0.4));
2221
p_theme->set_color("v_line_secondary_color", "AnimationTimelineEdit", p_config.mono_color * Color(1, 1, 1, 0.08));
2222
p_theme->set_color("h_line_color", "AnimationTimelineEdit", Color(1, 1, 1, 0));
2223
p_theme->set_color("font_primary_color", "AnimationTimelineEdit", p_config.font_color);
2224
p_theme->set_color("font_secondary_color", "AnimationTimelineEdit", p_config.font_disabled_color);
2225
2226
p_theme->set_constant("v_line_primary_margin", "AnimationTimelineEdit", p_config.base_margin * EDSCALE);
2227
p_theme->set_constant("v_line_secondary_margin", "AnimationTimelineEdit", p_config.base_margin * 1.5 * EDSCALE);
2228
p_theme->set_constant("v_line_primary_width", "AnimationTimelineEdit", Math::ceil(2 * EDSCALE));
2229
p_theme->set_constant("v_line_secondary_width", "AnimationTimelineEdit", Math::ceil(EDSCALE));
2230
p_theme->set_constant("text_primary_margin", "AnimationTimelineEdit", p_config.base_margin * 0.75 * EDSCALE);
2231
p_theme->set_constant("text_secondary_margin", "AnimationTimelineEdit", p_config.base_margin * 0.5 * EDSCALE);
2232
2233
// AnimationTrackEdit.
2234
2235
Ref<StyleBoxFlat> style_animation_track_odd = p_config.base_style->duplicate();
2236
style_animation_track_odd->set_bg_color(p_config.surface_base_color);
2237
2238
Ref<StyleBoxFlat> style_animation_track_hover = p_config.base_style->duplicate();
2239
style_animation_track_hover->set_bg_color(p_config.surface_high_color);
2240
2241
Ref<StyleBoxFlat> style_animation_track_focus = p_config.base_style->duplicate();
2242
style_animation_track_focus->set_content_margin_individual(p_config.base_margin * 1.5 * EDSCALE, p_config.base_margin * EDSCALE, p_config.base_margin * 1.5 * EDSCALE, p_config.base_margin * EDSCALE);
2243
style_animation_track_focus->set_border_width_all(2);
2244
style_animation_track_focus->set_border_color(p_config.surface_high_color);
2245
style_animation_track_focus->set_draw_center(false);
2246
2247
p_theme->set_stylebox("odd", "AnimationTrackEdit", style_animation_track_odd);
2248
p_theme->set_stylebox(SceneStringName(hover), "AnimationTrackEdit", style_animation_track_hover);
2249
p_theme->set_stylebox("focus", "AnimationTrackEdit", style_animation_track_focus);
2250
2251
p_theme->set_color("h_line_color", "AnimationTrackEdit", Color(1, 1, 1, 0));
2252
2253
p_theme->set_constant("h_separation", "AnimationTrackEdit", p_config.base_margin * 1.5 * EDSCALE);
2254
p_theme->set_constant("outer_margin", "AnimationTrackEdit", p_config.increased_margin * 6 * EDSCALE);
2255
2256
// AnimationTrackEditGroup.
2257
2258
Ref<StyleBoxFlat> style_animation_track_header = p_config.base_style->duplicate();
2259
style_animation_track_header->set_bg_color(p_config.surface_low_color);
2260
style_animation_track_header->set_content_margin_individual(p_config.base_margin * 4 * EDSCALE, p_config.base_margin * EDSCALE, 0, p_config.base_margin * EDSCALE);
2261
2262
p_theme->set_stylebox("header", "AnimationTrackEditGroup", style_animation_track_header);
2263
2264
Ref<StyleBoxFlat> style_animation_track_group_hover = p_config.base_style->duplicate();
2265
style_animation_track_group_hover->set_bg_color(p_config.highlight_color);
2266
p_theme->set_stylebox(SceneStringName(hover), "AnimationTrackEditGroup", style_animation_track_group_hover);
2267
2268
p_theme->set_color("bg_color", "AnimationTrackEditGroup", p_config.surface_base_color);
2269
p_theme->set_color("h_line_color", "AnimationTrackEditGroup", Color(1, 1, 1, 0));
2270
p_theme->set_color("v_line_color", "AnimationTrackEditGroup", Color(1, 1, 1, 0));
2271
2272
p_theme->set_constant("h_separation", "AnimationTrackEditGroup", p_config.base_margin * 2 * EDSCALE);
2273
p_theme->set_constant("v_separation", "AnimationTrackEditGroup", 0);
2274
2275
// AnimationBezierTrackEdit.
2276
2277
p_theme->set_color("focus_color", "AnimationBezierTrackEdit", p_config.accent_color * Color(1, 1, 1, 0.8));
2278
p_theme->set_color("track_focus_color", "AnimationBezierTrackEdit", p_config.mono_color * Color(1, 1, 1, 0.1));
2279
p_theme->set_color("h_line_color", "AnimationBezierTrackEdit", p_config.mono_color * Color(1, 1, 1, 0.12));
2280
p_theme->set_color("v_line_color", "AnimationBezierTrackEdit", Color(1, 1, 1, 0));
2281
2282
p_theme->set_constant("h_separation", "AnimationBezierTrackEdit", (p_config.increased_margin + 2) * EDSCALE);
2283
p_theme->set_constant("v_separation", "AnimationBezierTrackEdit", p_config.forced_even_separation * EDSCALE);
2284
}
2285
2286
// Editor help.
2287
{
2288
Ref<StyleBoxFlat> style_editor_help = p_config.base_style->duplicate();
2289
style_editor_help->set_bg_color(p_config.dark_color_2);
2290
style_editor_help->set_border_color(p_config.dark_color_3);
2291
p_theme->set_stylebox("background", "EditorHelp", style_editor_help);
2292
2293
const Color kbd_color = p_config.font_color.lerp(Color(0.5, 0.5, 0.5), 0.5);
2294
2295
p_theme->set_color("title_color", "EditorHelp", p_config.accent_color);
2296
p_theme->set_color("headline_color", "EditorHelp", p_config.mono_color_font);
2297
p_theme->set_color("text_color", "EditorHelp", p_config.font_color);
2298
p_theme->set_color("comment_color", "EditorHelp", p_config.font_color * Color(1, 1, 1, 0.6));
2299
p_theme->set_color("symbol_color", "EditorHelp", p_config.font_color * Color(1, 1, 1, 0.6));
2300
p_theme->set_color("value_color", "EditorHelp", p_config.font_color * Color(1, 1, 1, 0.6));
2301
p_theme->set_color("qualifier_color", "EditorHelp", p_config.font_color * Color(1, 1, 1, 0.8));
2302
p_theme->set_color("type_color", "EditorHelp", p_config.accent_color.lerp(p_config.font_color, 0.5));
2303
p_theme->set_color("override_color", "EditorHelp", p_config.warning_color);
2304
p_theme->set_color("selection_color", "EditorHelp", p_config.selection_color);
2305
p_theme->set_color("link_color", "EditorHelp", p_config.accent_color.lerp(p_config.mono_color_font, 0.8));
2306
p_theme->set_color("code_color", "EditorHelp", p_config.accent_color.lerp(p_config.mono_color_font, 0.6));
2307
p_theme->set_color("kbd_color", "EditorHelp", p_config.accent_color.lerp(kbd_color, 0.6));
2308
p_theme->set_color("code_bg_color", "EditorHelp", p_config.dark_color_3);
2309
p_theme->set_color("kbd_bg_color", "EditorHelp", p_config.dark_color_1);
2310
p_theme->set_color("param_bg_color", "EditorHelp", p_config.dark_color_1);
2311
p_theme->set_constant(SceneStringName(line_separation), "EditorHelp", Math::round(6 * EDSCALE));
2312
p_theme->set_constant("table_h_separation", "EditorHelp", 16 * EDSCALE);
2313
p_theme->set_constant("table_v_separation", "EditorHelp", 6 * EDSCALE);
2314
p_theme->set_constant("text_highlight_h_padding", "EditorHelp", 1 * EDSCALE);
2315
p_theme->set_constant("text_highlight_v_padding", "EditorHelp", 2 * EDSCALE);
2316
}
2317
2318
// EditorHelpBitTitle.
2319
{
2320
Ref<StyleBoxFlat> editor_help_title_style = p_config.base_style->duplicate();
2321
editor_help_title_style->set_bg_color(_get_base_color(p_config, p_config.dark_theme ? -0.55 : -0.9));
2322
editor_help_title_style->set_content_margin_individual(p_config.base_margin * 2 * EDSCALE, p_config.base_margin * EDSCALE, p_config.base_margin * 2 * EDSCALE, p_config.base_margin * EDSCALE);
2323
editor_help_title_style->set_corner_radius_individual(0, 0, p_config.corner_radius * EDSCALE, p_config.corner_radius * EDSCALE);
2324
if (p_config.draw_extra_borders) {
2325
editor_help_title_style->set_border_width_all(Math::round(EDSCALE));
2326
editor_help_title_style->set_border_color(p_config.extra_border_color_2);
2327
}
2328
2329
p_theme->set_type_variation("EditorHelpBitTitle", "RichTextLabel");
2330
p_theme->set_stylebox(CoreStringName(normal), "EditorHelpBitTitle", editor_help_title_style);
2331
}
2332
2333
// EditorHelpBitContent.
2334
{
2335
Ref<StyleBoxFlat> editor_help_content_style = p_config.base_style->duplicate();
2336
editor_help_content_style->set_bg_color(p_config.surface_low_color);
2337
editor_help_content_style->set_content_margin_individual(p_config.base_margin * 2 * EDSCALE, p_config.base_margin * EDSCALE, p_config.base_margin * 2 * EDSCALE, p_config.base_margin * EDSCALE);
2338
editor_help_content_style->set_corner_radius_individual(0, 0, p_config.corner_radius * EDSCALE, p_config.corner_radius * EDSCALE);
2339
if (p_config.draw_extra_borders) {
2340
editor_help_content_style->set_border_width_all(Math::round(EDSCALE));
2341
editor_help_content_style->set_border_color(p_config.extra_border_color_2);
2342
}
2343
2344
p_theme->set_type_variation("EditorHelpBitContent", "RichTextLabel");
2345
p_theme->set_stylebox(CoreStringName(normal), "EditorHelpBitContent", editor_help_content_style);
2346
}
2347
2348
// Asset Library.
2349
Ref<StyleBoxFlat> assetlib_panel_style = p_config.base_style->duplicate();
2350
assetlib_panel_style->set_bg_color(p_config.surface_low_color);
2351
assetlib_panel_style->set_content_margin_all(p_config.base_margin * 2 * EDSCALE);
2352
2353
p_theme->set_stylebox("bg", "AssetLib", EditorThemeManager::make_empty_stylebox(p_config.base_margin, p_config.base_margin, p_config.base_margin, p_config.base_margin));
2354
p_theme->set_stylebox(SceneStringName(panel), "AssetLib", assetlib_panel_style);
2355
p_theme->set_color("status_color", "AssetLib", Color(0.5, 0.5, 0.5)); // FIXME: Use a defined color instead.
2356
p_theme->set_icon("dismiss", "AssetLib", p_theme->get_icon(SNAME("Close"), EditorStringName(EditorIcons)));
2357
2358
// Debugger.
2359
Ref<StyleBoxFlat> debugger_panel_style = p_config.content_panel_style->duplicate();
2360
debugger_panel_style->set_border_width(SIDE_BOTTOM, 0);
2361
p_theme->set_stylebox("DebuggerPanel", EditorStringName(EditorStyles), debugger_panel_style);
2362
2363
// Resource and node editors.
2364
{
2365
// TextureRegion editor.
2366
Ref<StyleBoxFlat> style_texture_region_bg = p_config.tree_panel_style->duplicate();
2367
style_texture_region_bg->set_content_margin_all(0);
2368
p_theme->set_stylebox("TextureRegionPreviewBG", EditorStringName(EditorStyles), style_texture_region_bg);
2369
p_theme->set_stylebox("TextureRegionPreviewFG", EditorStringName(EditorStyles), EditorThemeManager::make_empty_stylebox(0, 0, 0, 0));
2370
2371
// Theme editor.
2372
{
2373
p_theme->set_color("preview_picker_overlay_color", "ThemeEditor", Color(0.1, 0.1, 0.1, 0.25));
2374
2375
Color theme_preview_picker_bg_color = p_config.accent_color;
2376
theme_preview_picker_bg_color.a = 0.2;
2377
Ref<StyleBoxFlat> theme_preview_picker_sb = EditorThemeManager::make_flat_stylebox(theme_preview_picker_bg_color, 0, 0, 0, 0);
2378
theme_preview_picker_sb->set_border_color(p_config.accent_color);
2379
theme_preview_picker_sb->set_border_width_all(1.0 * EDSCALE);
2380
p_theme->set_stylebox("preview_picker_overlay", "ThemeEditor", theme_preview_picker_sb);
2381
2382
Color theme_preview_picker_label_bg_color = p_config.accent_color;
2383
theme_preview_picker_label_bg_color.set_v(0.5);
2384
Ref<StyleBoxFlat> theme_preview_picker_label_sb = EditorThemeManager::make_flat_stylebox(theme_preview_picker_label_bg_color, 4.0, 1.0, 4.0, 3.0);
2385
p_theme->set_stylebox("preview_picker_label", "ThemeEditor", theme_preview_picker_label_sb);
2386
2387
Ref<StyleBoxFlat> style_theme_preview_tab = p_theme->get_stylebox(SNAME("tab_selected"), SNAME("TabContainer"))->duplicate();
2388
style_theme_preview_tab->set_expand_margin(SIDE_BOTTOM, 5 * EDSCALE);
2389
p_theme->set_stylebox("ThemeEditorPreviewFG", EditorStringName(EditorStyles), style_theme_preview_tab);
2390
2391
Ref<StyleBoxFlat> style_theme_preview_bg_tab = p_theme->get_stylebox(SNAME("tab_unselected"), SNAME("TabContainer"))->duplicate();
2392
style_theme_preview_bg_tab->set_expand_margin(SIDE_BOTTOM, 2 * EDSCALE);
2393
p_theme->set_stylebox("ThemeEditorPreviewBG", EditorStringName(EditorStyles), style_theme_preview_bg_tab);
2394
}
2395
2396
// VisualShader editor.
2397
p_theme->set_stylebox("label_style", "VShaderEditor", EditorThemeManager::make_empty_stylebox(4, 6, 4, 6));
2398
2399
// StateMachine graph.
2400
{
2401
p_theme->set_stylebox(SceneStringName(panel), "GraphStateMachine", p_config.tree_panel_style);
2402
p_theme->set_stylebox("error_panel", "GraphStateMachine", p_config.tree_panel_style);
2403
p_theme->set_color("error_color", "GraphStateMachine", p_config.error_color);
2404
2405
const int sm_margin_side = 10 * EDSCALE;
2406
const int sm_margin_bottom = 2;
2407
const Color sm_bg_color = p_config.dark_theme ? p_config.dark_color_3 : p_config.dark_color_1.lerp(p_config.mono_color, 0.09);
2408
2409
Ref<StyleBoxFlat> sm_node_style = EditorThemeManager::make_flat_stylebox(p_config.dark_color_3 * Color(1, 1, 1, 0.7), sm_margin_side, 24 * EDSCALE, sm_margin_side, sm_margin_bottom, p_config.corner_radius);
2410
sm_node_style->set_border_width_all(p_config.border_width);
2411
sm_node_style->set_border_color(sm_bg_color);
2412
2413
Ref<StyleBoxFlat> sm_node_selected_style = EditorThemeManager::make_flat_stylebox(sm_bg_color * Color(1, 1, 1, 0.9), sm_margin_side, 24 * EDSCALE, sm_margin_side, sm_margin_bottom, p_config.corner_radius);
2414
sm_node_selected_style->set_border_width_all(2 * EDSCALE + p_config.border_width);
2415
sm_node_selected_style->set_border_color(p_config.accent_color * Color(1, 1, 1, 0.9));
2416
sm_node_selected_style->set_shadow_size(8 * EDSCALE);
2417
sm_node_selected_style->set_shadow_color(p_config.shadow_color);
2418
2419
Ref<StyleBoxFlat> sm_node_playing_style = sm_node_selected_style->duplicate();
2420
sm_node_playing_style->set_border_color(p_config.warning_color);
2421
sm_node_playing_style->set_shadow_color(p_config.warning_color * Color(1, 1, 1, 0.2));
2422
sm_node_playing_style->set_draw_center(false);
2423
2424
p_theme->set_stylebox("node_frame", "GraphStateMachine", sm_node_style);
2425
p_theme->set_stylebox("node_frame_selected", "GraphStateMachine", sm_node_selected_style);
2426
p_theme->set_stylebox("node_frame_playing", "GraphStateMachine", sm_node_playing_style);
2427
2428
Ref<StyleBoxFlat> sm_node_start_style = sm_node_style->duplicate();
2429
sm_node_start_style->set_border_width_all(1 * EDSCALE);
2430
sm_node_start_style->set_border_color(p_config.success_color.lightened(0.24));
2431
p_theme->set_stylebox("node_frame_start", "GraphStateMachine", sm_node_start_style);
2432
2433
Ref<StyleBoxFlat> sm_node_end_style = sm_node_style->duplicate();
2434
sm_node_end_style->set_border_width_all(1 * EDSCALE);
2435
sm_node_end_style->set_border_color(p_config.error_color);
2436
p_theme->set_stylebox("node_frame_end", "GraphStateMachine", sm_node_end_style);
2437
2438
p_theme->set_font("node_title_font", "GraphStateMachine", p_theme->get_font(SceneStringName(font), SNAME("Label")));
2439
p_theme->set_font_size("node_title_font_size", "GraphStateMachine", p_theme->get_font_size(SceneStringName(font_size), SNAME("Label")));
2440
p_theme->set_color("node_title_font_color", "GraphStateMachine", p_config.font_color);
2441
2442
p_theme->set_color("transition_color", "GraphStateMachine", p_config.font_color);
2443
p_theme->set_color("transition_disabled_color", "GraphStateMachine", p_config.font_color * Color(1, 1, 1, 0.2));
2444
p_theme->set_color("transition_icon_color", "GraphStateMachine", Color(1, 1, 1));
2445
p_theme->set_color("transition_icon_disabled_color", "GraphStateMachine", Color(1, 1, 1, 0.2));
2446
p_theme->set_color("highlight_color", "GraphStateMachine", p_config.accent_color);
2447
p_theme->set_color("highlight_disabled_color", "GraphStateMachine", p_config.accent_color * Color(1, 1, 1, 0.6));
2448
p_theme->set_color("focus_color", "GraphStateMachine", p_config.accent_color * Color(1, 1, 1, 0.8));
2449
p_theme->set_color("guideline_color", "GraphStateMachine", p_config.font_color * Color(1, 1, 1, 0.3));
2450
2451
p_theme->set_color("playback_color", "GraphStateMachine", p_config.font_color);
2452
p_theme->set_color("playback_background_color", "GraphStateMachine", p_config.font_color * Color(1, 1, 1, 0.3));
2453
}
2454
}
2455
2456
// TileSet editor.
2457
// This editor is using Tree panel for the panel container of expanded view, while the theme
2458
// needs trees to be transparent, so it needs to have its own style.
2459
Ref<StyleBoxFlat> tile_expand_style = p_config.base_style->duplicate();
2460
tile_expand_style->set_corner_radius_all(0);
2461
p_theme->set_stylebox("expand_panel", "TileSetEditor", tile_expand_style);
2462
}
2463
2464