What Are GUI Layers And How Do They Work In GameMaker? (2024)

What Are GUI Layers And How Do They Work In GameMaker? (1)

The GUI layer is a powerful beast, and you can do all kinds of cool things with it, but it's also one of the most misunderstood things in GameMaker. With the recent changes to it in the 2.1.5 update, I thought it would be a good idea to go back over the basics, and explain some of the more advanced features it has....

Before we start, lets chat about the GUI layer, the events and what they let you do. The GUI layer was first added back in days of GM8.1 - a long time ago now - and it was added because developers were having to counteract scrolling and zooming in their views in order to display the on screen UI (things like scores, items, messages etc..). This was pretty nasty and depending on the game could make putting a sprite at a fixed point in space at a specific size, a real headache for developers.

With all this in mind, we introduced the GUI layer so that you could draw at a fixed size and location without having to worry about what your game views were doing. You could now scroll, zoom, and even rotate, to your hearts content, and still print text with a single line to the screen at the size you wanted. The GUI layer was also at a different resolution from the main game, as we realised that developers may want to have a hires UI, but a lowres game. If you think about some RPG style games, they want the game art to be in a certain style and resolution - possibly for a retro feel - but still have a nice hires UI for items, mana, spells, scores and all the rest of it. So we allowed you to specify what resolution you wanted.

So, now you know the reasoning behind it, let's discuss some GUI layer basics. As of version 2.1.5, the GUI layer sizes itself to be the same as the application surface, and this is mostly good news for everyone. This means when you create a game - no matter what resolution you pick; 320x200, 1920x1080, 64x64 or whatever - your GUI will match that pixel size, There are a few exceptions to this, which I'll discuss later, but for now let's consider these 2 images which we'll be using as sprites in our test project:

What Are GUI Layers And How Do They Work In GameMaker? (2)What Are GUI Layers And How Do They Work In GameMaker? (3)

The first image above, we'll place in a room that is 320x200 in size, and the second image we'll draw in the GUI layer using the Draw Guievent. If we then run this, we'll get the image below:

What Are GUI Layers And How Do They Work In GameMaker? (4)

Now, this shows exactly what we'd expect. The GUI layer has it's "pixel" size set to the same as the application_surface, which itself is set to the size of the view port(which in this case, happens to be the size of the room). If we scale this window, then things start to change... This is because the initial GUI layout allows you to adapt your UI to a changing amount of screen/window space available. This means in that an RPG (for example) you can have that hires display to show moreof the game, moving the UI around to free up more screen space. This is actually quite desirable in lots of games, particularly on a PC, as the user usually has a lot of space to play with, and this lets them see more of the game, and less of the UI.

What Are GUI Layers And How Do They Work In GameMaker? (5)

As you can see from this image, I've doubled the size of the window by stretching it up at the corner (this requires enabling Allow window resizein the Graphics option of the Windows Game Options), and the UI has stayed in the top left of the window. This means that I'll have to move UI elements around to better fit. You do this (usually) by binding elements to an edge of the screen, so as the window changes size, you draw from the right-hand edge using an offset value like the width of your sprite, or from the bottom edge with an offset the height of your sprite. This lets you free up space in the middle so the user can see more of the game, and less UI is getting in the way.

NOTE: The manualhas a list of GUI specific functions that can help when offsetting images on the GUI layer.

So what if you don't want that, and just want to layout the UI on the GUI layer so that it always appears in the same place, and the same size? Well this is pretty easy too. display_set_gui_size lets you do just that:

display_set_gui_size(320,200);

Simply calling this function with the size you want to set your GUI to will then tell GameMaker to maintain this size even when the window (or display) changes size, as illustrated in the following image:

What Are GUI Layers And How Do They Work In GameMaker? (6)

You'll notice 2 things here: First the size andaspect ratio are correct, and second, it doesn't match pixel-perfectly. There are some (very slight) offset pixels, particularly noticeable around the red square, where a little green from the background isn't quite matching up. This shouldn't be a huge shock to you, as both displays are setup using entirely different processes and matrices, and the maths just comes out with very small fractional differences. For an on screen display, however, this isn't a big issue, but it's worth remembering - especially if you're trying to do an effect to mask the game using the GUI layer.

For most people, this is all you'll need - set the GUI display size and then forget about it. But there is more power here if you want to use it. Lets remove the GUI size function and increase the VIEW PORT size. To do this, we add some views to our room like this:

