Add the ability to unbind keys using ESCAPE
This commit is contained in:
@@ -8,16 +8,16 @@ package moe.nea.firmament.gui.config
|
||||
|
||||
import io.github.cottonmc.cotton.gui.widget.WButton
|
||||
import io.github.cottonmc.cotton.gui.widget.data.InputResult
|
||||
import org.lwjgl.glfw.GLFW
|
||||
import kotlinx.serialization.json.Json
|
||||
import kotlinx.serialization.json.JsonElement
|
||||
import kotlinx.serialization.json.decodeFromJsonElement
|
||||
import kotlinx.serialization.json.encodeToJsonElement
|
||||
import moe.nea.firmament.keybindings.FirmamentKeyBindings
|
||||
import moe.nea.firmament.keybindings.SavedKeyBinding
|
||||
import net.minecraft.client.util.InputUtil
|
||||
import net.minecraft.text.Text
|
||||
import net.minecraft.util.Formatting
|
||||
import org.lwjgl.glfw.GLFW
|
||||
import moe.nea.firmament.keybindings.FirmamentKeyBindings
|
||||
import moe.nea.firmament.keybindings.SavedKeyBinding
|
||||
|
||||
class KeyBindingHandler(name: String, managedConfig: ManagedConfig) : ManagedConfig.OptionHandler<SavedKeyBinding> {
|
||||
init {
|
||||
@@ -46,6 +46,7 @@ class KeyBindingHandler(name: String, managedConfig: ManagedConfig) : ManagedCon
|
||||
lastPressedNonModifier = 0
|
||||
editing = false
|
||||
lastPressed = 0
|
||||
opt.value = SavedKeyBinding(GLFW.GLFW_KEY_UNKNOWN)
|
||||
updateButton!!()
|
||||
return InputResult.PROCESSED
|
||||
}
|
||||
|
||||
@@ -38,25 +38,8 @@ data class SavedKeyBinding(
|
||||
}
|
||||
}
|
||||
|
||||
fun hasShiftDown(): Boolean {
|
||||
return InputUtil.isKeyPressed(
|
||||
MinecraftClient.getInstance().window.handle,
|
||||
GLFW.GLFW_KEY_LEFT_SHIFT
|
||||
) || InputUtil.isKeyPressed(
|
||||
MinecraftClient.getInstance().window.handle, GLFW.GLFW_KEY_RIGHT_SHIFT
|
||||
)
|
||||
}
|
||||
|
||||
fun hasAltDown(): Boolean {
|
||||
return InputUtil.isKeyPressed(
|
||||
MinecraftClient.getInstance().window.handle,
|
||||
GLFW.GLFW_KEY_LEFT_ALT
|
||||
) || InputUtil.isKeyPressed(
|
||||
MinecraftClient.getInstance().window.handle, GLFW.GLFW_KEY_RIGHT_ALT
|
||||
)
|
||||
}
|
||||
|
||||
fun isPressed(): Boolean {
|
||||
if (this.keyCode == GLFW.GLFW_KEY_UNKNOWN) return false
|
||||
val h = MC.window.handle
|
||||
if (!InputUtil.isKeyPressed(h, keyCode)) return false
|
||||
|
||||
@@ -76,6 +59,7 @@ data class SavedKeyBinding(
|
||||
}
|
||||
|
||||
override fun matches(keyCode: Int, scanCode: Int, modifiers: Int): Boolean {
|
||||
if (this.keyCode == GLFW.GLFW_KEY_UNKNOWN) return false
|
||||
return keyCode == this.keyCode && getMods(modifiers) == Triple(shift, ctrl, alt)
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user