Summary
    Base class for all states in an 
		Animancer.AnimancerGraph graph which manages one or more
    UnityEngine.Playables.Playables.
    - Assembly
- Animancer.dll 
- Namespace
- Animancer
- Interfaces
- 
									- ICopyable<AnimancerNode> 
- IEnumerable<AnimancerState> 
- IEnumerator
- IHasDescription
- IAnimation Clip Collection 
- ICloneable<AnimancerState> 
- ICopyable<AnimancerState> 
 
- ICopyable
- Base Types
- 
									- Object
- AnimancerNodeBase
- AnimancerNode
 
- Derived Types
							graph BT
	Type-->Base0["AnimancerNode"]
	click Base0 "/animancer/api/Animancer/AnimancerNode"
	Base0-->Base1["AnimancerNodeBase"]
	click Base1 "/animancer/api/Animancer/AnimancerNodeBase"
	Base1-->Base2["Object"]
	Type-.->Interface0["ICopyable<AnimancerNode>"]
	Type-.->Interface1["IEnumerable<AnimancerState>"]
	Type-.->Interface2["IEnumerator"]
	Type-.->Interface3["IHasDescription"]
	click Interface3 "/animancer/api/Animancer/IHasDescription"
	Type-.->Interface4["IAnimationClipCollection"]
	click Interface4 "/animancer/api/Animancer/IAnimationClipCollection"
	Type-.->Interface5["ICloneable<AnimancerState>"]
	Type-.->Interface6["ICopyable<AnimancerState>"]
	Type["AnimancerState"]
class Type type-node
	Derived0["PlayableAssetState"]-->Type
	click Derived0 "/animancer/api/Animancer/PlayableAssetState"
	Derived1["ParentState"]-->Type
	click Derived1 "/animancer/api/Animancer/ParentState"
	Derived2["ClipState"]-->Type
	click Derived2 "/animancer/api/Animancer/ClipState"
	Derived3["ControllerState"]-->Type
	click Derived3 "/animancer/api/Animancer/ControllerState"
	Derived4["AnimationJobState<T>"]-->Type
	click Derived4 "/animancer/api/Animancer/AnimationJobState_1"
						
					Syntax
public abstract class AnimancerState : AnimancerNode, ICopyable<AnimancerNode>, 
    IEnumerable<AnimancerState>, IEnumerator, IHasDescription, IAnimationClipCollection, 
    ICloneable<AnimancerState>, ICopyable<AnimancerState>Remarks
    This class can be used as a custom yield instruction to wait until the animation either stops playing or
    reaches its end.
    
    Documentation:
    
    States
    
			Properties
| Name | Value | Summary | 
|---|---|---|
| ApplyAnimatorIK | bool | 
    Should Unity call  OnAnimatorIKon the animated object while this object and its children have anyAnimancer.AnimancerNode.Weight?Inherited from AnimancerNode | 
| ApplyFootIK | bool | Should this object and its children apply IK to the character's feet? Inherited from AnimancerNode | 
| Apply | bool | 
    Should setting the  Animancer.AnimancerNodeBase.Parentalso set this node'sAnimancer.AnimancerNode.ApplyAnimatorIKto match it?
    Default is true.Inherited from AnimancerNode static | 
| ApplyParentFootIK | bool | 
    Should setting the  Animancer.AnimancerNodeBase.Parentalso set this node'sAnimancer.AnimancerNode.ApplyFootIKto match it?
    Default is true.Inherited from AnimancerNode static | 
| AverageVelocity | Vector3 | The average velocity of the Root Motion caused by this state. | 
| ChildCount | int | The number of nodes using this as their  Animancer.AnimancerNodeBase.Parent.Inherited from AnimancerNodeBase | 
| Clip | AnimationClip | The  UnityEngine.AnimationClipwhich this state plays (if any). | 
| DebugName | Object | [Assert-Only] The Inspector display name of this node. Inherited from AnimancerNode | 
| Duration | float | 
     The number of seconds the animation will take to play fully at its current
      Animancer.AnimancerNodeBase.EffectiveSpeed. | 
| EffectiveSpeed | float | 
    The  Animancer.AnimancerNodeBase.Speedof this node multiplied by theAnimancer.AnimancerNodeBase.Speedof each of its parents to
    determine the actual speed it's playing at.Inherited from AnimancerNodeBase | 