What Are GUI Layers And How Do They Work In GameMaker? (7)

When we now run the project, we get the image below...

What Are GUI Layers And How Do They Work In GameMaker? (8)

Now, just like when we resized the game window, the GUI size now no longer matches the game scale. As mentioned previously, this is because the GUI is set to the size of the application_surface at the start or the game - or rather, what the app surface should start at, which in this case is x3 the size of the room. The reason the app surface isn't 320x200 anymore, but the size of the view port (960x600) is that you could have multiple view ports active here, meaning we need the resolution to display each view correctly. Also, each view port couldbe a different size/scale, but as the window size sets the actual number of pixels we have, the application_surface is set to the overall size of the display. This size is based on the bounding box of ALL active views ports in the firstroom.

The simplest way to get things sized correctly is to make a first room that is the size you want, then switch to another room to actually play the game. I tend to have a room first to initialise global variables and set things up anyway, so having it also specify the game window size isn't a huge issue.

Again, if you want to size your GUI to something else, you can simply use the display_set_gui_size specified above, and you should be good to go.

What Are GUI Layers And How Do They Work In GameMaker? (9)

display_set_gui_size(320,200);

In this demo image, We have a 320x200 room on a 640x400 view, and I've manually set the GUI size to 320x200. This means no matter how much I scale the window. the GUI will stay the same size. The image below shows a much wider window, and the GUI and room are matching nicely.

What Are GUI Layers And How Do They Work In GameMaker? (10)

This brings up another thing to be aware of... The GUI layer "origin" (0,0) always starts at the top left of the game screen, where the application_surface is drawn to. This is simply so you can position things like scores easily in relation to what's being drawn for your actual game, but that's not the whole story, Unlike the game - which renders into the application_surfaceand is then positioned inside the window, either filling or using aspect ratio correction - the GUI layer can render to the WHOLEof the window space. So if you have a game at 320x200 and don'tsetup anyGUI size and then resize the window, the GUI size will change to reflect this extra space. For example, if you have a 320x200 game then make the window 640x200, the GUI size will be 640x200 and not320x200. This is shown below:

What Are GUI Layers And How Do They Work In GameMaker? (11)

So why do we do this? Well, if you're doing a 4:3 game (for example), then you may well be running on a wide screen monitor or device, and as such might want to put some art/banners/backgrounds down the side of your game so it's not just black bars showing.

If you need the GUI size to STAY the same size each time, then you can set the GUI size as using the function we talked about above, and then it'll be that size each time you run the game or change room - even though you could still draw using a negative number to the space at the side. The image below shows the GUI size staying the same, even though the window has been resized, but we're still able to draw the ball outside using negative coordinates:

display_set_gui_size( 320,200 );draw_sprite( sBall,0, -64,100 );

What Are GUI Layers And How Do They Work In GameMaker? (12)

So, how can we get the actual window size, but keep the GUI locked to the 320x200 that we want? Well, you can get the distance offset for the left and right sides by getting the application_surface location, and subtracting thatfrom the window size, or you can work out the scale difference and use the display_set_gui_maximizefunction. This is an incredibly powerful function that lets us basically control the matrix being used to render the GUI layer. You can even specify the scale and offset dynamically, changing it throughout the GUI rendering process.

var app = application_get_position();var w = (app[2]-app[0])/320;var h = (app[3]-app[1])/200;display_set_gui_maximize(w,h,app[0],app[1]);

What Are GUI Layers And How Do They Work In GameMaker? (13)

Using the code above means your GUI will stay the correct size andreturn the actual width of the display in the scale of pixels your GUI layer is using. From here you can then draw things to the left and right easily. Bear in mind that (0,0) is the top/left of the game space, which means (320 - GUIsize) / 2is the offset for the right and left, with half being negative and the other half being 320 + n.

