|  | @@ -582,7 +582,22 @@ Ref<Theme> create_editor_theme(const Ref<Theme> p_theme) {
 | 
											
												
													
														|  |  	theme->set_color("font_color_disabled", "CheckButton", font_color_disabled);
 |  |  	theme->set_color("font_color_disabled", "CheckButton", font_color_disabled);
 | 
											
												
													
														|  |  	theme->set_color("icon_color_hover", "CheckButton", font_color_hl);
 |  |  	theme->set_color("icon_color_hover", "CheckButton", font_color_hl);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +	theme->set_constant("hseparation", "CheckButton", 4 * EDSCALE);
 | 
											
												
													
														|  | 
 |  | +	theme->set_constant("check_vadjust", "CheckButton", 0 * EDSCALE);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  	// Checkbox
 |  |  	// Checkbox
 | 
											
												
													
														|  | 
 |  | +	Ref<StyleBoxFlat> sb_checkbox = style_menu->duplicate();
 | 
											
												
													
														|  | 
 |  | +	// HACK, in reality, the checkbox draws the text over the icon by default, so the margin compensates that.
 | 
											
												
													
														|  | 
 |  | +	const int cb_w = theme->get_icon("GuiChecked", "EditorIcons")->get_width() + default_margin_size;
 | 
											
												
													
														|  | 
 |  | +	sb_checkbox->set_default_margin(MARGIN_LEFT, cb_w * EDSCALE);
 | 
											
												
													
														|  | 
 |  | +	sb_checkbox->set_default_margin(MARGIN_RIGHT, default_margin_size * EDSCALE);
 | 
											
												
													
														|  | 
 |  | +	sb_checkbox->set_default_margin(MARGIN_TOP, default_margin_size * EDSCALE);
 | 
											
												
													
														|  | 
 |  | +	sb_checkbox->set_default_margin(MARGIN_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("checked", "CheckBox", theme->get_icon("GuiChecked", "EditorIcons"));
 | 
											
												
													
														|  |  	theme->set_icon("unchecked", "CheckBox", theme->get_icon("GuiUnchecked", "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_checked", "CheckBox", theme->get_icon("GuiRadioChecked", "EditorIcons"));
 | 
											
										
											
												
													
														|  | @@ -594,6 +609,9 @@ Ref<Theme> create_editor_theme(const Ref<Theme> p_theme) {
 | 
											
												
													
														|  |  	theme->set_color("font_color_disabled", "CheckBox", font_color_disabled);
 |  |  	theme->set_color("font_color_disabled", "CheckBox", font_color_disabled);
 | 
											
												
													
														|  |  	theme->set_color("icon_color_hover", "CheckBox", font_color_hl);
 |  |  	theme->set_color("icon_color_hover", "CheckBox", font_color_hl);
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | 
 |  | +	theme->set_constant("hseparation", "CheckBox", 4 * EDSCALE);
 | 
											
												
													
														|  | 
 |  | +	theme->set_constant("check_vadjust", "CheckBox", 0 * EDSCALE);
 | 
											
												
													
														|  | 
 |  | +
 | 
											
												
													
														|  |  	// PopupMenu
 |  |  	// PopupMenu
 | 
											
												
													
														|  |  	Ref<StyleBoxFlat> style_popup_menu = style_popup;
 |  |  	Ref<StyleBoxFlat> style_popup_menu = style_popup;
 | 
											
												
													
														|  |  	theme->set_stylebox("panel", "PopupMenu", style_popup_menu);
 |  |  	theme->set_stylebox("panel", "PopupMenu", style_popup_menu);
 | 
											
										
											
												
													
														|  | @@ -1049,12 +1067,14 @@ Ref<Theme> create_editor_theme(const Ref<Theme> p_theme) {
 | 
											
												
													
														|  |  	return theme;
 |  |  	return theme;
 | 
											
												
													
														|  |  }
 |  |  }
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  | -Ref<Theme> create_custom_theme() {
 |  | 
 | 
											
												
													
														|  | -	Ref<Theme> theme = create_editor_theme();
 |  | 
 | 
											
												
													
														|  | 
 |  | +Ref<Theme> create_custom_theme(const Ref<Theme> p_theme) {
 | 
											
												
													
														|  | 
 |  | +	Ref<Theme> theme;
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	String custom_theme = EditorSettings::get_singleton()->get("interface/theme/custom_theme");
 |  |  	String custom_theme = EditorSettings::get_singleton()->get("interface/theme/custom_theme");
 | 
											
												
													
														|  |  	if (custom_theme != "") {
 |  |  	if (custom_theme != "") {
 | 
											
												
													
														|  |  		theme = ResourceLoader::load(custom_theme);
 |  |  		theme = ResourceLoader::load(custom_theme);
 | 
											
												
													
														|  | 
 |  | +	} else {
 | 
											
												
													
														|  | 
 |  | +		theme = create_editor_theme(p_theme);
 | 
											
												
													
														|  |  	}
 |  |  	}
 | 
											
												
													
														|  |  
 |  |  
 | 
											
												
													
														|  |  	String global_font = EditorSettings::get_singleton()->get("interface/editor/custom_font");
 |  |  	String global_font = EditorSettings::get_singleton()->get("interface/editor/custom_font");
 |