GitXplorerGitXplorer
W

MenuManager

public
8 stars
0 forks
1 issues

Commits

List of commits on branch master.
Unverified
55d3a9a18ad82bd24947565963c896fd9e8079a0

Add package.json meta

WWeersProductions committed 3 years ago
Unverified
ff97779650382807fa7d4e9cc30e026b902af18e

Reduce unity version

WWeersProductions committed 3 years ago
Unverified
87a51353dc766b31694427869d8981cf695e40ba

Specify year

WWeersProductions committed 3 years ago
Unverified
80628153726d379b4204841c48b25d061c9b32fe

Add Unity package metadata

WWeersProductions committed 3 years ago
Verified
4b51c1fff7b4a99440d274d135f4e42777e16df8

Merge pull request #8 from WeersProductions/Unity2020_x

WWeersProductions committed 4 years ago
Unverified
62732740fb572c5fdc195eab23ecfc3c67b483c3

Use AssemblyDefinitions

committed 4 years ago

README

The README file for this repository.

MenuManager

MenuManager is a manager for menus inside UGUI.

With just a small amount of code you can create relations between different menus. Think of popups, tooltips but also any regular menu.

Getting started

Set-up

Clone the repository, use it as a git submodule or download a UnityPackage from the forums. Open te project in Unity. This repository contains all the code you want to include in your project under the 'Assets' folder.

Git Submodule

This is the prefered way. Your current project will be your git repository and the MenuManager will be a submodule. This means it can be updated using git, but won't be in your way when managing your own repositories. To do this, go to the folder that contains all your packages (you can for example create a folder 'Imported' under 'Assets') and run the command git submodule add https://github.com/WeersProductions/MenuManager.git in your git terminal. To update it, run git submodule update.

Demo

In the Demo folder two demos show you how to use the MenuManager.

Demo Shows
Popups How to work with popups, tooltips and parent-child relations
MultipleMenuControllers How to use multiple menu controllers with shared menus

Create and select MenuController

  1. Create and/or open scene
  2. Open MenuManager editor (Window -> WeersProductions -> MenuManager)
  3. Press 'Create MenuController'
  4. Select an existing canvas of your scene, or press 'Create new'
  5. Select the newly created MenuController in the MenuManager editor on top

drawing

Adding a new menu

This system makes use of Unity Prefabs for different menus. Each menu (or popup/tooltip) is a prefab with a MCMenu component (or a subclass), which is registered in the MenuController class.

First you create your menu like you would usally do in the scene editor as a GameObject. This GameObject should have a MCMenu component or a subclass. To get started you can right click in the Hierarchy panel and click WeersProductions->Menu. This will create a new panel with the MCMenu component.

Once you have finished your menu, make it prefab and delete the Scene instance. Drag your prefab to the 'Specific menus' drag area. This will add the new menu to the selected MenuController.

Since we need a reference to the menu in code, add your menu to the Menus enum in the MenuController file, with the value being the same as the ID of the MCMenu component.

public enum Menus
        {
            UNDEFINED = -2,
            NONE = -1,
            SIMPLEPOPUP = 0,
            SIMPLETOOLTIP = 1
        }
MenuController.ShowMenuGlobal(Menus.SIMPLETOOLTIP);

To show the new menu.

Multiple MenuControllers

If you have, for example, a world canvas and a screen-space canvas, you might want to use two MenuControllers. This way they will keep track of their own states and pool their own menus. In that case, calling ShowMenuGlobal does not give enough information about what MenuController you are talking about.

Keep a reference to the MenuControllers and call

// Assign this sometime, E.G. in the editor.
MenuController _menuController;
// Call ShowMenu on the instance.
_menuController.ShowMenu(Menus.SIMPLETOOLTIP);

If you want a menu that should be possible to shown on every MenuController there is, without having to manually drag the prefab for each MenuController, use the 'Shared menus' drag area. These menus are added to all MenuControllers of your Unity project.

Editor

If your project contains a lot of menus, presets might help you organize them.

  1. Go to the tab Create preset, enter a name and click Create new. Click on the new preset and set the description field.
  2. Drag your menu prefab to the 'Preset Object' field at the bottom of the editor.
  3. Go to the tab Create menu, select your new preset and click Create Menu. This will instantiate a new object for the current selected MenuController. Edit this, and follow 'Adding a new menu' to use it.

Good practice

Data-flow

The main structure when looking at the data-flow when showing a new menu is as follows:

  1. Create a new data object. This will contain data for the specific menu. Think of an object that contains the following properties:

    • Message
    • Color of the message
    • An icon that should be displayed next to the message

    Example files:

  2. This data will be send to your menu class, that inherits from McMenu. This class will use the data from the data object to show specific things on screen. In our example, think of a Message class that will set a UI Text component's text to the Message property, its color to the Color property and sets a UI Image component's Sprite property to the Icon that is sent.

    Example files:

You can see a very simple example in MainWindow of how to create a data object and use it when showing a menu.

Demos

Achieve interesting menu set-ups with very little code. Click on the demos to go to the demo readme with more explanation.

Popups Multiple Managers Multiple managers Popups

If you have any questions of how to use this, or any suggestions on what features are missing, don't hesitate to send me a message!