summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--src/main/java/co/fantabos/bscv/modules/Hud.java80
1 files changed, 80 insertions, 0 deletions
diff --git a/src/main/java/co/fantabos/bscv/modules/Hud.java b/src/main/java/co/fantabos/bscv/modules/Hud.java
new file mode 100644
index 0000000..4b54adf
--- /dev/null
+++ b/src/main/java/co/fantabos/bscv/modules/Hud.java
@@ -0,0 +1,80 @@
+package co.fantabos.bscv.modules;
+
+import com.mojang.brigadier.CommandDispatcher;
+import com.mojang.brigadier.arguments.BoolArgumentType;
+import com.mojang.brigadier.arguments.IntegerArgumentType;
+
+import co.fantabos.bscv.BoSCoVicino;
+import co.fantabos.bscv.Module;
+import net.minecraft.client.Minecraft;
+import net.minecraft.client.gui.screen.ChatScreen;
+import net.minecraft.command.CommandSource;
+import net.minecraft.util.math.vector.Vector3d;
+import net.minecraft.util.text.Color;
+import net.minecraft.util.text.StringTextComponent;
+import net.minecraft.util.text.Style;
+import net.minecraft.util.text.TextComponent;
+import net.minecraft.util.text.TextFormatting;
+import net.minecraftforge.client.event.RenderGameOverlayEvent;
+import net.minecraftforge.client.event.RenderGameOverlayEvent.ElementType;
+import net.minecraftforge.common.ForgeConfigSpec;
+import net.minecraftforge.eventbus.api.SubscribeEvent;
+
+public class Hud extends Module {
+
+ private final ForgeConfigSpec.ConfigValue<Boolean> coordinates;
+ private final ForgeConfigSpec.ConfigValue<Boolean> activemods;
+ private final ForgeConfigSpec.ConfigValue<Integer> size;
+
+ public Hud(ForgeConfigSpec.Builder builder, CommandDispatcher<CommandSource> dispatcher) {
+ super("Hud", Group.CORE, builder, dispatcher);
+
+ this.coordinates = this.option(
+ "coords", "show coordinates on screen", true,
+ BoolArgumentType.bool(), Boolean.class,
+ builder, dispatcher
+ );
+
+ this.activemods = this.option(
+ "modules", "show active modules on screen", true,
+ BoolArgumentType.bool(), Boolean.class,
+ builder, dispatcher
+ );
+
+ this.size = this.option(
+ "size", "font size for text", 12,
+ IntegerArgumentType.integer(), Integer.class,
+ builder, dispatcher
+ );
+ }
+
+ @SubscribeEvent
+ public void onRenderOverlay(RenderGameOverlayEvent event) {
+ Minecraft mc = BoSCoVicino.minecraft;
+ if (event.getType() == ElementType.TEXT) {
+ if (this.coordinates.get() && BoSCoVicino.minecraft.player != null) {
+ Vector3d position = mc.player.getPosition(0.0f);
+ TextComponent text = new StringTextComponent(String.format("[ X %.1f | %.1f Z ] %.1f Y", position.x(), position.z(), position.y()));
+ text.setStyle(Style.EMPTY.withColor(Color.fromLegacyFormat(TextFormatting.WHITE)));
+ float height = 1.0f;
+ if (mc.screen != null && mc.screen instanceof ChatScreen) {
+ height = 16.0f;
+ }
+ mc.font.drawShadow(event.getMatrixStack(), text, 1.0f, (event.getWindow().getHeight() / 2) - (mc.font.lineHeight + height), this.size.get());
+ }
+
+ if (this.activemods.get()) {
+ float offset = 27.0f;
+ for (Module m : BoSCoVicino.mods) {
+ if (m.enabled.get()) {
+ TextComponent text = new StringTextComponent(String.format("%s <", m.name));
+ text.setStyle(Style.EMPTY.withColor(Color.fromLegacyFormat(TextFormatting.WHITE)));
+ int textWidth = BoSCoVicino.minecraft.font.width(String.format("%s <", m.name));
+ mc.font.drawShadow(event.getMatrixStack(), text, (event.getWindow().getWidth() / 2) - (textWidth + 1), offset, this.size.get());
+ offset += mc.font.lineHeight;
+ }
+ }
+ }
+ }
+ }
+}