aboutsummaryrefslogtreecommitdiff
path: root/src/main/java/de/hysky/skyblocker/skyblock/fancybars/StatusBar.java
diff options
context:
space:
mode:
authorvicisacat <victor.branchu@gmail.com>2024-03-31 14:51:18 +0200
committervicisacat <victor.branchu@gmail.com>2024-04-20 16:09:48 +0200
commit0d5b04f9a5f57be03c79b76ff9b730951b5f959f (patch)
treec3d8fe99dd4acbd1d01c037e1a110e48147411a5 /src/main/java/de/hysky/skyblocker/skyblock/fancybars/StatusBar.java
parent897b3021fbc1aca4b481c741fbe873bd7e5b197f (diff)
downloadSkyblocker-0d5b04f9a5f57be03c79b76ff9b730951b5f959f.tar.gz
Skyblocker-0d5b04f9a5f57be03c79b76ff9b730951b5f959f.tar.bz2
Skyblocker-0d5b04f9a5f57be03c79b76ff9b730951b5f959f.zip
progress ig
Diffstat (limited to 'src/main/java/de/hysky/skyblocker/skyblock/fancybars/StatusBar.java')
-rw-r--r--src/main/java/de/hysky/skyblocker/skyblock/fancybars/StatusBar.java136
1 files changed, 136 insertions, 0 deletions
diff --git a/src/main/java/de/hysky/skyblocker/skyblock/fancybars/StatusBar.java b/src/main/java/de/hysky/skyblocker/skyblock/fancybars/StatusBar.java
new file mode 100644
index 00000000..9c688051
--- /dev/null
+++ b/src/main/java/de/hysky/skyblocker/skyblock/fancybars/StatusBar.java
@@ -0,0 +1,136 @@
+package de.hysky.skyblocker.skyblock.fancybars;
+
+import de.hysky.skyblocker.SkyblockerMod;
+import de.hysky.skyblocker.utils.render.RenderHelper;
+import net.minecraft.client.gui.*;
+import net.minecraft.client.gui.screen.narration.NarrationMessageBuilder;
+import net.minecraft.client.gui.widget.ClickableWidget;
+import net.minecraft.client.gui.widget.Widget;
+import net.minecraft.util.Identifier;
+import org.jetbrains.annotations.Nullable;
+
+import java.awt.*;
+import java.util.function.Consumer;
+
+public class StatusBar implements Widget, Drawable, Element, Selectable {
+
+ private static final Identifier BAR_FILL = new Identifier(SkyblockerMod.NAMESPACE, "bars/bar_fill");
+ private static final Identifier BAR_BACK = new Identifier(SkyblockerMod.NAMESPACE, "bars/bar_back");
+
+ private final Identifier icon;
+ private final Color[] colors;
+ private final boolean hasOverflow;
+ private final @Nullable Color textColor;
+
+ private @Nullable Consumer<StatusBar> onClick = null;
+ public int gridX = 0;
+ public int gridY = 0;
+
+ public float size = 1;
+ private int width = 0;
+
+ public float fill = 0;
+ public float overflowFill = 0;
+
+ private int x = 0;
+ private int y = 0;
+
+ public StatusBar(Identifier icon, Color[] colors, boolean hasOverflow, @Nullable Color textColor) {
+ this.icon = icon;
+ this.colors = colors;
+ this.hasOverflow = hasOverflow;
+ this.textColor = textColor;
+ }
+
+ @Override
+ public void render(DrawContext context, int mouseX, int mouseY, float delta) {
+ context.drawGuiTexture(icon, x, y, 9, 9);
+ context.drawGuiTexture(BAR_BACK, x + 10, y + 1, width - 10, 7);
+ RenderHelper.renderNineSliceColored(context, BAR_FILL, x + 11, y + 2, (int) ((width - 12) * fill), 5, colors[0]);
+ if (hasOverflow) {
+ RenderHelper.renderNineSliceColored(context, BAR_FILL, x + 11, y + 2, (int) ((width - 12) * overflowFill), 5, colors[1]);
+ }
+ }
+
+ // GUI shenanigans
+
+ @Override
+ public void setX(int x) {
+ this.x = x;
+ }
+
+ @Override
+ public void setY(int y) {
+ this.y = y;
+ }
+
+ @Override
+ public int getX() {
+ return x;
+ }
+
+ @Override
+ public int getY() {
+ return y;
+ }
+
+ @Override
+ public int getWidth() {
+ return width;
+ }
+
+ public void setWidth(int width) {
+ this.width = width;
+ }
+
+ @Override
+ public int getHeight() {
+ return 9;
+ }
+
+ @Override
+ public ScreenRect getNavigationFocus() {
+ return Widget.super.getNavigationFocus();
+ }
+
+ @Override
+ public boolean isMouseOver(double mouseX, double mouseY) {
+ return mouseX >= x && mouseX <= x + getWidth() && mouseY >= y && mouseY <= y + getHeight();
+ }
+
+ @Override
+ public void forEachChild(Consumer<ClickableWidget> consumer) {}
+
+ @Override
+ public void setFocused(boolean focused) {
+
+ }
+
+ @Override
+ public boolean isFocused() {
+ return false;
+ }
+
+ @Override
+ public SelectionType getType() {
+ return SelectionType.NONE;
+ }
+
+ @Override
+ public boolean mouseClicked(double mouseX, double mouseY, int button) {
+ if (!isMouseOver(mouseX, mouseY)) return false;
+ if (onClick != null) {
+ onClick.accept(this);
+ }
+ return true;
+ }
+
+ public void setOnClick(@Nullable Consumer<StatusBar> onClick) {
+ this.onClick = onClick;
+ }
+
+ @Override
+ public void appendNarrations(NarrationMessageBuilder builder) {
+
+ }
+}