fix certain popup close clicks with popup buttons
This commit is contained in:
parent
d055031c73
commit
efc3ffb816
@ -1948,6 +1948,7 @@ CustomPropertyEditor::CustomPropertyEditor() {
|
|||||||
type_button->get_popup()->connect("id_pressed", this, "_type_create_selected");
|
type_button->get_popup()->connect("id_pressed", this, "_type_create_selected");
|
||||||
|
|
||||||
menu = memnew(PopupMenu);
|
menu = memnew(PopupMenu);
|
||||||
|
menu->set_pass_on_modal_close_click(false);
|
||||||
add_child(menu);
|
add_child(menu);
|
||||||
menu->connect("id_pressed", this, "_menu_option");
|
menu->connect("id_pressed", this, "_menu_option");
|
||||||
|
|
||||||
@ -4288,6 +4289,7 @@ PropertyEditor::PropertyEditor() {
|
|||||||
set_physics_process(true);
|
set_physics_process(true);
|
||||||
|
|
||||||
custom_editor = memnew(CustomPropertyEditor);
|
custom_editor = memnew(CustomPropertyEditor);
|
||||||
|
custom_editor->set_pass_on_modal_close_click(false);
|
||||||
add_child(custom_editor);
|
add_child(custom_editor);
|
||||||
|
|
||||||
tree->connect("custom_popup_edited", this, "_custom_editor_request");
|
tree->connect("custom_popup_edited", this, "_custom_editor_request");
|
||||||
|
@ -2470,6 +2470,16 @@ Control::MouseFilter Control::get_mouse_filter() const {
|
|||||||
return data.mouse_filter;
|
return data.mouse_filter;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Control::set_pass_on_modal_close_click(bool p_pass_on) {
|
||||||
|
|
||||||
|
data.pass_on_modal_close_click = p_pass_on;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Control::pass_on_modal_close_click() const {
|
||||||
|
|
||||||
|
return data.pass_on_modal_close_click;
|
||||||
|
}
|
||||||
|
|
||||||
Control *Control::get_focus_owner() const {
|
Control *Control::get_focus_owner() const {
|
||||||
|
|
||||||
ERR_FAIL_COND_V(!is_inside_tree(), NULL);
|
ERR_FAIL_COND_V(!is_inside_tree(), NULL);
|
||||||
@ -2934,6 +2944,7 @@ Control::Control() {
|
|||||||
data.parent = NULL;
|
data.parent = NULL;
|
||||||
|
|
||||||
data.mouse_filter = MOUSE_FILTER_STOP;
|
data.mouse_filter = MOUSE_FILTER_STOP;
|
||||||
|
data.pass_on_modal_close_click = true;
|
||||||
|
|
||||||
data.SI = NULL;
|
data.SI = NULL;
|
||||||
data.MI = NULL;
|
data.MI = NULL;
|
||||||
|
@ -165,6 +165,8 @@ private:
|
|||||||
bool pending_min_size_update;
|
bool pending_min_size_update;
|
||||||
Point2 custom_minimum_size;
|
Point2 custom_minimum_size;
|
||||||
|
|
||||||
|
bool pass_on_modal_close_click;
|
||||||
|
|
||||||
MouseFilter mouse_filter;
|
MouseFilter mouse_filter;
|
||||||
|
|
||||||
bool clip_contents;
|
bool clip_contents;
|
||||||
@ -401,6 +403,9 @@ public:
|
|||||||
void set_mouse_filter(MouseFilter p_filter);
|
void set_mouse_filter(MouseFilter p_filter);
|
||||||
MouseFilter get_mouse_filter() const;
|
MouseFilter get_mouse_filter() const;
|
||||||
|
|
||||||
|
void set_pass_on_modal_close_click(bool p_pass_on);
|
||||||
|
bool pass_on_modal_close_click() const;
|
||||||
|
|
||||||
/* SKINNING */
|
/* SKINNING */
|
||||||
|
|
||||||
void add_icon_override(const StringName &p_name, const Ref<Texture> &p_icon);
|
void add_icon_override(const StringName &p_name, const Ref<Texture> &p_icon);
|
||||||
|
@ -111,6 +111,7 @@ MenuButton::MenuButton() {
|
|||||||
popup->hide();
|
popup->hide();
|
||||||
add_child(popup);
|
add_child(popup);
|
||||||
popup->set_as_toplevel(true);
|
popup->set_as_toplevel(true);
|
||||||
|
popup->set_pass_on_modal_close_click(false);
|
||||||
connect("button_up", popup, "call_deferred", make_binds("grab_click_focus"));
|
connect("button_up", popup, "call_deferred", make_binds("grab_click_focus"));
|
||||||
set_process_unhandled_key_input(true);
|
set_process_unhandled_key_input(true);
|
||||||
set_action_mode(ACTION_MODE_BUTTON_PRESS);
|
set_action_mode(ACTION_MODE_BUTTON_PRESS);
|
||||||
|
@ -323,6 +323,7 @@ OptionButton::OptionButton() {
|
|||||||
popup = memnew(PopupMenu);
|
popup = memnew(PopupMenu);
|
||||||
popup->hide();
|
popup->hide();
|
||||||
popup->set_as_toplevel(true);
|
popup->set_as_toplevel(true);
|
||||||
|
popup->set_pass_on_modal_close_click(false);
|
||||||
add_child(popup);
|
add_child(popup);
|
||||||
popup->connect("id_pressed", this, "_selected");
|
popup->connect("id_pressed", this, "_selected");
|
||||||
|
|
||||||
|
@ -1649,6 +1649,8 @@ void Viewport::_gui_input_event(Ref<InputEvent> p_event) {
|
|||||||
|
|
||||||
} else {
|
} else {
|
||||||
|
|
||||||
|
bool is_handled = false;
|
||||||
|
|
||||||
_gui_sort_modal_stack();
|
_gui_sort_modal_stack();
|
||||||
while (!gui.modal_stack.empty()) {
|
while (!gui.modal_stack.empty()) {
|
||||||
|
|
||||||
@ -1666,11 +1668,20 @@ void Viewport::_gui_input_event(Ref<InputEvent> p_event) {
|
|||||||
top->notification(Control::NOTIFICATION_MODAL_CLOSE);
|
top->notification(Control::NOTIFICATION_MODAL_CLOSE);
|
||||||
top->_modal_stack_remove();
|
top->_modal_stack_remove();
|
||||||
top->hide();
|
top->hide();
|
||||||
|
|
||||||
|
if (!top->pass_on_modal_close_click()) {
|
||||||
|
is_handled = true;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (is_handled) {
|
||||||
|
get_tree()->set_input_as_handled();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
//Matrix32 parent_xform;
|
//Matrix32 parent_xform;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
Loading…
Reference in New Issue
Block a user