modular-avatar/docs~/docs/tutorials/advanced-toggles/index.md
bd_ 915ddc0d5b
docs: new tutorials (#983)
* fix: missing localization key

* docs: new tutorials
2024-08-11 16:45:54 -07:00

133 lines
4.8 KiB
Markdown

---
sidebar_position: 5
---
# Advanced toggles
Before we start, make sure you've read the [simple object toggle tutorial](/docs/tutorials/object_toggle/).
This tutorial will build on that tutorial, showing you how to also update blendshapes when toggling objects.
First, some background. Many avatars come with "shrink blendshapes", which are used to hide parts of the avatar, to
avoid them clipping through clothing. These blendshapes are often used in conjunction with toggles to hide and show
clothing items.
By using Modular Avatar's [`Shape Changer`](/docs/reference/reactive-components/shape-changer/) component, you can
easily update these
blendshapes
when toggling objects. Let's take a look at Anon's socks and shoes as an example.
<div style={{"display": "flex", "flex-direction": "row"}}>
<figure>
![Anon-chan with shoes and socks](0a-boots-on.png)
<figcaption>Shoes on</figcaption>
</figure>
<figure>
![Anon-chan with shoes and socks](0b-boots-off.png)
<figcaption>Shoes off</figcaption>
</figure>
</div>
As you can see, when the shoes are toggled off, you can see a bit of a stick here. This is because both the socks and
underlying foot are hidden by shrink shapekeys. Let's start by resetting them to zero.
<div style={{"display": "flex", "flex-direction": "row"}}>
<figure>
![Anon_body blendshapes](1a-bs-settings.png)
<figcaption>Anon_body blendshapes</figcaption>
</figure>
<figure>
![Socks blendshapes](1b-bs-settings.png)
<figcaption>Socks blendshapes</figcaption>
</figure>
</div>
<figure>
![With blendshapes reset](1c-results.png)
<figcaption>Blendshapes reset to zero</figcaption>
</figure>
Now, let's set up Shape Changer to toggle off the underlying layers. We'll add one to each of the shoes and socks
objects,
and shrink the layer(s) underneath them.
<div style={{"display": "flex", "flex-direction": "row"}}>
<figure>
![Shoes Shape Changer](2a-sc-boots.png)
<figcaption>Shoes Shape Changer</figcaption>
</figure>
<figure>
![Socks Shape Changer](2b-sc-socks.png)
<figcaption>Socks Shape Changer</figcaption>
</figure>
</div>
Note that we use `Delete` here. This is because, if we don't have any animatable toggles, Modular Avatar will
automatically remove the underlying polygons instead of shrinking them, which can save on performance. If you have
anything that can animate the object in question, it'll instead set the shape to 100. You can use `Set` instead if you
want to keep the underlying polygons in all cases.
Shape Changer will preview its effects in the editor... but if we do it right it's hard to tell that it's doing anything
at all! To check, click on the debug overlay button, and select `Overdraw`, to get a see-through view of what's going
on.
If you shrink too much, however, it'll be immediately obvious in the scene view.
<div style={{"display": "flex", "flex-direction": "row"}}>
<figure style={{"width": "100%"}}>
![Overdraw option](3a-overdraw-menu.png)
<figcaption>Overdraw debug view</figcaption>
</figure>
<figure>
![Overdraw view](3b-overdraw.png)
<figcaption>Overdraw view</figcaption>
</figure>
</div>
Now that we've set up our shape changers, we can go ahead and set up our toggles. Let's start by creating a submenu.
Create a new game object and add a `Menu Installer` and `Menu Item`. Then set the menu item type to `submenu`.
<div style={{"display": "flex", "flex-direction": "row", "justify-content": "center"}}>
<figure>
![Submenu setup](4-submenu-setup.png)
<figcaption>Submenu setup</figcaption>
</figure>
</div>
Now, click `Add Toggle` to create a new toggle under this submenu. Give it a new name and add our shoes object to it.
Do the same for socks as well.
<div style={{"display": "flex", "flex-direction": "row", "justify-content": "center"}}>
<figure>
![Shoes toggle setup](5-toggle-boots.png)
<figcaption>Shoes toggle setup</figcaption>
</figure>
<figure>
![Socks toggle setup](5b-toggle-socks.png)
<figcaption>Socks toggle setup</figcaption>
</figure>
</div>
:::warning
While we can preview the effect of these toggles by clicking the `default` checkbox on the menu items in
question, in the current version of Modular Avatar, the downstream effects of toggles on blendshapes can't be previewed
in the editor. Use Avatar 3.0 Emulator or Gesture Manager to test these out in play mode.
This limitation will be improved in future versions.
:::
And that's it! As you can see, Modular Avatar's Reactive Object system is designed to make it easy to set up shrink
shapekeys and other such common outfit settings.
:::tip
Outfit authors can preset these Shape Changers, to allow for easy installation of clothing, with automatically
configured blendshapes. The Reactive Object system responds to animations created by other NDMF-compatible systems, so
your users don't necessarily need to use Modular Avatar's toggle system to get the benefits of these blendshapes.
:::