Host your Minecraft server on BisectHosting - get 25% off your first month with code MODRINTH.

Moxvallix's GUI Lib

Making Datapack GUIs easier

Moxvallix's GUI Lib relies on Taglib, and Moxlib

This datapack automates much of hard parts of GUI development. It is data driven, meaning it renders the GUI based on a template stored in data storage.

Currently, the library works in two modes; "enderchest", and "barrel". In "enderchest" mode, the GUI is drawn to the player's Enderchest. This overrides whatever contents were previously in the enderchest, so be warned! Enderchest mode is the easiest to use, and is best for Adventure maps, where the main Enderchest functionality is not needed.

The other, "barrel", mode, draws the GUI to a container at ~ ~ ~. While this works with any container block, it is advised that a Barrel is used, as that allows for it to detect when the container is opened, allowing for it to then easily prevent other players using the GUI whilst the first player is.

One benefit of this GUI system, being data driven, means that making generators for GUIs should be fairly easy. I however have not created one yet.

Getting Started

Overview

Depending on whether the GUI should be drawn to a container, or the Enderchest, the API is namespaced under "barrel", or "enderchest" respectively. The following guide will use <type> as a placeholder for this. Swap it out for which ever method.

Note: type "barrel" should be executed at the same position as a container block. If you have multiple GUIs in your packs, you may want to have entities positioned at the same location as the block, executing at them.

There are two main functions: gui:api/<type>/render and gui:api/<type>/watch. Render will draw the gui, based on the page id, and watch will run any clicks in the GUI.

All functions outside of the api/ subfolder are to be considered private, and are not supported to be ran.

The watch function should be run as the player, on a loop, whenever the GUI should be active. If you wanted the GUI always active, you could set it to run as @a from your tick function.

Making an Index

For your GUI to work, you will need an index function. Such a function, when run, will take in @s score of gui.page, and will set the correct template data for that page.

It is recommended that you set the template data within a separate function, and that index merely calls said function.

An example index function

execute if score @s gui.page matches 1 run function pack:gui/menu
execute if score @s gui.page matches 2 run function pack:gui/options
execute if score @s gui.page matches 3 run function pack:gui/shop

You will then need to register your index function to run in the index tag. Add it to the gui:index function tag.

{
    "values": [
      "pack:gui/index"
    ]
}

Making a Template

Now we can create GUI templates. These will be functions that the index will run.

An example template function (pack:gui/menu)

data modify storage gui:page template set value [{slot:12b,page:2s,item:{id:"minecraft:redstone_dust"}},{slot:14b,page:3s,item:{id:"minecraft:chest"}}]

The above menu template would render two items to the GUI, one in slot 12, the other in slot 14. Slot 12:

  • has page:2s, would render pack:gui/options when clicked
  • has an item tag, setting the item to redstone_dust Slot 14:
  • has page:3s, would render pack:gui/shop when clicked
  • has an item tag, setting the item to chest

If you want to try it out, make sure to set your gui.page score to 1, then run either gui:api/<type>/render, or have gui:api/<type>/watch on loop as described above.

Manipulate Slots as they Render

Sometimes, you will want to manipulate slots as they render, such that you can have dynamic menus. You can add any custom tags you like to the slots in your template data, as long as the slot tag is defined.

Every time a slot is going to be rendered, it first calls the gui:render/slot function tag. You can add a custom function to this tag, in order to manipulate the slot data.

The current slot data will be available to be manipulated from the data storage gui:slot current.

Render will also call the function tag gui:render/item, with @s being a temporary armor stand, and the current item being rendered in its mainhand. This will allow for item modifiers to be run.

Custom Functionality on Selection

Another key part of a gui is being able to run custom functions when a particular slot is selected.

Whenever a slot is selected, it calls the gui:select/slot function tag, as the player that selected the slot.

You will then be able to read the selected slot from the data storage gui:slot current.

External resources



Project members

moxvallix

Owner


Technical information

License
LGPL-3.0-or-later
Project ID