MonoGame projects can take full advantage of the Gum tool and runtimes to create flexible layouts which are useful for HUDs, Menus, and UI of any complexity.
The Gum UI Tool is a WYSIWYG editor for creating layouts. Projects that are created in the Gum UI tool can be loaded into your MonoGame project with just a few lines of code.
The Gum runtime (called MonoGameGum) is a NuGet package which adds the classes necessary to load and interact with Gum projects.
Absolutely not! The Gum tool can be useful for doing complex layouts, previewing how things may be positioned, and helping you learn how to code with Gum - but it is not required! You can use Gum purely in code to do your own layouts or use only parts of Gum (such as font rendering).
This section uses screenshots of the Gum tool so you can see what is possible with Gum, but everything you see here can also be done purely in code.
If you prefer to dive in and see things working, the Gum repository includes sample projects that show how to work with Gum purely in code, and also how to load a Gum project into a MonoGame project.
You can clone the repository and open the projects in your favorite IDE (like Visual Studio) and try them out.
The direct link to the samples is here: https://github.com/vchelaru/Gum/tree/master/Samples
The Gum UI Tool (usually called “Gum”) is a visual editor for creating layouts using the Gum layout engine. Gum has been used on many commercial games to create all types of UI ranging from standard game HUDs to complex forms-based UIs. Gum can be used for any type of game.
The Gum tool is simple to use - you can create your screens by drag+dropping, moving, and resizing objects with the mouse.
Gum is an object oriented design tool, so projects can contain reusable components which contain other components and standard elements (text, sprite, container, etc). Gum also provides inheritance, and behaviors (a concept similar to interfaces in C#). For example, the following PauseMenu component inherits from UserControl - a base type defining the standard visuals for a framed UI element.
Gum produces a set of XML files (and PNG/FNT files for fonts) which can be added to any MonoGame project and loaded with a few lines of code. For information on loading projects, see the Loading .gumx (Gum Project) page.
The Gum Layout Engine is the core technology behind the Gum UI Tool and the Gum MonoGame runtimes. Gum layouts use a few rules to determine the position and size relationships between parents and children. These rules allow for the creation of virtually any type of layout.
Projects which perform their layouts purely in code can still take advantage of the Gum UI Tool to preview their layouts and to learn about the capiblities of the GraphicalUiElement (the C# object type providing access to all Gum properties).
A full list of Gum properties can be found in the Gum Element General Properties page, but we will cover a few concepts here to give you an idea of how Gum works.
By default, Gum elements are positioned relative to the top-left of their parent. Similarly, the origin of a Gum element is also its own top-left corner. Therefore, a rectangle that has an X of 100 and a Y of 50 appears as shown in the following image:
The Gum tool helps you visualize the relationship between a child and its parent when the child is selected. Notice that the child draws a line from its origin (its top-left corner) to the top left of its parent. In this case the parent is the entire screen, which has a dotted outline.
A child’s position is relative to its parent’s position, so changing the position of the parent ultimately changes the absolute position of its child as well. The following animation shows a parent container which has a white rectangle as its child. Notice the child can be moved relative to the parent. If the parent is moved, then the child’s absolute position changes as well.
This basic type of layout is similar to layouts provided by most visual APIs including SpriteBatch in MonoGame.
The Gum layout engine is built around the concept of “units”. As mentioned above, by default the X and Y values of an element is measured in units from the top-left corner. In other words, the default X Units is absolute pixels from left for X and absolute pixels from top for Y. The Gum tool exposes this as a set of buttons.
At runtime, these properties exist as enums which can be changed. For example, to set an element’s XUnits to be relative to the horizontal center of its parent, the following code can be used:
uiElement.XUnits = GeneralUnitType.PixelsFromMiddle;
As mentioned above, the Gum tool is very useful for testing out how different properties behave quickly. For example, the following animation shows how X and X Units can be used to change the position of an object relative to its parent:
The position, units, and origin values can be used to create common layouts. The following code could be used to center a child in its parent:
//assuming child is a valid GraphicalUiElement:
child.X = 0;
child.XUnits = GeneralUnitType.PixelsFromMiddle;
child.XOrigin = HorizontalAlignment.Center;
This same layout could be achieved in the Gum UI tool by setting the following values:
An element’s size can also be controlled through units. For example, a child rectangle could set to provide an 8 pixel border inside of its parent container using the following code.
child.X = 0;
child.XUnits = GeneralUnitType.PixelsFromMiddle;
child.XOrigin = HorizontalAlignment.Center;
child.Y = 0;
child.YUnits = GeneralUnitType.PixelsFromMiddle;
child.YOrigin = VerticalAlignment.Center;
child.Width = -16;
child.WidthUnits = DimensionUnitType.RelativeToContainer;
child.Height = -16;
child.HeightUnits = DimensionUnitType.RelativeToContainer;
Similarly, the following could be done in the Gum UI tool::
Note that the Width and Height are set to -16, which is twice the desired border. This is because the border of 8 pixels must appear on both the left and right sides for Width and both the top and bottom sides for Height.
Notice that each of these properties combines to produce a center layout. While this may seem verbose, this type of fine control provides ultimate flexibility. You aren’t limited to simple alignments such as left, right, and center. Rather, you can create layouts where any part of the object is positioned relative to any other part of its parent.
This type of center layout is responsive to changes in the parent, so if the parent changes position or size, the child moves along with it as expected.
Hierarchies can go many levels deep, and each parent child relationship follows the same rules. For example, the following animation shows a relationship where the blue and red children occupy the left and right half of the white rectangle, including a border of 8 pixels around and inbetween the rectangles. Notice that changing the parent size automatically cascades size and position changes to the children.
Children are in control of their own layouts using “unit” values, but parent elements can also apply rules to control layout by setting the Children Layout property. For example, a parent can stack its children from top-to-bottom by setting Children Layout to Top to Bottom Stack. Notice that changing the stacking from top-to-bottom changes the Y positioning of the children. The X position is intentionally staggered to be able to see the position of each rectangle when stacking is turned off.
Children can still control their position values relative to the stacking, so a child can change its X and Y value. If a child changes its Y or Height value in a Top to Bottom Stack, then subsequent children are adjusted react to this change immediately.
Stacking can be combined with wrapping and stack spacing to create list boxes and inventory grids quickly.
Layout dependencies can go from parent-> child and child-> parent to create powerful layouts. We recommend that new users spend some time in the Gum UI Tool to see what can be created and to browse the documentation to see more example images and animations.
If you’re ready to use Gum, then head on over to the Setup page. The MonoGame section provides information specific to MonoGame, but the rest of the Gum documentation site provides information which applies both to the Gum UI Tool and coding of Gum in MonoGame projects.
Also, if you have any questions, head on over to our Discord - we’re eager to help new users get their Gum projects up and running quickly!