mirror of
https://github.com/godotengine/godot.git
synced 2025-01-06 17:37:18 +08:00
75a8606b83
Allows specifying an expression as a condition for state machine transitions. This gives much greater flexibility for creating complex state machines. By directly interfacing with the script code, it is possible to create complex animation advance condition for switching between states. Ensure assigning AnimationTreeStateMachineTransition base expression node in editor is relative to current AnimationTree node. Allow setting an expression base node on the AnimationTree itself. Co-Authored-By: reduz <reduzio@gmail.com>
63 lines
3.8 KiB
XML
63 lines
3.8 KiB
XML
<?xml version="1.0" encoding="UTF-8" ?>
|
|
<class name="AnimationNodeStateMachineTransition" inherits="Resource" version="4.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../class.xsd">
|
|
<brief_description>
|
|
</brief_description>
|
|
<description>
|
|
</description>
|
|
<tutorials>
|
|
<link title="AnimationTree">$DOCS_URL/tutorials/animation/animation_tree.html</link>
|
|
</tutorials>
|
|
<members>
|
|
<member name="advance_condition" type="StringName" setter="set_advance_condition" getter="get_advance_condition" default="&""">
|
|
Turn on auto advance when this condition is set. The provided name will become a boolean parameter on the [AnimationTree] that can be controlled from code (see [url=$DOCS_URL/tutorials/animation/animation_tree.html#controlling-from-code][/url]). For example, if [member AnimationTree.tree_root] is an [AnimationNodeStateMachine] and [member advance_condition] is set to [code]"idle"[/code]:
|
|
[codeblocks]
|
|
[gdscript]
|
|
$animation_tree.set("parameters/conditions/idle", is_on_floor and (linear_velocity.x == 0))
|
|
[/gdscript]
|
|
[csharp]
|
|
GetNode<AnimationTree>("animation_tree").Set("parameters/conditions/idle", IsOnFloor && (LinearVelocity.x == 0));
|
|
[/csharp]
|
|
[/codeblocks]
|
|
</member>
|
|
<member name="advance_expression" type="String" setter="set_advance_expression" getter="get_advance_expression" default="""">
|
|
Use an expression as a condition for state machine transitions. It is possible to create complex animation advance conditions for switching between states and gives much greater flexibility for creating complex state machines by directly interfacing with the script code.
|
|
</member>
|
|
<member name="advance_expression_base_node" type="NodePath" setter="set_advance_expression_base_node" getter="get_advance_expression_base_node" default="NodePath("")">
|
|
The path to the [Node] used to evaluate an [Expression] if one is not explictly specified internally.
|
|
</member>
|
|
<member name="auto_advance" type="bool" setter="set_auto_advance" getter="has_auto_advance" default="false">
|
|
Turn on the transition automatically when this state is reached. This works best with [constant SWITCH_MODE_AT_END].
|
|
</member>
|
|
<member name="disabled" type="bool" setter="set_disabled" getter="is_disabled" default="false">
|
|
Don't use this transition during [method AnimationNodeStateMachinePlayback.travel] or [member auto_advance].
|
|
</member>
|
|
<member name="priority" type="int" setter="set_priority" getter="get_priority" default="1">
|
|
Lower priority transitions are preferred when travelling through the tree via [method AnimationNodeStateMachinePlayback.travel] or [member auto_advance].
|
|
</member>
|
|
<member name="switch_mode" type="int" setter="set_switch_mode" getter="get_switch_mode" enum="AnimationNodeStateMachineTransition.SwitchMode" default="0">
|
|
The transition type.
|
|
</member>
|
|
<member name="xfade_time" type="float" setter="set_xfade_time" getter="get_xfade_time" default="0.0">
|
|
The time to cross-fade between this state and the next.
|
|
</member>
|
|
</members>
|
|
<signals>
|
|
<signal name="advance_condition_changed">
|
|
<description>
|
|
Emitted when [member advance_condition] is changed.
|
|
</description>
|
|
</signal>
|
|
</signals>
|
|
<constants>
|
|
<constant name="SWITCH_MODE_IMMEDIATE" value="0" enum="SwitchMode">
|
|
Switch to the next state immediately. The current state will end and blend into the beginning of the new one.
|
|
</constant>
|
|
<constant name="SWITCH_MODE_SYNC" value="1" enum="SwitchMode">
|
|
Switch to the next state immediately, but will seek the new state to the playback position of the old state.
|
|
</constant>
|
|
<constant name="SWITCH_MODE_AT_END" value="2" enum="SwitchMode">
|
|
Wait for the current state playback to end, then switch to the beginning of the next state animation.
|
|
</constant>
|
|
</constants>
|
|
</class>
|