2024-08-11 11:04:29 +08:00
|
|
|
---
|
2024-08-12 07:45:54 +08:00
|
|
|
sidebar_position: 6
|
|
|
|
sidebar_label: Building an animator manually
|
2024-08-11 11:04:29 +08:00
|
|
|
---
|
|
|
|
|
|
|
|
# Toggle an object (using manual animations)
|
|
|
|
|
|
|
|
In this tutorial, we'll create a simple prefab that makes a cube appear and disappear. We'll also
|
|
|
|
attach it to the avatar's hand, so it's easy to see.
|
|
|
|
|
|
|
|
## Step 1: Creating our objects
|
|
|
|
|
|
|
|
We'll start by creating the GameObjects we'll be showing. Start by dropping a test avatar in the scene,
|
|
|
|
and adding an empty GameObject to be the base of your prefab (we'll call this `ToggleDemo`). Inside this GameObject,
|
|
|
|
create a `HandRef` object
|
|
|
|
which we'll use to track the hand, and put the cube we want to display inside of that object.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/a5f3a/a5f3a7df34d401420794b83f96ccadc885d1f2c0" alt="Initial object setup"
|
|
|
|
|
|
|
|
### Attach the cube to your hand
|
|
|
|
|
|
|
|
Next, let's have the HandRef track the avatar's right hand. Select the `HandRef` object, and click `Add Component` in
|
|
|
|
the inspector.
|
|
|
|
Add a `MA Bone Proxy`.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/eed8c/eed8c041603fefc59644b3cdffcd1c0593cace15" alt="Adding a bone proxy"
|
|
|
|
|
|
|
|
Drag-and-drop the avatar's right hand bone into the "Target" field. Set "Attachment Mode" to "As child; at root".
|
|
|
|
The cube will immediately snap to the avatar's hand. Adjust its scale and position until it's not quite so in the way.
|
|
|
|
Don't forget to remove the Box Collider from the Cube as well!
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/04150/0415072c08ba71a79fcb05238d9ac392ecaf6472" alt="Configuring a bone proxy"
|
|
|
|
|
|
|
|
## Step 2: Creating our animator controller
|
|
|
|
|
|
|
|
Next, we'll create an animator controller that will control the cube's visibility.
|
|
|
|
Create a new Animator Controller, and two animation clips (we'll call them `CubeOff` and `CubeOn`). Open the Animator
|
|
|
|
Controller, and drag the two clips in.
|
|
|
|
Then right click `Any State` and choose add transition to connect it to `CubeOff`. Do the same for `CubeOn`.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/94969/94969527aa4b2906e827f386d2fac1af04c975ef" alt="Initial animator setup"
|
|
|
|
|
|
|
|
### Setting up transitions
|
|
|
|
|
|
|
|
Create a new bool parameter called `Cube`. Then, for each of your transitions, set Transition Duration to be 0, and Can
|
|
|
|
Transition to Self off.
|
|
|
|
Add our Cube parameter to the conditions, and for the CubeOff transition set it to false.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/cd7b1/cd7b17896b180a224a997b2050b840e858504680" alt="Transition setup"
|
|
|
|
|
|
|
|
## Step 3: Merge Animator, and recording our animations
|
|
|
|
|
|
|
|
Go back to your top-level GameObject, and add a `MA Merge Animator` component.
|
|
|
|
Set the `Animator to merge` to your new animator controller. Check the `delete attached animator`
|
|
|
|
and `match avatar write defaults` boxes.
|
|
|
|
Then, _also_ add an Animator component, and point it to your new animator controller as well.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/f6b77/f6b776af06ccc295d1d1784de3f2f8a28449e356" alt="Adding merge animator"
|
|
|
|
|
|
|
|
:::tip
|
|
|
|
|
|
|
|
Merge Animator doesn't need to be at the top level GameObject. Feel free to put it further
|
|
|
|
down the hierarchy if you prefer. Just make sure that `MA Parameters` (which we'll discuss further down)
|
|
|
|
is on either the same object, or a parent of all your `Merge Animator`s and `Menu Installers`!
|
|
|
|
|
|
|
|
Adding an Animator here is also optional; we're just using it so that Unity allows us to
|
|
|
|
record animations. By checking the `delete attached animator` box, Modular Avatar will delete the
|
|
|
|
`Animator` component at build time.
|
|
|
|
|
|
|
|
:::
|
|
|
|
|
|
|
|
## Step 4: Recording our animations
|
|
|
|
|
|
|
|
Go to the unity "Animation" tab. If you don't have it, press Ctrl-6 to open it.
|
|
|
|
You should see `CubeOff` and `CubeOn` (only) in the list of animations; if not, make sure that your `ToggleDemo` object
|
|
|
|
is selected.
|
|
|
|
|
|
|
|
With `CubeOff` selected, click the red record button, then turn the `Cube` GameObject off.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c7c07/c7c0773dde1b4cc6e17e4dee67cb0b42ad0c71e1" alt="Recording CubeOff"
|
|
|
|
|
|
|
|
Then, with `CubeOn` selected, click the red record button, and turn the `Cube` GameObject off, then on again.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/c58d1/c58d1fe4fb3f5c8dcd514b13b7e9b04a1e658218" alt="Recording CubeOn"
|
|
|
|
|
|
|
|
## Step 5: Setting up synced parameters
|
|
|
|
|
|
|
|
Almost there! Next, we'll set up our synced parameters, so they are automatically added.
|
|
|
|
|
|
|
|
Head back to our `ToggleDemo` object, and add a `MA Parameters` component. Click the `Show Prefab Developer Options`
|
|
|
|
checkbox.
|
|
|
|
You'll see that our `Cube` parameter is automatically added. Set Sync Mode to `Bool` and check the `Internal` box.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/01e94/01e940b74dffc93cf9e6f259540dfc58b7dc6461" alt="MA Parameters configuration"
|
|
|
|
|
|
|
|
:::tip
|
|
|
|
|
|
|
|
If you set the internal checkbox, modular avatar will ensure that your `Cube` parameter doesn't interfere with anything
|
|
|
|
else on the avatar using the same parameter name.
|
|
|
|
If you leave it unchecked, the end-user will be able to rename the parameter if they want, but can also choose to have
|
|
|
|
multiple prefabs use the same parameter.
|
|
|
|
|
|
|
|
:::
|
|
|
|
|
|
|
|
## Setup 6: Setting up the menu
|
|
|
|
|
|
|
|
Finally, we'll set up the Av3 menu entry. Create an Expressions Menu asset:
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/91c55/91c553857a26f7d0df78584e6b9a06a4f4996d30" alt="Creating an expressions menu asset"
|
|
|
|
|
|
|
|
Add one control to it; set the name to Cube, type to Toggle, and for the parameter field, enter `Cube` in the text box.
|
|
|
|
Note that because we haven't actually built the avatar yet, the parameter isn't in the dropdown yet. That's okay!
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/67f87/67f87e599794a3b13592d1874cc6cd884cfd3fc6" alt="Expressions menu setup"
|
|
|
|
|
|
|
|
Now add a `MA Menu Installer` component to your `ToggleDemo` object. Open up the `Prefab Developer Options` section, and
|
|
|
|
put your expressions menu asset there.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/8fdbe/8fdbe3daeb75353f78e22d7045475c4fbc3a814c" alt="Menu installer"
|
|
|
|
|
|
|
|
At this point, we're done! If you build and upload the avatar, you should have a menu item which will summon a cube to
|
|
|
|
your right hand.
|
|
|
|
|
|
|
|
## Finishing up: Prefab conversion and component ordering
|
|
|
|
|
|
|
|
Let's get our cube ready to distribute. First, the components our end-users might want to mess with are primarily the
|
|
|
|
Menu Installer and (if you disabled the Internal checkbox) possibly MA parameters.
|
|
|
|
We might want to drag those up to the top of our inspector.
|
|
|
|
|
|
|
|
data:image/s3,"s3://crabby-images/170e2/170e2b7d6c05951601c750e3d74b9dec57c4a1d8" alt="Component ordering"
|
|
|
|
|
|
|
|
Once you're happy with things, drag ToggleDemo into your project pane to create a prefab. Now you can drop that onto any
|
|
|
|
other avatar, and have an instant cube!
|