Add world keyboard event
This commit is contained in:
17
src/main/java/moe/nea/firmament/mixins/MixinKeyboard.java
Normal file
17
src/main/java/moe/nea/firmament/mixins/MixinKeyboard.java
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
package moe.nea.firmament.mixins;
|
||||||
|
|
||||||
|
import moe.nea.firmament.events.WorldKeyboardEvent;
|
||||||
|
import net.minecraft.client.Keyboard;
|
||||||
|
import org.spongepowered.asm.mixin.Mixin;
|
||||||
|
import org.spongepowered.asm.mixin.injection.At;
|
||||||
|
import org.spongepowered.asm.mixin.injection.Inject;
|
||||||
|
import org.spongepowered.asm.mixin.injection.callback.CallbackInfo;
|
||||||
|
|
||||||
|
@Mixin(Keyboard.class)
|
||||||
|
public class MixinKeyboard {
|
||||||
|
|
||||||
|
@Inject(method = "onKey", at = @At(value = "INVOKE", target = "Lnet/minecraft/client/option/KeyBinding;onKeyPressed(Lnet/minecraft/client/util/InputUtil$Key;)V"))
|
||||||
|
public void onKeyBoardInWorld(long window, int key, int scancode, int action, int modifiers, CallbackInfo ci) {
|
||||||
|
WorldKeyboardEvent.Companion.publish(new WorldKeyboardEvent(key, scancode, modifiers));
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -0,0 +1,16 @@
|
|||||||
|
package moe.nea.firmament.events
|
||||||
|
|
||||||
|
import net.minecraft.client.option.KeyBinding
|
||||||
|
import moe.nea.firmament.keybindings.IKeyBinding
|
||||||
|
|
||||||
|
data class WorldKeyboardEvent(val keyCode: Int, val scanCode: Int, val modifiers: Int) : FirmamentEvent.Cancellable() {
|
||||||
|
companion object : FirmamentEventBus<WorldKeyboardEvent>()
|
||||||
|
|
||||||
|
fun matches(keyBinding: KeyBinding): Boolean {
|
||||||
|
return matches(IKeyBinding.minecraft(keyBinding))
|
||||||
|
}
|
||||||
|
|
||||||
|
fun matches(keyBinding: IKeyBinding): Boolean {
|
||||||
|
return keyBinding.matches(keyCode, scanCode, modifiers)
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user