| EffectiveWeight | float | 
    The  Animancer.AnimancerNode.Weightof this state multiplied by theAnimancer.AnimancerNode.Weightof each of its parents down
    the hierarchy to determine how much this state affects the final output.Inherited from AnimancerNode | 
| FadeGroup | FadeGroup | The current fade being applied to this node (if any). Inherited from AnimancerNode | 
| FadeSpeed | float | The speed at which this node is fading towards the  Animancer.AnimancerNode.TargetWeight.Inherited from AnimancerNode | 
| Graph | AnimancerGraph | The  Animancer.AnimancerGraphcontaining this node.Inherited from AnimancerNodeBase | 
| HasEvents | bool | Have the  Animancer.AnimancerState.SharedEventsorAnimancer.AnimancerState.OwnedEventsbeen initialized? | 
| HasOwnedEvents | bool | Have the  Animancer.AnimancerState.OwnedEventsbeen initialized? | 
| Index | int | The index of the port this node is connected to on the parent's  UnityEngine.Playables.Playable.Inherited from AnimancerNode | 
| IsActive | bool | Is this state currently updating or affecting the animation output? | 
| IsCurrent | bool | Is this state playing and not fading out? | 
| IsLooping | bool | Will this state loop back to the start when it reaches the end? | 
| IsPlaying | bool | Is the  Animancer.AnimancerState.Timeautomatically advancing? | 
| IsStopped | bool | Is this state not playing and at 0  Animancer.AnimancerNode.Weight? | 
| Keep | bool | Should child playables stay connected to the graph at all times? Inherited from AnimancerNodeBase | 
| Key | Object | 
    The object used to identify this state in the graph  Animancer.AnimancerGraph.Statesdictionary.
    Can be null. | 
| Layer | AnimancerLayer | The root  Animancer.AnimancerLayerwhich this node is connected to (if any).Inherited from AnimancerNodeBase | 
| LayerIndex | int | 
    The index of the  Animancer.AnimancerLayerthis state is connected to
    (determined by theAnimancer.AnimancerNodeBase.Parent). | 
| Length | float | 
    The total time this state would take to play in seconds when  Animancer.AnimancerNodeBase.Speed= 1. | 
| MainObject | Object | The main object to show in the Inspector for this state (if any). | 
| MainObjectType | Type | [Editor-Only] The base type which can be assigned to the  Animancer.AnimancerState.MainObject. | 
| NormalizedEndTime | float | 
    The  Animancer.AnimancerState.NormalizedTimeafter which theAnimancer.AnimancerEvent.Sequence.OnEndcallback will be invoked every frame. | 
| NormalizedTime | float | 
     The  Animancer.AnimancerState.Timeof this state as a portion of the animation'sAnimancer.AnimancerState.Length, meaning the
     value goes from 0 to 1 as it plays from start to end, regardless of how long that actually takes. | 
| NormalizedTimeD | double | The underlying  doublevalue ofAnimancer.AnimancerState.NormalizedTime. | 
| OwnedEvents | AnimancerEvent | 
    Events which will be triggered while this state plays
    based on its  Animancer.AnimancerState.NormalizedTime. | 
| Owner | Object | [Assert-Only] An optional reference to the object that owns this state. | 
| Parent | AnimancerNodeBase | The object which receives the output of the  Animancer.AnimancerNodeBase.Playable.Inherited from AnimancerNodeBase | 
| Playable | Playable | The internal object this node manages in the  UnityEngine.Playables.PlayableGraph.Inherited from AnimancerNodeBase | 
| Raise | bool | Should events be raised on a state which is currently fading out? static | 
| RawTime | double | 
    The internal implementation of  Animancer.AnimancerState.Timewhich directly gets and sets the underlying value. | 
| RemainingDuration | float | 
     The number of seconds this state will take to go from its current  Animancer.AnimancerState.NormalizedTimeto theAnimancer.AnimancerState.NormalizedEndTimeat its currentAnimancer.AnimancerNodeBase.EffectiveSpeed. | 
| SharedEvents | AnimancerEvent | 
    Events which will be triggered while this state plays
    based on its  Animancer.AnimancerState.NormalizedTime. | 
| Speed | float | [Pro-Only] How fast the  Animancer.AnimancerState.Timeis advancing every frame (default 1).Inherited from AnimancerNodeBase | 
| TargetWeight | float | 
    The desired  Animancer.AnimancerNode.Weightwhich this node is fading towards according to theAnimancer.AnimancerNode.FadeSpeed.Inherited from AnimancerNode | 
