From 18ec59c38af52b2fe3d5e315db915d6e50566d24 Mon Sep 17 00:00:00 2001 From: Aaron <51387595+AzureAaron@users.noreply.github.com> Date: Thu, 2 Jan 2025 17:23:57 -0500 Subject: Cancel Component Update Animation (#1116) --- .../config/categories/UIAndVisualsCategory.java | 8 ++++++++ .../config/configs/UIAndVisualsConfig.java | 3 +++ .../skyblocker/mixins/HeldItemRendererMixin.java | 20 ++++++++++++++++++++ 3 files changed, 31 insertions(+) create mode 100644 src/main/java/de/hysky/skyblocker/mixins/HeldItemRendererMixin.java (limited to 'src/main/java') diff --git a/src/main/java/de/hysky/skyblocker/config/categories/UIAndVisualsCategory.java b/src/main/java/de/hysky/skyblocker/config/categories/UIAndVisualsCategory.java index 3495e1f1..38dff23f 100644 --- a/src/main/java/de/hysky/skyblocker/config/categories/UIAndVisualsCategory.java +++ b/src/main/java/de/hysky/skyblocker/config/categories/UIAndVisualsCategory.java @@ -90,6 +90,14 @@ public class UIAndVisualsCategory { newValue -> config.uiAndVisuals.showEquipmentInInventory = newValue) .controller(ConfigUtils::createBooleanController) .build()) + .option(Option.createBuilder() + .name(Text.translatable("skyblocker.config.uiAndVisuals.cancelComponentUpdateAnimation")) + .description(OptionDescription.of(Text.translatable("skyblocker.config.uiAndVisuals.cancelComponentUpdateAnimation.@Tooltip"))) + .binding(defaults.uiAndVisuals.cancelComponentUpdateAnimation, + () -> config.uiAndVisuals.cancelComponentUpdateAnimation, + newValue -> config.uiAndVisuals.cancelComponentUpdateAnimation = newValue) + .controller(ConfigUtils::createBooleanController) + .build()) //Chest Value FIXME change dropdown to color controller .group(OptionGroup.createBuilder() diff --git a/src/main/java/de/hysky/skyblocker/config/configs/UIAndVisualsConfig.java b/src/main/java/de/hysky/skyblocker/config/configs/UIAndVisualsConfig.java index deb981a1..c2f94a36 100644 --- a/src/main/java/de/hysky/skyblocker/config/configs/UIAndVisualsConfig.java +++ b/src/main/java/de/hysky/skyblocker/config/configs/UIAndVisualsConfig.java @@ -35,6 +35,9 @@ public class UIAndVisualsConfig { @SerialEntry public boolean showEquipmentInInventory = true; + @SerialEntry + public boolean cancelComponentUpdateAnimation = true; + @SerialEntry public ChestValue chestValue = new ChestValue(); diff --git a/src/main/java/de/hysky/skyblocker/mixins/HeldItemRendererMixin.java b/src/main/java/de/hysky/skyblocker/mixins/HeldItemRendererMixin.java new file mode 100644 index 00000000..8605fec2 --- /dev/null +++ b/src/main/java/de/hysky/skyblocker/mixins/HeldItemRendererMixin.java @@ -0,0 +1,20 @@ +package de.hysky.skyblocker.mixins; + +import org.spongepowered.asm.mixin.Mixin; +import org.spongepowered.asm.mixin.injection.At; + +import com.llamalad7.mixinextras.injector.ModifyReturnValue; + +import de.hysky.skyblocker.config.SkyblockerConfigManager; +import de.hysky.skyblocker.utils.Utils; +import net.minecraft.client.render.item.HeldItemRenderer; +import net.minecraft.item.ItemStack; + +@Mixin(HeldItemRenderer.class) +public class HeldItemRendererMixin { + + @ModifyReturnValue(method = "shouldSkipHandAnimationOnSwap", at = @At("RETURN")) + private boolean skyblocker$cancelComponentUpdateAnimation(boolean original, ItemStack from, ItemStack to) { + return Utils.isOnSkyblock() && from.getItem() == to.getItem() ? original || SkyblockerConfigManager.get().uiAndVisuals.cancelComponentUpdateAnimation : original; + } +} -- cgit