mirror of
https://github.com/bdunderscore/modular-avatar.git
synced 2025-01-22 06:20:07 +08:00
aa698565ab
* chore: refactor state machine clone logic out as a separate class * feat: add layer priority and relative path root options to Merge Animator * feat: add Merge Blend Tree component * chore: adjust NDMF dependency * docs: update merge-animator docs * docs: merge blend tree docs
57 lines
3.4 KiB
Markdown
57 lines
3.4 KiB
Markdown
# Merge Animator
|
|
|
|
![Merge Animator](merge-animator.png)
|
|
|
|
The merge animator component will add the provided animator to a specified layer of the avatar it is added to. This can be used to make complex AV3 gimmicks that install themselves just by dragging and dropping onto an avatar.
|
|
|
|
[Two samples](/docs/samples/) are included that use this component: A hand-clap effect, and a finger-pen gimmick.
|
|
|
|
## When should I use it?
|
|
|
|
Merge Animator should be used when you have animations you'd like to play back as part of your gimmick.
|
|
|
|
## When shouldn't I use it?
|
|
|
|
Merge Animator adds to, but does not replace existing animator layers. If you want the end-user to completely replace an animator layer, it may be better to have them replace it in the avatar descriptor in the traditional way.
|
|
|
|
## Setting up Merge Animator
|
|
|
|
Add the Merge Animator component to an object in your prefab, and attach the animator in the "Animator to merge" field. Set the "Layer Type" field to the avatar layer this should be added to (e.g. FX).
|
|
|
|
### Recording animations
|
|
|
|
By default, paths in your animator are interpreted as relative to the merge animator component. This makes it easy to record new animations, provided you're animating object underneath the Merge Animator component.
|
|
|
|
Just attach an Animator component to your GameObject, and you can use the Animation panel to record animations:
|
|
|
|
![Recording an animation using Merge Animator](merge-animator-record.png)
|
|
|
|
As a development convenience, you can check the "Delete attached animator" box to remove the animator component at build time.
|
|
|
|
### Humanoid bone animations
|
|
|
|
Animations that move humanoid bones ignore the relative path logic, and will always apply to the overall avatar. As such most humanoid animations (e.g. AFK animations) can be used as-is.
|
|
|
|
### Path mode
|
|
|
|
The path mode option controls how animation paths are interpreted. In "Relative" mode, all paths are relative to a
|
|
specific object, usually the one the Merge Animator component is attached to. This allows you to create gimmicks that
|
|
work when they're moved around in the avatar,
|
|
and makes it easier to record the animations, by using the Unity animator component (as described above). You can
|
|
control which object is used as the root for paths in animations by setting the "Relative Path Root" field.
|
|
|
|
If you want to animate objects that are already attached to the avatar (that aren't under your object), set the path mode to "Absolute". This will cause the animator to use absolute paths, and will not attempt to interpret paths relative to the Merge Animator component.
|
|
This means you will need to record your animations using the avatar's root animator instead.
|
|
|
|
### Write Defaults
|
|
|
|
By default, the write defaults state of your animator will not be changed. If you want to ensure that the WD settings of your animator states always matches the avatar's animator, click "Match Avatar Write Defaults".
|
|
This will detect whether the avatar is using write defaults ON or OFF states consistently, and if so your animator will be adjusted to match. If the avatar is inconsistent in its use of write defaults, your animator will be unchanged.
|
|
|
|
## Limitations
|
|
|
|
### VRCAnimatorLayerControl
|
|
|
|
Currently, Merge Animator only supports VRCAnimatorLayerControl state behaviors which reference layers within the same animator.
|
|
If you intend to use this support, ensure the `Playable` field matches the layer set on the Merge Animator component, and set the `Layer`
|
|
field to be the index of the layer within your animator. |