2024-08-12 07:45:54 +08:00
|
|
|
---
|
|
|
|
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.
|
|
|
|
|
2024-08-26 12:03:42 +08:00
|
|
|
By using Modular Avatar's [`Shape Changer`](/docs/reference/reaction/shape-changer/) component, you can
|
2024-08-12 07:45:54 +08:00
|
|
|
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>
|
|
|
|
data:image/s3,"s3://crabby-images/e5ca1/e5ca1fe62313c7f39f97de56ed2bcacc5d213878" alt="Anon-chan with shoes and socks"
|
|
|
|
<figcaption>Shoes on</figcaption>
|
|
|
|
</figure>
|
|
|
|
|
|
|
|
<figure>
|
|
|
|
data:image/s3,"s3://crabby-images/17f7b/17f7bac8beb8f718cb6bdb33248d023471d36c77" alt="Anon-chan with shoes and socks"
|
|
|
|
<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>
|
|
|
|
data:image/s3,"s3://crabby-images/a3347/a3347c23fd880105febdbd2083d032ae1b7810b6" alt="Anon_body blendshapes"
|
|
|
|
<figcaption>Anon_body blendshapes</figcaption>
|
|
|
|
</figure>
|
|
|
|
|
|
|
|
<figure>
|
|
|
|
data:image/s3,"s3://crabby-images/294cc/294cc6a8dd888f590e70cb87bb458011beac61a3" alt="Socks blendshapes"
|
|
|
|
<figcaption>Socks blendshapes</figcaption>
|
|
|
|
</figure>
|
|
|
|
</div>
|
|
|
|
|
|
|
|
<figure>
|
|
|
|
data:image/s3,"s3://crabby-images/6f3a2/6f3a2a9d427ad9c703a7ee2c870e50bfd8c16192" alt="With blendshapes reset"
|
|
|
|
<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>
|
|
|
|
data:image/s3,"s3://crabby-images/82ba0/82ba0189f21d8ed06165fe7d4b342b3bfcf5d2ed" alt="Shoes Shape Changer"
|
|
|
|
<figcaption>Shoes Shape Changer</figcaption>
|
|
|
|
</figure>
|
|
|
|
|
|
|
|
<figure>
|
|
|
|
data:image/s3,"s3://crabby-images/0f72a/0f72aa0a68c630b90a88d87b2468bc3f8e91f00b" alt="Socks Shape Changer"
|
|
|
|
<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%"}}>
|
|
|
|
data:image/s3,"s3://crabby-images/ebc50/ebc50149d5e8609c721a5c40375476a96b21f802" alt="Overdraw option"
|
|
|
|
<figcaption>Overdraw debug view</figcaption>
|
|
|
|
</figure>
|
|
|
|
|
|
|
|
<figure>
|
|
|
|
data:image/s3,"s3://crabby-images/30d56/30d5612c2f4a05d69f28949286182e09b0e0c0a8" alt="Overdraw view"
|
|
|
|
<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>
|
|
|
|
data:image/s3,"s3://crabby-images/eb741/eb7417b38be2dab9649838b3a76d712c76060241" alt="Submenu setup"
|
|
|
|
<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>
|
|
|
|
data:image/s3,"s3://crabby-images/3db47/3db479a7f8d95b19b2efdc128d9340886209e971" alt="Shoes toggle setup"
|
|
|
|
<figcaption>Shoes toggle setup</figcaption>
|
|
|
|
</figure>
|
|
|
|
|
|
|
|
<figure>
|
|
|
|
data:image/s3,"s3://crabby-images/7c56b/7c56b1393d6dc293d4ea9d45d5ceaba163d77acd" alt="Socks toggle setup"
|
|
|
|
<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.
|
|
|
|
|
|
|
|
:::
|