🇬🇧 English
🇬🇧 English
Appearance
🇬🇧 English
🇬🇧 English
Appearance
INFO
This page refers to normal screens, not handled ones - these screens are the ones that are opened by the player on the client, not the ones that are handled by the server.
Screens are essentially the GUIs that the player interacts with, such as the title screen, pause screen etc.
You can create your own screens to display custom content, a custom settings menu, or more.
To create a screen, you need to extend the Screen
class and override the init
method - you may optionally override the render
method as well - but make sure to call it's super method or it wont render the background, widgets etc.
You should take note that:
width
and height
, are not yet available or not yet accurate.init
method is called when the screen is being initialized, and it is the best place to create widgets. addDrawableChild
method, which accepts any drawable widget.render
method is called every frame - you can access the draw context, and the mouse position from this method.As an example, we can create a simple screen that has a button and a label above it.
public class CustomScreen extends Screen {
// :::3
// Add a custom widget to the screen.
// x, y, width, height
CustomWidget customWidget = new CustomWidget(40, 80, 120, 20);
this.addDrawableChild(customWidget);
// :::3
You can open the screen using the MinecraftClient
's setScreen
method - you can do this from many places, such as a key binding, a command, or a client packet handler.
MinecraftClient.getInstance().setScreen(
new CustomScreen(Text.empty())
);
If you want to close the screen, simply set the screen to null
:
MinecraftClient.getInstance().setScreen(null);
If you want to be fancy, and return to the previous screen, you can pass the current screen into the CustomScreen
constructor and store it in a field, then use it to return to the previous screen when the close
method is called.
public Screen parent;
public CustomScreen(Text title, Screen parent) {
super(title);
this.parent = parent;
}
@Override
public void close() {
this.client.setScreen(this.parent);
}
Now, when opening the custom screen, you can pass the current screen as the second argument - so when you call CustomScreen#close
- it will return to the previous screen.
Screen currentScreen = MinecraftClient.getInstance().currentScreen;
MinecraftClient.getInstance().setScreen(
new CustomScreen(Text.empty(), currentScreen)
);