0d27c4d809
This uses the accent color to match pressed CheckButtons after they were updated. Checked checkboxes are now more prominent in the user's peripheral vision, which can be useful at times. This also matches how checkboxes look in most operating systems and web browsers.
1443 lines
79 KiB
C++
1443 lines
79 KiB
C++
/*************************************************************************/
|
|
/* editor_themes.cpp */
|
|
/*************************************************************************/
|
|
/* This file is part of: */
|
|
/* GODOT ENGINE */
|
|
/* https://godotengine.org */
|
|
/*************************************************************************/
|
|
/* Copyright (c) 2007-2021 Juan Linietsky, Ariel Manzur. */
|
|
/* Copyright (c) 2014-2021 Godot Engine contributors (cf. AUTHORS.md). */
|
|
/* */
|
|
/* Permission is hereby granted, free of charge, to any person obtaining */
|
|
/* a copy of this software and associated documentation files (the */
|
|
/* "Software"), to deal in the Software without restriction, including */
|
|
/* without limitation the rights to use, copy, modify, merge, publish, */
|
|
/* distribute, sublicense, and/or sell copies of the Software, and to */
|
|
/* permit persons to whom the Software is furnished to do so, subject to */
|
|
/* the following conditions: */
|
|
/* */
|
|
/* The above copyright notice and this permission notice shall be */
|
|
/* included in all copies or substantial portions of the Software. */
|
|
/* */
|
|
/* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, */
|
|
/* EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF */
|
|
/* MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.*/
|
|
/* IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY */
|
|
/* CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, */
|
|
/* TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE */
|
|
/* SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. */
|
|
/*************************************************************************/
|
|
|
|
#include "editor_themes.h"
|
|
|
|
#include "core/io/resource_loader.h"
|
|
#include "editor_fonts.h"
|
|
#include "editor_icons.gen.h"
|
|
#include "editor_scale.h"
|
|
#include "editor_settings.h"
|
|
|
|
#include "modules/modules_enabled.gen.h"
|
|
#ifdef MODULE_SVG_ENABLED
|
|
#include "modules/svg/image_loader_svg.h"
|
|
#endif
|
|
|
|
static Ref<StyleBoxTexture> make_stylebox(Ref<Texture2D> p_texture, float p_left, float p_top, float p_right, float p_bottom, float p_margin_left = -1, float p_margin_top = -1, float p_margin_right = -1, float p_margin_bottom = -1, bool p_draw_center = true) {
|
|
Ref<StyleBoxTexture> style(memnew(StyleBoxTexture));
|
|
style->set_texture(p_texture);
|
|
style->set_margin_size(SIDE_LEFT, p_left * EDSCALE);
|
|
style->set_margin_size(SIDE_RIGHT, p_right * EDSCALE);
|
|
style->set_margin_size(SIDE_BOTTOM, p_bottom * EDSCALE);
|
|
style->set_margin_size(SIDE_TOP, p_top * EDSCALE);
|
|
style->set_default_margin(SIDE_LEFT, p_margin_left * EDSCALE);
|
|
style->set_default_margin(SIDE_RIGHT, p_margin_right * EDSCALE);
|
|
style->set_default_margin(SIDE_BOTTOM, p_margin_bottom * EDSCALE);
|
|
style->set_default_margin(SIDE_TOP, p_margin_top * EDSCALE);
|
|
style->set_draw_center(p_draw_center);
|
|
return style;
|
|
}
|
|
|
|
static Ref<StyleBoxEmpty> make_empty_stylebox(float p_margin_left = -1, float p_margin_top = -1, float p_margin_right = -1, float p_margin_bottom = -1) {
|
|
Ref<StyleBoxEmpty> style(memnew(StyleBoxEmpty));
|
|
style->set_default_margin(SIDE_LEFT, p_margin_left * EDSCALE);
|
|
style->set_default_margin(SIDE_RIGHT, p_margin_right * EDSCALE);
|
|
style->set_default_margin(SIDE_BOTTOM, p_margin_bottom * EDSCALE);
|
|
style->set_default_margin(SIDE_TOP, p_margin_top * EDSCALE);
|
|
return style;
|
|
}
|
|
|
|
static Ref<StyleBoxFlat> make_flat_stylebox(Color p_color, float p_margin_left = -1, float p_margin_top = -1, float p_margin_right = -1, float p_margin_bottom = -1, int p_corner_width = 0) {
|
|
Ref<StyleBoxFlat> style(memnew(StyleBoxFlat));
|
|
style->set_bg_color(p_color);
|
|
// Adjust level of detail based on the corners' effective sizes.
|
|
style->set_corner_detail(Math::ceil(1.5 * p_corner_width * EDSCALE));
|
|
style->set_corner_radius_all(p_corner_width);
|
|
style->set_default_margin(SIDE_LEFT, p_margin_left * EDSCALE);
|
|
style->set_default_margin(SIDE_RIGHT, p_margin_right * EDSCALE);
|
|
style->set_default_margin(SIDE_BOTTOM, p_margin_bottom * EDSCALE);
|
|
style->set_default_margin(SIDE_TOP, p_margin_top * EDSCALE);
|
|
return style;
|
|
}
|
|
|
|
static Ref<StyleBoxLine> make_line_stylebox(Color p_color, int p_thickness = 1, float p_grow_begin = 1, float p_grow_end = 1, bool p_vertical = false) {
|
|
Ref<StyleBoxLine> style(memnew(StyleBoxLine));
|
|
style->set_color(p_color);
|
|
style->set_grow_begin(p_grow_begin);
|
|
style->set_grow_end(p_grow_end);
|
|
style->set_thickness(p_thickness);
|
|
style->set_vertical(p_vertical);
|
|
return style;
|
|
}
|
|
|
|
static Ref<Texture2D> flip_icon(Ref<Texture2D> p_texture, bool p_flip_y = false, bool p_flip_x = false) {
|
|
if (!p_flip_y && !p_flip_x) {
|
|
return p_texture;
|
|
}
|
|
|
|
Ref<ImageTexture> texture(memnew(ImageTexture));
|
|
Ref<Image> img = p_texture->get_image();
|
|
img = img->duplicate();
|
|
|
|
if (p_flip_y) {
|
|
img->flip_y();
|
|
}
|
|
if (p_flip_x) {
|
|
img->flip_x();
|
|
}
|
|
|
|
texture->create_from_image(img);
|
|
return texture;
|
|
}
|
|
|
|
#ifdef MODULE_SVG_ENABLED
|
|
static Ref<ImageTexture> editor_generate_icon(int p_index, bool p_convert_color, float p_scale = EDSCALE, float p_saturation = 1.0) {
|
|
Ref<ImageTexture> icon = memnew(ImageTexture);
|
|
Ref<Image> img = memnew(Image);
|
|
|
|
// Upsample icon generation only if the editor scale isn't an integer multiplier.
|
|
// Generating upsampled icons is slower, and the benefit is hardly visible
|
|
// with integer editor scales.
|
|
const bool upsample = !Math::is_equal_approx(Math::round(p_scale), p_scale);
|
|
ImageLoaderSVG::create_image_from_string(img, editor_icons_sources[p_index], p_scale, upsample, p_convert_color);
|
|
|
|
if (p_saturation != 1.0) {
|
|
img->adjust_bcs(1.0, 1.0, p_saturation);
|
|
}
|
|
icon->create_from_image(img); // in this case filter really helps
|
|
|
|
return icon;
|
|
}
|
|
#endif
|
|
|
|
#ifndef ADD_CONVERT_COLOR
|
|
#define ADD_CONVERT_COLOR(dictionary, old_color, new_color) dictionary[Color::html(old_color)] = Color::html(new_color)
|
|
#endif
|
|
|
|
void editor_register_and_generate_icons(Ref<Theme> p_theme, bool p_dark_theme = true, int p_thumb_size = 32, bool p_only_thumbs = false, float p_icon_saturation = 1.0) {
|
|
#ifdef MODULE_SVG_ENABLED
|
|
// The default icon theme is designed to be used for a dark theme.
|
|
// This dictionary stores color codes to convert to other colors
|
|
// for better readability on a light theme.
|
|
Dictionary dark_icon_color_dictionary;
|
|
|
|
// The names of the icons to never convert, even if one of their colors
|
|
// are contained in the dictionary above.
|
|
Set<StringName> exceptions;
|
|
|
|
if (!p_dark_theme) {
|
|
// convert color: FROM TO
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#e0e0e0", "#5a5a5a"); // common icon color
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#ffffff", "#414141"); // white
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#b4b4b4", "#363636"); // script darker color
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#f9f9f9", "#606060"); // scrollbar grabber highlight color
|
|
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#cea4f1", "#a85de9"); // animation
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#fc9c9c", "#cd3838"); // spatial
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#a5b7f3", "#3d64dd"); // 2d
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#708cea", "#1a3eac"); // 2d dark
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#a5efac", "#2fa139"); // control
|
|
|
|
// rainbow
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#ff7070", "#ff2929"); // red
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#ffeb70", "#ffe337"); // yellow
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#9dff70", "#74ff34"); // green
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#70ffb9", "#2cff98"); // aqua
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#70deff", "#22ccff"); // blue
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#9f70ff", "#702aff"); // purple
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#ff70ac", "#ff2781"); // pink
|
|
|
|
// audio gradient
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#ff8484", "#ff4040"); // red
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#e1dc7a", "#d6cf4b"); // yellow
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#84ffb1", "#00f010"); // green
|
|
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#ffd684", "#fea900"); // mesh (orange)
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#40a2ff", "#68b6ff"); // shape (blue)
|
|
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#ff8484", "#ff3333"); // remove (red)
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#84ffb1", "#00db50"); // add (green)
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#84c2ff", "#5caeff"); // selection (blue)
|
|
|
|
// Animation editor tracks
|
|
// The property track icon color is set by the common icon color
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#ea9568", "#bd5e2c"); // 3D Transform track
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#66f376", "#16a827"); // Call Method track
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#5792f6", "#236be6"); // Bezier Curve track
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#eae668", "#9f9722"); // Audio Playback track
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#b76ef0", "#9853ce"); // Animation Playback track
|
|
|
|
// TileSet editor icons
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#fce844", "#aa8d24"); // New Single Tile
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#4490fc", "#0350bd"); // New Autotile
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#c9cfd4", "#828f9b"); // New Atlas
|
|
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#69ecbd", "#25e3a0"); // VS variant
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#8da6f0", "#6d8eeb"); // VS bool
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#7dc6ef", "#4fb2e9"); // VS int
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#61daf4", "#27ccf0"); // VS float
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#6ba7ec", "#4690e7"); // VS string
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#bd91f1", "#ad76ee"); // VS vector2
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#f191a5", "#ee758e"); // VS rect
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#e286f0", "#dc6aed"); // VS vector3
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#c4ec69", "#96ce1a"); // VS transform2D
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#f77070", "#f77070"); // VS plane
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#ec69a3", "#ec69a3"); // VS quat
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#ee7991", "#ee7991"); // VS aabb
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#e3ec69", "#b2bb19"); // VS basis
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#f6a86e", "#f49047"); // VS transform
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#6993ec", "#6993ec"); // VS path
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#69ec9a", "#2ce573"); // VS rid
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#79f3e8", "#12d5c3"); // VS object
|
|
ADD_CONVERT_COLOR(dark_icon_color_dictionary, "#77edb1", "#57e99f"); // VS dict
|
|
|
|
exceptions.insert("EditorPivot");
|
|
exceptions.insert("EditorHandle");
|
|
exceptions.insert("Editor3DHandle");
|
|
exceptions.insert("Godot");
|
|
exceptions.insert("Sky");
|
|
exceptions.insert("EditorControlAnchor");
|
|
exceptions.insert("DefaultProjectIcon");
|
|
exceptions.insert("GuiChecked");
|
|
exceptions.insert("GuiCloseCustomizable");
|
|
exceptions.insert("GuiGraphNodePort");
|
|
exceptions.insert("GuiResizer");
|
|
exceptions.insert("ZoomMore");
|
|
exceptions.insert("ZoomLess");
|
|
exceptions.insert("ZoomReset");
|
|
exceptions.insert("LockViewport");
|
|
exceptions.insert("GroupViewport");
|
|
exceptions.insert("StatusError");
|
|
exceptions.insert("StatusSuccess");
|
|
exceptions.insert("StatusWarning");
|
|
exceptions.insert("NodeWarning");
|
|
exceptions.insert("OverbrightIndicator");
|
|
}
|
|
|
|
// These ones should be converted even if we are using a dark theme.
|
|
const Color error_color = p_theme->get_color("error_color", "Editor");
|
|
const Color success_color = p_theme->get_color("success_color", "Editor");
|
|
const Color warning_color = p_theme->get_color("warning_color", "Editor");
|
|
dark_icon_color_dictionary[Color::html("#ff0000")] = error_color;
|
|
dark_icon_color_dictionary[Color::html("#45ff8b")] = success_color;
|
|
dark_icon_color_dictionary[Color::html("#dbab09")] = warning_color;
|
|
|
|
ImageLoaderSVG::set_convert_colors(&dark_icon_color_dictionary);
|
|
|
|
// Generate icons.
|
|
if (!p_only_thumbs) {
|
|
for (int i = 0; i < editor_icons_count; i++) {
|
|
float saturation = p_icon_saturation;
|
|
|
|
if (strcmp(editor_icons_names[i], "DefaultProjectIcon") == 0 || strcmp(editor_icons_names[i], "Godot") == 0 || strcmp(editor_icons_names[i], "Logo") == 0) {
|
|
saturation = 1.0;
|
|
}
|
|
|
|
const int is_exception = exceptions.has(editor_icons_names[i]);
|
|
const Ref<ImageTexture> icon = editor_generate_icon(i, !is_exception, EDSCALE, saturation);
|
|
|
|
p_theme->set_icon(editor_icons_names[i], "EditorIcons", icon);
|
|
}
|
|
}
|
|
|
|
// Generate thumbnail icons with the given thumbnail size.
|
|
// We don't need filtering when generating at one of the default resolutions.
|
|
const bool force_filter = p_thumb_size != 64 && p_thumb_size != 32;
|
|
if (p_thumb_size >= 64) {
|
|
const float scale = (float)p_thumb_size / 64.0 * EDSCALE;
|
|
for (int i = 0; i < editor_bg_thumbs_count; i++) {
|
|
const int index = editor_bg_thumbs_indices[i];
|
|
const int is_exception = exceptions.has(editor_icons_names[index]);
|
|
const Ref<ImageTexture> icon = editor_generate_icon(index, !p_dark_theme && !is_exception, scale, force_filter);
|
|
|
|
p_theme->set_icon(editor_icons_names[index], "EditorIcons", icon);
|
|
}
|
|
} else {
|
|
const float scale = (float)p_thumb_size / 32.0 * EDSCALE;
|
|
for (int i = 0; i < editor_md_thumbs_count; i++) {
|
|
const int index = editor_md_thumbs_indices[i];
|
|
const bool is_exception = exceptions.has(editor_icons_names[index]);
|
|
const Ref<ImageTexture> icon = editor_generate_icon(index, !p_dark_theme && !is_exception, scale, force_filter);
|
|
|
|
p_theme->set_icon(editor_icons_names[index], "EditorIcons", icon);
|
|
}
|
|
}
|
|
|
|
ImageLoaderSVG::set_convert_colors(nullptr);
|
|
#else
|
|
WARN_PRINT("SVG support disabled, editor icons won't be rendered.");
|
|
#endif
|
|
}
|
|
|
|
Ref<Theme> create_editor_theme(const Ref<Theme> p_theme) {
|
|
Ref<Theme> theme = Ref<Theme>(memnew(Theme));
|
|
|
|
const float default_contrast = 0.3;
|
|
|
|
// Theme settings
|
|
Color accent_color = EDITOR_GET("interface/theme/accent_color");
|
|
Color base_color = EDITOR_GET("interface/theme/base_color");
|
|
float contrast = EDITOR_GET("interface/theme/contrast");
|
|
float icon_saturation = EDITOR_GET("interface/theme/icon_saturation");
|
|
float relationship_line_opacity = EDITOR_GET("interface/theme/relationship_line_opacity");
|
|
|
|
String preset = EDITOR_GET("interface/theme/preset");
|
|
|
|
int border_size = EDITOR_GET("interface/theme/border_size");
|
|
int corner_radius = EDITOR_GET("interface/theme/corner_radius");
|
|
|
|
Color preset_accent_color;
|
|
Color preset_base_color;
|
|
float preset_contrast = 0;
|
|
|
|
// Please use alphabetical order if you're adding a new theme here
|
|
// (after "Custom")
|
|
|
|
if (preset == "Custom") {
|
|
accent_color = EDITOR_GET("interface/theme/accent_color");
|
|
base_color = EDITOR_GET("interface/theme/base_color");
|
|
contrast = EDITOR_GET("interface/theme/contrast");
|
|
} else if (preset == "Breeze Dark") {
|
|
preset_accent_color = Color(0.26, 0.76, 1.00);
|
|
preset_base_color = Color(0.24, 0.26, 0.28);
|
|
preset_contrast = default_contrast;
|
|
} else if (preset == "Godot 2") {
|
|
preset_accent_color = Color(0.53, 0.67, 0.89);
|
|
preset_base_color = Color(0.24, 0.23, 0.27);
|
|
preset_contrast = default_contrast;
|
|
} else if (preset == "Grey") {
|
|
preset_accent_color = Color(0.72, 0.89, 1.00);
|
|
preset_base_color = Color(0.24, 0.24, 0.24);
|
|
preset_contrast = default_contrast;
|
|
} else if (preset == "Light") {
|
|
preset_accent_color = Color(0.18, 0.50, 1.00);
|
|
preset_base_color = Color(1.00, 1.00, 1.00);
|
|
preset_contrast = 0.08;
|
|
} else if (preset == "Solarized (Dark)") {
|
|
preset_accent_color = Color(0.15, 0.55, 0.82);
|
|
preset_base_color = Color(0.04, 0.23, 0.27);
|
|
preset_contrast = default_contrast;
|
|
} else if (preset == "Solarized (Light)") {
|
|
preset_accent_color = Color(0.15, 0.55, 0.82);
|
|
preset_base_color = Color(0.99, 0.96, 0.89);
|
|
preset_contrast = 0.08;
|
|
} else { // Default
|
|
preset_accent_color = Color(0.44, 0.73, 0.98);
|
|
preset_base_color = Color(0.21, 0.24, 0.29);
|
|
preset_contrast = default_contrast;
|
|
}
|
|
|
|
if (preset != "Custom") {
|
|
accent_color = preset_accent_color;
|
|
base_color = preset_base_color;
|
|
contrast = preset_contrast;
|
|
EditorSettings::get_singleton()->set_initial_value("interface/theme/accent_color", accent_color);
|
|
EditorSettings::get_singleton()->set_initial_value("interface/theme/base_color", base_color);
|
|
EditorSettings::get_singleton()->set_initial_value("interface/theme/contrast", contrast);
|
|
}
|
|
|
|
EditorSettings::get_singleton()->set_manually("interface/theme/preset", preset);
|
|
EditorSettings::get_singleton()->set_manually("interface/theme/accent_color", accent_color);
|
|
EditorSettings::get_singleton()->set_manually("interface/theme/base_color", base_color);
|
|
EditorSettings::get_singleton()->set_manually("interface/theme/contrast", contrast);
|
|
|
|
// Colors
|
|
bool dark_theme = EditorSettings::get_singleton()->is_dark_theme();
|
|
|
|
const Color dark_color_1 = base_color.lerp(Color(0, 0, 0, 1), contrast);
|
|
const Color dark_color_2 = base_color.lerp(Color(0, 0, 0, 1), contrast * 1.5);
|
|
const Color dark_color_3 = base_color.lerp(Color(0, 0, 0, 1), contrast * 2);
|
|
|
|
const Color background_color = dark_color_2;
|
|
|
|
// White (dark theme) or black (light theme), will be used to generate the rest of the colors
|
|
const Color mono_color = dark_theme ? Color(1, 1, 1) : Color(0, 0, 0);
|
|
|
|
const Color contrast_color_1 = base_color.lerp(mono_color, MAX(contrast, default_contrast));
|
|
const Color contrast_color_2 = base_color.lerp(mono_color, MAX(contrast * 1.5, default_contrast * 1.5));
|
|
|
|
const Color font_color = mono_color.lerp(base_color, 0.25);
|
|
const Color font_hover_color = mono_color.lerp(base_color, 0.125);
|
|
const Color font_disabled_color = Color(mono_color.r, mono_color.g, mono_color.b, 0.3);
|
|
const Color selection_color = accent_color * Color(1, 1, 1, 0.4);
|
|
const Color disabled_color = mono_color.inverted().lerp(base_color, 0.7);
|
|
const Color disabled_bg_color = mono_color.inverted().lerp(base_color, 0.9);
|
|
|
|
Color icon_hover_color = Color(1, 1, 1) * (dark_theme ? 1.15 : 1.45);
|
|
icon_hover_color.a = 1.0;
|
|
// Make the pressed icon color overbright because icons are not completely white on a dark theme.
|
|
// On a light theme, icons are dark, so we need to modulate them with an even brighter color.
|
|
Color icon_pressed_color = accent_color * (dark_theme ? 1.15 : 3.5);
|
|
icon_pressed_color.a = 1.0;
|
|
|
|
const Color separator_color = Color(mono_color.r, mono_color.g, mono_color.b, 0.1);
|
|
const Color highlight_color = Color(accent_color.r, accent_color.g, accent_color.b, 0.275);
|
|
|
|
float prev_icon_saturation = theme->has_color("icon_saturation", "Editor") ? theme->get_color("icon_saturation", "Editor").r : 1.0;
|
|
|
|
theme->set_color("icon_saturation", "Editor", Color(icon_saturation, icon_saturation, icon_saturation)); //can't save single float in theme, so using color
|
|
theme->set_color("accent_color", "Editor", accent_color);
|
|
theme->set_color("highlight_color", "Editor", highlight_color);
|
|
theme->set_color("base_color", "Editor", base_color);
|
|
theme->set_color("dark_color_1", "Editor", dark_color_1);
|
|
theme->set_color("dark_color_2", "Editor", dark_color_2);
|
|
theme->set_color("dark_color_3", "Editor", dark_color_3);
|
|
theme->set_color("contrast_color_1", "Editor", contrast_color_1);
|
|
theme->set_color("contrast_color_2", "Editor", contrast_color_2);
|
|
theme->set_color("box_selection_fill_color", "Editor", accent_color * Color(1, 1, 1, 0.3));
|
|
theme->set_color("box_selection_stroke_color", "Editor", accent_color * Color(1, 1, 1, 0.8));
|
|
|
|
theme->set_color("axis_x_color", "Editor", Color(0.96, 0.20, 0.32));
|
|
theme->set_color("axis_y_color", "Editor", Color(0.53, 0.84, 0.01));
|
|
theme->set_color("axis_z_color", "Editor", Color(0.16, 0.55, 0.96));
|
|
|
|
theme->set_color("font_color", "Editor", font_color);
|
|
theme->set_color("highlighted_font_color", "Editor", font_hover_color);
|
|
theme->set_color("disabled_font_color", "Editor", font_disabled_color);
|
|
|
|
theme->set_color("mono_color", "Editor", mono_color);
|
|
|
|
Color success_color = Color(0.45, 0.95, 0.5);
|
|
Color warning_color = Color(1, 0.87, 0.4);
|
|
Color error_color = Color(1, 0.47, 0.42);
|
|
Color property_color = font_color.lerp(Color(0.5, 0.5, 0.5), 0.5);
|
|
|
|
if (!dark_theme) {
|
|
// Darken some colors to be readable on a light background
|
|
success_color = success_color.lerp(mono_color, 0.35);
|
|
warning_color = warning_color.lerp(mono_color, 0.35);
|
|
error_color = error_color.lerp(mono_color, 0.25);
|
|
}
|
|
|
|
theme->set_color("success_color", "Editor", success_color);
|
|
theme->set_color("warning_color", "Editor", warning_color);
|
|
theme->set_color("error_color", "Editor", error_color);
|
|
theme->set_color("property_color", "Editor", property_color);
|
|
|
|
if (!dark_theme) {
|
|
theme->set_color("vulkan_color", "Editor", Color::hex(0xad1128ff));
|
|
} else {
|
|
theme->set_color("vulkan_color", "Editor", Color(1.0, 0.0, 0.0));
|
|
}
|
|
const int thumb_size = EDITOR_GET("filesystem/file_dialog/thumbnail_size");
|
|
theme->set_constant("scale", "Editor", EDSCALE);
|
|
theme->set_constant("thumb_size", "Editor", thumb_size);
|
|
theme->set_constant("dark_theme", "Editor", dark_theme);
|
|
|
|
// Register icons + font
|
|
|
|
// The resolution and the icon color (dark_theme bool) has not changed, so we do not regenerate the icons.
|
|
if (p_theme != nullptr && fabs(p_theme->get_constant("scale", "Editor") - EDSCALE) < 0.00001 && (bool)p_theme->get_constant("dark_theme", "Editor") == dark_theme && prev_icon_saturation == icon_saturation) {
|
|
// Register already generated icons.
|
|
for (int i = 0; i < editor_icons_count; i++) {
|
|
theme->set_icon(editor_icons_names[i], "EditorIcons", p_theme->get_icon(editor_icons_names[i], "EditorIcons"));
|
|
}
|
|
} else {
|
|
editor_register_and_generate_icons(theme, dark_theme, thumb_size, false, icon_saturation);
|
|
}
|
|
// Thumbnail size has changed, so we regenerate the medium sizes
|
|
if (p_theme != nullptr && fabs((double)p_theme->get_constant("thumb_size", "Editor") - thumb_size) > 0.00001) {
|
|
editor_register_and_generate_icons(p_theme, dark_theme, thumb_size, true);
|
|
}
|
|
|
|
editor_register_fonts(theme);
|
|
|
|
// Ensure borders are visible when using an editor scale below 100%.
|
|
const int border_width = CLAMP(border_size, 0, 2) * MAX(1, EDSCALE);
|
|
const int corner_width = CLAMP(corner_radius, 0, 6) * EDSCALE;
|
|
const int default_margin_size = 4;
|
|
const int margin_size_extra = default_margin_size + CLAMP(border_size, 0, 2);
|
|
|
|
// Styleboxes
|
|
// This is the most commonly used stylebox, variations should be made as duplicate of this
|
|
Ref<StyleBoxFlat> style_default = make_flat_stylebox(base_color, default_margin_size, default_margin_size, default_margin_size, default_margin_size, corner_width);
|
|
// Work around issue about antialiased edges being blurrier (GH-35279).
|
|
style_default->set_anti_aliased(false);
|
|
style_default->set_border_width_all(border_width);
|
|
style_default->set_border_color(base_color);
|
|
style_default->set_draw_center(true);
|
|
|
|
// Button and widgets
|
|
const float extra_spacing = EDITOR_GET("interface/theme/additional_spacing");
|
|
|
|
const Vector2 widget_default_margin = Vector2(extra_spacing + 6, extra_spacing + default_margin_size + 1) * EDSCALE;
|
|
|
|
Ref<StyleBoxFlat> style_widget = style_default->duplicate();
|
|
style_widget->set_default_margin(SIDE_LEFT, widget_default_margin.x);
|
|
style_widget->set_default_margin(SIDE_TOP, widget_default_margin.y);
|
|
style_widget->set_default_margin(SIDE_RIGHT, widget_default_margin.x);
|
|
style_widget->set_default_margin(SIDE_BOTTOM, widget_default_margin.y);
|
|
style_widget->set_bg_color(dark_color_1);
|
|
style_widget->set_border_color(dark_color_2);
|
|
|
|
Ref<StyleBoxFlat> style_widget_disabled = style_widget->duplicate();
|
|
style_widget_disabled->set_border_color(disabled_color);
|
|
style_widget_disabled->set_bg_color(disabled_bg_color);
|
|
|
|
Ref<StyleBoxFlat> style_widget_focus = style_widget->duplicate();
|
|
style_widget_focus->set_draw_center(false);
|
|
style_widget_focus->set_border_width_all(Math::round(2 * MAX(1, EDSCALE)));
|
|
style_widget_focus->set_border_color(accent_color);
|
|
|
|
Ref<StyleBoxFlat> style_widget_pressed = style_widget->duplicate();
|
|
style_widget_pressed->set_bg_color(dark_color_1.darkened(0.125));
|
|
|
|
Ref<StyleBoxFlat> style_widget_hover = style_widget->duplicate();
|
|
style_widget_hover->set_bg_color(mono_color * Color(1, 1, 1, 0.11));
|
|
style_widget_hover->set_border_color(mono_color * Color(1, 1, 1, 0.05));
|
|
|
|
// Style for windows, popups, etc..
|
|
Ref<StyleBoxFlat> style_popup = style_default->duplicate();
|
|
const int popup_margin_size = default_margin_size * EDSCALE * 3;
|
|
style_popup->set_default_margin(SIDE_LEFT, popup_margin_size);
|
|
style_popup->set_default_margin(SIDE_TOP, popup_margin_size);
|
|
style_popup->set_default_margin(SIDE_RIGHT, popup_margin_size);
|
|
style_popup->set_default_margin(SIDE_BOTTOM, popup_margin_size);
|
|
style_popup->set_border_color(contrast_color_1);
|
|
const Color shadow_color = Color(0, 0, 0, dark_theme ? 0.3 : 0.1);
|
|
style_popup->set_shadow_color(shadow_color);
|
|
style_popup->set_shadow_size(4 * EDSCALE);
|
|
|
|
Ref<StyleBoxLine> style_popup_separator(memnew(StyleBoxLine));
|
|
style_popup_separator->set_color(separator_color);
|
|
style_popup_separator->set_grow_begin(popup_margin_size - MAX(Math::round(EDSCALE), border_width));
|
|
style_popup_separator->set_grow_end(popup_margin_size - MAX(Math::round(EDSCALE), border_width));
|
|
style_popup_separator->set_thickness(MAX(Math::round(EDSCALE), border_width));
|
|
|
|
Ref<StyleBoxLine> style_popup_labeled_separator_left(memnew(StyleBoxLine));
|
|
style_popup_labeled_separator_left->set_grow_begin(popup_margin_size - MAX(Math::round(EDSCALE), border_width));
|
|
style_popup_labeled_separator_left->set_color(separator_color);
|
|
style_popup_labeled_separator_left->set_thickness(MAX(Math::round(EDSCALE), border_width));
|
|
|
|
Ref<StyleBoxLine> style_popup_labeled_separator_right(memnew(StyleBoxLine));
|
|
style_popup_labeled_separator_right->set_grow_end(popup_margin_size - MAX(Math::round(EDSCALE), border_width));
|
|
style_popup_labeled_separator_right->set_color(separator_color);
|
|
style_popup_labeled_separator_right->set_thickness(MAX(Math::round(EDSCALE), border_width));
|
|
|
|
Ref<StyleBoxEmpty> style_empty = make_empty_stylebox(default_margin_size, default_margin_size, default_margin_size, default_margin_size);
|
|
|
|
// Tabs
|
|
|
|
Ref<StyleBoxFlat> style_tab_selected = style_widget->duplicate();
|
|
|
|
// Add a highlight line at the top of the selected tab.
|
|
style_tab_selected->set_border_width_all(0);
|
|
style_tab_selected->set_border_width(SIDE_TOP, Math::round(2 * EDSCALE));
|
|
// Make the highlight line prominent, but not too prominent as to not be distracting.
|
|
style_tab_selected->set_border_color(dark_color_2.lerp(accent_color, 0.75));
|
|
// Don't round the top corners to avoid creating a small blank space between the tabs and the main panel.
|
|
// This also makes the top highlight look better.
|
|
style_tab_selected->set_corner_radius_all(0);
|
|
|
|
// Prevent visible artifacts and cover the top-left rounded corner of the panel below the tab if selected
|
|
// We can't prevent them with both rounded corners and non-zero border width, though
|
|
style_tab_selected->set_expand_margin_size(SIDE_BOTTOM, corner_width > 0 ? corner_width : border_width);
|
|
|
|
style_tab_selected->set_default_margin(SIDE_LEFT, widget_default_margin.x + 2 * EDSCALE);
|
|
style_tab_selected->set_default_margin(SIDE_RIGHT, widget_default_margin.x + 2 * EDSCALE);
|
|
style_tab_selected->set_default_margin(SIDE_BOTTOM, widget_default_margin.y);
|
|
style_tab_selected->set_default_margin(SIDE_TOP, widget_default_margin.y);
|
|
style_tab_selected->set_bg_color(base_color);
|
|
|
|
Ref<StyleBoxFlat> style_tab_unselected = style_tab_selected->duplicate();
|
|
style_tab_unselected->set_bg_color(dark_color_1);
|
|
style_tab_unselected->set_expand_margin_size(SIDE_BOTTOM, 0);
|
|
// Add some spacing between unselected tabs to make them easier to distinguish from each other
|
|
style_tab_unselected->set_border_color(Color(0, 0, 0, 0));
|
|
style_tab_unselected->set_border_width(SIDE_LEFT, Math::round(1 * EDSCALE));
|
|
style_tab_unselected->set_border_width(SIDE_RIGHT, Math::round(1 * EDSCALE));
|
|
style_tab_unselected->set_default_margin(SIDE_LEFT, widget_default_margin.x + 2 * EDSCALE);
|
|
style_tab_unselected->set_default_margin(SIDE_RIGHT, widget_default_margin.x + 2 * EDSCALE);
|
|
|
|
Ref<StyleBoxFlat> style_tab_disabled = style_tab_selected->duplicate();
|
|
style_tab_disabled->set_bg_color(disabled_bg_color);
|
|
style_tab_disabled->set_expand_margin_size(SIDE_BOTTOM, 0);
|
|
style_tab_disabled->set_border_color(disabled_bg_color);
|
|
|
|
// Editor background
|
|
Color background_color_opaque = background_color;
|
|
background_color_opaque.a = 1.0;
|
|
theme->set_stylebox("Background", "EditorStyles", make_flat_stylebox(background_color_opaque, default_margin_size, default_margin_size, default_margin_size, default_margin_size));
|
|
|
|
// Focus
|
|
theme->set_stylebox("Focus", "EditorStyles", style_widget_focus);
|
|
|
|
// Menu
|
|
Ref<StyleBoxFlat> style_menu = style_widget->duplicate();
|
|
style_menu->set_draw_center(false);
|
|
style_menu->set_border_width_all(0);
|
|
theme->set_stylebox("panel", "PanelContainer", style_menu);
|
|
theme->set_stylebox("MenuPanel", "EditorStyles", style_menu);
|
|
|
|
// Script Editor
|
|
theme->set_stylebox("ScriptEditorPanel", "EditorStyles", make_empty_stylebox(default_margin_size, 0, default_margin_size, default_margin_size));
|
|
theme->set_stylebox("ScriptEditor", "EditorStyles", make_empty_stylebox(0, 0, 0, 0));
|
|
|
|
// Play button group
|
|
theme->set_stylebox("PlayButtonPanel", "EditorStyles", style_empty);
|
|
|
|
theme->set_stylebox("normal", "MenuButton", style_menu);
|
|
theme->set_stylebox("hover", "MenuButton", style_widget_hover);
|
|
theme->set_stylebox("pressed", "MenuButton", style_menu);
|
|
theme->set_stylebox("focus", "MenuButton", style_menu);
|
|
theme->set_stylebox("disabled", "MenuButton", style_menu);
|
|
|
|
theme->set_color("font_color", "MenuButton", font_color);
|
|
theme->set_color("font_hover_color", "MenuButton", font_hover_color);
|
|
|
|
theme->set_stylebox("MenuHover", "EditorStyles", style_widget_hover);
|
|
|
|
// Buttons
|
|
theme->set_stylebox("normal", "Button", style_widget);
|
|
theme->set_stylebox("hover", "Button", style_widget_hover);
|
|
theme->set_stylebox("pressed", "Button", style_widget_pressed);
|
|
theme->set_stylebox("focus", "Button", style_widget_focus);
|
|
theme->set_stylebox("disabled", "Button", style_widget_disabled);
|
|
|
|
theme->set_color("font_color", "Button", font_color);
|
|
theme->set_color("font_hover_color", "Button", font_hover_color);
|
|
theme->set_color("font_pressed_color", "Button", accent_color);
|
|
theme->set_color("font_disabled_color", "Button", font_disabled_color);
|
|
theme->set_color("icon_hover_color", "Button", icon_hover_color);
|
|
theme->set_color("icon_pressed_color", "Button", icon_pressed_color);
|
|
|
|
// OptionButton
|
|
theme->set_stylebox("focus", "OptionButton", style_widget_focus);
|
|
|
|
theme->set_stylebox("normal", "OptionButton", style_widget);
|
|
theme->set_stylebox("hover", "OptionButton", style_widget_hover);
|
|
theme->set_stylebox("pressed", "OptionButton", style_widget_pressed);
|
|
theme->set_stylebox("disabled", "OptionButton", style_widget_disabled);
|
|
|
|
theme->set_stylebox("normal_mirrored", "OptionButton", style_widget);
|
|
theme->set_stylebox("hover_mirrored", "OptionButton", style_widget_hover);
|
|
theme->set_stylebox("pressed_mirrored", "OptionButton", style_widget_pressed);
|
|
theme->set_stylebox("disabled_mirrored", "OptionButton", style_widget_disabled);
|
|
|
|
theme->set_color("font_color", "OptionButton", font_color);
|
|
theme->set_color("font_hover_color", "OptionButton", font_hover_color);
|
|
theme->set_color("font_pressed_color", "OptionButton", accent_color);
|
|
theme->set_color("font_disabled_color", "OptionButton", font_disabled_color);
|
|
theme->set_color("icon_hover_color", "OptionButton", icon_hover_color);
|
|
theme->set_icon("arrow", "OptionButton", theme->get_icon("GuiOptionArrow", "EditorIcons"));
|
|
theme->set_constant("arrow_margin", "OptionButton", widget_default_margin.x - 2 * EDSCALE);
|
|
theme->set_constant("modulate_arrow", "OptionButton", true);
|
|
theme->set_constant("hseparation", "OptionButton", 4 * EDSCALE);
|
|
|
|
// CheckButton
|
|
theme->set_stylebox("normal", "CheckButton", style_menu);
|
|
theme->set_stylebox("pressed", "CheckButton", style_menu);
|
|
theme->set_stylebox("disabled", "CheckButton", style_menu);
|
|
theme->set_stylebox("hover", "CheckButton", style_menu);
|
|
|
|
theme->set_icon("on", "CheckButton", theme->get_icon("GuiToggleOn", "EditorIcons"));
|
|
theme->set_icon("on_disabled", "CheckButton", theme->get_icon("GuiToggleOnDisabled", "EditorIcons"));
|
|
theme->set_icon("off", "CheckButton", theme->get_icon("GuiToggleOff", "EditorIcons"));
|
|
theme->set_icon("off_disabled", "CheckButton", theme->get_icon("GuiToggleOffDisabled", "EditorIcons"));
|
|
|
|
theme->set_icon("on_mirrored", "CheckButton", theme->get_icon("GuiToggleOnMirrored", "EditorIcons"));
|
|
theme->set_icon("on_disabled_mirrored", "CheckButton", theme->get_icon("GuiToggleOnDisabledMirrored", "EditorIcons"));
|
|
theme->set_icon("off_mirrored", "CheckButton", theme->get_icon("GuiToggleOffMirrored", "EditorIcons"));
|
|
theme->set_icon("off_disabled_mirrored", "CheckButton", theme->get_icon("GuiToggleOffDisabledMirrored", "EditorIcons"));
|
|
|
|
theme->set_color("font_color", "CheckButton", font_color);
|
|
theme->set_color("font_hover_color", "CheckButton", font_hover_color);
|
|
theme->set_color("font_pressed_color", "CheckButton", accent_color);
|
|
theme->set_color("font_disabled_color", "CheckButton", font_disabled_color);
|
|
theme->set_color("icon_hover_color", "CheckButton", icon_hover_color);
|
|
|
|
theme->set_constant("hseparation", "CheckButton", 8 * EDSCALE);
|
|
theme->set_constant("check_vadjust", "CheckButton", 0 * EDSCALE);
|
|
|
|
// Checkbox
|
|
Ref<StyleBoxFlat> sb_checkbox = style_menu->duplicate();
|
|
sb_checkbox->set_default_margin(SIDE_LEFT, default_margin_size * EDSCALE);
|
|
sb_checkbox->set_default_margin(SIDE_RIGHT, default_margin_size * EDSCALE);
|
|
sb_checkbox->set_default_margin(SIDE_TOP, default_margin_size * EDSCALE);
|
|
sb_checkbox->set_default_margin(SIDE_BOTTOM, default_margin_size * EDSCALE);
|
|
|
|
theme->set_stylebox("normal", "CheckBox", sb_checkbox);
|
|
theme->set_stylebox("pressed", "CheckBox", sb_checkbox);
|
|
theme->set_stylebox("disabled", "CheckBox", sb_checkbox);
|
|
theme->set_stylebox("hover", "CheckBox", sb_checkbox);
|
|
theme->set_icon("checked", "CheckBox", theme->get_icon("GuiChecked", "EditorIcons"));
|
|
theme->set_icon("unchecked", "CheckBox", theme->get_icon("GuiUnchecked", "EditorIcons"));
|
|
theme->set_icon("radio_checked", "CheckBox", theme->get_icon("GuiRadioChecked", "EditorIcons"));
|
|
theme->set_icon("radio_unchecked", "CheckBox", theme->get_icon("GuiRadioUnchecked", "EditorIcons"));
|
|
|
|
theme->set_color("font_color", "CheckBox", font_color);
|
|
theme->set_color("font_hover_color", "CheckBox", font_hover_color);
|
|
theme->set_color("font_pressed_color", "CheckBox", accent_color);
|
|
theme->set_color("font_disabled_color", "CheckBox", font_disabled_color);
|
|
theme->set_color("icon_hover_color", "CheckBox", icon_hover_color);
|
|
|
|
theme->set_constant("hseparation", "CheckBox", 8 * EDSCALE);
|
|
theme->set_constant("check_vadjust", "CheckBox", 0 * EDSCALE);
|
|
|
|
// PopupDialog
|
|
theme->set_stylebox("panel", "PopupDialog", style_popup);
|
|
|
|
// PopupMenu
|
|
const int popup_menu_margin_size = default_margin_size * 1.5 * EDSCALE;
|
|
Ref<StyleBoxFlat> style_popup_menu = style_popup->duplicate();
|
|
// Use 1 pixel for the sides, since if 0 is used, the highlight of hovered items is drawn
|
|
// on top of the popup border. This causes a 'gap' in the panel border when an item is highlighted,
|
|
// and it looks weird. 1px solves this.
|
|
style_popup_menu->set_default_margin(SIDE_LEFT, 1 * EDSCALE);
|
|
style_popup_menu->set_default_margin(SIDE_TOP, popup_menu_margin_size);
|
|
style_popup_menu->set_default_margin(SIDE_RIGHT, 1 * EDSCALE);
|
|
style_popup_menu->set_default_margin(SIDE_BOTTOM, popup_menu_margin_size);
|
|
// Always display a border for PopupMenus so they can be distinguished from their background.
|
|
style_popup_menu->set_border_width_all(1 * EDSCALE);
|
|
style_popup_menu->set_border_color(dark_color_2);
|
|
theme->set_stylebox("panel", "PopupMenu", style_popup_menu);
|
|
|
|
Ref<StyleBoxFlat> style_menu_hover = style_widget_hover->duplicate();
|
|
// Don't use rounded corners for hover highlights since the StyleBox touches the PopupMenu's edges.
|
|
style_menu_hover->set_corner_radius_all(0);
|
|
theme->set_stylebox("hover", "PopupMenu", style_menu_hover);
|
|
|
|
theme->set_stylebox("separator", "PopupMenu", style_popup_separator);
|
|
theme->set_stylebox("labeled_separator_left", "PopupMenu", style_popup_labeled_separator_left);
|
|
theme->set_stylebox("labeled_separator_right", "PopupMenu", style_popup_labeled_separator_right);
|
|
|
|
theme->set_color("font_color", "PopupMenu", font_color);
|
|
theme->set_color("font_hover_color", "PopupMenu", font_hover_color);
|
|
theme->set_color("font_accelerator_color", "PopupMenu", font_disabled_color);
|
|
theme->set_color("font_disabled_color", "PopupMenu", font_disabled_color);
|
|
theme->set_color("font_separator_color", "PopupMenu", font_disabled_color);
|
|
theme->set_icon("checked", "PopupMenu", theme->get_icon("GuiChecked", "EditorIcons"));
|
|
theme->set_icon("unchecked", "PopupMenu", theme->get_icon("GuiUnchecked", "EditorIcons"));
|
|
theme->set_icon("radio_checked", "PopupMenu", theme->get_icon("GuiRadioChecked", "EditorIcons"));
|
|
theme->set_icon("radio_unchecked", "PopupMenu", theme->get_icon("GuiRadioUnchecked", "EditorIcons"));
|
|
theme->set_icon("submenu", "PopupMenu", theme->get_icon("ArrowRight", "EditorIcons"));
|
|
theme->set_icon("submenu_mirrored", "PopupMenu", theme->get_icon("ArrowLeft", "EditorIcons"));
|
|
theme->set_icon("visibility_hidden", "PopupMenu", theme->get_icon("GuiVisibilityHidden", "EditorIcons"));
|
|
theme->set_icon("visibility_visible", "PopupMenu", theme->get_icon("GuiVisibilityVisible", "EditorIcons"));
|
|
theme->set_icon("visibility_xray", "PopupMenu", theme->get_icon("GuiVisibilityXray", "EditorIcons"));
|
|
|
|
theme->set_constant("vseparation", "PopupMenu", (extra_spacing + default_margin_size + 1) * EDSCALE);
|
|
theme->set_constant("item_start_padding", "PopupMenu", popup_menu_margin_size * EDSCALE);
|
|
theme->set_constant("item_end_padding", "PopupMenu", popup_menu_margin_size * EDSCALE);
|
|
|
|
for (int i = 0; i < 16; i++) {
|
|
Color si_base_color = accent_color;
|
|
|
|
float hue_rotate = (i * 2 % 16) / 16.0;
|
|
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());
|
|
si_base_color = accent_color.lerp(si_base_color, float(EDITOR_GET("docks/property_editor/subresource_hue_tint")));
|
|
|
|
Ref<StyleBoxFlat> sub_inspector_bg;
|
|
|
|
sub_inspector_bg = make_flat_stylebox(dark_color_1.lerp(si_base_color, 0.08), 2, 0, 2, 2);
|
|
|
|
sub_inspector_bg->set_border_width(SIDE_LEFT, 2);
|
|
sub_inspector_bg->set_border_width(SIDE_RIGHT, 2);
|
|
sub_inspector_bg->set_border_width(SIDE_BOTTOM, 2);
|
|
sub_inspector_bg->set_border_width(SIDE_TOP, 2);
|
|
sub_inspector_bg->set_default_margin(SIDE_LEFT, 3);
|
|
sub_inspector_bg->set_default_margin(SIDE_RIGHT, 3);
|
|
sub_inspector_bg->set_default_margin(SIDE_BOTTOM, 10);
|
|
sub_inspector_bg->set_default_margin(SIDE_TOP, 5);
|
|
sub_inspector_bg->set_border_color(si_base_color * Color(0.7, 0.7, 0.7, 0.8));
|
|
sub_inspector_bg->set_draw_center(true);
|
|
|
|
theme->set_stylebox("sub_inspector_bg" + itos(i), "Editor", sub_inspector_bg);
|
|
|
|
Ref<StyleBoxFlat> bg_color;
|
|
bg_color.instance();
|
|
bg_color->set_bg_color(si_base_color * Color(0.7, 0.7, 0.7, 0.8));
|
|
bg_color->set_border_width_all(0);
|
|
|
|
Ref<StyleBoxFlat> bg_color_selected;
|
|
bg_color_selected.instance();
|
|
bg_color_selected->set_border_width_all(0);
|
|
bg_color_selected->set_bg_color(si_base_color * Color(0.8, 0.8, 0.8, 0.8));
|
|
|
|
theme->set_stylebox("sub_inspector_property_bg" + itos(i), "Editor", bg_color);
|
|
theme->set_stylebox("sub_inspector_property_bg_selected" + itos(i), "Editor", bg_color_selected);
|
|
}
|
|
|
|
theme->set_color("sub_inspector_property_color", "Editor", dark_theme ? Color(1, 1, 1, 1) : Color(0, 0, 0, 1));
|
|
theme->set_constant("sub_inspector_font_offset", "Editor", 4 * EDSCALE);
|
|
|
|
Ref<StyleBoxFlat> style_property_bg = style_default->duplicate();
|
|
style_property_bg->set_bg_color(highlight_color);
|
|
style_property_bg->set_border_width_all(0);
|
|
|
|
theme->set_constant("font_offset", "EditorProperty", 1 * EDSCALE);
|
|
theme->set_stylebox("bg_selected", "EditorProperty", style_property_bg);
|
|
theme->set_stylebox("bg", "EditorProperty", Ref<StyleBoxEmpty>(memnew(StyleBoxEmpty)));
|
|
theme->set_constant("vseparation", "EditorProperty", (extra_spacing + default_margin_size) * EDSCALE);
|
|
theme->set_color("error_color", "EditorProperty", error_color);
|
|
theme->set_color("property_color", "EditorProperty", property_color);
|
|
|
|
theme->set_constant("inspector_margin", "Editor", 8 * EDSCALE);
|
|
|
|
// Tree & ItemList background
|
|
Ref<StyleBoxFlat> style_tree_bg = style_default->duplicate();
|
|
// Make Trees easier to distinguish from other controls by using a darker background color.
|
|
style_tree_bg->set_bg_color(dark_color_1.lerp(dark_color_2, 0.5));
|
|
style_tree_bg->set_border_color(dark_color_3);
|
|
theme->set_stylebox("bg", "Tree", style_tree_bg);
|
|
|
|
const Color guide_color = mono_color * Color(1, 1, 1, 0.05);
|
|
Color relationship_line_color = mono_color * Color(1, 1, 1, relationship_line_opacity);
|
|
// Tree
|
|
theme->set_icon("checked", "Tree", theme->get_icon("GuiChecked", "EditorIcons"));
|
|
theme->set_icon("unchecked", "Tree", theme->get_icon("GuiUnchecked", "EditorIcons"));
|
|
theme->set_icon("arrow", "Tree", theme->get_icon("GuiTreeArrowDown", "EditorIcons"));
|
|
theme->set_icon("arrow_collapsed", "Tree", theme->get_icon("GuiTreeArrowRight", "EditorIcons"));
|
|
theme->set_icon("arrow_collapsed_mirrored", "Tree", theme->get_icon("GuiTreeArrowLeft", "EditorIcons"));
|
|
theme->set_icon("updown", "Tree", theme->get_icon("GuiTreeUpdown", "EditorIcons"));
|
|
theme->set_icon("select_arrow", "Tree", theme->get_icon("GuiDropdown", "EditorIcons"));
|
|
theme->set_stylebox("bg_focus", "Tree", style_widget_focus);
|
|
theme->set_stylebox("custom_button", "Tree", make_empty_stylebox());
|
|
theme->set_stylebox("custom_button_pressed", "Tree", make_empty_stylebox());
|
|
theme->set_stylebox("custom_button_hover", "Tree", style_widget);
|
|
theme->set_color("custom_button_font_highlight", "Tree", font_hover_color);
|
|
theme->set_color("font_color", "Tree", font_color);
|
|
theme->set_color("font_selected_color", "Tree", mono_color);
|
|
theme->set_color("title_button_color", "Tree", font_color);
|
|
theme->set_color("guide_color", "Tree", guide_color);
|
|
theme->set_color("relationship_line_color", "Tree", relationship_line_color);
|
|
theme->set_color("drop_position_color", "Tree", accent_color);
|
|
theme->set_constant("vseparation", "Tree", widget_default_margin.y - EDSCALE);
|
|
theme->set_constant("hseparation", "Tree", 6 * EDSCALE);
|
|
theme->set_constant("guide_width", "Tree", border_width);
|
|
theme->set_constant("item_margin", "Tree", 3 * default_margin_size * EDSCALE);
|
|
theme->set_constant("button_margin", "Tree", default_margin_size * EDSCALE);
|
|
theme->set_constant("draw_relationship_lines", "Tree", relationship_line_opacity >= 0.01);
|
|
theme->set_constant("draw_guides", "Tree", relationship_line_opacity < 0.01);
|
|
theme->set_constant("scroll_border", "Tree", 40 * EDSCALE);
|
|
theme->set_constant("scroll_speed", "Tree", 12);
|
|
|
|
Ref<StyleBoxFlat> style_tree_btn = style_default->duplicate();
|
|
style_tree_btn->set_bg_color(highlight_color);
|
|
style_tree_btn->set_border_width_all(0);
|
|
theme->set_stylebox("button_pressed", "Tree", style_tree_btn);
|
|
|
|
Ref<StyleBoxFlat> style_tree_hover = style_default->duplicate();
|
|
style_tree_hover->set_bg_color(highlight_color * Color(1, 1, 1, 0.4));
|
|
style_tree_hover->set_border_width_all(0);
|
|
theme->set_stylebox("hover", "Tree", style_tree_hover);
|
|
|
|
Ref<StyleBoxFlat> style_tree_focus = style_default->duplicate();
|
|
style_tree_focus->set_bg_color(highlight_color);
|
|
style_tree_focus->set_border_width_all(0);
|
|
theme->set_stylebox("selected_focus", "Tree", style_tree_focus);
|
|
|
|
Ref<StyleBoxFlat> style_tree_selected = style_tree_focus->duplicate();
|
|
theme->set_stylebox("selected", "Tree", style_tree_selected);
|
|
|
|
Ref<StyleBoxFlat> style_tree_cursor = style_default->duplicate();
|
|
style_tree_cursor->set_draw_center(false);
|
|
style_tree_cursor->set_border_width_all(MAX(1, border_width));
|
|
style_tree_cursor->set_border_color(contrast_color_1);
|
|
|
|
Ref<StyleBoxFlat> style_tree_title = style_default->duplicate();
|
|
style_tree_title->set_bg_color(dark_color_3);
|
|
style_tree_title->set_border_width_all(0);
|
|
theme->set_stylebox("cursor", "Tree", style_tree_cursor);
|
|
theme->set_stylebox("cursor_unfocused", "Tree", style_tree_cursor);
|
|
theme->set_stylebox("title_button_normal", "Tree", style_tree_title);
|
|
theme->set_stylebox("title_button_hover", "Tree", style_tree_title);
|
|
theme->set_stylebox("title_button_pressed", "Tree", style_tree_title);
|
|
|
|
Color prop_category_color = dark_color_1.lerp(mono_color, 0.12);
|
|
Color prop_section_color = dark_color_1.lerp(mono_color, 0.09);
|
|
Color prop_subsection_color = dark_color_1.lerp(mono_color, 0.06);
|
|
theme->set_color("prop_category", "Editor", prop_category_color);
|
|
theme->set_color("prop_section", "Editor", prop_section_color);
|
|
theme->set_color("prop_subsection", "Editor", prop_subsection_color);
|
|
theme->set_color("drop_position_color", "Tree", accent_color);
|
|
|
|
// ItemList
|
|
Ref<StyleBoxFlat> style_itemlist_bg = style_default->duplicate();
|
|
style_itemlist_bg->set_bg_color(dark_color_1);
|
|
style_itemlist_bg->set_border_width_all(border_width);
|
|
style_itemlist_bg->set_border_color(dark_color_3);
|
|
|
|
Ref<StyleBoxFlat> style_itemlist_cursor = style_default->duplicate();
|
|
style_itemlist_cursor->set_draw_center(false);
|
|
style_itemlist_cursor->set_border_width_all(border_width);
|
|
style_itemlist_cursor->set_border_color(highlight_color);
|
|
theme->set_stylebox("cursor", "ItemList", style_itemlist_cursor);
|
|
theme->set_stylebox("cursor_unfocused", "ItemList", style_itemlist_cursor);
|
|
theme->set_stylebox("selected_focus", "ItemList", style_tree_focus);
|
|
theme->set_stylebox("selected", "ItemList", style_tree_selected);
|
|
theme->set_stylebox("bg_focus", "ItemList", style_widget_focus);
|
|
theme->set_stylebox("bg", "ItemList", style_itemlist_bg);
|
|
theme->set_color("font_color", "ItemList", font_color);
|
|
theme->set_color("font_selected_color", "ItemList", mono_color);
|
|
theme->set_color("guide_color", "ItemList", guide_color);
|
|
theme->set_constant("vseparation", "ItemList", widget_default_margin.y - EDSCALE);
|
|
theme->set_constant("hseparation", "ItemList", 6 * EDSCALE);
|
|
theme->set_constant("icon_margin", "ItemList", 6 * EDSCALE);
|
|
theme->set_constant("line_separation", "ItemList", 3 * EDSCALE);
|
|
|
|
// Tabs & TabContainer
|
|
theme->set_stylebox("tab_selected", "TabContainer", style_tab_selected);
|
|
theme->set_stylebox("tab_unselected", "TabContainer", style_tab_unselected);
|
|
theme->set_stylebox("tab_disabled", "TabContainer", style_tab_disabled);
|
|
theme->set_stylebox("tab_selected", "Tabs", style_tab_selected);
|
|
theme->set_stylebox("tab_unselected", "Tabs", style_tab_unselected);
|
|
theme->set_stylebox("tab_disabled", "Tabs", style_tab_disabled);
|
|
theme->set_color("font_selected_color", "TabContainer", font_color);
|
|
theme->set_color("font_unselected_color", "TabContainer", font_disabled_color);
|
|
theme->set_color("font_selected_color", "Tabs", font_color);
|
|
theme->set_color("font_unselected_color", "Tabs", font_disabled_color);
|
|
theme->set_icon("menu", "TabContainer", theme->get_icon("GuiTabMenu", "EditorIcons"));
|
|
theme->set_icon("menu_highlight", "TabContainer", theme->get_icon("GuiTabMenuHl", "EditorIcons"));
|
|
theme->set_stylebox("SceneTabFG", "EditorStyles", style_tab_selected);
|
|
theme->set_stylebox("SceneTabBG", "EditorStyles", style_tab_unselected);
|
|
theme->set_icon("close", "Tabs", theme->get_icon("GuiClose", "EditorIcons"));
|
|
theme->set_stylebox("button_pressed", "Tabs", style_menu);
|
|
theme->set_stylebox("button", "Tabs", style_menu);
|
|
theme->set_icon("increment", "TabContainer", theme->get_icon("GuiScrollArrowRight", "EditorIcons"));
|
|
theme->set_icon("decrement", "TabContainer", theme->get_icon("GuiScrollArrowLeft", "EditorIcons"));
|
|
theme->set_icon("increment", "Tabs", theme->get_icon("GuiScrollArrowRight", "EditorIcons"));
|
|
theme->set_icon("decrement", "Tabs", theme->get_icon("GuiScrollArrowLeft", "EditorIcons"));
|
|
theme->set_icon("increment_highlight", "Tabs", theme->get_icon("GuiScrollArrowRightHl", "EditorIcons"));
|
|
theme->set_icon("decrement_highlight", "Tabs", theme->get_icon("GuiScrollArrowLeftHl", "EditorIcons"));
|
|
theme->set_icon("increment_highlight", "TabContainer", theme->get_icon("GuiScrollArrowRightHl", "EditorIcons"));
|
|
theme->set_icon("decrement_highlight", "TabContainer", theme->get_icon("GuiScrollArrowLeftHl", "EditorIcons"));
|
|
theme->set_constant("hseparation", "Tabs", 4 * EDSCALE);
|
|
|
|
// Content of each tab
|
|
Ref<StyleBoxFlat> style_content_panel = style_default->duplicate();
|
|
style_content_panel->set_border_color(dark_color_3);
|
|
style_content_panel->set_border_width_all(border_width);
|
|
// compensate the border
|
|
style_content_panel->set_default_margin(SIDE_TOP, margin_size_extra * EDSCALE);
|
|
style_content_panel->set_default_margin(SIDE_RIGHT, margin_size_extra * EDSCALE);
|
|
style_content_panel->set_default_margin(SIDE_BOTTOM, margin_size_extra * EDSCALE);
|
|
style_content_panel->set_default_margin(SIDE_LEFT, margin_size_extra * EDSCALE);
|
|
// Display border to visually split the body of the container from its possible backgrounds.
|
|
style_content_panel->set_border_width(Side::SIDE_TOP, Math::round(2 * EDSCALE));
|
|
style_content_panel->set_border_color(dark_color_2);
|
|
theme->set_stylebox("panel", "TabContainer", style_content_panel);
|
|
|
|
// this is the stylebox used in 3d and 2d viewports (no borders)
|
|
Ref<StyleBoxFlat> style_content_panel_vp = style_content_panel->duplicate();
|
|
style_content_panel_vp->set_default_margin(SIDE_LEFT, border_width * 2);
|
|
style_content_panel_vp->set_default_margin(SIDE_TOP, default_margin_size * EDSCALE);
|
|
style_content_panel_vp->set_default_margin(SIDE_RIGHT, border_width * 2);
|
|
style_content_panel_vp->set_default_margin(SIDE_BOTTOM, border_width * 2);
|
|
theme->set_stylebox("Content", "EditorStyles", style_content_panel_vp);
|
|
|
|
// These styleboxes can be used on tabs against the base color background (e.g. nested tabs).
|
|
Ref<StyleBoxFlat> style_tab_selected_odd = style_tab_selected->duplicate();
|
|
style_tab_selected_odd->set_bg_color(disabled_bg_color);
|
|
theme->set_stylebox("tab_selected_odd", "TabContainer", style_tab_selected_odd);
|
|
|
|
Ref<StyleBoxFlat> style_content_panel_odd = style_content_panel->duplicate();
|
|
style_content_panel_odd->set_bg_color(disabled_bg_color);
|
|
theme->set_stylebox("panel_odd", "TabContainer", style_content_panel_odd);
|
|
|
|
// Separators
|
|
theme->set_stylebox("separator", "HSeparator", make_line_stylebox(separator_color, MAX(Math::round(EDSCALE), border_width)));
|
|
theme->set_stylebox("separator", "VSeparator", make_line_stylebox(separator_color, MAX(Math::round(EDSCALE), border_width), 0, 0, true));
|
|
|
|
// Debugger
|
|
|
|
Ref<StyleBoxFlat> style_panel_debugger = style_content_panel->duplicate();
|
|
style_panel_debugger->set_border_width(SIDE_BOTTOM, 0);
|
|
theme->set_stylebox("DebuggerPanel", "EditorStyles", style_panel_debugger);
|
|
|
|
Ref<StyleBoxFlat> style_panel_invisible_top = style_content_panel->duplicate();
|
|
int stylebox_offset = theme->get_font("tab_selected", "TabContainer")->get_height(theme->get_font_size("tab_selected", "TabContainer")) + theme->get_stylebox("tab_selected", "TabContainer")->get_minimum_size().height + theme->get_stylebox("panel", "TabContainer")->get_default_margin(SIDE_TOP);
|
|
style_panel_invisible_top->set_expand_margin_size(SIDE_TOP, -stylebox_offset);
|
|
style_panel_invisible_top->set_default_margin(SIDE_TOP, 0);
|
|
theme->set_stylebox("BottomPanelDebuggerOverride", "EditorStyles", style_panel_invisible_top);
|
|
|
|
// LineEdit
|
|
|
|
Ref<StyleBoxFlat> style_line_edit = style_widget->duplicate();
|
|
// Add a bottom line to make LineEdits more visible, especially in sectioned inspectors
|
|
// such as the Project Settings.
|
|
style_line_edit->set_border_width(SIDE_BOTTOM, Math::round(2 * EDSCALE));
|
|
style_line_edit->set_border_color(dark_color_2);
|
|
// Don't round the bottom corner to make the line look sharper.
|
|
style_tab_selected->set_corner_radius(CORNER_BOTTOM_LEFT, 0);
|
|
style_tab_selected->set_corner_radius(CORNER_BOTTOM_RIGHT, 0);
|
|
|
|
Ref<StyleBoxFlat> style_line_edit_disabled = style_line_edit->duplicate();
|
|
style_line_edit_disabled->set_border_color(disabled_color);
|
|
style_line_edit_disabled->set_bg_color(disabled_bg_color);
|
|
|
|
theme->set_stylebox("normal", "LineEdit", style_line_edit);
|
|
theme->set_stylebox("focus", "LineEdit", style_widget_focus);
|
|
theme->set_stylebox("read_only", "LineEdit", style_line_edit_disabled);
|
|
theme->set_icon("clear", "LineEdit", theme->get_icon("GuiClose", "EditorIcons"));
|
|
theme->set_color("read_only", "LineEdit", font_disabled_color);
|
|
theme->set_color("font_color", "LineEdit", font_color);
|
|
theme->set_color("font_selected_color", "LineEdit", mono_color);
|
|
theme->set_color("caret_color", "LineEdit", font_color);
|
|
theme->set_color("selection_color", "LineEdit", selection_color);
|
|
theme->set_color("clear_button_color", "LineEdit", font_color);
|
|
theme->set_color("clear_button_color_pressed", "LineEdit", accent_color);
|
|
|
|
// TextEdit
|
|
theme->set_stylebox("normal", "TextEdit", style_line_edit);
|
|
theme->set_stylebox("focus", "TextEdit", style_widget_focus);
|
|
theme->set_stylebox("read_only", "TextEdit", style_line_edit_disabled);
|
|
theme->set_constant("side_margin", "TabContainer", 0);
|
|
theme->set_icon("tab", "TextEdit", theme->get_icon("GuiTab", "EditorIcons"));
|
|
theme->set_icon("space", "TextEdit", theme->get_icon("GuiSpace", "EditorIcons"));
|
|
theme->set_color("font_color", "TextEdit", font_color);
|
|
theme->set_color("caret_color", "TextEdit", font_color);
|
|
theme->set_color("selection_color", "TextEdit", selection_color);
|
|
|
|
// CodeEdit
|
|
theme->set_stylebox("normal", "CodeEdit", style_widget);
|
|
theme->set_stylebox("focus", "CodeEdit", style_widget_hover);
|
|
theme->set_stylebox("read_only", "CodeEdit", style_widget_disabled);
|
|
theme->set_constant("side_margin", "TabContainer", 0);
|
|
theme->set_icon("tab", "CodeEdit", theme->get_icon("GuiTab", "EditorIcons"));
|
|
theme->set_icon("space", "CodeEdit", theme->get_icon("GuiSpace", "EditorIcons"));
|
|
theme->set_icon("folded", "CodeEdit", theme->get_icon("GuiTreeArrowRight", "EditorIcons"));
|
|
theme->set_icon("can_fold", "CodeEdit", theme->get_icon("GuiTreeArrowDown", "EditorIcons"));
|
|
theme->set_icon("executing_line", "CodeEdit", theme->get_icon("MainPlay", "EditorIcons"));
|
|
theme->set_color("font_color", "CodeEdit", font_color);
|
|
theme->set_color("caret_color", "CodeEdit", font_color);
|
|
theme->set_color("selection_color", "CodeEdit", selection_color);
|
|
|
|
// H/VSplitContainer
|
|
theme->set_stylebox("bg", "VSplitContainer", make_stylebox(theme->get_icon("GuiVsplitBg", "EditorIcons"), 1, 1, 1, 1));
|
|
theme->set_stylebox("bg", "HSplitContainer", make_stylebox(theme->get_icon("GuiHsplitBg", "EditorIcons"), 1, 1, 1, 1));
|
|
|
|
theme->set_icon("grabber", "VSplitContainer", theme->get_icon("GuiVsplitter", "EditorIcons"));
|
|
theme->set_icon("grabber", "HSplitContainer", theme->get_icon("GuiHsplitter", "EditorIcons"));
|
|
|
|
theme->set_constant("separation", "HSplitContainer", default_margin_size * 2 * EDSCALE);
|
|
theme->set_constant("separation", "VSplitContainer", default_margin_size * 2 * EDSCALE);
|
|
|
|
// Containers
|
|
theme->set_constant("separation", "BoxContainer", default_margin_size * EDSCALE);
|
|
theme->set_constant("separation", "HBoxContainer", default_margin_size * EDSCALE);
|
|
theme->set_constant("separation", "VBoxContainer", default_margin_size * EDSCALE);
|
|
theme->set_constant("margin_left", "MarginContainer", 0);
|
|
theme->set_constant("margin_top", "MarginContainer", 0);
|
|
theme->set_constant("margin_right", "MarginContainer", 0);
|
|
theme->set_constant("margin_bottom", "MarginContainer", 0);
|
|
theme->set_constant("hseparation", "GridContainer", default_margin_size * EDSCALE);
|
|
theme->set_constant("vseparation", "GridContainer", default_margin_size * EDSCALE);
|
|
|
|
// Window
|
|
|
|
// Prevent corner artifacts between window title and body.
|
|
Ref<StyleBoxFlat> style_window_title = style_default->duplicate();
|
|
style_window_title->set_corner_radius(CORNER_TOP_LEFT, 0);
|
|
style_window_title->set_corner_radius(CORNER_TOP_RIGHT, 0);
|
|
// Prevent visible line between window title and body.
|
|
style_window_title->set_expand_margin_size(SIDE_BOTTOM, 2 * EDSCALE);
|
|
theme->set_stylebox("panel", "Window", style_window_title);
|
|
|
|
Ref<StyleBoxFlat> style_window = style_popup->duplicate();
|
|
style_window->set_border_color(base_color);
|
|
style_window->set_border_width(SIDE_TOP, 24 * EDSCALE);
|
|
style_window->set_expand_margin_size(SIDE_TOP, 24 * EDSCALE);
|
|
theme->set_stylebox("panel_window", "Window", style_window);
|
|
|
|
theme->set_color("title_color", "Window", font_color);
|
|
theme->set_icon("close", "Window", theme->get_icon("GuiClose", "EditorIcons"));
|
|
theme->set_icon("close_highlight", "Window", theme->get_icon("GuiClose", "EditorIcons"));
|
|
theme->set_constant("close_h_ofs", "Window", 22 * EDSCALE);
|
|
theme->set_constant("close_v_ofs", "Window", 20 * EDSCALE);
|
|
theme->set_constant("title_height", "Window", 24 * EDSCALE);
|
|
theme->set_constant("resize_margin", "Window", 4 * EDSCALE);
|
|
theme->set_font("title_font", "Window", theme->get_font("title", "EditorFonts"));
|
|
theme->set_font_size("title_font_size", "Window", theme->get_font_size("title_size", "EditorFonts"));
|
|
|
|
// Complex window (currently only Editor Settings and Project Settings)
|
|
Ref<StyleBoxFlat> style_complex_window = style_window->duplicate();
|
|
style_complex_window->set_bg_color(dark_color_2);
|
|
style_complex_window->set_border_color(dark_color_2);
|
|
theme->set_stylebox("panel", "EditorSettingsDialog", style_complex_window);
|
|
theme->set_stylebox("panel", "ProjectSettingsEditor", style_complex_window);
|
|
theme->set_stylebox("panel", "EditorAbout", style_complex_window);
|
|
|
|
// HScrollBar
|
|
Ref<Texture2D> empty_icon = memnew(ImageTexture);
|
|
|
|
theme->set_stylebox("scroll", "HScrollBar", make_stylebox(theme->get_icon("GuiScrollBg", "EditorIcons"), 5, 5, 5, 5, 0, 0, 0, 0));
|
|
theme->set_stylebox("scroll_focus", "HScrollBar", make_stylebox(theme->get_icon("GuiScrollBg", "EditorIcons"), 5, 5, 5, 5, 0, 0, 0, 0));
|
|
theme->set_stylebox("grabber", "HScrollBar", make_stylebox(theme->get_icon("GuiScrollGrabber", "EditorIcons"), 6, 6, 6, 6, 2, 2, 2, 2));
|
|
theme->set_stylebox("grabber_highlight", "HScrollBar", make_stylebox(theme->get_icon("GuiScrollGrabberHl", "EditorIcons"), 5, 5, 5, 5, 2, 2, 2, 2));
|
|
theme->set_stylebox("grabber_pressed", "HScrollBar", make_stylebox(theme->get_icon("GuiScrollGrabberPressed", "EditorIcons"), 6, 6, 6, 6, 2, 2, 2, 2));
|
|
|
|
theme->set_icon("increment", "HScrollBar", empty_icon);
|
|
theme->set_icon("increment_highlight", "HScrollBar", empty_icon);
|
|
theme->set_icon("decrement", "HScrollBar", empty_icon);
|
|
theme->set_icon("decrement_highlight", "HScrollBar", empty_icon);
|
|
|
|
// VScrollBar
|
|
theme->set_stylebox("scroll", "VScrollBar", make_stylebox(theme->get_icon("GuiScrollBg", "EditorIcons"), 5, 5, 5, 5, 0, 0, 0, 0));
|
|
theme->set_stylebox("scroll_focus", "VScrollBar", make_stylebox(theme->get_icon("GuiScrollBg", "EditorIcons"), 5, 5, 5, 5, 0, 0, 0, 0));
|
|
theme->set_stylebox("grabber", "VScrollBar", make_stylebox(theme->get_icon("GuiScrollGrabber", "EditorIcons"), 6, 6, 6, 6, 2, 2, 2, 2));
|
|
theme->set_stylebox("grabber_highlight", "VScrollBar", make_stylebox(theme->get_icon("GuiScrollGrabberHl", "EditorIcons"), 5, 5, 5, 5, 2, 2, 2, 2));
|
|
theme->set_stylebox("grabber_pressed", "VScrollBar", make_stylebox(theme->get_icon("GuiScrollGrabberPressed", "EditorIcons"), 6, 6, 6, 6, 2, 2, 2, 2));
|
|
|
|
theme->set_icon("increment", "VScrollBar", empty_icon);
|
|
theme->set_icon("increment_highlight", "VScrollBar", empty_icon);
|
|
theme->set_icon("decrement", "VScrollBar", empty_icon);
|
|
theme->set_icon("decrement_highlight", "VScrollBar", empty_icon);
|
|
|
|
// HSlider
|
|
theme->set_icon("grabber_highlight", "HSlider", theme->get_icon("GuiSliderGrabberHl", "EditorIcons"));
|
|
theme->set_icon("grabber", "HSlider", theme->get_icon("GuiSliderGrabber", "EditorIcons"));
|
|
theme->set_stylebox("slider", "HSlider", make_flat_stylebox(dark_color_3, 0, default_margin_size / 2, 0, default_margin_size / 2, corner_width));
|
|
theme->set_stylebox("grabber_area", "HSlider", make_flat_stylebox(contrast_color_1, 0, default_margin_size / 2, 0, default_margin_size / 2, corner_width));
|
|
theme->set_stylebox("grabber_area_highlight", "HSlider", make_flat_stylebox(contrast_color_1, 0, default_margin_size / 2, 0, default_margin_size / 2));
|
|
|
|
// VSlider
|
|
theme->set_icon("grabber", "VSlider", theme->get_icon("GuiSliderGrabber", "EditorIcons"));
|
|
theme->set_icon("grabber_highlight", "VSlider", theme->get_icon("GuiSliderGrabberHl", "EditorIcons"));
|
|
theme->set_stylebox("slider", "VSlider", make_flat_stylebox(dark_color_3, default_margin_size / 2, 0, default_margin_size / 2, 0, corner_width));
|
|
theme->set_stylebox("grabber_area", "VSlider", make_flat_stylebox(contrast_color_1, default_margin_size / 2, 0, default_margin_size / 2, 0, corner_width));
|
|
theme->set_stylebox("grabber_area_highlight", "VSlider", make_flat_stylebox(contrast_color_1, default_margin_size / 2, 0, default_margin_size / 2, 0));
|
|
|
|
// RichTextLabel
|
|
theme->set_color("default_color", "RichTextLabel", font_color);
|
|
theme->set_color("font_shadow_color", "RichTextLabel", Color(0, 0, 0, 0));
|
|
theme->set_constant("shadow_offset_x", "RichTextLabel", 1 * EDSCALE);
|
|
theme->set_constant("shadow_offset_y", "RichTextLabel", 1 * EDSCALE);
|
|
theme->set_constant("shadow_as_outline", "RichTextLabel", 0 * EDSCALE);
|
|
theme->set_stylebox("focus", "RichTextLabel", make_empty_stylebox());
|
|
theme->set_stylebox("normal", "RichTextLabel", style_tree_bg);
|
|
|
|
theme->set_color("headline_color", "EditorHelp", mono_color);
|
|
|
|
// Panel
|
|
theme->set_stylebox("panel", "Panel", make_flat_stylebox(dark_color_1, 6, 4, 6, 4, corner_width));
|
|
theme->set_stylebox("panel_fg", "Panel", style_default);
|
|
|
|
// Label
|
|
theme->set_stylebox("normal", "Label", style_empty);
|
|
theme->set_color("font_color", "Label", font_color);
|
|
theme->set_color("font_shadow_color", "Label", Color(0, 0, 0, 0));
|
|
theme->set_constant("shadow_offset_x", "Label", 1 * EDSCALE);
|
|
theme->set_constant("shadow_offset_y", "Label", 1 * EDSCALE);
|
|
theme->set_constant("shadow_as_outline", "Label", 0 * EDSCALE);
|
|
theme->set_constant("line_spacing", "Label", 3 * EDSCALE);
|
|
|
|
// LinkButton
|
|
theme->set_stylebox("focus", "LinkButton", style_empty);
|
|
theme->set_color("font_color", "LinkButton", font_color);
|
|
theme->set_color("font_hover_color", "LinkButton", font_hover_color);
|
|
theme->set_color("font_pressed_color", "LinkButton", accent_color);
|
|
theme->set_color("font_disabled_color", "LinkButton", font_disabled_color);
|
|
|
|
// TooltipPanel
|
|
Ref<StyleBoxFlat> style_tooltip = style_popup->duplicate();
|
|
style_tooltip->set_shadow_size(0);
|
|
style_tooltip->set_default_margin(SIDE_LEFT, default_margin_size * EDSCALE);
|
|
style_tooltip->set_default_margin(SIDE_TOP, default_margin_size * EDSCALE * 0.5);
|
|
style_tooltip->set_default_margin(SIDE_RIGHT, default_margin_size * EDSCALE);
|
|
style_tooltip->set_default_margin(SIDE_BOTTOM, default_margin_size * EDSCALE * 0.5);
|
|
style_tooltip->set_bg_color(mono_color.inverted() * Color(1, 1, 1, 0.8));
|
|
style_tooltip->set_border_width_all(0);
|
|
theme->set_color("font_color", "TooltipLabel", font_hover_color);
|
|
theme->set_color("font_color_shadow", "TooltipLabel", Color(0, 0, 0, 0));
|
|
theme->set_stylebox("panel", "TooltipPanel", style_tooltip);
|
|
|
|
// PopupPanel
|
|
theme->set_stylebox("panel", "PopupPanel", style_popup);
|
|
|
|
// SpinBox
|
|
theme->set_icon("updown", "SpinBox", theme->get_icon("GuiSpinboxUpdown", "EditorIcons"));
|
|
|
|
// ProgressBar
|
|
theme->set_stylebox("bg", "ProgressBar", make_stylebox(theme->get_icon("GuiProgressBar", "EditorIcons"), 4, 4, 4, 4, 0, 0, 0, 0));
|
|
theme->set_stylebox("fg", "ProgressBar", make_stylebox(theme->get_icon("GuiProgressFill", "EditorIcons"), 6, 6, 6, 6, 2, 1, 2, 1));
|
|
theme->set_color("font_color", "ProgressBar", font_color);
|
|
|
|
// GraphEdit
|
|
theme->set_stylebox("bg", "GraphEdit", style_tree_bg);
|
|
if (dark_theme) {
|
|
theme->set_color("grid_major", "GraphEdit", Color(1.0, 1.0, 1.0, 0.15));
|
|
theme->set_color("grid_minor", "GraphEdit", Color(1.0, 1.0, 1.0, 0.07));
|
|
} else {
|
|
theme->set_color("grid_major", "GraphEdit", Color(0.0, 0.0, 0.0, 0.15));
|
|
theme->set_color("grid_minor", "GraphEdit", Color(0.0, 0.0, 0.0, 0.07));
|
|
}
|
|
theme->set_color("selection_fill", "GraphEdit", theme->get_color("box_selection_fill_color", "Editor"));
|
|
theme->set_color("selection_stroke", "GraphEdit", theme->get_color("box_selection_stroke_color", "Editor"));
|
|
theme->set_color("activity", "GraphEdit", accent_color);
|
|
theme->set_icon("minus", "GraphEdit", theme->get_icon("ZoomLess", "EditorIcons"));
|
|
theme->set_icon("more", "GraphEdit", theme->get_icon("ZoomMore", "EditorIcons"));
|
|
theme->set_icon("reset", "GraphEdit", theme->get_icon("ZoomReset", "EditorIcons"));
|
|
theme->set_icon("snap", "GraphEdit", theme->get_icon("SnapGrid", "EditorIcons"));
|
|
theme->set_icon("minimap", "GraphEdit", theme->get_icon("GridMinimap", "EditorIcons"));
|
|
theme->set_constant("bezier_len_pos", "GraphEdit", 80 * EDSCALE);
|
|
theme->set_constant("bezier_len_neg", "GraphEdit", 160 * EDSCALE);
|
|
|
|
// GraphEditMinimap
|
|
Ref<StyleBoxFlat> style_minimap_bg = make_flat_stylebox(dark_color_1, 0, 0, 0, 0);
|
|
style_minimap_bg->set_border_color(dark_color_3);
|
|
style_minimap_bg->set_border_width_all(1);
|
|
theme->set_stylebox("bg", "GraphEditMinimap", style_minimap_bg);
|
|
|
|
Ref<StyleBoxFlat> style_minimap_camera;
|
|
Ref<StyleBoxFlat> style_minimap_node;
|
|
if (dark_theme) {
|
|
style_minimap_camera = make_flat_stylebox(Color(0.65, 0.65, 0.65, 0.2), 0, 0, 0, 0);
|
|
style_minimap_camera->set_border_color(Color(0.65, 0.65, 0.65, 0.45));
|
|
style_minimap_node = make_flat_stylebox(Color(1, 1, 1), 0, 0, 0, 0);
|
|
} else {
|
|
style_minimap_camera = make_flat_stylebox(Color(0.38, 0.38, 0.38, 0.2), 0, 0, 0, 0);
|
|
style_minimap_camera->set_border_color(Color(0.38, 0.38, 0.38, 0.45));
|
|
style_minimap_node = make_flat_stylebox(Color(0, 0, 0), 0, 0, 0, 0);
|
|
}
|
|
style_minimap_camera->set_border_width_all(1);
|
|
style_minimap_node->set_corner_radius_all(1);
|
|
theme->set_stylebox("camera", "GraphEditMinimap", style_minimap_camera);
|
|
theme->set_stylebox("node", "GraphEditMinimap", style_minimap_node);
|
|
|
|
Ref<Texture2D> minimap_resizer_icon = theme->get_icon("GuiResizer", "EditorIcons");
|
|
Color minimap_resizer_color;
|
|
if (dark_theme) {
|
|
minimap_resizer_color = Color(1, 1, 1, 0.65);
|
|
} else {
|
|
minimap_resizer_color = Color(0, 0, 0, 0.65);
|
|
}
|
|
theme->set_icon("resizer", "GraphEditMinimap", flip_icon(minimap_resizer_icon, true, true));
|
|
theme->set_color("resizer_color", "GraphEditMinimap", minimap_resizer_color);
|
|
|
|
// GraphNode
|
|
const int gn_margin_side = 28;
|
|
|
|
Ref<StyleBoxFlat> graphsb = make_flat_stylebox(dark_color_3 * Color(1, 1, 1, 0.7), gn_margin_side, 24, gn_margin_side, 5, corner_width);
|
|
graphsb->set_border_width_all(border_width);
|
|
graphsb->set_border_color(dark_color_3);
|
|
Ref<StyleBoxFlat> graphsbselected = make_flat_stylebox(dark_color_3 * Color(1, 1, 1, 0.9), gn_margin_side, 24, gn_margin_side, 5, corner_width);
|
|
graphsbselected->set_border_width_all(2 * EDSCALE + border_width);
|
|
graphsbselected->set_border_color(Color(accent_color.r, accent_color.g, accent_color.b, 0.9));
|
|
Ref<StyleBoxFlat> graphsbcomment = make_flat_stylebox(dark_color_3 * Color(1, 1, 1, 0.3), gn_margin_side, 24, gn_margin_side, 5, corner_width);
|
|
graphsbcomment->set_border_width_all(border_width);
|
|
graphsbcomment->set_border_color(dark_color_3);
|
|
Ref<StyleBoxFlat> graphsbcommentselected = make_flat_stylebox(dark_color_3 * Color(1, 1, 1, 0.4), gn_margin_side, 24, gn_margin_side, 5, corner_width);
|
|
graphsbcommentselected->set_border_width_all(border_width);
|
|
graphsbcommentselected->set_border_color(dark_color_3);
|
|
Ref<StyleBoxFlat> graphsbbreakpoint = graphsbselected->duplicate();
|
|
graphsbbreakpoint->set_draw_center(false);
|
|
graphsbbreakpoint->set_border_color(warning_color);
|
|
graphsbbreakpoint->set_shadow_color(warning_color * Color(1.0, 1.0, 1.0, 0.1));
|
|
Ref<StyleBoxFlat> graphsbposition = graphsbselected->duplicate();
|
|
graphsbposition->set_draw_center(false);
|
|
graphsbposition->set_border_color(error_color);
|
|
graphsbposition->set_shadow_color(error_color * Color(1.0, 1.0, 1.0, 0.2));
|
|
Ref<StyleBoxFlat> smgraphsb = make_flat_stylebox(dark_color_3 * Color(1, 1, 1, 0.7), gn_margin_side, 24, gn_margin_side, 5, corner_width);
|
|
smgraphsb->set_border_width_all(border_width);
|
|
smgraphsb->set_border_color(dark_color_3);
|
|
Ref<StyleBoxFlat> smgraphsbselected = make_flat_stylebox(dark_color_3 * Color(1, 1, 1, 0.9), gn_margin_side, 24, gn_margin_side, 5, corner_width);
|
|
smgraphsbselected->set_border_width_all(2 * EDSCALE + border_width);
|
|
smgraphsbselected->set_border_color(Color(accent_color.r, accent_color.g, accent_color.b, 0.9));
|
|
smgraphsbselected->set_shadow_size(8 * EDSCALE);
|
|
smgraphsbselected->set_shadow_color(shadow_color);
|
|
|
|
graphsb->set_border_width(SIDE_TOP, 24 * EDSCALE);
|
|
graphsbselected->set_border_width(SIDE_TOP, 24 * EDSCALE);
|
|
graphsbcomment->set_border_width(SIDE_TOP, 24 * EDSCALE);
|
|
graphsbcommentselected->set_border_width(SIDE_TOP, 24 * EDSCALE);
|
|
|
|
theme->set_stylebox("frame", "GraphNode", graphsb);
|
|
theme->set_stylebox("selectedframe", "GraphNode", graphsbselected);
|
|
theme->set_stylebox("comment", "GraphNode", graphsbcomment);
|
|
theme->set_stylebox("commentfocus", "GraphNode", graphsbcommentselected);
|
|
theme->set_stylebox("breakpoint", "GraphNode", graphsbbreakpoint);
|
|
theme->set_stylebox("position", "GraphNode", graphsbposition);
|
|
theme->set_stylebox("state_machine_frame", "GraphNode", smgraphsb);
|
|
theme->set_stylebox("state_machine_selectedframe", "GraphNode", smgraphsbselected);
|
|
|
|
Color default_node_color = dark_color_1.inverted();
|
|
theme->set_color("title_color", "GraphNode", default_node_color);
|
|
default_node_color.a = 0.7;
|
|
theme->set_color("close_color", "GraphNode", default_node_color);
|
|
theme->set_color("resizer_color", "GraphNode", default_node_color);
|
|
|
|
theme->set_constant("port_offset", "GraphNode", 14 * EDSCALE);
|
|
theme->set_constant("title_h_offset", "GraphNode", -16 * EDSCALE);
|
|
theme->set_constant("title_offset", "GraphNode", 20 * EDSCALE);
|
|
theme->set_constant("close_h_offset", "GraphNode", 20 * EDSCALE);
|
|
theme->set_constant("close_offset", "GraphNode", 20 * EDSCALE);
|
|
theme->set_constant("separation", "GraphNode", 1 * EDSCALE);
|
|
|
|
theme->set_icon("close", "GraphNode", theme->get_icon("GuiCloseCustomizable", "EditorIcons"));
|
|
theme->set_icon("resizer", "GraphNode", theme->get_icon("GuiResizer", "EditorIcons"));
|
|
theme->set_icon("port", "GraphNode", theme->get_icon("GuiGraphNodePort", "EditorIcons"));
|
|
|
|
// GridContainer
|
|
theme->set_constant("vseparation", "GridContainer", Math::round(widget_default_margin.y - 2 * EDSCALE));
|
|
|
|
// FileDialog
|
|
theme->set_icon("folder", "FileDialog", theme->get_icon("Folder", "EditorIcons"));
|
|
theme->set_icon("parent_folder", "FileDialog", theme->get_icon("ArrowUp", "EditorIcons"));
|
|
theme->set_icon("back_folder", "FileDialog", theme->get_icon("Back", "EditorIcons"));
|
|
theme->set_icon("forward_folder", "FileDialog", theme->get_icon("Forward", "EditorIcons"));
|
|
theme->set_icon("reload", "FileDialog", theme->get_icon("Reload", "EditorIcons"));
|
|
theme->set_icon("toggle_hidden", "FileDialog", theme->get_icon("GuiVisibilityVisible", "EditorIcons"));
|
|
// Use a different color for folder icons to make them easier to distinguish from files.
|
|
// On a light theme, the icon will be dark, so we need to lighten it before blending it with the accent color.
|
|
theme->set_color("folder_icon_modulate", "FileDialog", (dark_theme ? Color(1, 1, 1) : Color(4.25, 4.25, 4.25)).lerp(accent_color, 0.7));
|
|
theme->set_color("files_disabled", "FileDialog", font_disabled_color);
|
|
|
|
// color picker
|
|
theme->set_constant("margin", "ColorPicker", popup_margin_size);
|
|
theme->set_constant("sv_width", "ColorPicker", 256 * EDSCALE);
|
|
theme->set_constant("sv_height", "ColorPicker", 256 * EDSCALE);
|
|
theme->set_constant("h_width", "ColorPicker", 30 * EDSCALE);
|
|
theme->set_constant("label_width", "ColorPicker", 10 * EDSCALE);
|
|
theme->set_icon("screen_picker", "ColorPicker", theme->get_icon("ColorPick", "EditorIcons"));
|
|
theme->set_icon("add_preset", "ColorPicker", theme->get_icon("Add", "EditorIcons"));
|
|
theme->set_icon("preset_bg", "ColorPicker", theme->get_icon("GuiMiniCheckerboard", "EditorIcons"));
|
|
theme->set_icon("overbright_indicator", "ColorPicker", theme->get_icon("OverbrightIndicator", "EditorIcons"));
|
|
theme->set_icon("bar_arrow", "ColorPicker", theme->get_icon("ColorPickerBarArrow", "EditorIcons"));
|
|
theme->set_icon("picker_cursor", "ColorPicker", theme->get_icon("PickerCursor", "EditorIcons"));
|
|
|
|
theme->set_icon("bg", "ColorPickerButton", theme->get_icon("GuiMiniCheckerboard", "EditorIcons"));
|
|
|
|
// Information on 3D viewport
|
|
Ref<StyleBoxFlat> style_info_3d_viewport = style_default->duplicate();
|
|
style_info_3d_viewport->set_bg_color(style_info_3d_viewport->get_bg_color() * Color(1, 1, 1, 0.5));
|
|
style_info_3d_viewport->set_border_width_all(0);
|
|
theme->set_stylebox("Information3dViewport", "EditorStyles", style_info_3d_viewport);
|
|
|
|
// adaptive script theme constants
|
|
// for comments and elements with lower relevance
|
|
const Color dim_color = Color(font_color.r, font_color.g, font_color.b, 0.5);
|
|
|
|
const float mono_value = mono_color.r;
|
|
const Color alpha1 = Color(mono_value, mono_value, mono_value, 0.07);
|
|
const Color alpha2 = Color(mono_value, mono_value, mono_value, 0.14);
|
|
const Color alpha3 = Color(mono_value, mono_value, mono_value, 0.7);
|
|
|
|
// editor main color
|
|
const Color main_color = dark_theme ? Color(0.34, 0.7, 1.0) : Color(0.02, 0.5, 1.0);
|
|
|
|
const Color symbol_color = Color(0.34, 0.57, 1.0).lerp(mono_color, dark_theme ? 0.5 : 0.3);
|
|
const Color keyword_color = Color(1.0, 0.44, 0.52);
|
|
const Color control_flow_keyword_color = dark_theme ? Color(1.0, 0.55, 0.8) : Color(0.8, 0.4, 0.6);
|
|
const Color basetype_color = dark_theme ? Color(0.26, 1.0, 0.76) : Color(0.0, 0.76, 0.38);
|
|
const Color type_color = basetype_color.lerp(mono_color, dark_theme ? 0.4 : 0.3);
|
|
const Color usertype_color = basetype_color.lerp(mono_color, dark_theme ? 0.7 : 0.5);
|
|
const Color comment_color = dim_color;
|
|
const Color string_color = (dark_theme ? Color(1.0, 0.85, 0.26) : Color(1.0, 0.82, 0.09)).lerp(mono_color, dark_theme ? 0.5 : 0.3);
|
|
|
|
const Color te_background_color = dark_theme ? background_color : base_color;
|
|
const Color completion_background_color = dark_theme ? base_color : background_color;
|
|
const Color completion_selected_color = alpha1;
|
|
const Color completion_existing_color = alpha2;
|
|
const Color completion_scroll_color = alpha1;
|
|
const Color completion_font_color = font_color;
|
|
const Color text_color = font_color;
|
|
const Color line_number_color = dim_color;
|
|
const Color safe_line_number_color = dim_color * Color(1, 1.2, 1, 1.5);
|
|
const Color caret_color = mono_color;
|
|
const Color caret_background_color = mono_color.inverted();
|
|
const Color text_selected_color = dark_color_3;
|
|
const Color brace_mismatch_color = error_color;
|
|
const Color current_line_color = alpha1;
|
|
const Color line_length_guideline_color = dark_theme ? base_color : background_color;
|
|
const Color word_highlighted_color = alpha1;
|
|
const Color number_color = basetype_color.lerp(mono_color, dark_theme ? 0.5 : 0.3);
|
|
const Color function_color = main_color;
|
|
const Color member_variable_color = main_color.lerp(mono_color, 0.6);
|
|
const Color mark_color = Color(error_color.r, error_color.g, error_color.b, 0.3);
|
|
const Color bookmark_color = Color(0.08, 0.49, 0.98);
|
|
const Color breakpoint_color = error_color;
|
|
const Color executing_line_color = Color(0.98, 0.89, 0.27);
|
|
const Color code_folding_color = alpha3;
|
|
const Color search_result_color = alpha1;
|
|
const Color search_result_border_color = Color(0.41, 0.61, 0.91, 0.38);
|
|
|
|
EditorSettings *setting = EditorSettings::get_singleton();
|
|
String text_editor_color_theme = setting->get("text_editor/theme/color_theme");
|
|
if (text_editor_color_theme == "Adaptive") {
|
|
setting->set_initial_value("text_editor/highlighting/symbol_color", symbol_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/keyword_color", keyword_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/control_flow_keyword_color", control_flow_keyword_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/base_type_color", basetype_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/engine_type_color", type_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/user_type_color", usertype_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/comment_color", comment_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/string_color", string_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/background_color", te_background_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/completion_background_color", completion_background_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/completion_selected_color", completion_selected_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/completion_existing_color", completion_existing_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/completion_scroll_color", completion_scroll_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/completion_font_color", completion_font_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/text_color", text_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/line_number_color", line_number_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/safe_line_number_color", safe_line_number_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/caret_color", caret_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/caret_background_color", caret_background_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/text_selected_color", text_selected_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/selection_color", selection_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/brace_mismatch_color", brace_mismatch_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/current_line_color", current_line_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/line_length_guideline_color", line_length_guideline_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/word_highlighted_color", word_highlighted_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/number_color", number_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/function_color", function_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/member_variable_color", member_variable_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/mark_color", mark_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/bookmark_color", bookmark_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/breakpoint_color", breakpoint_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/executing_line_color", executing_line_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/code_folding_color", code_folding_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/search_result_color", search_result_color, true);
|
|
setting->set_initial_value("text_editor/highlighting/search_result_border_color", search_result_border_color, true);
|
|
} else if (text_editor_color_theme == "Default") {
|
|
setting->load_text_editor_theme();
|
|
}
|
|
|
|
return theme;
|
|
}
|
|
|
|
Ref<Theme> create_custom_theme(const Ref<Theme> p_theme) {
|
|
Ref<Theme> theme;
|
|
|
|
const String custom_theme = EditorSettings::get_singleton()->get("interface/theme/custom_theme");
|
|
if (custom_theme != "") {
|
|
theme = ResourceLoader::load(custom_theme);
|
|
}
|
|
|
|
if (!theme.is_valid()) {
|
|
theme = create_editor_theme(p_theme);
|
|
}
|
|
|
|
return theme;
|
|
}
|
|
|
|
Ref<ImageTexture> create_unscaled_default_project_icon() {
|
|
#ifdef MODULE_SVG_ENABLED
|
|
for (int i = 0; i < editor_icons_count; i++) {
|
|
// ESCALE should never affect size of the icon
|
|
if (strcmp(editor_icons_names[i], "DefaultProjectIcon") == 0) {
|
|
return editor_generate_icon(i, false, 1.0);
|
|
}
|
|
}
|
|
#endif
|
|
return Ref<ImageTexture>(memnew(ImageTexture));
|
|
}
|