From c3af0d9cd112cbe71966c57cbbf914346faadfc3 Mon Sep 17 00:00:00 2001 From: ronald Date: Sun, 30 Jul 2023 19:58:05 -0500 Subject: Added more HUD stuff and clipboard BUGFIX --- .../kotlin/com/dulkirfabric/DulkirModFabric.kt | 1 - .../com/dulkirfabric/commands/AnimationCommand.kt | 17 ++++------- .../kotlin/com/dulkirfabric/config/DulkirConfig.kt | 12 ++++++++ src/main/kotlin/com/dulkirfabric/hud/Garden.kt | 31 +++++++++++++++++-- .../kotlin/com/dulkirfabric/hud/SpeedOverlay.kt | 35 ++++++++++++++++++---- 5 files changed, 76 insertions(+), 20 deletions(-) (limited to 'src') diff --git a/src/main/kotlin/com/dulkirfabric/DulkirModFabric.kt b/src/main/kotlin/com/dulkirfabric/DulkirModFabric.kt index 0c8c314..80f4dc2 100644 --- a/src/main/kotlin/com/dulkirfabric/DulkirModFabric.kt +++ b/src/main/kotlin/com/dulkirfabric/DulkirModFabric.kt @@ -46,7 +46,6 @@ object DulkirModFabric : ModInitializer { Registrations.registerEvents() DulkirConfig.loadConfig() - System.setProperty("java.awt.headless", "false"); } } \ No newline at end of file diff --git a/src/main/kotlin/com/dulkirfabric/commands/AnimationCommand.kt b/src/main/kotlin/com/dulkirfabric/commands/AnimationCommand.kt index 39a9f11..6a8829d 100644 --- a/src/main/kotlin/com/dulkirfabric/commands/AnimationCommand.kt +++ b/src/main/kotlin/com/dulkirfabric/commands/AnimationCommand.kt @@ -1,17 +1,14 @@ package com.dulkirfabric.commands +import com.dulkirfabric.DulkirModFabric.mc import com.dulkirfabric.config.DulkirConfig -import com.dulkirfabric.util.render.AnimationPreset import com.dulkirfabric.util.TextUtils +import com.dulkirfabric.util.render.AnimationPreset import com.google.gson.Gson import com.mojang.brigadier.CommandDispatcher import com.mojang.brigadier.builder.LiteralArgumentBuilder import net.fabricmc.fabric.api.client.command.v2.FabricClientCommandSource import net.minecraft.command.CommandRegistryAccess -import java.awt.Toolkit -import java.awt.datatransfer.Clipboard -import java.awt.datatransfer.DataFlavor -import java.awt.datatransfer.StringSelection import java.util.* object AnimationCommand { @@ -51,8 +48,7 @@ object AnimationCommand { private fun applyPresetFromClipboard() { val gson = Gson() - val clipboard = Toolkit.getDefaultToolkit().systemClipboard - val base64 = clipboard.getData(DataFlavor.stringFlavor) as String + val base64 = mc.keyboard.clipboard try { val jsonString = String(Base64.getDecoder().decode(base64)) val import = gson.fromJson(jsonString, AnimationPreset::class.java) @@ -74,14 +70,11 @@ object AnimationCommand { } private fun applyPresetToClipboard() { - var s = "" val gson = Gson() val jsonString = gson.toJson(DulkirConfig.configOptions.animationPreset) - s = Base64.getEncoder().encodeToString(jsonString.toByteArray()) + val s = Base64.getEncoder().encodeToString(jsonString.toByteArray()) // set clipboard - val selection = StringSelection(s) - val clipboard: Clipboard = Toolkit.getDefaultToolkit().systemClipboard - clipboard.setContents(selection, selection) + mc.keyboard.clipboard = s TextUtils.info("ยง6Animation config has been copied to clipboard") } } \ No newline at end of file diff --git a/src/main/kotlin/com/dulkirfabric/config/DulkirConfig.kt b/src/main/kotlin/com/dulkirfabric/config/DulkirConfig.kt index 1457a85..c6ed544 100644 --- a/src/main/kotlin/com/dulkirfabric/config/DulkirConfig.kt +++ b/src/main/kotlin/com/dulkirfabric/config/DulkirConfig.kt @@ -144,6 +144,9 @@ class DulkirConfig { entryBuilder.mkToggle(Text.literal("Convert Action Bar to HUD elements"), configOptions::hudifyActionBar, tooltip = Text.literal("This converts Mana/Health/Def/Stacks as HUD elements")) ) + general.addEntry( + entryBuilder.mkToggle(Text.literal("Show Speed in HUD"), configOptions::speedHud) + ) general.addEntry( entryBuilder.mkToggle(Text.literal("Include EHP in def HUD element"), configOptions::showEHP, tooltip = Text.literal("Must have Action Bar HUD elements Enabled")) @@ -320,6 +323,12 @@ class DulkirConfig { garden.addEntry( entryBuilder.mkToggle(Text.literal("Persistent Visitor alert (dependent on previous)"), configOptions::persistentVisitorAlert) ) + garden.addEntry( + entryBuilder.mkToggle(Text.literal("Show Blocks per second (SPEED)"), configOptions::speedBpsHud) + ) + garden.addEntry( + entryBuilder.mkToggle(Text.literal("Show Pitch/Yaw in HUD"), configOptions::pitchYawDisplay) + ) builder.transparentBackground() screen = builder.build() @@ -377,6 +386,9 @@ class DulkirConfig { var brokenHypNotif: Boolean = false, var steakDisplay: Boolean = false, var ichorHighlight: Boolean = false, + var speedHud: Boolean = false, + var speedBpsHud: Boolean = false, + var pitchYawDisplay: Boolean = false, ) @Serializable diff --git a/src/main/kotlin/com/dulkirfabric/hud/Garden.kt b/src/main/kotlin/com/dulkirfabric/hud/Garden.kt index 673b630..1c77c77 100644 --- a/src/main/kotlin/com/dulkirfabric/hud/Garden.kt +++ b/src/main/kotlin/com/dulkirfabric/hud/Garden.kt @@ -12,9 +12,11 @@ import net.minecraft.util.Formatting object Garden { private val visitorHud = DulkirConfig.hudElement("visitors", Text.literal("Visitors"), 100, 21, - Point(0.4056462738575835, 0.4479382203757649),1.2286775f) + Point(0.4056462738575835, 0.055456899963360104),1.101687f) private val composterHud = DulkirConfig.hudElement("composter", Text.literal("Composter"), 100, 21, - Point(0.4056462738575835, 0.4479382203757649),1.2286775f) + Point(0.027783937063393563, 0.10514400299398007),0.9619154f) + private val pitchYawHud = DulkirConfig.hudElement("pitch/yaw", Text.literal("Pitch/Yaw"), 100, 21, + Point(0.027783937063393563, 0.15514400299398007),0.9619154f) @EventHandler fun onHudRender(event: HudRenderEvent) { @@ -48,5 +50,30 @@ object Garden { context.drawText(mc.textRenderer, composterText,0, 1, -1, true) matrices.pop() } + var yaw = mc.player?.yaw ?: return + val pitch = mc.player?.pitch ?: return + yaw %= 360f + if (yaw < -180.0f) { + yaw += 360.0f; + } else if (yaw > 180.0f) { + yaw -= 360.0f; + } + + if (DulkirConfig.configOptions.pitchYawDisplay) { + matrices.push() + pitchYawHud.applyTransformations(matrices) + + val yawText = Text.literal("Yaw: ") + .setStyle(Style.EMPTY.withColor(Formatting.GOLD)) + .append(Text.literal("%.2f".format(yaw)) + .setStyle(Style.EMPTY.withColor(Formatting.GRAY))) + context.drawText(mc.textRenderer, yawText,0, 1, -1, true) + val pitchText = Text.literal("Pitch: ") + .setStyle(Style.EMPTY.withColor(Formatting.GOLD)) + .append(Text.literal("%.2f".format(pitch)) + .setStyle(Style.EMPTY.withColor(Formatting.GRAY))) + context.drawText(mc.textRenderer, pitchText,0, 13, -1, true) + matrices.pop() + } } } \ No newline at end of file diff --git a/src/main/kotlin/com/dulkirfabric/hud/SpeedOverlay.kt b/src/main/kotlin/com/dulkirfabric/hud/SpeedOverlay.kt index 53aca50..85756ee 100644 --- a/src/main/kotlin/com/dulkirfabric/hud/SpeedOverlay.kt +++ b/src/main/kotlin/com/dulkirfabric/hud/SpeedOverlay.kt @@ -2,23 +2,48 @@ package com.dulkirfabric.hud import com.dulkirfabric.DulkirModFabric.mc import com.dulkirfabric.config.DulkirConfig +import com.dulkirfabric.events.ClientTickEvent import com.dulkirfabric.events.HudRenderEvent import com.dulkirfabric.util.TablistUtils import meteordevelopment.orbit.EventHandler import moe.nea.jarvis.api.Point +import net.fabricmc.loader.impl.lib.sat4j.core.Vec +import net.minecraft.text.Style import net.minecraft.text.Text +import net.minecraft.util.math.Vec3d object SpeedOverlay { private val speedHud = DulkirConfig.hudElement("SpeedHud", Text.literal("Speed"), 24 + 4, 11, - Point(0.3669986675110943, 0.9857798862704453), 1.6367052f) + Point(0.028240898890913812, 0.9857798862704453), 1.6367052f) + private val bpsOverlay = DulkirConfig.hudElement("MovementHud", Text.literal("Speed (BPS)"), 69, 11, + Point(0.020240898890, 0.9857798862704453), 1.5052f) + + + private var tickMomentum = 0.0 @EventHandler fun onHudRender(event: HudRenderEvent) { val context = event.context val matrices = context.matrices - matrices.push() - speedHud.applyTransformations(matrices) - context.drawText(mc.textRenderer, Text.literal(TablistUtils.persistentInfo.speed),0, 1, -1, true) - matrices.pop() + if (DulkirConfig.configOptions.speedHud) { + matrices.push() + speedHud.applyTransformations(matrices) + context.drawText(mc.textRenderer, Text.literal(TablistUtils.persistentInfo.speed),0, 1, -1, true) + matrices.pop() + } + if (DulkirConfig.configOptions.speedBpsHud) { + matrices.push() + bpsOverlay.applyTransformations(matrices) + context.drawText(mc.textRenderer, Text.literal("${"%.2f".format(tickMomentum)} BPS (speed)"),0, 1, -1, true) + matrices.pop() + } + } + + @EventHandler + fun onTick(event: ClientTickEvent) { + val player = mc.player ?: return + val last = Vec3d(player.prevX, player.prevY, player.prevZ) + val now = player.pos ?: return + tickMomentum = last.distanceTo(now) * 20 } } \ No newline at end of file -- cgit