modular-avatar/docs/docs/tutorials/menu/index.md

99 lines
5.4 KiB
Markdown
Raw Normal View History

2023-04-04 18:57:09 +08:00
---
sidebar_position: 4
sidebar_label: Edit menus
---
Modular Avatar includes an object-based menu editing system, which lets you easily edit menus and even create simple toggles from within the Unity inspector.
This tutorial will show you how to use this system to edit your avatar's existing menus, and how to include it in your assets.
## Converting an existing avatar's menu
The easiest way to get started with the menu editor is to convert the menu on your existing avatar. Right click your avatar and select `[Modular Avatar] Extract menu`.
![Extracting a menu](extract-menu.png)
When you do this, a new `Avatar Menu` object will be added to your avatar, containing the top level of your avatar's menu.
![Top-level menu](menu-toplevel.png)
As you can see, your menu items have been turned into objects. You can inspect the individual menu items as well.
![Single menu item](menuitem-single.png)
You can click the "extract to objects" button here to convert this submenu as well. This will then let you see multiple levels
of your menu right in the hierarchy window.
![Extracted second-level menu item](second-level-extract.png)
Once extracted to objects, you can drag and drop items around to move them within your menus.
### Adding new menu items
When you've extracted a menu, you can add new menu items to it by clicking the "Add menu item" button at the bottom of the list of controls.
![Add menu item button](add-menu-item-button.png)
This will add a new menu item to the end of the list. You can then edit the name, type, parameter, etc.
To create submenus, set "Type" to "Sub Menu", then set "Submenu Source" to "Children". Then, you can click "add menu item" to add sub-items to this new menu.
![Creating a submenu](new-submenu-item.png)
### Parameters
When setting parameters, you can click the arrow next to the parameter name box to search for parameters by name. This takes into account any MA Parameters components in parent objects as well.
![Parameter search](param-search.png)
## Toggles
Modular Avatar also supports creating simple toggle animations directly from the hierarchy. First, let's look at a simple ON/OFF toggle.
![Simple toggle](simple-toggle.png)
This object is available as the "Simple Toggle" sample. As you can see, all we've done is add a "MA Action Toggle Object" to our MA Menu Item, set the menu item to "Toggle", and added the objects we want to show or hide.
The checkbox next to the cube indicates that the cube should show when the toggle is on, and hide when the toggle is off. If you clear the checkbox, then the cube will be visible when the menu toggle is off, and hidden when on.
:::tip
You can drag-and-drop objects directly to the object list to easily add them!
:::
### Multi-option toggles
In some cases you might want more complex toggles. This can be done by adding a "MA Control Group" to group the toggles. Let's look at an example.
![Sample control group object](control-group.png)
Here we have a clothing menu which has a control group on it. The control group has no settings on it; it's just there to tie together the menu items. Here's what those look like:
![Clothing menu item: Default](clothes-0.png)
![Clothing menu item: Blanchir](clothes-1.png)
![Clothing menu item: SailorOnepiece](clothes-2.png)
As you can see, each of these menu items has a "Toggle" type, and a "MA Action Toggle Object" component. The "MA Action Toggle Object" component has a checkbox next to each object, which indicates whether that object should be shown when the menu item is selected.
What's different here is that we've specified the control group object under "Control Group", and on the default object, we selected "Is Group Default".
When you specify a control group, only one menu item out of the control group can be selected at a time. This essentially means they'll be bound to the same parameter.
You can select one item out of your control group to be the default item. When you do this, the default item will be selected initially, and anything that it selects will be reversed when you select a different item. In this example, because we selected the "Kikyo_Blouse", "Kikyo_Coat", and "Kikyo_Skirt" objects ON in the default item, these will be toggled off when we select Blanchir or SailorOnepiece. You can override this on the individual other items by adding that item in explicitly.
### Limitations
This feature is in preview and has a number of limitations you should be aware of:
1. Objects can only be controlled by one control group or ungrouped toggle at this time.
2. Currently, these toggles will not be saved. This means that if you change avatars or move between worlds, your toggles will not be saved.
3. A toggle cannot both control actions and traditional animators at the same time.
These limitations will be improved on in future releases.
## Using on reusable assets
You can use the new menu item controls on reusable assets as well. Take a look at the Fingerpen or SimpleToggle assets for an example.
At a high level, if you just want to add a single control or submenu, add a MA Menu Installer and MA Menu Item on the same Game Object. The menu installer will install the menu item on the target avatar automatically.
If you want to add multiple controls to the avatar without grouping them into a submenu, you can add a MA Menu Installer and MA Menu Group. The menu group allows the menu installer to install multiple items without adding them to a submenu. This is how the extract menu system recreates the base avatar menu as unity objects.