| Time | float | The number of seconds that have passed since the start of this animation. | 
| TimeD | double | The underlying  doublevalue ofAnimancer.AnimancerState.Time. | 
| TraceConstructor | bool | [Assert-Only]
    Should a  System.Diagnostics.StackTracebe captured in the constructor of all new nodes soAnimancer.OptionalWarning.UnusedNodecan include it in the warning if that node ends up being unused?Inherited from AnimancerNode static | 
| Weight | float | The current blend weight of this node which determines how much it affects the final output. Inherited from AnimancerNode | 
Methods
| Name | Value | Summary | 
|---|---|---|
| ~AnimancerNode | void | [Assert-Only] Checks  Animancer.OptionalWarning.UnusedNode.Inherited from AnimancerNode | 
| AddContextMenuIK | void | [Editor-Only]
    Adds functions to show and set  Animancer.AnimancerNodeBase.ApplyAnimatorIKandAnimancer.AnimancerNodeBase.ApplyFootIK.Inherited from AnimancerNodeBase static | 
| AppendDescription | void | Appends a detailed descrption of the current details of this object. Inherited from AnimancerNode | 
| AppendDetails | void | Called by  Animancer.AnimancerNode.AppendDescription(System.Text.StringBuilder,System.String)to append the details of this node. | 
| AppendIKDetails | void | 
    Appends the details of  Animancer.AnimancerNodeBase.ApplyAnimatorIKandAnimancer.AnimancerNodeBase.ApplyFootIK.Inherited from AnimancerNode static | 
| Assert | void | [Assert-Only]
    Calls  Animancer.AnimancerNode.GetConnectionStatusErrorand logs the result if it isn'tnull.Inherited from AnimancerNode | 
| Assert | void | [Assert-Only] Calls  Animancer.AnimancerNode.AssertConnectionStatusfor the `node` and all of its children.Inherited from AnimancerNode static | 
| AssertOwnership | void | [Assert-Conditional]
    Sets the  Animancer.AnimancerState.Ownerand asserts that it wasn't already set to a different object. | 
| CancelFade | void | Removes this node from the  Animancer.AnimancerNode.FadeGroup.Inherited from AnimancerNode | 
| ChangeMainObject | bool | 
    Sets the `currentObject` and calls  Animancer.AnimancerNode.RecreatePlayable.
    If the `currentObject` was being used as theAnimancer.AnimancerState.Keythen it is changed as well. | 
| Clone | AnimancerState | Creates a new object with the same type and values this. | 
| CopyFrom | void | Copies the details of `copyFrom` into this node, replacing its previous contents. | 
| CopyFrom | void | Copies the contents of `copyFrom` into this object, replacing its previous contents. | 
| CopyIKFlags | void | 
    Copies the IK settings from `copyFrom` into this node:
     
 Inherited from AnimancerNode | 
| CreatePlayable | void | Creates and assigns the  UnityEngine.Playables.Playablemanaged by this state. | 
| CreatePlayable | void | Creates and assigns the  UnityEngine.Playables.Playablemanaged by this node.Inherited from AnimancerNode | 
| Destroy | void | Destroys the  UnityEngine.Playables.Playableand cleans up this state. | 
| DestroyPlayable | void | Destroys the  UnityEngine.Playables.Playable.Inherited from AnimancerNode | 
| DisconnectChildSafe | void | Disconnects the  UnityEngine.Playables.Playableof the child at the specified `index` from this node.Inherited from AnimancerNode | 
| Events | bool | 
    If the `events` are  null, this method assigns anewAnimancer.AnimancerEvent.Sequenceand returnstrueto indicate that the caller should now initialize their event callbacks.
    Otherwise, this method simply assigns the provided `events` to this state and returnsfalse. | 
| Events | AnimancerEvent | 
    If the  Animancer.AnimancerState.OwnedEventshaven't been initialized yet,
    this method gets them and returnstrue. | 
| Events | bool | 
    If the  Animancer.AnimancerState.OwnedEventshaven't been initialized yet,
    this method gets them and returnstrue. | 
| FinishImmediately | void | 
    Sets the  Animancer.AnimancerState.NormalizedTimeto theAnimancer.AnimancerState.NormalizedEndTimeand invokes any remainingAnimancer.AnimancerEvents. | 
| GatherAnimationClips | void | [ Animancer.IAnimationClipCollection] Gathers all the animations in this state. | 
| GetChild | AnimancerState | Returns the state connected to the specified `index` as a child of this node. Inherited from AnimancerNode | 
| Get | string | 
    Returns  nullif this node is properly connected to its parent.
    Otherwise, returns an error message to be logged. | 
| Get | StackTrace | [Assert-Only]
    Returns the stack trace of the constructor (or null if  Animancer.AnimancerNode.TraceConstructorwas false).Inherited from AnimancerNode static | 
| GetEnumerator | FastEnumerator | Gets an enumerator for all of this node's child states. Inherited from AnimancerNode | 
| GetEventDispatchInfo | AnimancerEvent | Gets the details used to trigger  Animancer.AnimancerEvents on this state. | 
| GetPath | string | Returns the hierarchy path of this node through its  Animancer.AnimancerNodeBase.Parents.Inherited from AnimancerNode | 
| Is | bool | 
    Returns true if the animation is playing and has not yet passed the
     Animancer.AnimancerEvent.Sequence.EndEvent. | 
| MarkAsUsed | void | [Assert-Conditional] Prevents the `node` from causing  Animancer.OptionalWarning.UnusedNode.Inherited from AnimancerNodeBase static | 
| MoveTime | void | 
    Sets the  Animancer.AnimancerState.TimeorAnimancer.AnimancerState.NormalizedTime, but unlike those properties
    this method doesn't skip Events or Root Motion between the old and new time. | 
| MoveTime | void | 
    Sets the  Animancer.AnimancerState.TimeorAnimancer.AnimancerState.NormalizedTime, but unlike those properties
    this method doesn't skip Events or Root Motion between the old and new time. | 
| On | void | Called when a child's  Animancer.AnimancerState.IsLoopingvalue changes.Inherited from AnimancerNodeBase | 
| OnSetIsPlaying | void | Called when the value of  Animancer.AnimancerState.IsPlayingis changed. | 
| Play | void | 
    Plays this state immediately, without any blending and without affecting any other states.
     | 
| RecreatePlayable | void | Calls  Animancer.AnimancerNode.DestroyPlayableandAnimancer.AnimancerNode.CreatePlayable.Inherited from AnimancerNode | 
| Recreate | void | Calls  Animancer.AnimancerNode.RecreatePlayableon this node and all its children recursively.Inherited from AnimancerNode | 
| SetDebugName | void | [Assert-Conditional] Sets the  Animancer.AnimancerNode.DebugNameto display in the Inspector.Inherited from AnimancerNode | 
| SetExpectFade | void | [Internal] Sets a flag for  Animancer.OptionalWarning.ExpectFade.static | 
| SetGraph | void | Sets the  Animancer.AnimancerNodeBase.Graph. | 
| SetParent | void | Connects this state to the `parent` at its next available child index. | 
| SetWeight | void | 
    Sets the current blend weight of this node which determines how much it affects the final output.
    0 has no effect while 1 applies the full effect of this node.
     | 
| StartFade | void | 
    Calls  Animancer.AnimancerNode.OnStartFadeand starts fading theAnimancer.AnimancerNode.Weightover the course
    of theAnimancer.AnimancerGraph.DefaultFadeDuration(in seconds).Inherited from AnimancerNode | 
| StartFade | void | 
    Calls  Animancer.AnimancerNode.OnStartFadeand starts fading theAnimancer.AnimancerNode.Weightover the course of the `fadeDuration` (in seconds).Inherited from AnimancerNode | 
| Stop | void | Stops the animation and makes it inactive immediately so it no longer affects the output. Inherited from AnimancerNode | 
| ToString | string | 
    Returns the  Animancer.AnimancerNode.DebugNameif one is set, otherwise a string describing the type of
    this state and the name of theAnimancer.AnimancerState.MainObject. | 
| Update | void | 
    Checks if any events should be invoked on the `parent` and its children recursively.
     static | 
| Update | void | 
    Checks if any events should be invoked on the `parent` and its children recursively.
     static | 
Extension Methods
| Name | Value | Summary | 
|---|---|---|
| Calculate | float | [Animancer Extension] [Editor-Only]
    Returns the duration of the `node`s current fade (if any), otherwise returns the `defaultDuration`.
     | 
| IsValid | bool | [Animancer Extension]
    Is the `node` is not null and its  Animancer.AnimancerNodeBase.Playablevalid?From AnimancerUtilities |