|
@@ -370,8 +370,9 @@ bool GraphEdit::_filter_input(const Point2 &p_point) {
|
|
void GraphEdit::_top_layer_input(const Ref<InputEvent> &p_ev) {
|
|
void GraphEdit::_top_layer_input(const Ref<InputEvent> &p_ev) {
|
|
Ref<InputEventMouseButton> mb = p_ev;
|
|
Ref<InputEventMouseButton> mb = p_ev;
|
|
if (mb.is_valid() && mb->get_button_index() == BUTTON_LEFT && mb->is_pressed()) {
|
|
if (mb.is_valid() && mb->get_button_index() == BUTTON_LEFT && mb->is_pressed()) {
|
|
|
|
+ connecting_valid = false;
|
|
Ref<Texture2D> port = get_theme_icon("port", "GraphNode");
|
|
Ref<Texture2D> port = get_theme_icon("port", "GraphNode");
|
|
- Vector2 mpos(mb->get_position().x, mb->get_position().y);
|
|
|
|
|
|
+ click_pos = mb->get_position();
|
|
for (int i = get_child_count() - 1; i >= 0; i--) {
|
|
for (int i = get_child_count() - 1; i >= 0; i--) {
|
|
GraphNode *gn = Object::cast_to<GraphNode>(get_child(i));
|
|
GraphNode *gn = Object::cast_to<GraphNode>(get_child(i));
|
|
if (!gn) {
|
|
if (!gn) {
|
|
@@ -380,7 +381,7 @@ void GraphEdit::_top_layer_input(const Ref<InputEvent> &p_ev) {
|
|
|
|
|
|
for (int j = 0; j < gn->get_connection_output_count(); j++) {
|
|
for (int j = 0; j < gn->get_connection_output_count(); j++) {
|
|
Vector2 pos = gn->get_connection_output_position(j) + gn->get_position();
|
|
Vector2 pos = gn->get_connection_output_position(j) + gn->get_position();
|
|
- if (is_in_hot_zone(pos, mpos)) {
|
|
|
|
|
|
+ if (is_in_hot_zone(pos, click_pos)) {
|
|
if (valid_left_disconnect_types.has(gn->get_connection_output_type(j))) {
|
|
if (valid_left_disconnect_types.has(gn->get_connection_output_type(j))) {
|
|
//check disconnect
|
|
//check disconnect
|
|
for (List<Connection>::Element *E = connections.front(); E; E = E->next()) {
|
|
for (List<Connection>::Element *E = connections.front(); E; E = E->next()) {
|
|
@@ -422,7 +423,7 @@ void GraphEdit::_top_layer_input(const Ref<InputEvent> &p_ev) {
|
|
|
|
|
|
for (int j = 0; j < gn->get_connection_input_count(); j++) {
|
|
for (int j = 0; j < gn->get_connection_input_count(); j++) {
|
|
Vector2 pos = gn->get_connection_input_position(j) + gn->get_position();
|
|
Vector2 pos = gn->get_connection_input_position(j) + gn->get_position();
|
|
- if (is_in_hot_zone(pos, mpos)) {
|
|
|
|
|
|
+ if (is_in_hot_zone(pos, click_pos)) {
|
|
if (right_disconnects || valid_right_disconnect_types.has(gn->get_connection_input_type(j))) {
|
|
if (right_disconnects || valid_right_disconnect_types.has(gn->get_connection_input_type(j))) {
|
|
//check disconnect
|
|
//check disconnect
|
|
for (List<Connection>::Element *E = connections.front(); E; E = E->next()) {
|
|
for (List<Connection>::Element *E = connections.front(); E; E = E->next()) {
|
|
@@ -470,37 +471,40 @@ void GraphEdit::_top_layer_input(const Ref<InputEvent> &p_ev) {
|
|
connecting_to = mm->get_position();
|
|
connecting_to = mm->get_position();
|
|
connecting_target = false;
|
|
connecting_target = false;
|
|
top_layer->update();
|
|
top_layer->update();
|
|
|
|
+ connecting_valid = click_pos.distance_to(connecting_to) > 20.0 * zoom;
|
|
|
|
|
|
- Ref<Texture2D> port = get_theme_icon("port", "GraphNode");
|
|
|
|
- Vector2 mpos = mm->get_position();
|
|
|
|
- for (int i = get_child_count() - 1; i >= 0; i--) {
|
|
|
|
- GraphNode *gn = Object::cast_to<GraphNode>(get_child(i));
|
|
|
|
- if (!gn) {
|
|
|
|
- continue;
|
|
|
|
- }
|
|
|
|
|
|
+ if (connecting_valid) {
|
|
|
|
+ Ref<Texture2D> port = get_theme_icon("port", "GraphNode");
|
|
|
|
+ Vector2 mpos = mm->get_position();
|
|
|
|
+ for (int i = get_child_count() - 1; i >= 0; i--) {
|
|
|
|
+ GraphNode *gn = Object::cast_to<GraphNode>(get_child(i));
|
|
|
|
+ if (!gn) {
|
|
|
|
+ continue;
|
|
|
|
+ }
|
|
|
|
|
|
- if (!connecting_out) {
|
|
|
|
- for (int j = 0; j < gn->get_connection_output_count(); j++) {
|
|
|
|
- Vector2 pos = gn->get_connection_output_position(j) + gn->get_position();
|
|
|
|
- int type = gn->get_connection_output_type(j);
|
|
|
|
- if ((type == connecting_type || valid_connection_types.has(ConnType(type, connecting_type))) && is_in_hot_zone(pos, mpos)) {
|
|
|
|
- connecting_target = true;
|
|
|
|
- connecting_to = pos;
|
|
|
|
- connecting_target_to = gn->get_name();
|
|
|
|
- connecting_target_index = j;
|
|
|
|
- return;
|
|
|
|
|
|
+ if (!connecting_out) {
|
|
|
|
+ for (int j = 0; j < gn->get_connection_output_count(); j++) {
|
|
|
|
+ Vector2 pos = gn->get_connection_output_position(j) + gn->get_position();
|
|
|
|
+ int type = gn->get_connection_output_type(j);
|
|
|
|
+ if ((type == connecting_type || valid_connection_types.has(ConnType(type, connecting_type))) && is_in_hot_zone(pos, mpos)) {
|
|
|
|
+ connecting_target = true;
|
|
|
|
+ connecting_to = pos;
|
|
|
|
+ connecting_target_to = gn->get_name();
|
|
|
|
+ connecting_target_index = j;
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
- }
|
|
|
|
- } else {
|
|
|
|
- for (int j = 0; j < gn->get_connection_input_count(); j++) {
|
|
|
|
- Vector2 pos = gn->get_connection_input_position(j) + gn->get_position();
|
|
|
|
- int type = gn->get_connection_input_type(j);
|
|
|
|
- if ((type == connecting_type || valid_connection_types.has(ConnType(type, connecting_type))) && is_in_hot_zone(pos, mpos)) {
|
|
|
|
- connecting_target = true;
|
|
|
|
- connecting_to = pos;
|
|
|
|
- connecting_target_to = gn->get_name();
|
|
|
|
- connecting_target_index = j;
|
|
|
|
- return;
|
|
|
|
|
|
+ } else {
|
|
|
|
+ for (int j = 0; j < gn->get_connection_input_count(); j++) {
|
|
|
|
+ Vector2 pos = gn->get_connection_input_position(j) + gn->get_position();
|
|
|
|
+ int type = gn->get_connection_input_type(j);
|
|
|
|
+ if ((type == connecting_type || valid_connection_types.has(ConnType(type, connecting_type))) && is_in_hot_zone(pos, mpos)) {
|
|
|
|
+ connecting_target = true;
|
|
|
|
+ connecting_to = pos;
|
|
|
|
+ connecting_target_to = gn->get_name();
|
|
|
|
+ connecting_target_index = j;
|
|
|
|
+ return;
|
|
|
|
+ }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
@@ -508,27 +512,29 @@ void GraphEdit::_top_layer_input(const Ref<InputEvent> &p_ev) {
|
|
}
|
|
}
|
|
|
|
|
|
if (mb.is_valid() && mb->get_button_index() == BUTTON_LEFT && !mb->is_pressed()) {
|
|
if (mb.is_valid() && mb->get_button_index() == BUTTON_LEFT && !mb->is_pressed()) {
|
|
- if (connecting && connecting_target) {
|
|
|
|
- String from = connecting_from;
|
|
|
|
- int from_slot = connecting_index;
|
|
|
|
- String to = connecting_target_to;
|
|
|
|
- int to_slot = connecting_target_index;
|
|
|
|
-
|
|
|
|
- if (!connecting_out) {
|
|
|
|
- SWAP(from, to);
|
|
|
|
- SWAP(from_slot, to_slot);
|
|
|
|
- }
|
|
|
|
- emit_signal("connection_request", from, from_slot, to, to_slot);
|
|
|
|
|
|
+ if (connecting_valid) {
|
|
|
|
+ if (connecting && connecting_target) {
|
|
|
|
+ String from = connecting_from;
|
|
|
|
+ int from_slot = connecting_index;
|
|
|
|
+ String to = connecting_target_to;
|
|
|
|
+ int to_slot = connecting_target_index;
|
|
|
|
+
|
|
|
|
+ if (!connecting_out) {
|
|
|
|
+ SWAP(from, to);
|
|
|
|
+ SWAP(from_slot, to_slot);
|
|
|
|
+ }
|
|
|
|
+ emit_signal("connection_request", from, from_slot, to, to_slot);
|
|
|
|
|
|
- } else if (!just_disconnected) {
|
|
|
|
- String from = connecting_from;
|
|
|
|
- int from_slot = connecting_index;
|
|
|
|
- Vector2 ofs = Vector2(mb->get_position().x, mb->get_position().y);
|
|
|
|
|
|
+ } else if (!just_disconnected) {
|
|
|
|
+ String from = connecting_from;
|
|
|
|
+ int from_slot = connecting_index;
|
|
|
|
+ Vector2 ofs = Vector2(mb->get_position().x, mb->get_position().y);
|
|
|
|
|
|
- if (!connecting_out) {
|
|
|
|
- emit_signal("connection_from_empty", from, from_slot, ofs);
|
|
|
|
- } else {
|
|
|
|
- emit_signal("connection_to_empty", from, from_slot, ofs);
|
|
|
|
|
|
+ if (!connecting_out) {
|
|
|
|
+ emit_signal("connection_from_empty", from, from_slot, ofs);
|
|
|
|
+ } else {
|
|
|
|
+ emit_signal("connection_to_empty", from, from_slot, ofs);
|
|
|
|
+ }
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
|