aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/de/hysky/skyblocker/skyblock
diff options
context:
space:
mode:
authorKevinthegreat <92656833+kevinthegreat1@users.noreply.github.com>2024-01-28 22:14:27 -0500
committerKevinthegreat <92656833+kevinthegreat1@users.noreply.github.com>2024-05-24 19:51:16 -0400
commitbf4034da76adcc7760628d49e518404273efceee (patch)
tree458181e87af22d7cd8654c118fe2cd1daa18525e /src/main/java/de/hysky/skyblocker/skyblock
parent6ad1335dd95e5df4db38e1d8d022a6c2925d6921 (diff)
downloadSkyblocker-bf4034da76adcc7760628d49e518404273efceee.tar.gz
Skyblocker-bf4034da76adcc7760628d49e518404273efceee.tar.bz2
Skyblocker-bf4034da76adcc7760628d49e518404273efceee.zip
Add waypoints gui
Diffstat (limited to 'src/main/java/de/hysky/skyblocker/skyblock')
-rw-r--r--src/main/java/de/hysky/skyblocker/skyblock/waypoint/WaypointsListWidget.java76
-rw-r--r--src/main/java/de/hysky/skyblocker/skyblock/waypoint/WaypointsScreen.java37
2 files changed, 113 insertions, 0 deletions
diff --git a/src/main/java/de/hysky/skyblocker/skyblock/waypoint/WaypointsListWidget.java b/src/main/java/de/hysky/skyblocker/skyblock/waypoint/WaypointsListWidget.java
new file mode 100644
index 00000000..a1410397
--- /dev/null
+++ b/src/main/java/de/hysky/skyblocker/skyblock/waypoint/WaypointsListWidget.java
@@ -0,0 +1,76 @@
+package de.hysky.skyblocker.skyblock.waypoint;
+
+import de.hysky.skyblocker.utils.waypoint.NamedWaypoint;
+import de.hysky.skyblocker.utils.waypoint.WaypointCategory;
+import net.minecraft.client.MinecraftClient;
+import net.minecraft.client.gui.DrawContext;
+import net.minecraft.client.gui.Element;
+import net.minecraft.client.gui.Selectable;
+import net.minecraft.client.gui.widget.ElementListWidget;
+import net.minecraft.util.math.BlockPos;
+
+import java.util.List;
+
+public class WaypointsListWidget extends ElementListWidget<WaypointsListWidget.AbstractWaypointEntry> {
+ public WaypointsListWidget(MinecraftClient client, int width, int height, int y, int itemHeight) {
+ super(client, width, height, y, itemHeight);
+ }
+
+ protected static abstract class AbstractWaypointEntry extends ElementListWidget.Entry<AbstractWaypointEntry> {
+ }
+
+ protected class WaypointCategoryEntry extends AbstractWaypointEntry {
+ private final WaypointCategory category;
+
+ public WaypointCategoryEntry(WaypointCategory category) {
+ this.category = category;
+ }
+
+ @Override
+ public List<? extends Selectable> selectableChildren() {
+ return List.of();
+ }
+
+ @Override
+ public List<? extends Element> children() {
+ return List.of();
+ }
+
+ @Override
+ public void render(DrawContext context, int index, int y, int x, int entryWidth, int entryHeight, int mouseX, int mouseY, boolean hovered, float tickDelta) {
+ context.drawTextWithShadow(client.textRenderer, category.name(), width / 2 - 150, y + 5, 0xFFFFFF);
+ }
+ }
+
+ protected class WaypointEntry extends AbstractWaypointEntry {
+ private final WaypointCategoryEntry category;
+ private final NamedWaypoint waypoint;
+
+ public WaypointEntry(WaypointCategoryEntry category) {
+ this(category, new NamedWaypoint(BlockPos.ORIGIN, "New Waypoint", new float[]{0f, 1f, 0f}));
+ }
+
+ public WaypointEntry(WaypointCategoryEntry category, NamedWaypoint waypoint) {
+ this.category = category;
+ this.waypoint = waypoint;
+ }
+
+ @Override
+ public List<? extends Selectable> selectableChildren() {
+ return null;
+ }
+
+ @Override
+ public List<? extends Element> children() {
+ return null;
+ }
+
+ @Override
+ public void render(DrawContext context, int index, int y, int x, int entryWidth, int entryHeight, int mouseX, int mouseY, boolean hovered, float tickDelta) {
+ context.drawTextWithShadow(client.textRenderer, waypoint.getName(), width / 2 - 125, y + 5, 0xFFFFFF);
+ context.drawTextWithShadow(client.textRenderer, waypoint.pos.toString(), width / 2 - 50, y + 5, 0xFFFFFF);
+ float[] colorComponents = waypoint.getColorComponents();
+ context.drawTextWithShadow(client.textRenderer, String.format("#%02X%02X%02X", (int) (colorComponents[0] * 255), (int) (colorComponents[1] * 255), (int) (colorComponents[2] * 255)), width / 2 + 10, y + 5, 0xFFFFFF);
+ }
+ }
+}
diff --git a/src/main/java/de/hysky/skyblocker/skyblock/waypoint/WaypointsScreen.java b/src/main/java/de/hysky/skyblocker/skyblock/waypoint/WaypointsScreen.java
new file mode 100644
index 00000000..f98addda
--- /dev/null
+++ b/src/main/java/de/hysky/skyblocker/skyblock/waypoint/WaypointsScreen.java
@@ -0,0 +1,37 @@
+package de.hysky.skyblocker.skyblock.waypoint;
+
+import net.minecraft.client.gui.DrawContext;
+import net.minecraft.client.gui.screen.Screen;
+import net.minecraft.text.Text;
+
+public class WaypointsScreen extends Screen {
+ private WaypointsListWidget waypointsListWidget;
+ private final Screen parent;
+
+ protected WaypointsScreen() {
+ this(null);
+ }
+
+ public WaypointsScreen(Screen parent) {
+ super(Text.translatable("skyblocker.waypoints.config"));
+ this.parent = parent;
+ }
+
+ @Override
+ protected void init() {
+ super.init();
+ waypointsListWidget = addDrawableChild(new WaypointsListWidget(client, width, height - 96, 32, 25));
+ }
+
+ @Override
+ public void render(DrawContext context, int mouseX, int mouseY, float delta) {
+ super.render(context, mouseX, mouseY, delta);
+ context.drawCenteredTextWithShadow(this.textRenderer, this.title, this.width / 2, 16, 0xFFFFFF);
+ }
+
+ @SuppressWarnings("DataFlowIssue")
+ @Override
+ public void close() {
+ client.setScreen(parent);
+ }
+}