diff options
author | Linnea Gräf <nea@nea.moe> | 2024-07-30 19:18:19 +0200 |
---|---|---|
committer | Linnea Gräf <nea@nea.moe> | 2024-07-30 19:18:19 +0200 |
commit | 95c1b75a14d41b070c4e23addb3ac4788a014365 (patch) | |
tree | 7fdc8cf94df1df100b06a60f4b0aad7c36d2ebd0 /src/main/kotlin/moe/nea/firmament/gui/entity/ModifyPlayerSkin.kt | |
parent | df29eccdcc1184b3d9ac116192442a359b8185bd (diff) | |
download | firmament-95c1b75a14d41b070c4e23addb3ac4788a014365.tar.gz firmament-95c1b75a14d41b070c4e23addb3ac4788a014365.tar.bz2 firmament-95c1b75a14d41b070c4e23addb3ac4788a014365.zip |
Fix top skin layers not being rendered in mob drop recipes
Diffstat (limited to 'src/main/kotlin/moe/nea/firmament/gui/entity/ModifyPlayerSkin.kt')
-rw-r--r-- | src/main/kotlin/moe/nea/firmament/gui/entity/ModifyPlayerSkin.kt | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/src/main/kotlin/moe/nea/firmament/gui/entity/ModifyPlayerSkin.kt b/src/main/kotlin/moe/nea/firmament/gui/entity/ModifyPlayerSkin.kt index b382fe2..f2de698 100644 --- a/src/main/kotlin/moe/nea/firmament/gui/entity/ModifyPlayerSkin.kt +++ b/src/main/kotlin/moe/nea/firmament/gui/entity/ModifyPlayerSkin.kt @@ -7,11 +7,17 @@ package moe.nea.firmament.gui.entity import com.google.gson.JsonObject +import com.google.gson.JsonPrimitive +import kotlin.experimental.and +import kotlin.experimental.or import net.minecraft.client.util.SkinTextures import net.minecraft.entity.LivingEntity +import net.minecraft.entity.player.PlayerEntity +import net.minecraft.entity.player.PlayerModelPart import net.minecraft.util.Identifier object ModifyPlayerSkin : EntityModifier { + val playerModelPartIndex = PlayerModelPart.entries.associateBy { it.getName() } override fun apply(entity: LivingEntity, info: JsonObject): LivingEntity { require(entity is GuiPlayer) info["cape"]?.let { @@ -24,7 +30,21 @@ object ModifyPlayerSkin : EntityModifier { entity.model = if (it.asBoolean) SkinTextures.Model.SLIM else SkinTextures.Model.WIDE } info["parts"]?.let { - // TODO: support parts + var trackedData = entity.dataTracker.get(PlayerEntity.PLAYER_MODEL_PARTS) + if (it is JsonPrimitive && it.isBoolean) { + trackedData = (if (it.asBoolean) -1 else 0).toByte() + } else { + val obj = it.asJsonObject + for ((k, v) in obj.entrySet()) { + val part = playerModelPartIndex[k]!! + trackedData = if (v.asBoolean) { + trackedData and (part.bitFlag.inv().toByte()) + } else { + trackedData or (part.bitFlag.toByte()) + } + } + } + entity.dataTracker.set(PlayerEntity.PLAYER_MODEL_PARTS, trackedData) } return entity } |