Compare commits

..

No commits in common. "master" and "v0.1.4" have entirely different histories.

6 changed files with 23 additions and 80 deletions

View File

@ -29,10 +29,10 @@ jobs:
- name: Build with Gradle Wrapper
run: ./gradlew build
# - name: Upload build artifacts
# uses: actions/upload-artifact@v4
# with:
# name: JARs
# path: build/libs
# retention-days: 30
# compression-level: 9
- name: Upload build artifacts
uses: actions/upload-artifact@v4
with:
name: JARs
path: build/libs
retention-days: 30
compression-level: 9

View File

@ -8,7 +8,7 @@ yarn_mappings=1.21.5+build.1
loader_version=0.16.13
# Mod Properties
mod_version = 0.1.5
mod_version = 0.1.4
maven_group = xyz.twokilohertz
archives_base_name = HotbarReplace

View File

@ -23,7 +23,7 @@ public class HotbarReplace implements ClientModInitializer {
@Override
public void onInitializeClient() {
LOGGER.info("HotbarReplace v0.1.5 initialised");
LOGGER.info("HotbarReplace v0.1.4 initialised");
}
public static void tryReplaceSlot(PlayerEntity player, Hand hand, Item item) {
@ -50,16 +50,19 @@ public class HotbarReplace implements ClientModInitializer {
// I honestly do not know Minecraft internals enough to be sure that there won't
// be de-sync issues.
final int click_delay_ms = 50;
int current_fps = client.getCurrentFps();
int click_delay = Math.round(1.0f / (float) current_fps) * 1000;
client.interactionManager.clickSlot(player.currentScreenHandler.syncId, i, GLFW.GLFW_MOUSE_BUTTON_1,
SlotActionType.PICKUP, player);
int slot = (hand == Hand.OFF_HAND ? 9 : inventory.getSelectedSlot());
scheduler.schedule(() -> client.interactionManager.clickSlot(player.currentScreenHandler.syncId,
scheduler.schedule(() -> {
client.interactionManager.clickSlot(player.currentScreenHandler.syncId,
slot + PlayerInventory.MAIN_SIZE, GLFW.GLFW_MOUSE_BUTTON_1,
SlotActionType.PICKUP, player), click_delay_ms, TimeUnit.MILLISECONDS);
SlotActionType.PICKUP, player);
}, click_delay, TimeUnit.MILLISECONDS);
return;
}

View File

@ -22,54 +22,28 @@ public class ItemStackMixin {
@Inject(at = @At("HEAD"), method = "use")
private void ItemStack_use_HEAD(World world, PlayerEntity player, Hand hand,
CallbackInfoReturnable<ActionResult> info) {
if (!world.isClient())
return;
Item item = player.getStackInHand(hand).getItem();
if (item == null)
return;
lastUsedItem = item;
lastUsedItem = player.getStackInHand(hand).getItem();
}
@Inject(at = @At("HEAD"), method = "useOnBlock")
private void ItemStack_useOnBlock_HEAD(ItemUsageContext context,
CallbackInfoReturnable<ActionResult> info) {
if (!context.getWorld().isClient())
return;
Item item = context.getPlayer().getStackInHand(context.getHand()).getItem();
if (item == null)
return;
lastUsedItem = item;
lastUsedItem = context.getPlayer().getStackInHand(context.getHand()).getItem();
}
@Inject(at = @At("HEAD"), method = "useOnEntity")
private void ItemStack_useOnEntity_HEAD(PlayerEntity player, LivingEntity entity, Hand hand,
CallbackInfoReturnable<ActionResult> info) {
if (!player.getWorld().isClient())
return;
Item item = player.getStackInHand(hand).getItem();
if (item == null)
return;
lastUsedItem = item;
lastUsedItem = player.getStackInHand(hand).getItem();
}
@Inject(at = @At("TAIL"), method = "use")
private void ItemStack_use_TAIL(World world, PlayerEntity player, Hand hand,
CallbackInfoReturnable<ActionResult> info) {
if (!world.isClient())
return;
if (info.getReturnValue() != ActionResult.SUCCESS)
return;
ItemStack stack = player.getStackInHand(hand);
if (stack.getCount() > 1)
if (player.getStackInHand(hand).getCount() != 0)
return;
HotbarReplace.tryReplaceSlot(player, hand, lastUsedItem);
@ -77,17 +51,13 @@ public class ItemStackMixin {
@Inject(at = @At("TAIL"), method = "useOnBlock")
private void ItemStack_useOnBlock_TAIL(ItemUsageContext context, CallbackInfoReturnable<ActionResult> info) {
if (!context.getWorld().isClient())
return;
if (info.getReturnValue() != ActionResult.SUCCESS)
return;
PlayerEntity player = context.getPlayer();
Hand hand = context.getHand();
ItemStack stack = player.getStackInHand(hand);
if (stack.getCount() != 0)
if (player.getStackInHand(hand).getCount() != 0)
return;
HotbarReplace.tryReplaceSlot(player, hand, lastUsedItem);
@ -99,38 +69,9 @@ public class ItemStackMixin {
if (info.getReturnValue() != ActionResult.SUCCESS)
return;
ItemStack stack = player.getStackInHand(hand);
if (stack.getCount() > 1)
if (player.getStackInHand(hand).getCount() != 0)
return;
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

@ -1,7 +1,7 @@
{
"schemaVersion": 1,
"id": "hotbarreplace",
"version": "0.1.5",
"version": "0.1.4",
"name": "HotbarReplace",
"description": "Replace blocks in your hotbar when you run out with blocks from your inventory",
"authors": [

View File

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