Minestom features a number of interaction methods for players. Many of them are described below, however this list is not exhaustive.
Sidebars can be used to display up to 16 lines on a scoreboard for the player. They are created given a title as follows:
Sidebar#<init>(Component /* title */)
Sidebar titles do not support JSON chat components, however the provided component will be serialized using Adventure's legacy serializer.
Once created, a scoreboard can be added and removed from players as follows:
Lines on a sidebar are made up of
ScoreboardLines. They render on the scoreboard in order of their line number (score), where the vertically highest line represents the highest line number (score). If two lines have the same line number (score), they will be sorted alphabetically.
ScoreboardLines can be created using their constructor:
Sidebar.ScoreboardLine#<init>(String /* unique id*/, Component /* content */, int /* line */);
// For example
Sidebar.ScoreboardLine line = new Sidebar.ScoreboardLine(
Component.text("Hello, Sidebar!", NamedTextColor.RED),
Once created, scoreboard lines may be added to
Sidebars as follows:
Lines are indexed by their unique id, and can be modified with it:
Sidebar#getLine(String /* unique id */);
Sidebar#updateLineContent(String /* unique id */, Component /* new content */);
Sidebar#updateLineScore(String /* unique id */, Int /* new score */);
Notifications are a system to send advancement completion toasts to a player as a form of communication.
Notification#<init>(Component /* title */, FrameType, ItemStack /* icon */);
// For example
Notification notification = new Notification(
Component.text("Hello, Notifications!", NamedTextColor.GREEN),
To send the notification, use one of the static methods on
The example renders as the following: