Merge pull request #42891 from gvaneyck/graph-begin-node-move-timing

Fix emit_signal timing for GraphEdit's begin/end node move
This commit is contained in:
Rémi Verschelde 2020-10-20 07:48:06 +02:00 committed by GitHub
commit 970d0d433b
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 9 additions and 2 deletions

View file

@ -775,6 +775,11 @@ void GraphEdit::_gui_input(const Ref<InputEvent> &p_ev) {
}
if (mm.is_valid() && dragging) {
if (!moving_selection) {
emit_signal("_begin_node_move");
moving_selection = true;
}
just_selected = true;
drag_accum += mm->get_relative();
for (int i = get_child_count() - 1; i >= 0; i--) {
@ -881,16 +886,17 @@ void GraphEdit::_gui_input(const Ref<InputEvent> &p_ev) {
}
if (drag_accum != Vector2()) {
emit_signal("_begin_node_move");
for (int i = get_child_count() - 1; i >= 0; i--) {
GraphNode *gn = Object::cast_to<GraphNode>(get_child(i));
if (gn && gn->is_selected()) {
gn->set_drag(false);
}
}
}
if (moving_selection) {
emit_signal("_end_node_move");
moving_selection = false;
}
dragging = false;

View file

@ -98,6 +98,7 @@ private:
bool dragging;
bool just_selected;
bool moving_selection;
Vector2 drag_accum;
float zoom;