-
Notifications
You must be signed in to change notification settings - Fork 2
User Beginner Guide
At first, you'll have to download the following plugins for GuiEngine to work:
- GuiEngine Base plugin
- ToberoCore Dependency
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.
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
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.
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.
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):
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 &.
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:
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:
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):
Running the commands from above again and the gui looks like this:
Now, usually items in guis have special descriptions below when hovering above them. This can also be done using guiengine.
Inbetween the component tag you can write <lore>Text</lore>
with your text to add into the item description.
Now having added some lores, my gui now looks like this:
And in game:
Now that you've created static items, we now want something to happen when you click them. This can be done using the same approach as we used for lores. Add a on-click tag. This time, the tag also has some attributes. The attribute is type. Types define what should happen when clicked. We'll use the type action and edit. Actions are a way interact with things outside of the gui. Edit is a type of interactin within the gui, specifically edit something.
My first item having the action on-clicks:
You can have multiple on clicks happening. In this case. The actions will do following:
- The first will send a message to the player
- The second one executes any command, in this case /summon zombie
- The last one closes the gui
Now to the edit item:
There's lot of stuff to cover here. First, I've given the componet a id, so the gui can find it again. The id can be any name, as long as it does only container alphabet, numbers, dashes and underscores.
Now the on-click. The type edit requires three attirbutes, target, attribute and set-value. The target should reference a component by id. The attribute should be which attribute you want to edit of this target component and the set-value tells the edit function which value the attribute will have.
Opening the gui in minecraft and clicking both items should be working as intented
The final code:
<gui width="9" height="4" title="§bMy first gui">
<component type="item" x="5" y="2" material="REDSTONE_BLOCK" name="§cSuspicious red button">
<lore>§7A button</lore>
<lore>§7You shouldn't click me</lore>
<on-click type="action">[message] §cYou shouldn't have clicked me...</on-click>
<on-click type="action">[player] summon zombie</on-click>
<on-click type="action">[close]</on-click>
</component>
<component type="item" id="green-button" x="3" y="2" material="GREEN_TERRACOTTA" name="§aGreen button">
<lore>§7Click me</lore>
<lore>§7I promise §ait's worth§7 it</lore>
<on-click type="edit" target="green-button" attribute="name" set-value="§eYou clicked me :)"/>
<on-click type="edit" target="green-button" attribute="material" set-value="YELLOW_TERRACOTTA"/>
</component>
</gui>
That's all for this beginner guide. If you want to know what else gui engine provides, you can visit the docs, where all pre made components, functions, etc are listed
Thank you for choosing GuiEngine for your GUI development needs. Explore the Developer Docs and User Beginner Guide to unleash the full potential of this powerful framework and create stunning GUIs that leave a lasting impression on your players!