Add support for food items
Some checks failed
Java CI with Gradle / build (push) Has been cancelled

This commit is contained in:
Adam 2025-04-24 20:06:24 +01:00
parent d8373f5469
commit 9d44d319d1
3 changed files with 68 additions and 9 deletions

View File

@ -50,8 +50,7 @@ public class HotbarReplace implements ClientModInitializer {
// I honestly do not know Minecraft internals enough to be sure that there won't // I honestly do not know Minecraft internals enough to be sure that there won't
// be de-sync issues. // be de-sync issues.
int current_fps = client.getCurrentFps(); final int click_delay_ms = 50;
int click_delay = Math.round(1.0f / (float) current_fps) * 1000;
client.interactionManager.clickSlot(player.currentScreenHandler.syncId, i, GLFW.GLFW_MOUSE_BUTTON_1, client.interactionManager.clickSlot(player.currentScreenHandler.syncId, i, GLFW.GLFW_MOUSE_BUTTON_1,
SlotActionType.PICKUP, player); SlotActionType.PICKUP, player);
@ -62,7 +61,7 @@ public class HotbarReplace implements ClientModInitializer {
client.interactionManager.clickSlot(player.currentScreenHandler.syncId, client.interactionManager.clickSlot(player.currentScreenHandler.syncId,
slot + PlayerInventory.MAIN_SIZE, GLFW.GLFW_MOUSE_BUTTON_1, slot + PlayerInventory.MAIN_SIZE, GLFW.GLFW_MOUSE_BUTTON_1,
SlotActionType.PICKUP, player); SlotActionType.PICKUP, player);
}, click_delay, TimeUnit.MILLISECONDS); }, click_delay_ms, TimeUnit.MILLISECONDS);
return; return;
} }

View File

@ -22,28 +22,54 @@ public class ItemStackMixin {
@Inject(at = @At("HEAD"), method = "use") @Inject(at = @At("HEAD"), method = "use")
private void ItemStack_use_HEAD(World world, PlayerEntity player, Hand hand, private void ItemStack_use_HEAD(World world, PlayerEntity player, Hand hand,
CallbackInfoReturnable<ActionResult> info) { CallbackInfoReturnable<ActionResult> info) {
lastUsedItem = player.getStackInHand(hand).getItem(); if (!world.isClient())
return;
Item item = player.getStackInHand(hand).getItem();
if (item == null)
return;
lastUsedItem = item;
} }
@Inject(at = @At("HEAD"), method = "useOnBlock") @Inject(at = @At("HEAD"), method = "useOnBlock")
private void ItemStack_useOnBlock_HEAD(ItemUsageContext context, private void ItemStack_useOnBlock_HEAD(ItemUsageContext context,
CallbackInfoReturnable<ActionResult> info) { CallbackInfoReturnable<ActionResult> info) {
lastUsedItem = context.getPlayer().getStackInHand(context.getHand()).getItem(); if (!context.getWorld().isClient())
return;
Item item = context.getPlayer().getStackInHand(context.getHand()).getItem();
if (item == null)
return;
lastUsedItem = item;
} }
@Inject(at = @At("HEAD"), method = "useOnEntity") @Inject(at = @At("HEAD"), method = "useOnEntity")
private void ItemStack_useOnEntity_HEAD(PlayerEntity player, LivingEntity entity, Hand hand, private void ItemStack_useOnEntity_HEAD(PlayerEntity player, LivingEntity entity, Hand hand,
CallbackInfoReturnable<ActionResult> info) { CallbackInfoReturnable<ActionResult> info) {
lastUsedItem = player.getStackInHand(hand).getItem(); if (!player.getWorld().isClient())
return;
Item item = player.getStackInHand(hand).getItem();
if (item == null)
return;
lastUsedItem = item;
} }
@Inject(at = @At("TAIL"), method = "use") @Inject(at = @At("TAIL"), method = "use")
private void ItemStack_use_TAIL(World world, PlayerEntity player, Hand hand, private void ItemStack_use_TAIL(World world, PlayerEntity player, Hand hand,
CallbackInfoReturnable<ActionResult> info) { CallbackInfoReturnable<ActionResult> info) {
if (!world.isClient())
return;
if (info.getReturnValue() != ActionResult.SUCCESS) if (info.getReturnValue() != ActionResult.SUCCESS)
return; return;
if (player.getStackInHand(hand).getCount() != 0) ItemStack stack = player.getStackInHand(hand);
if (stack.getCount() > 1)
return; return;
HotbarReplace.tryReplaceSlot(player, hand, lastUsedItem); HotbarReplace.tryReplaceSlot(player, hand, lastUsedItem);
@ -51,13 +77,17 @@ public class ItemStackMixin {
@Inject(at = @At("TAIL"), method = "useOnBlock") @Inject(at = @At("TAIL"), method = "useOnBlock")
private void ItemStack_useOnBlock_TAIL(ItemUsageContext context, CallbackInfoReturnable<ActionResult> info) { private void ItemStack_useOnBlock_TAIL(ItemUsageContext context, CallbackInfoReturnable<ActionResult> info) {
if (!context.getWorld().isClient())
return;
if (info.getReturnValue() != ActionResult.SUCCESS) if (info.getReturnValue() != ActionResult.SUCCESS)
return; return;
PlayerEntity player = context.getPlayer(); PlayerEntity player = context.getPlayer();
Hand hand = context.getHand(); Hand hand = context.getHand();
ItemStack stack = player.getStackInHand(hand);
if (player.getStackInHand(hand).getCount() != 0) if (stack.getCount() != 0)
return; return;
HotbarReplace.tryReplaceSlot(player, hand, lastUsedItem); HotbarReplace.tryReplaceSlot(player, hand, lastUsedItem);
@ -69,9 +99,38 @@ public class ItemStackMixin {
if (info.getReturnValue() != ActionResult.SUCCESS) if (info.getReturnValue() != ActionResult.SUCCESS)
return; return;
if (player.getStackInHand(hand).getCount() != 0) ItemStack stack = player.getStackInHand(hand);
if (stack.getCount() > 1)
return; return;
HotbarReplace.tryReplaceSlot(player, hand, lastUsedItem); HotbarReplace.tryReplaceSlot(player, hand, lastUsedItem);
} }
@Inject(at = @At("HEAD"), method = "Lnet/minecraft/item/ItemStack;finishUsing(Lnet/minecraft/world/World;Lnet/minecraft/entity/LivingEntity;)Lnet/minecraft/item/ItemStack;")
private void ItemStack_finishUsing_HEAD(World world, LivingEntity user,
CallbackInfoReturnable<ItemStack> info) {
if (!world.isClient())
return;
ItemStack stack = (ItemStack) (Object) this;
// ItemStack stack = info.getReturnValue(); -- only applicable when injecting at TAIL
if (lastUsedItem != stack.getItem())
return;
// Food items disappear into thin (minecraft:)air before their stack size reaches 0
if (stack.getCount() > 1)
return;
if (!user.isPlayer())
return;
PlayerEntity player = (PlayerEntity) user;
if (!player.isMainPlayer())
return;
HotbarReplace.tryReplaceSlot(player, player.getActiveHand(), lastUsedItem);
}
} }

View File

@ -6,6 +6,7 @@
"client": [ "client": [
"ItemStackMixin" "ItemStackMixin"
], ],
"server": [],
"injectors": { "injectors": {
"defaultRequire": 1 "defaultRequire": 1
} }