Added default left hand transforms for forge transform strings. Closes #2615.
This commit is contained in:
parent
9eb04ce1ef
commit
bebf22c0b0
1 changed files with 23 additions and 9 deletions
|
@ -437,7 +437,7 @@ public class ForgeBlockStateV1 extends Marker
|
||||||
throw new UnsupportedOperationException("Forge BlockStateLoader V1 does not support nested submodels.");
|
throw new UnsupportedOperationException("Forge BlockStateLoader V1 does not support nested submodels.");
|
||||||
}
|
}
|
||||||
|
|
||||||
private TRSRTransformation get(float tx, float ty, float tz, float ax, float ay, float az, float s)
|
private static TRSRTransformation get(float tx, float ty, float tz, float ax, float ay, float az, float s)
|
||||||
{
|
{
|
||||||
return TRSRTransformation.blockCenterToCorner(new TRSRTransformation(
|
return TRSRTransformation.blockCenterToCorner(new TRSRTransformation(
|
||||||
new Vector3f(tx / 16, ty / 16, tz / 16),
|
new Vector3f(tx / 16, ty / 16, tz / 16),
|
||||||
|
@ -446,6 +446,13 @@ public class ForgeBlockStateV1 extends Marker
|
||||||
null));
|
null));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private static final TRSRTransformation flipX = new TRSRTransformation(null, null, new Vector3f(-1, 1, 1), null);
|
||||||
|
|
||||||
|
private static TRSRTransformation leftify(TRSRTransformation transform)
|
||||||
|
{
|
||||||
|
return TRSRTransformation.blockCenterToCorner(flipX.compose(TRSRTransformation.blockCornerToCenter(transform)).compose(flipX));
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ForgeBlockStateV1.Variant deserialize(JsonElement element, Type typeOfT, JsonDeserializationContext context) throws JsonParseException
|
public ForgeBlockStateV1.Variant deserialize(JsonElement element, Type typeOfT, JsonDeserializationContext context) throws JsonParseException
|
||||||
{
|
{
|
||||||
|
@ -495,23 +502,30 @@ public class ForgeBlockStateV1 extends Marker
|
||||||
// block/block
|
// block/block
|
||||||
else if (transform.equals("forge:default-block"))
|
else if (transform.equals("forge:default-block"))
|
||||||
{
|
{
|
||||||
|
TRSRTransformation thirdperson = get(0, 2.5f, 0, 75, 45, 0, 0.375f);
|
||||||
ImmutableMap.Builder<TransformType, TRSRTransformation> builder = ImmutableMap.builder();
|
ImmutableMap.Builder<TransformType, TRSRTransformation> builder = ImmutableMap.builder();
|
||||||
builder.put(TransformType.GUI, get(0, 0, 0, 30, 225, 0, 0.625f));
|
builder.put(TransformType.GUI, get(0, 0, 0, 30, 225, 0, 0.625f));
|
||||||
builder.put( TransformType.GROUND, get(0, 3, 0, 0, 0, 0, 0.25f));
|
builder.put(TransformType.GROUND, get(0, 3, 0, 0, 0, 0, 0.25f));
|
||||||
builder.put(TransformType.FIXED, get(0, 0, 0, 0, 0, 0, 0.5f));
|
builder.put(TransformType.FIXED, get(0, 0, 0, 0, 0, 0, 0.5f));
|
||||||
builder.put(TransformType.THIRD_PERSON_RIGHT_HAND, get(0, 2.5f, 0, 75, 45, 0, 0.375f));
|
builder.put(TransformType.THIRD_PERSON_RIGHT_HAND, thirdperson);
|
||||||
builder.put( TransformType.FIRST_PERSON_RIGHT_HAND, get(0, 0, 0, 0, 45, 0, 0.4f));
|
builder.put(TransformType.THIRD_PERSON_LEFT_HAND, leftify(thirdperson));
|
||||||
|
builder.put(TransformType.FIRST_PERSON_RIGHT_HAND, get(0, 0, 0, 0, 45, 0, 0.4f));
|
||||||
builder.put(TransformType.FIRST_PERSON_LEFT_HAND, get(0, 0, 0, 0, 255, 0, 0.4f));
|
builder.put(TransformType.FIRST_PERSON_LEFT_HAND, get(0, 0, 0, 0, 255, 0, 0.4f));
|
||||||
ret.state = Optional.<IModelState>of(new SimpleModelState(builder.build()));
|
ret.state = Optional.<IModelState>of(new SimpleModelState(builder.build()));
|
||||||
}
|
}
|
||||||
// item/generated
|
// item/generated
|
||||||
else if (transform.equals("forge:default-item"))
|
else if (transform.equals("forge:default-item"))
|
||||||
{
|
{
|
||||||
ret.state = Optional.<IModelState>of(new SimpleModelState(ImmutableMap.of(
|
TRSRTransformation thirdperson = get(0, 3, 1, 0, 0, 0, 0.55f);
|
||||||
TransformType.GROUND, get(0, 2, 0, 0, 0, 0, 0.5f),
|
TRSRTransformation firstperson = get(1.13f, 3.2f, 1.13f, 0, -90, 25, 0.68f);
|
||||||
TransformType.HEAD, get(0, 13, 7, 0, 180, 0, 1),
|
ImmutableMap.Builder<TransformType, TRSRTransformation> builder = ImmutableMap.builder();
|
||||||
TransformType.THIRD_PERSON_RIGHT_HAND, get(0, 3, 1, 0, 0, 0, 0.55f),
|
builder.put(TransformType.GROUND, get(0, 2, 0, 0, 0, 0, 0.5f));
|
||||||
TransformType.FIRST_PERSON_RIGHT_HAND, get(1.13f, 3.2f, 1.13f, 0, -90, 25, 0.68f))));
|
builder.put(TransformType.HEAD, get(0, 13, 7, 0, 180, 0, 1));
|
||||||
|
builder.put(TransformType.THIRD_PERSON_RIGHT_HAND, thirdperson);
|
||||||
|
builder.put(TransformType.THIRD_PERSON_LEFT_HAND, leftify(thirdperson));
|
||||||
|
builder.put(TransformType.FIRST_PERSON_RIGHT_HAND, firstperson);
|
||||||
|
builder.put(TransformType.FIRST_PERSON_LEFT_HAND, leftify(firstperson));
|
||||||
|
ret.state = Optional.<IModelState>of(new SimpleModelState(builder.build()));
|
||||||
}
|
}
|
||||||
// item/handheld
|
// item/handheld
|
||||||
else if (transform.equals("forge:default-tool"))
|
else if (transform.equals("forge:default-tool"))
|
||||||
|
|
Loading…
Reference in a new issue