diff options
author | nea <nea@nea.moe> | 2023-09-06 02:26:25 +0200 |
---|---|---|
committer | nea <nea@nea.moe> | 2023-09-06 02:26:25 +0200 |
commit | d29f886e25d7376c6942e7dbe6c305f601e2768d (patch) | |
tree | e2b15ca1cfea28cbcac97333b7fef192f50e2440 /src/main/kotlin/moe/nea | |
parent | 7515c6048c5fcee27af394ace02ba35256d10106 (diff) | |
download | Firmament-d29f886e25d7376c6942e7dbe6c305f601e2768d.tar.gz Firmament-d29f886e25d7376c6942e7dbe6c305f601e2768d.tar.bz2 Firmament-d29f886e25d7376c6942e7dbe6c305f601e2768d.zip |
Add auto sprint toggle keybinding
Diffstat (limited to 'src/main/kotlin/moe/nea')
3 files changed, 47 insertions, 2 deletions
diff --git a/src/main/kotlin/moe/nea/firmament/events/HudRenderEvent.kt b/src/main/kotlin/moe/nea/firmament/events/HudRenderEvent.kt new file mode 100644 index 0000000..bf008d3 --- /dev/null +++ b/src/main/kotlin/moe/nea/firmament/events/HudRenderEvent.kt @@ -0,0 +1,16 @@ +/* + * SPDX-FileCopyrightText: 2023 Linnea Gräf <nea@nea.moe> + * + * SPDX-License-Identifier: GPL-3.0-or-later + */ + +package moe.nea.firmament.events + +import net.minecraft.client.gui.DrawContext + +/** + * Called when hud elements should be rendered, before the screen, but after the world. + */ +data class HudRenderEvent(val context: DrawContext, val tickDelta: Float) : FirmamentEvent() { + companion object : FirmamentEventBus<HudRenderEvent>() +} diff --git a/src/main/kotlin/moe/nea/firmament/features/fixes/Fixes.kt b/src/main/kotlin/moe/nea/firmament/features/fixes/Fixes.kt index acf23ba..a6f4965 100644 --- a/src/main/kotlin/moe/nea/firmament/features/fixes/Fixes.kt +++ b/src/main/kotlin/moe/nea/firmament/features/fixes/Fixes.kt @@ -6,11 +6,15 @@ package moe.nea.firmament.features.fixes +import moe.nea.firmament.events.HudRenderEvent +import moe.nea.firmament.events.WorldKeyboardEvent import moe.nea.firmament.features.FirmamentFeature import moe.nea.firmament.gui.config.ManagedConfig import moe.nea.firmament.util.MC +import moe.nea.jarvis.api.Point import net.minecraft.client.MinecraftClient import net.minecraft.client.option.KeyBinding +import net.minecraft.text.Text import org.spongepowered.asm.mixin.injection.callback.CallbackInfoReturnable object Fixes : FirmamentFeature { @@ -19,7 +23,9 @@ object Fixes : FirmamentFeature { object TConfig : ManagedConfig(identifier) { val fixUnsignedPlayerSkins by toggle("player-skins") { true } - val autoSprint by toggle("auto-sprint") { false } + var autoSprint by toggle("auto-sprint") { false } + val autoSprintKeyBinding by keyBindingWithDefaultUnbound("auto-sprint-keybinding") + val autoSprintHud by position("auto-sprint-hud", 80, 10) { Point(0.0, 1.0) } val peekChat by keyBindingWithDefaultUnbound("peek-chat") } @@ -35,6 +41,27 @@ object Fixes : FirmamentFeature { } override fun onLoad() { + WorldKeyboardEvent.subscribe { + if (it.matches(TConfig.autoSprintKeyBinding)) { + TConfig.autoSprint = !TConfig.autoSprint + } + } + HudRenderEvent.subscribe { + if (!TConfig.autoSprintKeyBinding.isBound) return@subscribe + it.context.matrices.push() + TConfig.autoSprintHud.applyTransformations(it.context.matrices) + it.context.drawText( + MC.font, Text.translatable( + if (TConfig.autoSprint) + "firmament.fixes.auto-sprint.on" + else if (MC.player?.isSprinting == true) + "firmament.fixes.auto-sprint.sprinting" + else + "firmament.fixes.auto-sprint.not-sprinting" + ), 0, 0, -1, false + ) + it.context.matrices.pop() + } } fun shouldPeekChat(): Boolean { diff --git a/src/main/kotlin/moe/nea/firmament/keybindings/SavedKeyBinding.kt b/src/main/kotlin/moe/nea/firmament/keybindings/SavedKeyBinding.kt index ac73366..c5205bc 100644 --- a/src/main/kotlin/moe/nea/firmament/keybindings/SavedKeyBinding.kt +++ b/src/main/kotlin/moe/nea/firmament/keybindings/SavedKeyBinding.kt @@ -19,6 +19,8 @@ data class SavedKeyBinding( val ctrl: Boolean = false, val alt: Boolean = false, ) : IKeyBinding { + val isBound: Boolean get() = keyCode != GLFW.GLFW_KEY_UNKNOWN + constructor(keyCode: Int, mods: Triple<Boolean, Boolean, Boolean>) : this( keyCode, mods.first && keyCode != GLFW.GLFW_KEY_LEFT_SHIFT && keyCode != GLFW.GLFW_KEY_RIGHT_SHIFT, @@ -39,7 +41,7 @@ data class SavedKeyBinding( } fun isPressed(atLeast: Boolean = false): Boolean { - if (this.keyCode == GLFW.GLFW_KEY_UNKNOWN) return false + if (!isBound) return false val h = MC.window.handle if (!InputUtil.isKeyPressed(h, keyCode)) return false |