diff options
author | ingle <inglettronald@gmail.com> | 2022-09-23 03:49:56 -0500 |
---|---|---|
committer | ingle <inglettronald@gmail.com> | 2022-09-23 03:49:56 -0500 |
commit | 033de65a180b64fc645036d142589f57956ea263 (patch) | |
tree | 301fcca8a63348313f66193932c60f6c19c95024 /src/main/java/com/example/mixin | |
parent | cfcdcda458b2fe9fbe33bb81759dfd4e4fb3bcc0 (diff) | |
download | DulkirMod-033de65a180b64fc645036d142589f57956ea263.tar.gz DulkirMod-033de65a180b64fc645036d142589f57956ea263.tar.bz2 DulkirMod-033de65a180b64fc645036d142589f57956ea263.zip |
Nothing works yet :+1:
Diffstat (limited to 'src/main/java/com/example/mixin')
-rw-r--r-- | src/main/java/com/example/mixin/MixinGuiMainMenu.java | 16 | ||||
-rw-r--r-- | src/main/java/com/example/mixin/MixinRendererManager.java | 49 | ||||
-rw-r--r-- | src/main/java/com/example/mixin/MixinWorld.java | 21 |
3 files changed, 70 insertions, 16 deletions
diff --git a/src/main/java/com/example/mixin/MixinGuiMainMenu.java b/src/main/java/com/example/mixin/MixinGuiMainMenu.java deleted file mode 100644 index 47eee87..0000000 --- a/src/main/java/com/example/mixin/MixinGuiMainMenu.java +++ /dev/null @@ -1,16 +0,0 @@ -package com.example.mixin; - -import net.minecraft.client.gui.GuiMainMenu; -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(GuiMainMenu.class) -public class MixinGuiMainMenu { - - @Inject(method = "initGui", at = @At("HEAD")) - public void onInitGui(CallbackInfo ci) { - System.out.println("Hello from Main Menu!"); - } -} diff --git a/src/main/java/com/example/mixin/MixinRendererManager.java b/src/main/java/com/example/mixin/MixinRendererManager.java new file mode 100644 index 0000000..eae11fa --- /dev/null +++ b/src/main/java/com/example/mixin/MixinRendererManager.java @@ -0,0 +1,49 @@ +package com.example.mixin;
+
+import net.minecraft.client.renderer.entity.RenderManager;
+import net.minecraft.entity.Entity;
+import net.minecraft.entity.item.EntityArmorStand;
+import net.minecraft.init.Items;
+import net.minecraft.item.ItemStack;
+import net.minecraft.nbt.NBTTagCompound;
+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.CallbackInfoReturnable;
+
+@Mixin(RenderManager.class)
+public class MixinRendererManager {
+
+ @Inject(method = "doRenderEntity", at = @At("HEAD"))
+ public void doRender(
+ Entity entity,
+ double x,
+ double y,
+ double z,
+ float entityYaw,
+ float partialTicks,
+ boolean p_147939_10_,
+ CallbackInfoReturnable<Boolean> cir
+ ) {
+
+ if (entity instanceof EntityArmorStand) {
+ if (((EntityArmorStand) entity).getHeldItem() != null && ((EntityArmorStand) entity).getHeldItem().getItem() == Items.skull) {
+ ItemStack stack = ((EntityArmorStand) entity).getHeldItem();
+ if (stack.hasTagCompound() && stack.getTagCompound().hasKey("SkullOwner")) {
+ NBTTagCompound skullOwner = stack.getTagCompound().getCompoundTag("SkullOwner");
+ if (skullOwner.hasKey("Properties")) {
+ NBTTagCompound properties = skullOwner.getCompoundTag("Properties");
+ if (properties.hasKey("textures")) {
+ if ("eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvOTZjM2UzMWNmYzY2NzMzMjc1YzQyZmNmYjVkOWE0NDM0MmQ2NDNiNTVjZDE0YzljNzdkMjczYTIzNTIifX19"
+ .equals(properties.getTagList("textures", 10).getCompoundTagAt(0).getString("Value")))
+ cir.cancel();
+ }
+
+ }
+
+ }
+
+ }
+ }
+ }
+}
\ No newline at end of file diff --git a/src/main/java/com/example/mixin/MixinWorld.java b/src/main/java/com/example/mixin/MixinWorld.java new file mode 100644 index 0000000..9bacbcd --- /dev/null +++ b/src/main/java/com/example/mixin/MixinWorld.java @@ -0,0 +1,21 @@ +package com.example.mixin; + +import net.minecraft.client.gui.GuiMainMenu; +import net.minecraft.world.World; +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; +import com.example.Settings; + +@Mixin(World.class) +public class MixinWorld { + + @Inject(method = "spawnParticle(IZDDDDDD[I)V", at = @At("HEAD"), cancellable = true) + public void onInitGui(int particleID, boolean p_175720_2_, double xCood, double yCoord, double zCoord, + double xOffset, double yOffset, double zOffset, int[] p_175720_15_, CallbackInfo ci) { + if (particleID == 25 && Settings.EnchantRune) { + ci.cancel(); + } + } +} |