From 91a783c85a2b3bf5a9161e87fb23a95312c95807 Mon Sep 17 00:00:00 2001 From: thesefer <20844000+thesefer@users.noreply.github.com> Date: Sat, 29 Apr 2023 00:10:37 +0200 Subject: Yaw and pitch module (#73) Co-authored-by: hannibal2 <24389977+hannibal00212@users.noreply.github.com> --- src/main/java/at/hannibal2/skyhanni/SkyHanniMod.kt | 1 + .../hannibal2/skyhanni/config/features/Garden.java | 8 ++++ .../skyhanni/features/garden/GardenYawAndPitch.kt | 51 ++++++++++++++++++++++ 3 files changed, 60 insertions(+) create mode 100755 src/main/java/at/hannibal2/skyhanni/features/garden/GardenYawAndPitch.kt (limited to 'src/main/java/at/hannibal2/skyhanni') diff --git a/src/main/java/at/hannibal2/skyhanni/SkyHanniMod.kt b/src/main/java/at/hannibal2/skyhanni/SkyHanniMod.kt index 885a8093e..e1efbc052 100644 --- a/src/main/java/at/hannibal2/skyhanni/SkyHanniMod.kt +++ b/src/main/java/at/hannibal2/skyhanni/SkyHanniMod.kt @@ -261,6 +261,7 @@ class SkyHanniMod { loadModule(GardenBurrowingSporesNotifier()) loadModule(WildStrawberryDyeNotification()) loadModule(JacobContestFFNeededDisplay()) + loadModule(GardenYawAndPitch()) init() loadModule(LorenzTest()) loadModule(ButtonOnPause()) diff --git a/src/main/java/at/hannibal2/skyhanni/config/features/Garden.java b/src/main/java/at/hannibal2/skyhanni/config/features/Garden.java index 825b2b3bf..bfe47798b 100644 --- a/src/main/java/at/hannibal2/skyhanni/config/features/Garden.java +++ b/src/main/java/at/hannibal2/skyhanni/config/features/Garden.java @@ -1023,6 +1023,14 @@ public class Garden { @Expose public Position farmingFortuneForContestPos = new Position(180, 156, false, true); + @Expose + @ConfigOption(name = "Yaw / Pitch", desc = "Displays yaw and pitch with 4-digit accuracy while holding a farming tool. Automatically fades out if there is no movement for 3 seconds.") + @ConfigEditorBoolean + public boolean showYawAndPitch = false; + + @Expose + public Position YawAndPitchDisplayPos = new Position(445, 225, false, true); + @Expose @ConfigOption(name = "Always Finnegan", desc = "Forcefully set the Finnegan Farming Simulator perk to be active. This is useful if the auto mayor detection fails.") @ConfigEditorBoolean diff --git a/src/main/java/at/hannibal2/skyhanni/features/garden/GardenYawAndPitch.kt b/src/main/java/at/hannibal2/skyhanni/features/garden/GardenYawAndPitch.kt new file mode 100755 index 000000000..a6738aa16 --- /dev/null +++ b/src/main/java/at/hannibal2/skyhanni/features/garden/GardenYawAndPitch.kt @@ -0,0 +1,51 @@ +package at.hannibal2.skyhanni.features.garden + +import at.hannibal2.skyhanni.SkyHanniMod +import at.hannibal2.skyhanni.events.GardenToolChangeEvent +import at.hannibal2.skyhanni.events.GuiRenderEvent +import at.hannibal2.skyhanni.utils.LorenzUtils.round +import at.hannibal2.skyhanni.utils.RenderUtils.renderStrings +import net.minecraft.client.Minecraft +import net.minecraftforge.fml.common.eventhandler.SubscribeEvent + +class GardenYawAndPitch { + private val config get() = SkyHanniMod.feature.garden + private var lastChange = 0L + private var lastYaw = 0f + private var lastPitch = 0f + + @SubscribeEvent + fun onRenderOverlay(event: GuiRenderEvent.GameOverlayRenderEvent) { + if (!isEnabled()) return + if (GardenAPI.toolInHand == null) return + + val ypList = mutableListOf() + val player = Minecraft.getMinecraft().thePlayer + + var pYaw = player.rotationYaw % 360 + if (pYaw < 0) pYaw += 360 + if (pYaw > 180) pYaw -= 360 + val pPitch = player.rotationPitch + + if (pYaw != lastYaw || pPitch != lastPitch) { + lastChange = System.currentTimeMillis() + } + lastYaw = pYaw + lastPitch = pPitch + + if (System.currentTimeMillis() > lastChange + 3_000) return + + ypList.add("§aYaw: §f${pYaw.toDouble().round(4)}") + + ypList.add("§aPitch: §f${pPitch.toDouble().round(4)}") + + config.YawAndPitchDisplayPos.renderStrings(ypList, posLabel = "Yaw and Pitch") + } + + @SubscribeEvent + fun onGardenToolChange(event: GardenToolChangeEvent) { + lastChange = System.currentTimeMillis() + } + + private fun isEnabled() = GardenAPI.inGarden() && config.showYawAndPitch +} -- cgit