diff options
author | inglettronald <inglettronald@gmail.com> | 2023-05-19 05:37:57 -0500 |
---|---|---|
committer | inglettronald <inglettronald@gmail.com> | 2023-05-19 05:37:57 -0500 |
commit | d4be68fd8bf4e14ae7064f15215afabe09d191d5 (patch) | |
tree | af265b14c42456cbe6f961729b05ef0123410443 /src/main/kotlin/dulkirmod/features/rift/IchorHighlight.kt | |
parent | 170c6504bdb949c5dd133514b3db91823169cbad (diff) | |
download | DulkirMod-d4be68fd8bf4e14ae7064f15215afabe09d191d5.tar.gz DulkirMod-d4be68fd8bf4e14ae7064f15215afabe09d191d5.tar.bz2 DulkirMod-d4be68fd8bf4e14ae7064f15215afabe09d191d5.zip |
initial commit
Diffstat (limited to 'src/main/kotlin/dulkirmod/features/rift/IchorHighlight.kt')
-rw-r--r-- | src/main/kotlin/dulkirmod/features/rift/IchorHighlight.kt | 58 |
1 files changed, 58 insertions, 0 deletions
diff --git a/src/main/kotlin/dulkirmod/features/rift/IchorHighlight.kt b/src/main/kotlin/dulkirmod/features/rift/IchorHighlight.kt new file mode 100644 index 0000000..72581d3 --- /dev/null +++ b/src/main/kotlin/dulkirmod/features/rift/IchorHighlight.kt @@ -0,0 +1,58 @@ +package dulkirmod.features.rift + +import dulkirmod.config.DulkirConfig +import dulkirmod.utils.TabListUtils +import dulkirmod.utils.WorldRenderUtils +import net.minecraft.entity.item.EntityArmorStand +import net.minecraft.init.Items +import net.minecraftforge.client.event.RenderLivingEvent +import net.minecraftforge.fml.common.eventhandler.SubscribeEvent +import java.awt.Color + +object IchorHighlight { + private const val ichorTexture = + "eyJ0ZXh0dXJlcyI6eyJTS0lOIjp7InVybCI6Imh0dHA6Ly90ZXh0dXJlcy5taW5lY3JhZnQubmV0L3RleHR1cmUvYzAzNDA5MjNhNmRlNDgyNWExNzY4MTNkMTMzNTAzZWZmMTg2ZGIwODk2ZTMyYjY3MDQ5MjhjMmEyYmY2ODQyMiJ9fX0=" + + @SubscribeEvent + fun onRenderLiving(event: RenderLivingEvent.Post<*>) { + if (!DulkirConfig.ichorHighlight) return + if (TabListUtils.area != "The Rift") return + val entity = event.entity + + val x = + entity.lastTickPosX + (entity.posX - entity.lastTickPosX) * WorldRenderUtils.partialTicks + val y = + entity.lastTickPosY + (entity.posY - entity.lastTickPosY) * WorldRenderUtils.partialTicks + val z = + entity.lastTickPosZ + (entity.posZ - entity.lastTickPosZ) * WorldRenderUtils.partialTicks + + if (entity is EntityArmorStand) { + if (entity.getEquipmentInSlot(4) != null && entity.getEquipmentInSlot(4).item === Items.skull) { + val stack = entity.getEquipmentInSlot(4) + if (stack.hasTagCompound() && stack.tagCompound.hasKey("SkullOwner")) { + val skullOwner = stack.tagCompound.getCompoundTag("SkullOwner") + if (skullOwner.hasKey("Properties")) { + val properties = skullOwner.getCompoundTag("Properties") + if (properties.hasKey("textures")) { + if (ichorTexture == properties.getTagList("textures", 10).getCompoundTagAt(0) + .getString("Value") + ) { + WorldRenderUtils.drawCustomBox( + x - .5, + 1.0, + y - 2, + 1.0, + z - .5, + 1.0, + Color(15, 247, 236, 255), + 3f, + phase = false + ) + } + } + } + } + } + } + } +}
\ No newline at end of file |