aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/main/java/io/github/cottonmc/cotton/gui/widget/WLabel.java7
-rw-r--r--src/main/java/io/github/cottonmc/cotton/gui/widget/WText.java133
2 files changed, 140 insertions, 0 deletions
diff --git a/src/main/java/io/github/cottonmc/cotton/gui/widget/WLabel.java b/src/main/java/io/github/cottonmc/cotton/gui/widget/WLabel.java
index f09c263..73e6433 100644
--- a/src/main/java/io/github/cottonmc/cotton/gui/widget/WLabel.java
+++ b/src/main/java/io/github/cottonmc/cotton/gui/widget/WLabel.java
@@ -14,6 +14,9 @@ import net.minecraft.text.Text;
import javax.annotation.Nullable;
+/**
+ * A single-line label widget.
+ */
public class WLabel extends WWidget {
protected Text text;
protected Alignment alignment = Alignment.LEFT;
@@ -37,6 +40,10 @@ public class WLabel extends WWidget {
this(text, DEFAULT_TEXT_COLOR);
}
+ public WLabel(Text text) {
+ this(text, DEFAULT_TEXT_COLOR);
+ }
+
@Override
public void paintBackground(int x, int y, int mouseX, int mouseY) {
String translated = text.asFormattedString();
diff --git a/src/main/java/io/github/cottonmc/cotton/gui/widget/WText.java b/src/main/java/io/github/cottonmc/cotton/gui/widget/WText.java
new file mode 100644
index 0000000..7e90b39
--- /dev/null
+++ b/src/main/java/io/github/cottonmc/cotton/gui/widget/WText.java
@@ -0,0 +1,133 @@
+package io.github.cottonmc.cotton.gui.widget;
+
+import io.github.cottonmc.cotton.gui.client.LibGuiClient;
+import io.github.cottonmc.cotton.gui.client.ScreenDrawing;
+import io.github.cottonmc.cotton.gui.widget.data.Alignment;
+import net.fabricmc.api.EnvType;
+import net.fabricmc.api.Environment;
+import net.fabricmc.loader.api.FabricLoader;
+import net.minecraft.client.MinecraftClient;
+import net.minecraft.client.font.TextRenderer;
+import net.minecraft.client.util.Texts;
+import net.minecraft.text.Text;
+
+import javax.annotation.Nullable;
+import java.util.List;
+import java.util.Objects;
+
+/**
+ * A multiline label widget.
+ *
+ * @since 1.8.0
+ */
+public class WText extends WWidget {
+ protected Text text;
+ protected int color;
+ protected int darkmodeColor;
+ protected Alignment alignment = Alignment.LEFT;
+ private List<Text> wrappedLines;
+
+ public WText(Text text) {
+ this(text, WLabel.DEFAULT_TEXT_COLOR);
+ }
+
+ public WText(Text text, int color) {
+ this.text = Objects.requireNonNull(text, "text must not be null");
+ this.color = color;
+ this.darkmodeColor = (color == WLabel.DEFAULT_TEXT_COLOR) ? WLabel.DEFAULT_DARKMODE_TEXT_COLOR : color;
+ }
+
+ @Override
+ public void setSize(int x, int y) {
+ super.setSize(x, y);
+ if (FabricLoader.getInstance().getEnvironmentType() == EnvType.CLIENT) {
+ wrapLines();
+ }
+ }
+
+ @Environment(EnvType.CLIENT)
+ private void wrapLines() {
+ TextRenderer font = MinecraftClient.getInstance().textRenderer;
+ wrappedLines = Texts.wrapLines(text, width, font, true, true);
+ }
+
+ @Environment(EnvType.CLIENT)
+ @Nullable
+ protected Text getTextAt(int x, int y) {
+ TextRenderer font = MinecraftClient.getInstance().textRenderer;
+ int lineIndex = y / font.fontHeight;
+
+ if (lineIndex >= 0 && lineIndex < wrappedLines.size()) {
+ Text line = wrappedLines.get(lineIndex);
+ int xi = 0;
+ for (Text part : line) {
+ xi += font.getStringWidth(part.asFormattedString());
+ if (xi > x) return part;
+ }
+ }
+
+ return null;
+ }
+
+ @Environment(EnvType.CLIENT)
+ @Override
+ public void paintBackground(int x, int y, int mouseX, int mouseY) {
+ TextRenderer font = MinecraftClient.getInstance().textRenderer;
+ for (int i = 0; i < wrappedLines.size(); i++) {
+ Text line = wrappedLines.get(i);
+ int c = LibGuiClient.config.darkMode ? darkmodeColor : color;
+ String str = line.asFormattedString();
+
+ ScreenDrawing.drawString(str, alignment, x, y + i * font.fontHeight, width, c);
+ }
+ }
+
+ @Override
+ public void onClick(int x, int y, int button) {
+ if (button != 0) return; // only left clicks
+
+ Text hoveredText = getTextAt(x, y);
+ if (hoveredText != null) {
+ MinecraftClient.getInstance().currentScreen.handleTextClick(hoveredText);
+ }
+ }
+
+ public Text getText() {
+ return text;
+ }
+
+ public WText setText(Text text) {
+ this.text = text;
+
+ if (FabricLoader.getInstance().getEnvironmentType() == EnvType.CLIENT) {
+ wrapLines();
+ }
+
+ return this;
+ }
+
+ public int getColor() {
+ return color;
+ }
+
+ public WText setColor(int color) {
+ this.color = color;
+ return this;
+ }
+
+ public WText setDarkmodeColor(int darkmodeColor) {
+ this.darkmodeColor = darkmodeColor;
+ return this;
+ }
+
+ public WText setColor(int color, int darkmodeColor) {
+ setColor(color);
+ setDarkmodeColor(darkmodeColor);
+ return this;
+ }
+
+ public WText disableDarkmode() {
+ this.darkmodeColor = this.color;
+ return this;
+ }
+}