-Improved theme editor, when a new class is added, the members are created empty, closes #4619

-Made theme editor take less vertical space by using a scroll area
This commit is contained in:
Juan Linietsky 2016-06-20 11:33:51 -03:00
parent 0e07f49a03
commit a1e32a6f7d
2 changed files with 50 additions and 36 deletions

View file

@ -348,7 +348,7 @@ void ThemeEditor::_dialog_cbk() {
names.clear(); names.clear();
Theme::get_default()->get_icon_list(fromtype,&names); Theme::get_default()->get_icon_list(fromtype,&names);
for(List<StringName>::Element *E=names.front();E;E=E->next()) { for(List<StringName>::Element *E=names.front();E;E=E->next()) {
theme->set_icon(E->get(),fromtype,Theme::get_default()->get_icon(E->get(),fromtype)); theme->set_icon(E->get(),fromtype,Ref<Texture>());
} }
@ -357,7 +357,7 @@ void ThemeEditor::_dialog_cbk() {
names.clear(); names.clear();
Theme::get_default()->get_stylebox_list(fromtype,&names); Theme::get_default()->get_stylebox_list(fromtype,&names);
for(List<StringName>::Element *E=names.front();E;E=E->next()) { for(List<StringName>::Element *E=names.front();E;E=E->next()) {
theme->set_stylebox(E->get(),fromtype,Theme::get_default()->get_stylebox(E->get(),fromtype)); theme->set_stylebox(E->get(),fromtype,Ref<StyleBox>());
} }
@ -366,7 +366,7 @@ void ThemeEditor::_dialog_cbk() {
names.clear(); names.clear();
Theme::get_default()->get_font_list(fromtype,&names); Theme::get_default()->get_font_list(fromtype,&names);
for(List<StringName>::Element *E=names.front();E;E=E->next()) { for(List<StringName>::Element *E=names.front();E;E=E->next()) {
theme->set_font(E->get(),fromtype,Theme::get_default()->get_font(E->get(),fromtype)); theme->set_font(E->get(),fromtype,Ref<Font>());
} }
} }
@ -537,7 +537,7 @@ void ThemeEditor::_theme_menu_cbk(int p_option) {
add_del_dialog->set_title(TTR("Add Item")); add_del_dialog->set_title(TTR("Add Item"));
add_del_dialog->get_ok()->set_text(TTR("Add")); add_del_dialog->get_ok()->set_text(TTR("Add"));
add_del_dialog->popup_centered(Size2(490,85)); add_del_dialog->popup_centered(Size2(490,85)*EDSCALE);
base_theme=Theme::get_default(); base_theme=Theme::get_default();
@ -545,7 +545,7 @@ void ThemeEditor::_theme_menu_cbk(int p_option) {
add_del_dialog->set_title(TTR("Add All Items")); add_del_dialog->set_title(TTR("Add All Items"));
add_del_dialog->get_ok()->set_text(TTR("Add All")); add_del_dialog->get_ok()->set_text(TTR("Add All"));
add_del_dialog->popup_centered(Size2(240,85)); add_del_dialog->popup_centered(Size2(240,85)*EDSCALE);
base_theme=Theme::get_default(); base_theme=Theme::get_default();
@ -559,7 +559,7 @@ void ThemeEditor::_theme_menu_cbk(int p_option) {
add_del_dialog->set_title(TTR("Remove Item")); add_del_dialog->set_title(TTR("Remove Item"));
add_del_dialog->get_ok()->set_text(TTR("Remove")); add_del_dialog->get_ok()->set_text(TTR("Remove"));
add_del_dialog->popup_centered(Size2(490,85)); add_del_dialog->popup_centered(Size2(490,85)*EDSCALE);
base_theme=theme; base_theme=theme;
@ -567,7 +567,7 @@ void ThemeEditor::_theme_menu_cbk(int p_option) {
add_del_dialog->set_title("Remove All Items"); add_del_dialog->set_title("Remove All Items");
add_del_dialog->get_ok()->set_text("Remove All"); add_del_dialog->get_ok()->set_text("Remove All");
add_del_dialog->popup_centered(Size2(240,85)); add_del_dialog->popup_centered(Size2(240,85)*EDSCALE);
base_theme=Theme::get_default(); base_theme=Theme::get_default();
@ -583,12 +583,14 @@ void ThemeEditor::_theme_menu_cbk(int p_option) {
List<StringName> types; List<StringName> types;
base_theme->get_type_list(&types); base_theme->get_type_list(&types);
type_menu->get_popup()->clear();; type_menu->get_popup()->clear();;
if (p_option==0 || p_option==1) {//add if (p_option==0 || p_option==1) {//add
List<StringName> new_types; List<StringName> new_types;
theme->get_type_list(&new_types); theme->get_type_list(&new_types);
//uh kind of sucks //uh kind of sucks
for(List<StringName>::Element *F=new_types.front();F;F=F->next()) { for(List<StringName>::Element *F=new_types.front();F;F=F->next()) {
@ -606,8 +608,8 @@ void ThemeEditor::_theme_menu_cbk(int p_option) {
} }
} }
types.sort(); //types.sort();
types.sort_custom<StringName::AlphCompare>();
for(List<StringName>::Element *E=types.front();E;E=E->next()) { for(List<StringName>::Element *E=types.front();E;E=E->next()) {
type_menu->get_popup()->add_item( E->get() ); type_menu->get_popup()->add_item( E->get() );
@ -641,15 +643,23 @@ ThemeEditor::ThemeEditor() {
time_left=0; time_left=0;
scroll = memnew( ScrollContainer );
add_child(scroll);
scroll->set_area_as_parent_rect(3);
scroll->set_margin(MARGIN_TOP,30*EDSCALE);
//scroll->set_enable_h_scroll(true);
scroll->set_enable_v_scroll(true);
scroll->set_enable_h_scroll(false);
Panel * panel = memnew( Panel ); Panel * panel = memnew( Panel );
add_child(panel); scroll->add_child(panel);
panel->set_area_as_parent_rect(0); panel->set_custom_minimum_size(Size2(500,800)*EDSCALE);
panel->set_margin(MARGIN_TOP,25);
panel->set_theme(Theme::get_default()); panel->set_theme(Theme::get_default());
panel->set_h_size_flags(SIZE_EXPAND_FILL);
main_vb= memnew( VBoxContainer ); main_vb= memnew( VBoxContainer );
panel->add_child(main_vb); panel->add_child(main_vb);
main_vb->set_area_as_parent_rect(4); main_vb->set_area_as_parent_rect(4*EDSCALE);
HBoxContainer *hb_menu = memnew(HBoxContainer); HBoxContainer *hb_menu = memnew(HBoxContainer);
@ -667,7 +677,8 @@ ThemeEditor::ThemeEditor() {
theme_menu->get_popup()->add_item(TTR("Create Empty Template"),POPUP_CREATE_EMPTY); theme_menu->get_popup()->add_item(TTR("Create Empty Template"),POPUP_CREATE_EMPTY);
theme_menu->get_popup()->add_item(TTR("Create Empty Editor Template"),POPUP_CREATE_EDITOR_EMPTY); theme_menu->get_popup()->add_item(TTR("Create Empty Editor Template"),POPUP_CREATE_EDITOR_EMPTY);
hb_menu->add_child(theme_menu); add_child(theme_menu);
theme_menu->set_pos(Vector2(3,3)*EDSCALE);
theme_menu->get_popup()->connect("item_pressed", this,"_theme_menu_cbk"); theme_menu->get_popup()->connect("item_pressed", this,"_theme_menu_cbk");
@ -742,26 +753,26 @@ ThemeEditor::ThemeEditor() {
pb->set_val(50); pb->set_val(50);
first_vb->add_child( pb); first_vb->add_child( pb);
Panel *pn=memnew( Panel ); Panel *pn=memnew( Panel );
pn->set_custom_minimum_size(Size2(40,40)); pn->set_custom_minimum_size(Size2(40,40)*EDSCALE);
first_vb->add_child( pn); first_vb->add_child( pn);
first_vb->add_constant_override("separation",10); first_vb->add_constant_override("separation",10*EDSCALE);
VBoxContainer *second_vb = memnew( VBoxContainer ); VBoxContainer *second_vb = memnew( VBoxContainer );
second_vb->set_h_size_flags(SIZE_EXPAND_FILL); second_vb->set_h_size_flags(SIZE_EXPAND_FILL);
main_hb->add_child(second_vb); main_hb->add_child(second_vb);
second_vb->add_constant_override("separation",10); second_vb->add_constant_override("separation",10*EDSCALE);
LineEdit *le = memnew( LineEdit ); LineEdit *le = memnew( LineEdit );
le->set_text("LineEdit"); le->set_text("LineEdit");
second_vb->add_child(le); second_vb->add_child(le);
TextEdit *te = memnew( TextEdit ); TextEdit *te = memnew( TextEdit );
te->set_text("TextEdit"); te->set_text("TextEdit");
//te->set_v_size_flags(SIZE_EXPAND_FILL); //te->set_v_size_flags(SIZE_EXPAND_FILL);
te->set_custom_minimum_size(Size2(0,160)); te->set_custom_minimum_size(Size2(0,160)*EDSCALE);
second_vb->add_child(te); second_vb->add_child(te);
Tree *test_tree = memnew(Tree); Tree *test_tree = memnew(Tree);
second_vb->add_child(test_tree); second_vb->add_child(test_tree);
test_tree->set_custom_minimum_size(Size2(0,160)); test_tree->set_custom_minimum_size(Size2(0,160)*EDSCALE);
TreeItem *item = test_tree->create_item(); TreeItem *item = test_tree->create_item();
@ -789,7 +800,7 @@ ThemeEditor::ThemeEditor() {
main_hb->add_child(third_vb); main_hb->add_child(third_vb);
HBoxContainer *vhb = memnew( HBoxContainer ); HBoxContainer *vhb = memnew( HBoxContainer );
vhb->set_custom_minimum_size(Size2(0,160)); vhb->set_custom_minimum_size(Size2(0,160)*EDSCALE);
vhb->add_child(memnew(VSeparator)); vhb->add_child(memnew(VSeparator));
vhb->add_child(memnew(VSlider)); vhb->add_child(memnew(VSlider));
vhb->add_child(memnew(VScrollBar)); vhb->add_child(memnew(VScrollBar));
@ -797,7 +808,7 @@ ThemeEditor::ThemeEditor() {
TabContainer *tc = memnew( TabContainer ); TabContainer *tc = memnew( TabContainer );
third_vb->add_child(tc); third_vb->add_child(tc);
tc->set_custom_minimum_size(Size2(0,160)); tc->set_custom_minimum_size(Size2(0,160)*EDSCALE);
Control *tcc = memnew( Control ); Control *tcc = memnew( Control );
tcc->set_name(TTR("Tab 1")); tcc->set_name(TTR("Tab 1"));
tc->add_child(tcc); tc->add_child(tcc);
@ -808,7 +819,7 @@ ThemeEditor::ThemeEditor() {
tcc->set_name(TTR("Tab 3")); tcc->set_name(TTR("Tab 3"));
tc->add_child(tcc); tc->add_child(tcc);
main_hb->add_constant_override("separation",20); main_hb->add_constant_override("separation",20*EDSCALE);
@ -871,37 +882,37 @@ ThemeEditor::ThemeEditor() {
Label *l = memnew( Label ); Label *l = memnew( Label );
l->set_pos( Point2(5,5) ); l->set_pos( Point2(5,5)*EDSCALE );
l->set_text(TTR("Type:")); l->set_text(TTR("Type:"));
add_del_dialog->add_child(l); add_del_dialog->add_child(l);
dtype_select_label=l; dtype_select_label=l;
type_edit = memnew( LineEdit ); type_edit = memnew( LineEdit );
type_edit->set_pos(Point2(5,25)); type_edit->set_pos(Point2(5,25)*EDSCALE);
type_edit->set_size(Point2(150,5)); type_edit->set_size(Point2(150,5)*EDSCALE);
add_del_dialog->add_child(type_edit); add_del_dialog->add_child(type_edit);
type_menu = memnew( MenuButton ); type_menu = memnew( MenuButton );
type_menu->set_pos(Point2(160,25)); type_menu->set_pos(Point2(160,25)*EDSCALE);
type_menu->set_size(Point2(30,5)); type_menu->set_size(Point2(30,5)*EDSCALE);
type_menu->set_text(".."); type_menu->set_text("..");
add_del_dialog->add_child(type_menu); add_del_dialog->add_child(type_menu);
type_menu->get_popup()->connect("item_pressed", this,"_type_menu_cbk"); type_menu->get_popup()->connect("item_pressed", this,"_type_menu_cbk");
l = memnew( Label ); l = memnew( Label );
l->set_pos( Point2(200,5) ); l->set_pos( Point2(200,5)*EDSCALE );
l->set_text(TTR("Name:")); l->set_text(TTR("Name:"));
add_del_dialog->add_child(l); add_del_dialog->add_child(l);
name_select_label=l; name_select_label=l;
name_edit = memnew( LineEdit ); name_edit = memnew( LineEdit );
name_edit->set_pos(Point2(200,25)); name_edit->set_pos(Point2(200,25)*EDSCALE);
name_edit->set_size(Point2(150,5)); name_edit->set_size(Point2(150,5)*EDSCALE);
add_del_dialog->add_child(name_edit); add_del_dialog->add_child(name_edit);
name_menu = memnew( MenuButton ); name_menu = memnew( MenuButton );
name_menu->set_pos(Point2(360,25)); name_menu->set_pos(Point2(360,25)*EDSCALE);
name_menu->set_size(Point2(30,5)); name_menu->set_size(Point2(30,5)*EDSCALE);
name_menu->set_text(".."); name_menu->set_text("..");
add_del_dialog->add_child(name_menu); add_del_dialog->add_child(name_menu);
@ -910,7 +921,7 @@ ThemeEditor::ThemeEditor() {
name_menu->get_popup()->connect("item_pressed", this,"_name_menu_cbk"); name_menu->get_popup()->connect("item_pressed", this,"_name_menu_cbk");
type_select_label= memnew( Label ); type_select_label= memnew( Label );
type_select_label->set_pos( Point2(400,5) ); type_select_label->set_pos( Point2(400,5)*EDSCALE );
type_select_label->set_text(TTR("Data Type:")); type_select_label->set_text(TTR("Data Type:"));
add_del_dialog->add_child(type_select_label); add_del_dialog->add_child(type_select_label);
@ -920,8 +931,8 @@ ThemeEditor::ThemeEditor() {
type_select->add_item(TTR("Font")); type_select->add_item(TTR("Font"));
type_select->add_item(TTR("Color")); type_select->add_item(TTR("Color"));
type_select->add_item(TTR("Constant")); type_select->add_item(TTR("Constant"));
type_select->set_pos( Point2( 400,25 ) ); type_select->set_pos( Point2( 400,25 )*EDSCALE );
type_select->set_size( Point2( 80,5 ) ); type_select->set_size( Point2( 80,5 )*EDSCALE );
add_del_dialog->add_child(type_select); add_del_dialog->add_child(type_select);
@ -974,7 +985,7 @@ ThemeEditorPlugin::ThemeEditorPlugin(EditorNode *p_node) {
editor=p_node; editor=p_node;
theme_editor = memnew( ThemeEditor ); theme_editor = memnew( ThemeEditor );
theme_editor->set_custom_minimum_size(Size2(0,500)); theme_editor->set_custom_minimum_size(Size2(0,200));
// p_node->get_viewport()->add_child(theme_editor); // p_node->get_viewport()->add_child(theme_editor);
button=editor->add_bottom_panel_item("Theme",theme_editor); button=editor->add_bottom_panel_item("Theme",theme_editor);

View file

@ -35,16 +35,19 @@
#include "scene/gui/file_dialog.h" #include "scene/gui/file_dialog.h"
#include "scene/gui/check_box.h" #include "scene/gui/check_box.h"
#include "scene/gui/button_group.h" #include "scene/gui/button_group.h"
#include "scene/gui/scroll_container.h"
#include "tools/editor/editor_node.h" #include "tools/editor/editor_node.h"
class ThemeEditor : public Control { class ThemeEditor : public Control {
OBJ_TYPE( ThemeEditor, Control ); OBJ_TYPE( ThemeEditor, Control );
ScrollContainer *scroll;
VBoxContainer *main_vb; VBoxContainer *main_vb;
Ref<Theme> theme; Ref<Theme> theme;