Lastly, the GUI layer can also be told to use ALL the available space, and go into "native" pixel mode. When you do this, pixels on the GUI layer are no longer scaled but will be 1:1 with the native pixel size of your monitor (or desktop resolution if you're in windowed mode). This means if your game is 320x200, and you're on a 1920x1080 monitor, your GUI size would be 1920x1080 and your pixels would be the native monitor pixel size. This gives you total control over the GUI as it means you can draw small text/icons over a lowres game if you want, and it also means you can dynamically resize based on the window size, allowing the player to see as much as possible without having to scale graphics.

What Are GUI Layers And How Do They Work In GameMaker? (14)

The image above shows what happens after we call display_set_gui_maximise without passing in any parameters (like this).

display_set_gui_maximize();

This sets the origin to (0,0) in the window/display, and gives you the whole space to play with. You can also pass in 1, 1, app[0], app[1] as arguments if you want to keep the 1:1 pixel size, but keep the origin at the application surface so that drawing is always based from the app surface location. You'd need to do this at the start of the Draw GUI event, as this location could change each frame as a window resizes.

Note that display set gui maximise works in realtime. This means that you can set it, draw something then set it again, then draw something, and again and again. This allows you to actually change the origin dynamically to (for example) scroll things on and off the screen if you want, or use the scale and origin to wobble the whole UI when you get hit by a bullet. It's incredibly powerful but does take some getting used to to get the most from it.

So... there you go. For the average user, I'd recommend simply using display_set_gui_size to be whatever you're expectingthe GUI to be, and it'll stick to that, and you'll never have to care again. But if you want an adaptive display, or if you want to do some cool effects, then it's worth remembering the rest of the GUI commands and how you can use them.

What Are GUI Layers And How Do They Work In GameMaker? (15)

Written by

Mike Dailly

Mike Dailly was the previous head of development at GameMaker, helping us to transform the game engine during his tenure. He was also the lead game programmer and creator of Lemmings and Grand Theft Auto.

Back to blogs

What Are GUI Layers And How Do They Work In GameMaker? (2024)

FAQs

What Are GUI Layers And How Do They Work In GameMaker? ›

With all this in mind, we introduced the GUI layer so that you could draw at a fixed size and location without having to worry about what your game views were doing. You could now scroll, zoom, and even rotate, to your hearts content, and still print text with a single line to the screen at the size you wanted.

What is GUI layer? ›

A GUI Layer Component is attached to a Camera to enable rendering of 2D GUIs. When a GUI Layer is attached to a Camera it will render all GUI Textures and GUI Texts in the scene. GUI Layers do not affect UnityGUI in any way.

What is a layer in GameMaker? ›

Any assets that you add to rooms are placed on a layer. These assets can be tile maps (using tile sets), backgrounds, sprites or sequences, particle systems and instances. You can add and modify a room's layers in The Room Editor or at runtime through code.

How deep are GameMaker layers? ›

The layer depth is defined as being higher when "further away" from the camera and lower when "closer" to the camera, so if you have three layers with depths -100, 0, 100, the layers will draw in the order 100, 0, -100, so that the "top" layer (i.e., the closest to the camera view and so drawn over everything else) ...

How does GameMaker Studio work? ›

Making games with GameMaker is, conceptually, a fairly simple and straightforward affair, following these general steps: Create image assets (sprites, tile sets, fonts) and add them to the Asset Browser. Create object assets to represent the things you want to use in your game and assign them the required image assets.

How does a GUI work? ›

A GUI uses windows, icons, menus, and buttons to show the user how to execute commands. This can be done with a pointer, keyboard, or touch screen. For example, you can open a file icon on your desktop by pointing and clicking with your mouse.

What is a GUI example? ›

The main pieces of a GUI are a pointer, icons, windows, menus, scroll bars, and an intuitive input device. Some common GUIs are the ones associated with Microsoft Windows, Mac OSX, Chrome OS, GNOME, KDE, and Android. GUIs sort of bring computers and users out of the stone age and into the future.

How hard is GameMaker? ›

Is GameMaker good for beginners? Yes! GameMaker Studio is relatively easy to learn compared to other game engiens like Unity or Unreal, as you can make a game without very much code or scripting. However, the games made in GameMaker are geneallly not as complex as with other game engines.

Is Undertale made in GameMaker? ›

Answer. Undertale, the indie hit known for its unique gameplay and story, was created using a game engine called GameMaker Studio.

Is Deltarune a GameMaker? ›

Deltarune was developed by Fox in GameMaker Studio 2.

Is GameMaker 100% free? ›

Which version of GameMaker is right for me? Yes - all versions of GameMaker are completely free to download. You'll only need to pay if you plan to release your game commercially or if you'd like to export your games to Console platforms.

Does GameMaker use coding? ›

The GameMaker Language (also called simply GML) is the proprietary GameMaker scripting language. This language is structured to permit users to create their games in an intuitive and flexible way while offering all the power of any other major programming language.

Is GameMaker powerful? ›

GameMaker Studio 2, developed by YoYo Games, is a powerful 2D game development platform. It is known for its user-friendly drag-and-drop interface, which allows developers to build complex games without needing to know coding.

What is a UI layer? ›

The User Interface (UI) layer sits above the Logic layer. There are two components that can be used to create the UI. The Builder component provides a simple drag-and-drop interface which allows simple manipulations of the default UI, such as changing the layout of the default display.

What is GUI on my router? ›

Also known as the graphical user interface (GUI), remote GUI allows you to access your router's online settings, through a WAN connection. To access your modem remotely, you will enter https:// followed by your modem's IP in the URL field of a browser.

What does the acronym GUI stand for? ›

GUI (Graphical User Interface)

What is a GUI image? ›

A graphical user interface (GUI) is a digital interface in which a user interacts with graphical components such as icons, buttons, and menus. In a GUI, the visuals displayed in the user interface convey information relevant to the user, as well as actions that they can take.

Top Articles
How to Make Perfect Latkes • foolproof recipe!
Thick Elderberry Syrup Recipe {NO more spills / texture of store-bought!}
Jail Inquiry | Polk County Sheriff's Office
Ron Martin Realty Cam
Katie Pavlich Bikini Photos
What Happened To Dr Ray On Dr Pol
Klustron 9
The Best Classes in WoW War Within - Best Class in 11.0.2 | Dving Guides
Naturalization Ceremonies Can I Pick Up Citizenship Certificate Before Ceremony
Farmers Branch Isd Calendar
My Vidant Chart
A Fashion Lover's Guide To Copenhagen
Craigslist Free Grand Rapids
Phillies Espn Schedule
Bahsid Mclean Uncensored Photo
Uc Santa Cruz Events
Sni 35 Wiring Diagram
Ally Joann
Why Does Lawrence Jones Have Ptsd
2024 INFINITI Q50 Specs, Trims, Dimensions & Prices
Jeffers Funeral Home Obituaries Greeneville Tennessee
If you have a Keurig, then try these hot cocoa options
Slim Thug’s Wealth and Wellness: A Journey Beyond Music
پنل کاربری سایت همسریابی هلو
Craigslist Panama City Beach Fl Pets
Creed 3 Showtimes Near Island 16 Cinema De Lux
The Collective - Upscale Downtown Milwaukee Hair Salon
FSA Award Package
Renfield Showtimes Near Marquee Cinemas - Wakefield 12
Kids and Adult Dinosaur Costume
Pokemmo Level Caps
A Man Called Otto Showtimes Near Carolina Mall Cinema
Lucky Larry's Latina's
Audi Q3 | 2023 - 2024 | De Waal Autogroep
3302577704
Dying Light Nexus
Thelemagick Library - The New Comment to Liber AL vel Legis
2024-09-13 | Iveda Solutions, Inc. Announces Reverse Stock Split to be Effective September 17, 2024; Publicly Traded Warrant Adjustment | NDAQ:IVDA | Press Release
Leland Nc Craigslist
Chase Bank Zip Code
Fatal Accident In Nashville Tn Today
Holzer Athena Portal
Tacos Diego Hugoton Ks
Lawrence E. Moon Funeral Home | Flint, Michigan
John Wick: Kapitel 4 (2023)
Yosemite Sam Hood Ornament
Phunextra
Coleman Funeral Home Olive Branch Ms Obituaries
Spongebob Meme Pic
Costco Tire Promo Code Michelin 2022
What Is The Gcf Of 44J5K4 And 121J2K6
Southwind Village, Southend Village, Southwood Village, Supervision Of Alcohol Sales In Church And Village Halls
Latest Posts
Article information

Author: Kieth Sipes

Last Updated:

Views: 5988

Rating: 4.7 / 5 (67 voted)

Reviews: 82% of readers found this page helpful

Author information

Name: Kieth Sipes

Birthday: 2001-04-14

Address: Suite 492 62479 Champlin Loop, South Catrice, MS 57271

Phone: +9663362133320

Job: District Sales Analyst

Hobby: Digital arts, Dance, Ghost hunting, Worldbuilding, Kayaking, Table tennis, 3D printing

Introduction: My name is Kieth Sipes, I am a zany, rich, courageous, powerful, faithful, jolly, excited person who loves writing and wants to share my knowledge and understanding with you.