变换
当BakedModel被渲染为物品时,它可以根据在哪个变换中渲染它来应用特殊处理。“变换”是指在什么上下文中渲染模型。可能的转换在代码中由ItemDisplayContext枚举表示。有两种处理转换的系统:不推荐使用的原版系统,由BakedModel#getTransforms、ItemTransforms和ItemTransform构成;Forge系统,由方法IForgeBakedModel#applyTransform实现。原版代码被进行了修补,以便尽可能使用applyTransform而不是原版系统。
ItemDisplayContext
NONE - 默认情况下,当未设置上下文时,用于显示实体;当Block的RenderShape设置为#ENTITYBLOCK_ANIMATED时,被Forge使用。
THIRD_PERSON_LEFT_HAND/THIRD_PERSON_RIGHT_HAND/FIRST_PERSON_LEFT_HAND/FIRST_PERSON_RIGHT_HAND - 第一人称值表示玩家何时将物品握在自己手中。第三人称值表示当另一个玩家拿着物品,而客户端用第三人称看着它们时。手的含义是不言自明的。
HEAD - 表示当任何玩家在头盔槽中佩戴该物品时(例如南瓜)。
GUI - 表示当该物品被在一个Screen中渲染时。
GROUND - 表示该物品在存档中作为一个ItemEntity被渲染时。
FIXED - 用于物品展示框。
原版的方式
原版处理转换的方式是通过BakedModel#getTransforms。此方法返回一个ItemTransforms,这是一个简单的对象,包含各种作为public final的ItemTransform字段。ItemTransform表示要应用于模型的旋转、平移和比例。ItemTransforms是这些的容器,除了NONE之外,每个ItemDisplayContext都有一个容器。在原版实现中,为NONE调用#getTransform会产生默认转换ItemTransform#NO_TRANSFORM。
Forge废弃了使用处理转换的整个原版系统,BakedModel的大多数实现应该简单地从BakedModel#getTransforms中return ItemTransforms#NO_TRANSFORMS(这是默认实现)。相反,他们应该实现#applyTransform。
Forge的方式
Forge处理转换的方法是#applyTransform,这是一种修补到BakedModel中的方法。它取代了#getTransforms方法。
BakedModel#applyTransform
给定一个ItemDisplayContext、PoseStack和一个布尔值来确定是否对左手应用变换,此方法将生成一个要渲染的BakedModel。因为返回的BakedModel可以是一个全新的模型,所以这种方法比原版方法(例如,一张手里看起来很平但在地上皱巴巴的纸)更灵活。