Improved bindings and added documentation for AnimationNode, closes #20720
This commit is contained in:
parent
95d604b9cd
commit
81c86e8047
@ -29,8 +29,6 @@
|
|||||||
<member name="Geometry" type="Geometry" setter="" getter="">
|
<member name="Geometry" type="Geometry" setter="" getter="">
|
||||||
[Geometry] singleton
|
[Geometry] singleton
|
||||||
</member>
|
</member>
|
||||||
<member name="GodotSharp" type="GodotSharp" setter="" getter="">
|
|
||||||
</member>
|
|
||||||
<member name="IP" type="IP" setter="" getter="">
|
<member name="IP" type="IP" setter="" getter="">
|
||||||
[IP] singleton
|
[IP] singleton
|
||||||
</member>
|
</member>
|
||||||
|
@ -1,8 +1,11 @@
|
|||||||
<?xml version="1.0" encoding="UTF-8" ?>
|
<?xml version="1.0" encoding="UTF-8" ?>
|
||||||
<class name="AnimationNode" inherits="Resource" category="Core" version="3.1">
|
<class name="AnimationNode" inherits="Resource" category="Core" version="3.1">
|
||||||
<brief_description>
|
<brief_description>
|
||||||
|
Base resource for [AnimationTree] nodes.
|
||||||
</brief_description>
|
</brief_description>
|
||||||
<description>
|
<description>
|
||||||
|
Base resource for [AnimationTree] nodes. In general it's not used directly but you can create custom ones with custom blending formulas.
|
||||||
|
Inherit this when creating nodes mainly for use in [AnimationNodeBlendTree], otherwise [AnimationRootNode] should be used instead.
|
||||||
</description>
|
</description>
|
||||||
<tutorials>
|
<tutorials>
|
||||||
</tutorials>
|
</tutorials>
|
||||||
@ -15,6 +18,7 @@
|
|||||||
<argument index="0" name="name" type="String">
|
<argument index="0" name="name" type="String">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Add an input to the node. This is only useful for nodes created for use in an [AnimationNodeBlendTree]
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="blend_animation">
|
<method name="blend_animation">
|
||||||
@ -31,6 +35,7 @@
|
|||||||
<argument index="4" name="blend" type="float">
|
<argument index="4" name="blend" type="float">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Blend an animation by "blend" amount (name must be valid in the linked [AnimationPlayer]). A time and delta mas be passed, as well as whether seek happened.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="blend_input">
|
<method name="blend_input">
|
||||||
@ -49,6 +54,7 @@
|
|||||||
<argument index="5" name="optimize" type="bool" default="true">
|
<argument index="5" name="optimize" type="bool" default="true">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Blend an input. This is only useful for nodes created for an AnimationBlendTree. Time is a delta, unless "seek" is true, in which case it is absolute. A filter mode may be optionally passed.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="blend_node">
|
<method name="blend_node">
|
||||||
@ -69,18 +75,37 @@
|
|||||||
<argument index="6" name="optimize" type="bool" default="true">
|
<argument index="6" name="optimize" type="bool" default="true">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Blend another animaiton node (in case this node contains children animation nodes). This function is only useful if you inherit from [AnimationRootNode] instead, else editors will not display your node for addition.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="get_caption" qualifiers="virtual">
|
<method name="get_caption" qualifiers="virtual">
|
||||||
<return type="String">
|
<return type="String">
|
||||||
</return>
|
</return>
|
||||||
<description>
|
<description>
|
||||||
|
Get the text caption for this node (used by some editors)
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
|
<method name="get_child_by_name" qualifiers="virtual">
|
||||||
|
<return type="Object">
|
||||||
|
</return>
|
||||||
|
<argument index="0" name="name" type="String">
|
||||||
|
</argument>
|
||||||
|
<description>
|
||||||
|
Get the a child node by index (used by editors inheriting from [AnimationRootNode]).
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
|
<method name="get_child_nodes" qualifiers="virtual">
|
||||||
|
<return type="Dictionary">
|
||||||
|
</return>
|
||||||
|
<description>
|
||||||
|
Get all children nodes, in order as a name:node dictionary. Only useful when inheriting [AnimationRootNode].
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="get_input_count" qualifiers="const">
|
<method name="get_input_count" qualifiers="const">
|
||||||
<return type="int">
|
<return type="int">
|
||||||
</return>
|
</return>
|
||||||
<description>
|
<description>
|
||||||
|
Amount of inputs in this node, only useful for nodes that go into [AnimationBlendTree].
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="get_input_name">
|
<method name="get_input_name">
|
||||||
@ -89,6 +114,7 @@
|
|||||||
<argument index="0" name="input" type="int">
|
<argument index="0" name="input" type="int">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Get the name of an input by index.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="get_parameter" qualifiers="const">
|
<method name="get_parameter" qualifiers="const">
|
||||||
@ -97,12 +123,31 @@
|
|||||||
<argument index="0" name="name" type="String">
|
<argument index="0" name="name" type="String">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Get the value of a parameter. Parameters are custom local memory used for your nodes, given a resource can be reused in multiple trees.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
|
<method name="get_parameter_default_value" qualifiers="virtual">
|
||||||
|
<return type="Variant">
|
||||||
|
</return>
|
||||||
|
<argument index="0" name="name" type="String">
|
||||||
|
</argument>
|
||||||
|
<description>
|
||||||
|
Get the default value of a parameter. Parameters are custom local memory used for your nodes, given a resource can be reused in multiple trees.
|
||||||
|
</description>
|
||||||
|
</method>
|
||||||
|
<method name="get_parameter_list" qualifiers="virtual">
|
||||||
|
<return type="Array">
|
||||||
|
</return>
|
||||||
|
<description>
|
||||||
|
Get the property information for parameter. Parameters are custom local memory used for your nodes, given a resource can be reused in multiple trees.
|
||||||
|
Format is similar to [Object.get_property_list]
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="has_filter" qualifiers="virtual">
|
<method name="has_filter" qualifiers="virtual">
|
||||||
<return type="String">
|
<return type="String">
|
||||||
</return>
|
</return>
|
||||||
<description>
|
<description>
|
||||||
|
Return true whether you want the blend tree editor to display filter editing on this node.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="is_path_filtered" qualifiers="const">
|
<method name="is_path_filtered" qualifiers="const">
|
||||||
@ -111,6 +156,7 @@
|
|||||||
<argument index="0" name="path" type="NodePath">
|
<argument index="0" name="path" type="NodePath">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Return true wether a given path is filtered.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="process" qualifiers="virtual">
|
<method name="process" qualifiers="virtual">
|
||||||
@ -121,6 +167,10 @@
|
|||||||
<argument index="1" name="seek" type="bool">
|
<argument index="1" name="seek" type="bool">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Called when a custom node is processed. The argument "time" is relative, unless "seek" is true (in which case it is absolute).
|
||||||
|
Here, call the [method blend_input], [method blend_node] or [method blend_animation] functions.
|
||||||
|
You can also use [method get_parameter] and [method set_parameter] to modify local memory.
|
||||||
|
This function returns the time left for the current animation to finish (if unsure, just pass the value from the main blend being called).
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="remove_input">
|
<method name="remove_input">
|
||||||
@ -129,6 +179,7 @@
|
|||||||
<argument index="0" name="index" type="int">
|
<argument index="0" name="index" type="int">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Remove an input, call this only when inactive.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="set_filter_path">
|
<method name="set_filter_path">
|
||||||
@ -139,6 +190,7 @@
|
|||||||
<argument index="1" name="enable" type="bool">
|
<argument index="1" name="enable" type="bool">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Add/Remove a path for the filter.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
<method name="set_parameter">
|
<method name="set_parameter">
|
||||||
@ -149,16 +201,19 @@
|
|||||||
<argument index="1" name="value" type="Variant">
|
<argument index="1" name="value" type="Variant">
|
||||||
</argument>
|
</argument>
|
||||||
<description>
|
<description>
|
||||||
|
Set a custom parameter. These are used as local storage, because resources can be reused across the tree or scenes.
|
||||||
</description>
|
</description>
|
||||||
</method>
|
</method>
|
||||||
</methods>
|
</methods>
|
||||||
<members>
|
<members>
|
||||||
<member name="filter_enabled" type="bool" setter="set_filter_enabled" getter="is_filter_enabled">
|
<member name="filter_enabled" type="bool" setter="set_filter_enabled" getter="is_filter_enabled">
|
||||||
|
Return whether filtering is enabled.
|
||||||
</member>
|
</member>
|
||||||
</members>
|
</members>
|
||||||
<signals>
|
<signals>
|
||||||
<signal name="removed_from_graph">
|
<signal name="removed_from_graph">
|
||||||
<description>
|
<description>
|
||||||
|
Called when the node was removed from the graph.
|
||||||
</description>
|
</description>
|
||||||
</signal>
|
</signal>
|
||||||
<signal name="tree_changed">
|
<signal name="tree_changed">
|
||||||
@ -168,12 +223,16 @@
|
|||||||
</signals>
|
</signals>
|
||||||
<constants>
|
<constants>
|
||||||
<constant name="FILTER_IGNORE" value="0" enum="FilterAction">
|
<constant name="FILTER_IGNORE" value="0" enum="FilterAction">
|
||||||
|
Do not use filtering.
|
||||||
</constant>
|
</constant>
|
||||||
<constant name="FILTER_PASS" value="1" enum="FilterAction">
|
<constant name="FILTER_PASS" value="1" enum="FilterAction">
|
||||||
|
Paths matching the filter will be allowed to pass.
|
||||||
</constant>
|
</constant>
|
||||||
<constant name="FILTER_STOP" value="2" enum="FilterAction">
|
<constant name="FILTER_STOP" value="2" enum="FilterAction">
|
||||||
|
Paths matching the filter will be discarded.
|
||||||
</constant>
|
</constant>
|
||||||
<constant name="FILTER_BLEND" value="3" enum="FilterAction">
|
<constant name="FILTER_BLEND" value="3" enum="FilterAction">
|
||||||
|
Paths matching the filter will be blended (by the blend value).
|
||||||
</constant>
|
</constant>
|
||||||
</constants>
|
</constants>
|
||||||
</class>
|
</class>
|
||||||
|
@ -588,14 +588,6 @@
|
|||||||
<member name="memory/limits/multithreaded_server/rid_pool_prealloc" type="int" setter="" getter="">
|
<member name="memory/limits/multithreaded_server/rid_pool_prealloc" type="int" setter="" getter="">
|
||||||
This is used by servers when used in multi threading mode (servers and visual). RIDs are preallocated to avoid stalling the server requesting them on threads. If servers get stalled too often when loading resources in a thread, increase this number.
|
This is used by servers when used in multi threading mode (servers and visual). RIDs are preallocated to avoid stalling the server requesting them on threads. If servers get stalled too often when loading resources in a thread, increase this number.
|
||||||
</member>
|
</member>
|
||||||
<member name="mono/debugger_agent/port" type="int" setter="" getter="">
|
|
||||||
</member>
|
|
||||||
<member name="mono/debugger_agent/wait_for_debugger" type="bool" setter="" getter="">
|
|
||||||
</member>
|
|
||||||
<member name="mono/debugger_agent/wait_timeout" type="int" setter="" getter="">
|
|
||||||
</member>
|
|
||||||
<member name="mono/export/include_scripts_content" type="bool" setter="" getter="">
|
|
||||||
</member>
|
|
||||||
<member name="network/limits/debugger_stdout/max_chars_per_second" type="int" setter="" getter="">
|
<member name="network/limits/debugger_stdout/max_chars_per_second" type="int" setter="" getter="">
|
||||||
Maximum amount of characters allowed to send as output from the debugger. Over this value, content is dropped. This helps not to stall the debugger connection.
|
Maximum amount of characters allowed to send as output from the debugger. Over this value, content is dropped. This helps not to stall the debugger connection.
|
||||||
</member>
|
</member>
|
||||||
|
@ -37,9 +37,20 @@
|
|||||||
#include "servers/audio/audio_stream.h"
|
#include "servers/audio/audio_stream.h"
|
||||||
|
|
||||||
void AnimationNode::get_parameter_list(List<PropertyInfo> *r_list) const {
|
void AnimationNode::get_parameter_list(List<PropertyInfo> *r_list) const {
|
||||||
|
if (get_script_instance()) {
|
||||||
|
Array parameters = get_script_instance()->call("get_parameter_list");
|
||||||
|
for (int i = 0; i < parameters.size(); i++) {
|
||||||
|
Dictionary d = parameters[i];
|
||||||
|
ERR_CONTINUE(d.empty());
|
||||||
|
r_list->push_back(PropertyInfo::from_dict(d));
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Variant AnimationNode::get_parameter_default_value(const StringName &p_parameter) const {
|
Variant AnimationNode::get_parameter_default_value(const StringName &p_parameter) const {
|
||||||
|
if (get_script_instance()) {
|
||||||
|
return get_script_instance()->call("get_parameter_default_value");
|
||||||
|
}
|
||||||
return Variant();
|
return Variant();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -62,6 +73,18 @@ Variant AnimationNode::get_parameter(const StringName &p_name) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
void AnimationNode::get_child_nodes(List<ChildNode> *r_child_nodes) {
|
void AnimationNode::get_child_nodes(List<ChildNode> *r_child_nodes) {
|
||||||
|
|
||||||
|
if (get_script_instance()) {
|
||||||
|
Dictionary cn = get_script_instance()->call("get_child_nodes");
|
||||||
|
List<Variant> keys;
|
||||||
|
cn.get_key_list(&keys);
|
||||||
|
for (List<Variant>::Element *E = keys.front(); E; E = E->next()) {
|
||||||
|
ChildNode child;
|
||||||
|
child.name = E->get();
|
||||||
|
child.node = cn[E->get()];
|
||||||
|
r_child_nodes->push_back(child);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void AnimationNode::blend_animation(const StringName &p_animation, float p_time, float p_delta, bool p_seeked, float p_blend) {
|
void AnimationNode::blend_animation(const StringName &p_animation, float p_time, float p_delta, bool p_seeked, float p_blend) {
|
||||||
@ -373,6 +396,9 @@ void AnimationNode::_validate_property(PropertyInfo &property) const {
|
|||||||
}
|
}
|
||||||
|
|
||||||
Ref<AnimationNode> AnimationNode::get_child_by_name(const StringName &p_name) {
|
Ref<AnimationNode> AnimationNode::get_child_by_name(const StringName &p_name) {
|
||||||
|
if (get_script_instance()) {
|
||||||
|
return get_script_instance()->call("get_child_by_nane");
|
||||||
|
}
|
||||||
return Ref<AnimationNode>();
|
return Ref<AnimationNode>();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -403,6 +429,14 @@ void AnimationNode::_bind_methods() {
|
|||||||
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "filter_enabled", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR), "set_filter_enabled", "is_filter_enabled");
|
ADD_PROPERTY(PropertyInfo(Variant::BOOL, "filter_enabled", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR), "set_filter_enabled", "is_filter_enabled");
|
||||||
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "filters", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR | PROPERTY_USAGE_INTERNAL), "_set_filters", "_get_filters");
|
ADD_PROPERTY(PropertyInfo(Variant::ARRAY, "filters", PROPERTY_HINT_NONE, "", PROPERTY_USAGE_NOEDITOR | PROPERTY_USAGE_INTERNAL), "_set_filters", "_get_filters");
|
||||||
|
|
||||||
|
BIND_VMETHOD(MethodInfo(Variant::DICTIONARY, "get_child_nodes"));
|
||||||
|
BIND_VMETHOD(MethodInfo(Variant::ARRAY, "get_parameter_list"));
|
||||||
|
BIND_VMETHOD(MethodInfo(Variant::OBJECT, "get_child_by_name", PropertyInfo(Variant::STRING, "name")));
|
||||||
|
{
|
||||||
|
MethodInfo mi = MethodInfo(Variant::NIL, "get_parameter_default_value", PropertyInfo(Variant::STRING, "name"));
|
||||||
|
mi.return_val.usage = PROPERTY_USAGE_NIL_IS_VARIANT;
|
||||||
|
BIND_VMETHOD(mi);
|
||||||
|
}
|
||||||
BIND_VMETHOD(MethodInfo("process", PropertyInfo(Variant::REAL, "time"), PropertyInfo(Variant::BOOL, "seek")));
|
BIND_VMETHOD(MethodInfo("process", PropertyInfo(Variant::REAL, "time"), PropertyInfo(Variant::BOOL, "seek")));
|
||||||
BIND_VMETHOD(MethodInfo(Variant::STRING, "get_caption"));
|
BIND_VMETHOD(MethodInfo(Variant::STRING, "get_caption"));
|
||||||
BIND_VMETHOD(MethodInfo(Variant::STRING, "has_filter"));
|
BIND_VMETHOD(MethodInfo(Variant::STRING, "has_filter"));
|
||||||
|
Loading…
Reference in New Issue
Block a user