mirror of
https://github.com/godotengine/godot.git
synced 2025-01-24 11:32:51 -05:00
-Cleaned up find/replace bar for replace (made selection only default if selection exists), also made buttons look like buttons
-Fixed a bug related to theme propagation, may be able to solve #6443, #6302 and others. Please test.
This commit is contained in:
parent
e6ef92d217
commit
1bf684cea2
9 changed files with 47 additions and 31 deletions
|
@ -2140,6 +2140,7 @@ Vector<String> VisualScriptEditor::get_functions(){
|
||||||
|
|
||||||
void VisualScriptEditor::set_edited_script(const Ref<Script>& p_script){
|
void VisualScriptEditor::set_edited_script(const Ref<Script>& p_script){
|
||||||
|
|
||||||
|
|
||||||
script=p_script;
|
script=p_script;
|
||||||
signal_editor->script=p_script;
|
signal_editor->script=p_script;
|
||||||
signal_editor->undo_redo=undo_redo;
|
signal_editor->undo_redo=undo_redo;
|
||||||
|
|
|
@ -431,8 +431,7 @@ void Control::add_child_notify(Node *p_child) {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (child_c->data.theme.is_null() && data.theme_owner) {
|
if (child_c->data.theme.is_null() && data.theme_owner) {
|
||||||
child_c->data.theme_owner=data.theme_owner;
|
_propagate_theme_changed(child_c,data.theme_owner); //need to propagate here, since many controls may require setting up stuff
|
||||||
child_c->notification(NOTIFICATION_THEME_CHANGED);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -443,8 +442,7 @@ void Control::remove_child_notify(Node *p_child) {
|
||||||
return;
|
return;
|
||||||
|
|
||||||
if (child_c->data.theme_owner && child_c->data.theme.is_null()) {
|
if (child_c->data.theme_owner && child_c->data.theme.is_null()) {
|
||||||
child_c->data.theme_owner=NULL;
|
_propagate_theme_changed(child_c,NULL);
|
||||||
//notification(NOTIFICATION_THEME_CHANGED);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
@ -482,10 +480,10 @@ void Control::_notification(int p_notification) {
|
||||||
if (is_set_as_toplevel()) {
|
if (is_set_as_toplevel()) {
|
||||||
data.SI=get_viewport()->_gui_add_subwindow_control(this);
|
data.SI=get_viewport()->_gui_add_subwindow_control(this);
|
||||||
|
|
||||||
if (data.theme.is_null() && data.parent && data.parent->data.theme_owner) {
|
/*if (data.theme.is_null() && data.parent && data.parent->data.theme_owner) {
|
||||||
data.theme_owner=data.parent->data.theme_owner;
|
data.theme_owner=data.parent->data.theme_owner;
|
||||||
notification(NOTIFICATION_THEME_CHANGED);
|
notification(NOTIFICATION_THEME_CHANGED);
|
||||||
}
|
}*/
|
||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
@ -521,10 +519,10 @@ void Control::_notification(int p_notification) {
|
||||||
|
|
||||||
if (parent_control) {
|
if (parent_control) {
|
||||||
//do nothing, has a parent control
|
//do nothing, has a parent control
|
||||||
if (data.theme.is_null() && parent_control->data.theme_owner) {
|
/*if (data.theme.is_null() && parent_control->data.theme_owner) {
|
||||||
data.theme_owner=parent_control->data.theme_owner;
|
data.theme_owner=parent_control->data.theme_owner;
|
||||||
notification(NOTIFICATION_THEME_CHANGED);
|
notification(NOTIFICATION_THEME_CHANGED);
|
||||||
}
|
}*/
|
||||||
} else if (subwindow) {
|
} else if (subwindow) {
|
||||||
//is a subwindow (process input before other controls for that canvas)
|
//is a subwindow (process input before other controls for that canvas)
|
||||||
data.SI=get_viewport()->_gui_add_subwindow_control(this);
|
data.SI=get_viewport()->_gui_add_subwindow_control(this);
|
||||||
|
@ -1915,7 +1913,7 @@ void Control::_propagate_theme_changed(CanvasItem *p_at,Control *p_owner,bool p_
|
||||||
|
|
||||||
CanvasItem *child = p_at->get_child(i)->cast_to<CanvasItem>();
|
CanvasItem *child = p_at->get_child(i)->cast_to<CanvasItem>();
|
||||||
if (child) {
|
if (child) {
|
||||||
_propagate_theme_changed(child,p_owner);
|
_propagate_theme_changed(child,p_owner,p_assign);
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -356,7 +356,7 @@ void FindReplaceBar::_show_search() {
|
||||||
show();
|
show();
|
||||||
search_text->grab_focus();
|
search_text->grab_focus();
|
||||||
|
|
||||||
if (text_edit->is_selection_active()) {
|
if (text_edit->is_selection_active() && !selection_only->is_pressed()) {
|
||||||
search_text->set_text(text_edit->get_selection_text());
|
search_text->set_text(text_edit->get_selection_text());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -376,12 +376,16 @@ void FindReplaceBar::popup_search() {
|
||||||
|
|
||||||
void FindReplaceBar::popup_replace() {
|
void FindReplaceBar::popup_replace() {
|
||||||
|
|
||||||
|
|
||||||
if (!replace_hbc->is_visible() || !replace_options_hbc->is_visible()) {
|
if (!replace_hbc->is_visible() || !replace_options_hbc->is_visible()) {
|
||||||
replace_text->clear();
|
replace_text->clear();
|
||||||
replace_hbc->show();
|
replace_hbc->show();
|
||||||
replace_options_hbc->show();
|
replace_options_hbc->show();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
selection_only->set_pressed( (text_edit->is_selection_active() && text_edit->get_selection_from_line() < text_edit->get_selection_to_line()) );
|
||||||
|
|
||||||
_show_search();
|
_show_search();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -409,6 +413,14 @@ void FindReplaceBar::_search_text_entered(const String& p_text) {
|
||||||
search_next();
|
search_next();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void FindReplaceBar::_replace_text_entered(const String& p_text) {
|
||||||
|
|
||||||
|
if (selection_only->is_pressed() && text_edit->is_selection_active()) {
|
||||||
|
_replace_all();
|
||||||
|
_hide_bar();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
String FindReplaceBar::get_search_text() const {
|
String FindReplaceBar::get_search_text() const {
|
||||||
|
|
||||||
return search_text->get_text();
|
return search_text->get_text();
|
||||||
|
@ -452,6 +464,7 @@ void FindReplaceBar::_bind_methods() {
|
||||||
ObjectTypeDB::bind_method("_editor_text_changed",&FindReplaceBar::_editor_text_changed);
|
ObjectTypeDB::bind_method("_editor_text_changed",&FindReplaceBar::_editor_text_changed);
|
||||||
ObjectTypeDB::bind_method("_search_text_changed",&FindReplaceBar::_search_text_changed);
|
ObjectTypeDB::bind_method("_search_text_changed",&FindReplaceBar::_search_text_changed);
|
||||||
ObjectTypeDB::bind_method("_search_text_entered",&FindReplaceBar::_search_text_entered);
|
ObjectTypeDB::bind_method("_search_text_entered",&FindReplaceBar::_search_text_entered);
|
||||||
|
ObjectTypeDB::bind_method("_replace_text_entered",&FindReplaceBar::_replace_text_entered);
|
||||||
ObjectTypeDB::bind_method("_search_current",&FindReplaceBar::search_current);
|
ObjectTypeDB::bind_method("_search_current",&FindReplaceBar::search_current);
|
||||||
ObjectTypeDB::bind_method("_search_next",&FindReplaceBar::search_next);
|
ObjectTypeDB::bind_method("_search_next",&FindReplaceBar::search_next);
|
||||||
ObjectTypeDB::bind_method("_search_prev",&FindReplaceBar::search_prev);
|
ObjectTypeDB::bind_method("_search_prev",&FindReplaceBar::search_prev);
|
||||||
|
@ -497,18 +510,19 @@ FindReplaceBar::FindReplaceBar() {
|
||||||
replace_text = memnew(LineEdit);
|
replace_text = memnew(LineEdit);
|
||||||
replace_hbc->add_child(replace_text);
|
replace_hbc->add_child(replace_text);
|
||||||
replace_text->set_custom_minimum_size(Size2(200, 0));
|
replace_text->set_custom_minimum_size(Size2(200, 0));
|
||||||
replace_text->connect("text_entered",this,"_search_text_entered");
|
replace_text->connect("text_entered",this,"_replace_text_entered");
|
||||||
|
|
||||||
replace = memnew(ToolButton);
|
|
||||||
|
replace = memnew(Button);
|
||||||
replace_hbc->add_child(replace);
|
replace_hbc->add_child(replace);
|
||||||
replace->set_text(TTR("Replace"));
|
replace->set_text(TTR("Replace"));
|
||||||
replace->set_focus_mode(FOCUS_NONE);
|
//replace->set_focus_mode(FOCUS_NONE);
|
||||||
replace->connect("pressed",this,"_replace_pressed");
|
replace->connect("pressed",this,"_replace_pressed");
|
||||||
|
|
||||||
replace_all = memnew(ToolButton);
|
replace_all = memnew(Button);
|
||||||
replace_hbc->add_child(replace_all);
|
replace_hbc->add_child(replace_all);
|
||||||
replace_all->set_text(TTR("Replace All"));
|
replace_all->set_text(TTR("Replace All"));
|
||||||
replace_all->set_focus_mode(FOCUS_NONE);
|
//replace_all->set_focus_mode(FOCUS_NONE);
|
||||||
replace_all->connect("pressed",this,"_replace_all_pressed");
|
replace_all->connect("pressed",this,"_replace_all_pressed");
|
||||||
|
|
||||||
Control *spacer_split = memnew( Control );
|
Control *spacer_split = memnew( Control );
|
||||||
|
@ -581,8 +595,10 @@ void FindReplaceDialog::popup_search() {
|
||||||
|
|
||||||
void FindReplaceDialog::popup_replace() {
|
void FindReplaceDialog::popup_replace() {
|
||||||
|
|
||||||
|
|
||||||
set_title(TTR("Replace"));
|
set_title(TTR("Replace"));
|
||||||
bool do_selection=(text_edit->is_selection_active() && text_edit->get_selection_from_line() < text_edit->get_selection_to_line());
|
bool do_selection=(text_edit->is_selection_active() && text_edit->get_selection_from_line() < text_edit->get_selection_to_line());
|
||||||
|
|
||||||
set_replace_selection_only(do_selection);
|
set_replace_selection_only(do_selection);
|
||||||
|
|
||||||
if (!do_selection && text_edit->is_selection_active()) {
|
if (!do_selection && text_edit->is_selection_active()) {
|
||||||
|
|
|
@ -73,8 +73,8 @@ class FindReplaceBar : public HBoxContainer {
|
||||||
TextureButton *hide_button;
|
TextureButton *hide_button;
|
||||||
|
|
||||||
LineEdit *replace_text;
|
LineEdit *replace_text;
|
||||||
ToolButton *replace;
|
Button *replace;
|
||||||
ToolButton *replace_all;
|
Button *replace_all;
|
||||||
CheckBox *selection_only;
|
CheckBox *selection_only;
|
||||||
|
|
||||||
VBoxContainer *text_vbc;
|
VBoxContainer *text_vbc;
|
||||||
|
@ -98,6 +98,7 @@ class FindReplaceBar : public HBoxContainer {
|
||||||
void _search_options_changed(bool p_pressed);
|
void _search_options_changed(bool p_pressed);
|
||||||
void _search_text_changed(const String& p_text);
|
void _search_text_changed(const String& p_text);
|
||||||
void _search_text_entered(const String& p_text);
|
void _search_text_entered(const String& p_text);
|
||||||
|
void _replace_text_entered(const String& p_text);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void _notification(int p_what);
|
void _notification(int p_what);
|
||||||
|
|
|
@ -5419,9 +5419,9 @@ EditorNode::EditorNode() {
|
||||||
theme_base->add_child(gui_base);
|
theme_base->add_child(gui_base);
|
||||||
gui_base->set_area_as_parent_rect();
|
gui_base->set_area_as_parent_rect();
|
||||||
|
|
||||||
theme_base->set_theme( create_default_theme() );
|
Ref<Theme> theme = create_editor_theme();
|
||||||
theme = create_editor_theme();
|
theme_base->set_theme( theme );
|
||||||
gui_base->set_theme(theme);
|
gui_base->set_theme(create_custom_theme());
|
||||||
|
|
||||||
resource_preview = memnew( EditorResourcePreview );
|
resource_preview = memnew( EditorResourcePreview );
|
||||||
add_child(resource_preview);
|
add_child(resource_preview);
|
||||||
|
|
|
@ -33,7 +33,7 @@
|
||||||
#include "editor_settings.h"
|
#include "editor_settings.h"
|
||||||
#include "core/io/resource_loader.h"
|
#include "core/io/resource_loader.h"
|
||||||
|
|
||||||
Ref<Theme> create_default_theme()
|
Ref<Theme> create_editor_theme()
|
||||||
{
|
{
|
||||||
Ref<Theme> theme = Ref<Theme>( memnew( Theme ) );
|
Ref<Theme> theme = Ref<Theme>( memnew( Theme ) );
|
||||||
|
|
||||||
|
@ -57,23 +57,22 @@ Ref<Theme> create_default_theme()
|
||||||
return theme;
|
return theme;
|
||||||
}
|
}
|
||||||
|
|
||||||
Ref<Theme> create_editor_theme()
|
Ref<Theme> create_custom_theme()
|
||||||
{
|
{
|
||||||
Ref<Theme> theme = NULL;
|
Ref<Theme> theme;
|
||||||
|
|
||||||
String custom_theme = EditorSettings::get_singleton()->get("global/custom_theme");
|
String custom_theme = EditorSettings::get_singleton()->get("global/custom_theme");
|
||||||
if (custom_theme!="") {
|
if (custom_theme!="") {
|
||||||
theme = ResourceLoader::load(custom_theme);
|
theme = ResourceLoader::load(custom_theme);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (theme.is_null() || !theme.is_valid()) {
|
|
||||||
theme = create_default_theme();
|
|
||||||
}
|
|
||||||
|
|
||||||
String global_font = EditorSettings::get_singleton()->get("global/custom_font");
|
String global_font = EditorSettings::get_singleton()->get("global/custom_font");
|
||||||
if (global_font!="") {
|
if (global_font!="") {
|
||||||
Ref<Font> fnt = ResourceLoader::load(global_font);
|
Ref<Font> fnt = ResourceLoader::load(global_font);
|
||||||
if (fnt.is_valid()) {
|
if (fnt.is_valid()) {
|
||||||
|
if (!theme.is_valid()) {
|
||||||
|
theme.instance();
|
||||||
|
}
|
||||||
theme->set_default_theme_font(fnt);
|
theme->set_default_theme_font(fnt);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,8 +31,8 @@
|
||||||
|
|
||||||
#include "scene/resources/theme.h"
|
#include "scene/resources/theme.h"
|
||||||
|
|
||||||
Ref<Theme> create_default_theme();
|
|
||||||
|
|
||||||
Ref<Theme> create_editor_theme();
|
Ref<Theme> create_editor_theme();
|
||||||
|
|
||||||
|
Ref<Theme> create_custom_theme();
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -1513,6 +1513,7 @@ void ScriptEditor::edit(const Ref<Script>& p_script, bool p_grab_focus) {
|
||||||
}
|
}
|
||||||
ERR_FAIL_COND(!se);
|
ERR_FAIL_COND(!se);
|
||||||
tab_container->add_child(se);
|
tab_container->add_child(se);
|
||||||
|
|
||||||
se->set_edited_script(p_script);
|
se->set_edited_script(p_script);
|
||||||
se->set_tooltip_request_func("_get_debug_tooltip",this);
|
se->set_tooltip_request_func("_get_debug_tooltip",this);
|
||||||
if (se->get_edit_menu()) {
|
if (se->get_edit_menu()) {
|
||||||
|
|
|
@ -1196,7 +1196,7 @@ ProjectManager::ProjectManager() {
|
||||||
FileDialog::set_default_show_hidden_files(EditorSettings::get_singleton()->get("file_dialog/show_hidden_files"));
|
FileDialog::set_default_show_hidden_files(EditorSettings::get_singleton()->get("file_dialog/show_hidden_files"));
|
||||||
|
|
||||||
set_area_as_parent_rect();
|
set_area_as_parent_rect();
|
||||||
set_theme(create_default_theme());
|
set_theme(create_editor_theme());
|
||||||
|
|
||||||
gui_base = memnew( Control );
|
gui_base = memnew( Control );
|
||||||
add_child(gui_base);
|
add_child(gui_base);
|
||||||
|
@ -1389,7 +1389,7 @@ ProjectManager::ProjectManager() {
|
||||||
|
|
||||||
SceneTree::get_singleton()->connect("files_dropped", this, "_files_dropped");
|
SceneTree::get_singleton()->connect("files_dropped", this, "_files_dropped");
|
||||||
|
|
||||||
gui_base->set_theme(create_editor_theme());
|
gui_base->set_theme(create_custom_theme());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue