|  add info |  add sync delegate | ||
| Line 11: | Line 11: | ||
| |Fields|{{RootFieldType|SyncList`1|[[Type:DriveRef`1|DriveRef`1]]<[[Type:IField|IField]]>}}|TypeAdv2=true| the list of values stored in this animation. Each field and it's type/animation data is determined by track index order. | |Fields|{{RootFieldType|SyncList`1|[[Type:DriveRef`1|DriveRef`1]]<[[Type:IField|IField]]>}}|TypeAdv2=true| the list of values stored in this animation. Each field and it's type/animation data is determined by track index order. | ||
| }} | }} | ||
| === Special Functions === | |||
| {| class="wikitable" style="font-size:10pt;" | |||
| ! colspan="2" style="background: lightblue; font-size:10pt;" | Custom UI Elements | |||
| |- style="font-size:10pt; text-align:center; font-weight:bold;" | |||
| | Name | |||
| | Description | |||
| |- | |||
| |Setup fields by name | |||
| |Sets up all the target values based on the <code>property</code> field of each track in the animation <code>Clip</code> file. | |||
| |} | |||
| == Behavior == | == Behavior == | ||
| This component doesn't require every item of <code>Fields</code> to be filled out to still function. This behavior can be taken advantage of. | |||
| In the case of Ghostly's Mantis Blade, the arm which the blade is attached to comes with an animation to animate the blade. However, the animation being imported onto a full [[Component:VRIK|VRIK]] rig will prevent the VRIK from being generated. Though if the model is imported again without the animation, the rig will not be animated but it will have VRIK. If the Animator component is moved to the root of the VRIK avatar and the user hits set up slots, then the animator will animate the mantis blade on the arm once again, even though most of the fields are empty. | |||
| == Examples == | == Examples == | ||
Revision as of 20:11, 19 March 2024

Animator is a component that's used to play Animation and drive a list of fields using the contained animation data. The order and type of said fields is determined by the Animation in the Clip field, and the value sampled from the Animation for any field (Fields) is determined by the Animation's sampled value at the position the _playback is currently at. Sampling is determined by the type of Animation Clip is.
Usage
| Name | Type | Description | 
|---|---|---|
| persistent | Bool | Determines whether or not this item will be saved to the server. | 
| UpdateOrder | Int | Controls the order in which this component is updated. | 
| Enabled | Bool | Controls whether or not this component is enabled. Some components stop their functionality when this field is disabled, but some don't. | 
| _playback | direct SyncPlayback | Is populated by the length and properties of Clipand is used to determine what point at which to sample theClip. | 
| Clip | Animation | An Animation used to determine the list of Fieldson this component and their value/ref types. | 
| Fields | list of DriveRef`1<IField> | the list of values stored in this animation. Each field and it's type/animation data is determined by track index order. | 
Special Functions
| Custom UI Elements | |
|---|---|
| Name | Description | 
| Setup fields by name | Sets up all the target values based on the propertyfield of each track in the animationClipfile. | 
Behavior
This component doesn't require every item of Fields to be filled out to still function. This behavior can be taken advantage of.
In the case of Ghostly's Mantis Blade, the arm which the blade is attached to comes with an animation to animate the blade. However, the animation being imported onto a full VRIK rig will prevent the VRIK from being generated. Though if the model is imported again without the animation, the rig will not be animated but it will have VRIK. If the Animator component is moved to the root of the VRIK avatar and the user hits set up slots, then the animator will animate the mantis blade on the arm once again, even though most of the fields are empty.
Examples
This is generated by the GLTF and FBX importers when a file with animation data is imported. Any extra animations that don't fit into the animator (EX: NLA tracks from Blender3D) when the animation is imported is put as a component attached to the AssetSlot for the file that is generated by the importer while importing.
