Skip to content

User Beginner Guide

Tobero edited this page May 21, 2023 · 11 revisions

Getting started

At first, you'll have to download the following plugins for GuiEngine to work:

Once the plugins are installed on your server, start it. Once the server started, you'll be able to navigate to plugins/GuiEngine/guis. This folder contains all guis you created without a plugin requiring them. I'll now refer to it as gui folder.

Commands

Now, before we'll dive into creating our first gui, you should make yourself familiar with the commands the plugin provided. The most important one will be /guiengine reload. This will reload all guis, no matter which plugin is requiring them. The second command you'll need is /guiengine open <plugin> <gui>. This command allows you to open any gui, no matter which plugin or nesting (We'll come later to that). When using this command, I highly recommend using the tablist (The black box above the chatbar when typing). It suggests all possible options. When no plugins are installed using GuiEngine, the command list should show as first argument default. So a example usage for this command would be /guiengine open default my-gui

Picking the right gui folder

Now that you know the commands, let's start creating a gui. First thing you'll have to know what gui you want to create. Is it from a specific plugin? If yes, you should navigate to the gui folder of the plugin and edit a file !IMPORTANT: Don't create new files in a non default gui folder except the plugin needs it!. If you want to create a gui from scratch, you should use the gui folder fo GuiEngine.

Gui folder structure

Once you found yourself in the right folder, depending on your case, the folder might not be empty.

The gui folder is able to contain folders and gui files. You can create folders in folders and so on to group your guis, while the gui files represent the actual gui. Note that when you have a gui placed in a subfolder of the gui folder, it will no longer just have the name of the file, it will now be subfoldername/filename. If you have even one more layer of folders, there will be another subfolder in the name.

Create a gui

In the GuiEngine gui folder create a file named my-gui.gui. Make sure when creating the file that the extension is correct. When on windows, the extensions might be hidden. You should show them, to make sure they're correct.

Once the file has been created, open it in a text file editor of your choice. I recommend using a editor that detects and supports xml files, as this will make your live easier writing them. A free editor you can use is Visual Studio Code from Microsoft. I'll be using Intellij from Jetbrains for my XMl file editing.

Once you've opened the file, you'll have to create the base layout of the gui, starting with the root tag. The root tag in this is will be <gui></gui>. Now that the root tag exists, you can define some generic gui values, like the title, height and width. Note: Height is counted in minecraft gui rows, meaning the maximum is 6 and minimum is 1. The width in minecraft is limited to 9 slots per row. This property gets more meaning when creating more complex guis.

Now you can choose a different interpreter (The thing that translates this file into an actual minecraft gui). You can leave it for now, but that you know when you need it, the attribute goes like interpreter="default" for the default interpreter.

Now the gui file should look like this (Color can be different depending on your text editor): grafik Note that I've used a color code in the title to make it more colorful (§b is the color code). Minecraft color codes can be used with § instead of &.

Adding components to the gui

Now to make the gui functional, you have to add components. Components are just a way to decribe certain things in a gui. For simplicity, we'll add a simple item, which when clicked prints a text to the player.

To add a component, create a component tag, with the attribute type set to item. Now depending on the component type choosen, you now have to add addional attributes. The item needs at least a material property, saying which item you wanted. Additionally, you can provide a name, x and y. Note: The material property needs values you can find when pressing f3 + H in minecraft, showing advanced tooltips. The item name showen when overing over the item, without minecraft: in upper case is the material

Here is how my gui looks now: grafik

Testing your gui is as important as creating it. To do so, type /guiengine reload to reload the guis. Once it reloaded, type /guiengine open default my-gui. This should now open a gui looking like this: grafik

Now, lets add a second item. Just copy the previous component and paste it below. You can now change values to your likings, save and test inbetween until you're happy with the layout of your items.

My gui file now looks like this (Ignore the light bulb): grafik

Running the commands from above again and the gui looks like this: grafik

Adding click events

Clone this wiki locally