|
@@ -66,9 +66,13 @@ void AnimationNodeBlendTreeEditor::remove_custom_type(const Ref<Script> &p_scrip
|
|
|
_update_options_menu();
|
|
|
}
|
|
|
|
|
|
-void AnimationNodeBlendTreeEditor::_update_options_menu() {
|
|
|
+void AnimationNodeBlendTreeEditor::_update_options_menu(bool p_has_input_ports) {
|
|
|
add_node->get_popup()->clear();
|
|
|
+ add_node->get_popup()->set_size(Size2i(-1, -1));
|
|
|
for (int i = 0; i < add_options.size(); i++) {
|
|
|
+ if (p_has_input_ports && add_options[i].input_port_count == 0) {
|
|
|
+ continue;
|
|
|
+ }
|
|
|
add_node->get_popup()->add_item(add_options[i].name, i);
|
|
|
}
|
|
|
|
|
@@ -309,6 +313,11 @@ void AnimationNodeBlendTreeEditor::_add_node(int p_idx) {
|
|
|
return;
|
|
|
}
|
|
|
|
|
|
+ if (!from_node.is_empty() && anode->get_input_count() == 0) {
|
|
|
+ from_node = "";
|
|
|
+ return;
|
|
|
+ }
|
|
|
+
|
|
|
Point2 instance_pos = graph->get_scroll_ofs();
|
|
|
if (use_popup_menu_position) {
|
|
|
instance_pos += popup_menu_position;
|
|
@@ -328,11 +337,51 @@ void AnimationNodeBlendTreeEditor::_add_node(int p_idx) {
|
|
|
undo_redo->create_action(TTR("Add Node to BlendTree"));
|
|
|
undo_redo->add_do_method(blend_tree.ptr(), "add_node", name, anode, instance_pos / EDSCALE);
|
|
|
undo_redo->add_undo_method(blend_tree.ptr(), "remove_node", name);
|
|
|
+
|
|
|
+ if (!from_node.is_empty()) {
|
|
|
+ undo_redo->add_do_method(blend_tree.ptr(), "connect_node", name, 0, from_node);
|
|
|
+ from_node = "";
|
|
|
+ }
|
|
|
+ if (!to_node.is_empty() && to_slot != -1) {
|
|
|
+ undo_redo->add_do_method(blend_tree.ptr(), "connect_node", to_node, to_slot, name);
|
|
|
+ to_node = "";
|
|
|
+ to_slot = -1;
|
|
|
+ }
|
|
|
+
|
|
|
undo_redo->add_do_method(this, "_update_graph");
|
|
|
undo_redo->add_undo_method(this, "_update_graph");
|
|
|
undo_redo->commit_action();
|
|
|
}
|
|
|
|
|
|
+void AnimationNodeBlendTreeEditor::_popup(bool p_has_input_ports, const Vector2 &p_popup_position, const Vector2 &p_node_position) {
|
|
|
+ _update_options_menu(p_has_input_ports);
|
|
|
+ use_popup_menu_position = true;
|
|
|
+ popup_menu_position = p_popup_position;
|
|
|
+ add_node->get_popup()->set_position(p_node_position);
|
|
|
+ add_node->get_popup()->popup();
|
|
|
+}
|
|
|
+
|
|
|
+void AnimationNodeBlendTreeEditor::_popup_request(const Vector2 &p_position) {
|
|
|
+ _popup(false, graph->get_local_mouse_position(), p_position);
|
|
|
+}
|
|
|
+
|
|
|
+void AnimationNodeBlendTreeEditor::_connection_to_empty(const String &p_from, int p_from_slot, const Vector2 &p_release_position) {
|
|
|
+ Ref<AnimationNode> node = blend_tree->get_node(p_from);
|
|
|
+ if (node.is_valid()) {
|
|
|
+ from_node = p_from;
|
|
|
+ _popup(true, p_release_position, graph->get_global_mouse_position());
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
+void AnimationNodeBlendTreeEditor::_connection_from_empty(const String &p_to, int p_to_slot, const Vector2 &p_release_position) {
|
|
|
+ Ref<AnimationNode> node = blend_tree->get_node(p_to);
|
|
|
+ if (node.is_valid()) {
|
|
|
+ to_node = p_to;
|
|
|
+ to_slot = p_to_slot;
|
|
|
+ _popup(false, p_release_position, graph->get_global_mouse_position());
|
|
|
+ }
|
|
|
+}
|
|
|
+
|
|
|
void AnimationNodeBlendTreeEditor::_node_dragged(const Vector2 &p_from, const Vector2 &p_to, const StringName &p_which) {
|
|
|
updating = true;
|
|
|
undo_redo->create_action(TTR("Node Moved"));
|
|
@@ -431,14 +480,6 @@ void AnimationNodeBlendTreeEditor::_delete_nodes_request() {
|
|
|
undo_redo->commit_action();
|
|
|
}
|
|
|
|
|
|
-void AnimationNodeBlendTreeEditor::_popup_request(const Vector2 &p_position) {
|
|
|
- _update_options_menu();
|
|
|
- use_popup_menu_position = true;
|
|
|
- popup_menu_position = graph->get_local_mouse_position();
|
|
|
- add_node->get_popup()->set_position(p_position);
|
|
|
- add_node->get_popup()->popup();
|
|
|
-}
|
|
|
-
|
|
|
void AnimationNodeBlendTreeEditor::_node_selected(Object *p_node) {
|
|
|
GraphNode *gn = Object::cast_to<GraphNode>(p_node);
|
|
|
ERR_FAIL_COND(!gn);
|
|
@@ -890,6 +931,8 @@ AnimationNodeBlendTreeEditor::AnimationNodeBlendTreeEditor() {
|
|
|
graph->connect("scroll_offset_changed", callable_mp(this, &AnimationNodeBlendTreeEditor::_scroll_changed));
|
|
|
graph->connect("delete_nodes_request", callable_mp(this, &AnimationNodeBlendTreeEditor::_delete_nodes_request));
|
|
|
graph->connect("popup_request", callable_mp(this, &AnimationNodeBlendTreeEditor::_popup_request));
|
|
|
+ graph->connect("connection_to_empty", callable_mp(this, &AnimationNodeBlendTreeEditor::_connection_to_empty));
|
|
|
+ graph->connect("connection_from_empty", callable_mp(this, &AnimationNodeBlendTreeEditor::_connection_from_empty));
|
|
|
float graph_minimap_opacity = EditorSettings::get_singleton()->get("editors/visual_editors/minimap_opacity");
|
|
|
graph->set_minimap_opacity(graph_minimap_opacity);
|
|
|
|
|
@@ -905,13 +948,13 @@ AnimationNodeBlendTreeEditor::AnimationNodeBlendTreeEditor() {
|
|
|
add_node->connect("about_to_popup", callable_mp(this, &AnimationNodeBlendTreeEditor::_update_options_menu));
|
|
|
|
|
|
add_options.push_back(AddOption("Animation", "AnimationNodeAnimation"));
|
|
|
- add_options.push_back(AddOption("OneShot", "AnimationNodeOneShot"));
|
|
|
- add_options.push_back(AddOption("Add2", "AnimationNodeAdd2"));
|
|
|
- add_options.push_back(AddOption("Add3", "AnimationNodeAdd3"));
|
|
|
- add_options.push_back(AddOption("Blend2", "AnimationNodeBlend2"));
|
|
|
- add_options.push_back(AddOption("Blend3", "AnimationNodeBlend3"));
|
|
|
- add_options.push_back(AddOption("Seek", "AnimationNodeTimeSeek"));
|
|
|
- add_options.push_back(AddOption("TimeScale", "AnimationNodeTimeScale"));
|
|
|
+ add_options.push_back(AddOption("OneShot", "AnimationNodeOneShot", 2));
|
|
|
+ add_options.push_back(AddOption("Add2", "AnimationNodeAdd2", 2));
|
|
|
+ add_options.push_back(AddOption("Add3", "AnimationNodeAdd3", 3));
|
|
|
+ add_options.push_back(AddOption("Blend2", "AnimationNodeBlend2", 2));
|
|
|
+ add_options.push_back(AddOption("Blend3", "AnimationNodeBlend3", 3));
|
|
|
+ add_options.push_back(AddOption("Seek", "AnimationNodeTimeSeek", 1));
|
|
|
+ add_options.push_back(AddOption("TimeScale", "AnimationNodeTimeScale", 1));
|
|
|
add_options.push_back(AddOption("Transition", "AnimationNodeTransition"));
|
|
|
add_options.push_back(AddOption("BlendTree", "AnimationNodeBlendTree"));
|
|
|
add_options.push_back(AddOption("BlendSpace1D", "AnimationNodeBlendSpace1D"));
|