aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/me/xmrvizzy/skyblocker/utils/title/TitleContainer.java
diff options
context:
space:
mode:
authorFuturemappermydud <54294576+Futuremappermydud@users.noreply.github.com>2023-07-07 18:00:58 -0400
committerFuturemappermydud <54294576+Futuremappermydud@users.noreply.github.com>2023-07-07 18:00:58 -0400
commita4917d92ab77bc980b68017721adac2091a51f3e (patch)
treee417198494cdc022c4c3af4b83d1a84fee726673 /src/main/java/me/xmrvizzy/skyblocker/utils/title/TitleContainer.java
parente393d6f9fa44b0314734ce54927ebf3bf0551d47 (diff)
downloadSkyblocker-a4917d92ab77bc980b68017721adac2091a51f3e.tar.gz
Skyblocker-a4917d92ab77bc980b68017721adac2091a51f3e.tar.bz2
Skyblocker-a4917d92ab77bc980b68017721adac2091a51f3e.zip
WIP Title Container movement + Duration methods
Added a WIP configuration screen under /Skyblocker hud titleContainer that allows you to move, change alignment, and reorient the titles inside. Added methods(TitleContainer.addTitleWithDismiss, and RenderHelper.displayInTitleContainerWDismissAndPlaySound) that will display the given title and after a set amount of ticks will disable that title.
Diffstat (limited to 'src/main/java/me/xmrvizzy/skyblocker/utils/title/TitleContainer.java')
-rw-r--r--src/main/java/me/xmrvizzy/skyblocker/utils/title/TitleContainer.java81
1 files changed, 72 insertions, 9 deletions
diff --git a/src/main/java/me/xmrvizzy/skyblocker/utils/title/TitleContainer.java b/src/main/java/me/xmrvizzy/skyblocker/utils/title/TitleContainer.java
index 9728e1eb..e888fbda 100644
--- a/src/main/java/me/xmrvizzy/skyblocker/utils/title/TitleContainer.java
+++ b/src/main/java/me/xmrvizzy/skyblocker/utils/title/TitleContainer.java
@@ -1,27 +1,50 @@
package me.xmrvizzy.skyblocker.utils.title;
+import me.xmrvizzy.skyblocker.SkyblockerMod;
import me.xmrvizzy.skyblocker.config.SkyblockerConfig;
+import me.xmrvizzy.skyblocker.skyblock.dwarven.DwarvenHudConfigScreen;
+import net.fabricmc.fabric.api.client.command.v2.ClientCommandManager;
+import net.fabricmc.fabric.api.client.command.v2.ClientCommandRegistrationCallback;
import net.fabricmc.fabric.api.client.rendering.v1.HudRenderCallback;
import net.minecraft.client.MinecraftClient;
import net.minecraft.client.font.TextRenderer;
import net.minecraft.client.gui.DrawContext;
+import net.minecraft.text.Text;
import net.minecraft.util.math.MathHelper;
import java.util.ArrayList;
import java.util.List;
public class TitleContainer {
+ public static final MinecraftClient client = MinecraftClient.getInstance();
public static List<Title> titles = new ArrayList<>();
public static void init() {
HudRenderCallback.EVENT.register(TitleContainer::draw);
+ ClientCommandRegistrationCallback.EVENT.register((dispatcher, registryAccess) -> dispatcher.register(ClientCommandManager.literal("skyblocker")
+ .then(ClientCommandManager.literal("hud")
+ .then(ClientCommandManager.literal("titleContainer")
+ .executes(context -> {
+ client.send(() -> client.setScreen(new TitleContainerConfigScreen(Text.of("Title Container HUD Config"))));
+ return 1;
+ })))));
}
public static void addTitle(Title title) {
title.active = true;
title.lastX = 0;
+ title.lastY = SkyblockerConfig.get().general.titleContainer.y;
titles.add(title);
}
+ public static void addTitleWithDismiss(Title title, int ticks) {
+ addTitle(title);
+ SkyblockerMod.getInstance().scheduler.schedule(() -> {
+ title.active = false;
+ }, ticks);
+ }
public static void draw(DrawContext context, float tickDelta) {
+ draw(titles, SkyblockerConfig.get().general.titleContainer.x, SkyblockerConfig.get().general.titleContainer.y, context, tickDelta, false);
+ }
+ public static void draw(List<Title> titlesToDraw, int xPos, int yPos, DrawContext context, float tickDelta, boolean example) {
var client = MinecraftClient.getInstance();
TextRenderer textRenderer = client.textRenderer;
@@ -29,27 +52,67 @@ public class TitleContainer {
float scale = 3F * (SkyblockerConfig.get().general.titleContainer.titleContainerScale / 100F);
- float x;
+ var direction = SkyblockerConfig.get().general.titleContainer.direction;
+ var alignment = SkyblockerConfig.get().general.titleContainer.alignment;
+ float x = 0;
+ float y;
float width = 0;
- for (Title title : titles) {
+ for (Title title : titlesToDraw) {
width += textRenderer.getWidth(title.text) * scale + 10;
}
+ if (alignment == SkyblockerConfig.Alignment.MIDDLE) {
+ if(direction == SkyblockerConfig.Direction.HORIZONTAL) {
+ x = xPos - width / 2;
+ } else {
+ if (titlesToDraw.size() > 0) {
+ if (titlesToDraw.size() > 0) {
+ x = xPos - (textRenderer.getWidth(titlesToDraw.get(0).text) / 2 * scale);
+ }
+ }
+ }
+ } else {
+ if (alignment == SkyblockerConfig.Alignment.LEFT) {
+ x = xPos;
+ } else {
+ if (titlesToDraw.size() > 0) {
+ x = xPos - (textRenderer.getWidth(titlesToDraw.get(0).text) * scale);
+ }
+ }
+ }
+ y = yPos;
- x = (client.getWindow().getScaledWidth() / 2) - width / 2;
-
- for (Title title : titles) {
+ for (Title title : titlesToDraw) {
context.getMatrices().push();
- context.getMatrices().translate(title.lastX, client.getWindow().getScaledHeight() * 0.7F, 0);
+ context.getMatrices().translate(title.lastX, title.lastY, 200);
context.getMatrices().scale(scale, scale, scale);
title.lastX = MathHelper.lerp(tickDelta * 0.5F, title.lastX, x);
- x += textRenderer.getWidth(title.text) * scale + 10;
+ title.lastY = MathHelper.lerp(tickDelta * 0.5F, title.lastY, y);
+
+ if(direction == SkyblockerConfig.Direction.HORIZONTAL) {
+ switch (alignment) {
+ case LEFT -> x += textRenderer.getWidth(title.text) * scale + 10;
+ case RIGHT -> x -= (textRenderer.getWidth(title.text) * scale + 10);
+ case MIDDLE -> x += textRenderer.getWidth(title.text) * scale + 10;
+ }
+ y = yPos;
+ } else {
+ switch (alignment) {
+ case LEFT -> x = xPos;
+ case RIGHT -> x = xPos - (textRenderer.getWidth(title.text) * scale);
+ case MIDDLE -> x = xPos - ((textRenderer.getWidth(title.text) * scale));
+ }
+ y += textRenderer.fontHeight * scale + 10;
+ }
+
context.drawText(textRenderer, title.text, 0, 0, title.color, true);
context.getMatrices().pop();
- if (!title.active) {
+ if (!title.active && !example) {
toRemove.add(title);
}
}
- titles.removeAll(toRemove);
+ if (!example) {
+ titlesToDraw.removeAll(toRemove);
+ }
}
} \ No newline at end of file