Porting Forge rendering code to 1.13 (#5132)

This commit is contained in:
tterrag 2018-09-08 16:34:59 -04:00 committed by LexManos
parent eac693e785
commit dde7dccef1
57 changed files with 1186 additions and 775 deletions

View file

@ -0,0 +1,58 @@
--- a/net/minecraft/client/renderer/BufferBuilder.java
+++ b/net/minecraft/client/renderer/BufferBuilder.java
@@ -107,7 +107,8 @@
bitset.set(i1);
}
-
+ this.rawIntBuffer.limit(this.rawIntBuffer.capacity());
+ this.rawIntBuffer.position(this.getBufferSize());
}
public BufferBuilder.State getVertexState() {
@@ -438,15 +439,15 @@
break;
case USHORT:
case SHORT:
- this.byteBuffer.putShort(i, (short)((int)x * 32767 & '\uffff'));
- this.byteBuffer.putShort(i + 2, (short)((int)y * 32767 & '\uffff'));
- this.byteBuffer.putShort(i + 4, (short)((int)z * 32767 & '\uffff'));
+ this.byteBuffer.putShort(i, (short)((int)(x * Short.MAX_VALUE) & 0xFFFF));
+ this.byteBuffer.putShort(i + 2, (short)((int)(y * Short.MAX_VALUE) & 0xFFFF));
+ this.byteBuffer.putShort(i + 4, (short)((int)(z * Short.MAX_VALUE) & 0xFFFF));
break;
case UBYTE:
case BYTE:
- this.byteBuffer.put(i, (byte)((int)x * 127 & 255));
- this.byteBuffer.put(i + 1, (byte)((int)y * 127 & 255));
- this.byteBuffer.put(i + 2, (byte)((int)z * 127 & 255));
+ this.byteBuffer.put(i, (byte)((int)(x * Byte.MAX_VALUE) & 0xFF));
+ this.byteBuffer.put(i + 1, (byte)((int)(y * Byte.MAX_VALUE) & 0xFF));
+ this.byteBuffer.put(i + 2, (byte)((int)(z * Byte.MAX_VALUE) & 0xFF));
}
this.nextVertexFormatIndex();
@@ -521,4 +522,23 @@
return this.stateVertexFormat;
}
}
+
+ //For some unknown reason Mojang changed the vanilla function to hardcode alpha as 255.... So lets re-add the parameter -.-
+ public void putColorRGBA(int index, int red, int green, int blue, int alpha) {
+ if (ByteOrder.nativeOrder() == ByteOrder.LITTLE_ENDIAN)
+ this.rawIntBuffer.put(index, alpha << 24 | blue << 16 | green << 8 | red);
+ else
+ this.rawIntBuffer.put(index, red << 24 | green << 16 | blue << 8 | alpha);
}
+
+ public boolean isColorDisabled() {
+ return noColor;
+ }
+
+ public void putBulkData(ByteBuffer buffer) {
+ growBuffer(buffer.limit() + this.vertexFormat.getSize());
+ this.byteBuffer.position(this.vertexCount * this.vertexFormat.getSize());
+ this.byteBuffer.put(buffer);
+ this.vertexCount += buffer.limit() / this.vertexFormat.getSize();
+ }
+}

View file

@ -0,0 +1,11 @@
--- a/net/minecraft/client/renderer/ItemRenderer.java
+++ b/net/minecraft/client/renderer/ItemRenderer.java
@@ -49,7 +49,7 @@
public ItemRenderer(TextureManager p_i46552_1_, ModelManager p_i46552_2_, ItemColors p_i46552_3_) {
this.textureManager = p_i46552_1_;
- this.itemModelMesher = new ItemModelMesher(p_i46552_2_);
+ this.itemModelMesher = new net.minecraftforge.client.ItemModelMesherForge(p_i46552_2_);
for(Item item : Item.REGISTRY) {
if (!field_195411_c.contains(item)) {

View file

@ -0,0 +1,48 @@
--- a/net/minecraft/client/renderer/block/model/BakedQuad.java
+++ b/net/minecraft/client/renderer/block/model/BakedQuad.java
@@ -6,13 +6,23 @@
import net.minecraftforge.api.distmarker.OnlyIn;
@OnlyIn(Dist.CLIENT)
-public class BakedQuad {
+public class BakedQuad implements net.minecraftforge.client.model.pipeline.IVertexProducer {
protected final int[] vertexData;
protected final int tintIndex;
protected final EnumFacing face;
protected final TextureAtlasSprite sprite;
+ /**
+ * @deprecated Use constructor with the format argument.
+ */
+ @Deprecated
public BakedQuad(int[] vertexDataIn, int tintIndexIn, EnumFacing faceIn, TextureAtlasSprite spriteIn) {
+ this(vertexDataIn, tintIndexIn, faceIn, spriteIn, true, net.minecraft.client.renderer.vertex.DefaultVertexFormats.BLOCK);
+ }
+
+ public BakedQuad(int[] vertexDataIn, int tintIndexIn, EnumFacing faceIn, TextureAtlasSprite spriteIn, boolean applyDiffuseLighting, net.minecraft.client.renderer.vertex.VertexFormat format) {
+ this.format = format;
+ this.applyDiffuseLighting = applyDiffuseLighting;
this.vertexData = vertexDataIn;
this.tintIndex = tintIndexIn;
this.face = faceIn;
@@ -38,4 +48,20 @@
public EnumFacing getFace() {
return this.face;
}
+
+ protected final net.minecraft.client.renderer.vertex.VertexFormat format;
+ protected final boolean applyDiffuseLighting;
+
+ @Override
+ public void pipe(net.minecraftforge.client.model.pipeline.IVertexConsumer consumer) {
+ net.minecraftforge.client.model.pipeline.LightUtil.putBakedQuad(consumer, this);
}
+
+ public net.minecraft.client.renderer.vertex.VertexFormat getFormat() {
+ return format;
+ }
+
+ public boolean shouldApplyDiffuseLighting() {
+ return applyDiffuseLighting;
+ }
+}

View file

@ -0,0 +1,88 @@
--- a/net/minecraft/client/renderer/block/model/FaceBakery.java
+++ b/net/minecraft/client/renderer/block/model/FaceBakery.java
@@ -39,18 +39,23 @@
};
public BakedQuad func_199332_a(Vector3f p_199332_1_, Vector3f p_199332_2_, BlockPartFace p_199332_3_, TextureAtlasSprite p_199332_4_, EnumFacing p_199332_5_, ModelRotation p_199332_6_, @Nullable BlockPartRotation p_199332_7_, boolean p_199332_8_, boolean p_199332_9_) {
+ return makeBakedQuad(p_199332_1_, p_199332_2_, p_199332_3_, p_199332_4_, p_199332_5_, (net.minecraftforge.common.model.ITransformation)p_199332_6_, p_199332_7_, p_199332_8_, p_199332_9_);
+ }
+
+ public BakedQuad makeBakedQuad(Vector3f p_199332_1_, Vector3f p_199332_2_, BlockPartFace p_199332_3_, TextureAtlasSprite p_199332_4_, EnumFacing p_199332_5_, net.minecraftforge.common.model.ITransformation p_199332_6_, BlockPartRotation p_199332_7_, boolean p_199332_8_, boolean p_199332_9_) {
BlockFaceUV blockfaceuv = p_199332_3_.blockFaceUV;
if (p_199332_8_) {
- blockfaceuv = this.applyUVLock(p_199332_3_.blockFaceUV, p_199332_5_, p_199332_6_);
+ blockfaceuv = net.minecraftforge.client.ForgeHooksClient.applyUVLock(p_199332_3_.blockFaceUV, p_199332_5_, p_199332_6_);
}
- int[] aint = this.makeQuadVertexData(blockfaceuv, p_199332_4_, p_199332_5_, this.func_199337_a(p_199332_1_, p_199332_2_), p_199332_6_, p_199332_7_, p_199332_9_);
+ int[] aint = this.makeQuadVertexData(blockfaceuv, p_199332_4_, p_199332_5_, this.func_199337_a(p_199332_1_, p_199332_2_), p_199332_6_, p_199332_7_, false);
EnumFacing enumfacing = getFacingFromVertexData(aint);
if (p_199332_7_ == null) {
this.applyFacing(aint, enumfacing);
}
- return new BakedQuad(aint, p_199332_3_.tintIndex, enumfacing, p_199332_4_);
+ net.minecraftforge.client.ForgeHooksClient.fillNormal(aint, enumfacing);
+ return new BakedQuad(aint, p_199332_3_.tintIndex, enumfacing, p_199332_4_, p_199332_9_, net.minecraft.client.renderer.vertex.DefaultVertexFormats.BLOCK);
}
private BlockFaceUV applyUVLock(BlockFaceUV p_188010_1_, EnumFacing p_188010_2_, ModelRotation p_188010_3_) {
@@ -58,6 +63,10 @@
}
private int[] makeQuadVertexData(BlockFaceUV uvs, TextureAtlasSprite sprite, EnumFacing orientation, float[] p_188012_4_, ModelRotation rotationIn, @Nullable BlockPartRotation partRotation, boolean shade) {
+ return makeQuadVertexData(uvs, sprite, orientation, p_188012_4_, (net.minecraftforge.common.model.ITransformation)rotationIn, partRotation, shade);
+ }
+
+ private int[] makeQuadVertexData(BlockFaceUV uvs, TextureAtlasSprite sprite, EnumFacing orientation, float[] p_188012_4_, net.minecraftforge.common.model.ITransformation rotationIn, BlockPartRotation partRotation, boolean shade) {
int[] aint = new int[28];
for(int i = 0; i < 4; ++i) {
@@ -102,12 +111,16 @@
}
private void fillVertexData(int[] p_188015_1_, int p_188015_2_, EnumFacing p_188015_3_, BlockFaceUV p_188015_4_, float[] p_188015_5_, TextureAtlasSprite p_188015_6_, ModelRotation p_188015_7_, @Nullable BlockPartRotation p_188015_8_, boolean p_188015_9_) {
- EnumFacing enumfacing = p_188015_7_.rotateFace(p_188015_3_);
+ fillVertexData(p_188015_1_, p_188015_2_, p_188015_3_, p_188015_4_, p_188015_5_, p_188015_6_, (net.minecraftforge.common.model.ITransformation)p_188015_7_, p_188015_8_, p_188015_9_);
+ }
+
+ private void fillVertexData(int[] p_188015_1_, int p_188015_2_, EnumFacing p_188015_3_, BlockFaceUV p_188015_4_, float[] p_188015_5_, TextureAtlasSprite p_188015_6_, net.minecraftforge.common.model.ITransformation p_188015_7_, BlockPartRotation p_188015_8_, boolean p_188015_9_) {
+ EnumFacing enumfacing = p_188015_7_.rotate(p_188015_3_);
int i = p_188015_9_ ? this.getFaceShadeColor(enumfacing) : -1;
EnumFaceDirection.VertexInformation enumfacedirection$vertexinformation = EnumFaceDirection.getFacing(p_188015_3_).getVertexInformation(p_188015_2_);
Vector3f vector3f = new Vector3f(p_188015_5_[enumfacedirection$vertexinformation.xIndex], p_188015_5_[enumfacedirection$vertexinformation.yIndex], p_188015_5_[enumfacedirection$vertexinformation.zIndex]);
this.func_199336_a(vector3f, p_188015_8_);
- int j = this.func_199335_a(vector3f, p_188015_3_, p_188015_2_, p_188015_7_);
+ int j = this.rotateVertex(vector3f, p_188015_3_, p_188015_2_, p_188015_7_);
this.func_199333_a(p_188015_1_, j, p_188015_2_, vector3f, i, p_188015_6_, p_188015_4_);
}
@@ -117,8 +130,8 @@
p_199333_1_[i + 1] = Float.floatToRawIntBits(p_199333_4_.func_195900_b());
p_199333_1_[i + 2] = Float.floatToRawIntBits(p_199333_4_.func_195902_c());
p_199333_1_[i + 3] = p_199333_5_;
- p_199333_1_[i + 4] = Float.floatToRawIntBits(p_199333_6_.getInterpolatedU((double)p_199333_7_.getVertexU(p_199333_3_)));
- p_199333_1_[i + 4 + 1] = Float.floatToRawIntBits(p_199333_6_.getInterpolatedV((double)p_199333_7_.getVertexV(p_199333_3_)));
+ p_199333_1_[i + 4] = Float.floatToRawIntBits(p_199333_6_.getInterpolatedU((double)p_199333_7_.getVertexU(p_199333_3_) * .999 + p_199333_7_.getVertexU((p_199333_3_ + 2) % 4) * .001));
+ p_199333_1_[i + 4 + 1] = Float.floatToRawIntBits(p_199333_6_.getInterpolatedV((double)p_199333_7_.getVertexV(p_199333_3_) * .999 + p_199333_7_.getVertexV((p_199333_3_ + 2) % 4) * .001));
}
private void func_199336_a(Vector3f p_199336_1_, @Nullable BlockPartRotation p_199336_2_) {
@@ -160,11 +173,15 @@
}
public int func_199335_a(Vector3f p_199335_1_, EnumFacing p_199335_2_, int p_199335_3_, ModelRotation p_199335_4_) {
+ return rotateVertex(p_199335_1_, p_199335_2_, p_199335_3_, (net.minecraftforge.common.model.ITransformation)p_199335_4_);
+ }
+
+ public int rotateVertex(Vector3f p_199335_1_, EnumFacing p_199335_2_, int p_199335_3_, net.minecraftforge.common.model.ITransformation p_199335_4_) {
if (p_199335_4_ == ModelRotation.X0_Y0) {
return p_199335_3_;
} else {
- this.func_199334_a(p_199335_1_, new Vector3f(0.5F, 0.5F, 0.5F), p_199335_4_.func_195820_a(), new Vector3f(1.0F, 1.0F, 1.0F));
- return p_199335_4_.rotateVertex(p_199335_2_, p_199335_3_);
+ net.minecraftforge.client.ForgeHooksClient.transform(p_199335_1_, p_199335_4_.getMatrix());
+ return p_199335_4_.rotate(p_199335_2_, p_199335_3_);
}
}

View file

@ -0,0 +1,22 @@
--- a/net/minecraft/client/renderer/block/model/IBakedModel.java
+++ b/net/minecraft/client/renderer/block/model/IBakedModel.java
@@ -21,7 +21,18 @@
TextureAtlasSprite getParticleTexture();
- ItemCameraTransforms getItemCameraTransforms();
+ @Deprecated
+ default ItemCameraTransforms getItemCameraTransforms() { return ItemCameraTransforms.DEFAULT; }
ItemOverrideList getOverrides();
+
+ default boolean isAmbientOcclusion(IBlockState state) { return isAmbientOcclusion(); }
+
+ /*
+ * Returns the pair of the model for the given perspective, and the matrix
+ * that should be applied to the GL state before rendering it (matrix may be null).
+ */
+ default org.apache.commons.lang3.tuple.Pair<? extends IBakedModel, javax.vecmath.Matrix4f> handlePerspective(ItemCameraTransforms.TransformType cameraTransformType) {
+ return net.minecraftforge.client.ForgeHooksClient.handlePerspective(this, cameraTransformType);
}
+}

View file

@ -0,0 +1,26 @@
--- a/net/minecraft/client/renderer/block/model/IUnbakedModel.java
+++ b/net/minecraft/client/renderer/block/model/IUnbakedModel.java
@@ -8,13 +8,21 @@
import net.minecraft.util.ResourceLocation;
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.api.distmarker.OnlyIn;
+import net.minecraftforge.client.model.IModel;
+import net.minecraftforge.common.model.IModelState;
@OnlyIn(Dist.CLIENT)
-public interface IUnbakedModel {
+public interface IUnbakedModel extends IModel<IUnbakedModel> {
Collection<ResourceLocation> getOverrideLocations();
Collection<ResourceLocation> func_209559_a(Function<ResourceLocation, IUnbakedModel> p_209559_1_, Set<String> p_209559_2_);
+ /**
+ * @deprecated Use {@link #bake(Function, Function, IModelState, boolean)}.
+ */
@Nullable
- IBakedModel func_209558_a(Function<ResourceLocation, IUnbakedModel> p_209558_1_, Function<ResourceLocation, TextureAtlasSprite> p_209558_2_, ModelRotation p_209558_3_, boolean p_209558_4_);
+ @Deprecated
+ default IBakedModel func_209558_a(Function<ResourceLocation, IUnbakedModel> p_209558_1_, Function<ResourceLocation, TextureAtlasSprite> p_209558_2_, ModelRotation p_209558_3_, boolean p_209558_4_) {
+ return bake(p_209558_1_, p_209558_2_, p_209558_3_, p_209558_4_, net.minecraft.client.renderer.vertex.DefaultVertexFormats.BLOCK);
}
+}

View file

@ -0,0 +1,46 @@
--- a/net/minecraft/client/renderer/block/model/ItemCameraTransforms.java
+++ b/net/minecraft/client/renderer/block/model/ItemCameraTransforms.java
@@ -12,6 +12,10 @@
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.api.distmarker.OnlyIn;
+/**
+ * @deprecated use {@link net.minecraft.client.renderer.block.model.IBakedModel#handlePerspective(TransformType)} instead
+ */
+@Deprecated
@OnlyIn(Dist.CLIENT)
public class ItemCameraTransforms {
public static final ItemCameraTransforms DEFAULT = new ItemCameraTransforms();
@@ -37,6 +41,7 @@
this(ItemTransformVec3f.DEFAULT, ItemTransformVec3f.DEFAULT, ItemTransformVec3f.DEFAULT, ItemTransformVec3f.DEFAULT, ItemTransformVec3f.DEFAULT, ItemTransformVec3f.DEFAULT, ItemTransformVec3f.DEFAULT, ItemTransformVec3f.DEFAULT);
}
+ @Deprecated
public ItemCameraTransforms(ItemCameraTransforms transforms) {
this.thirdperson_left = transforms.thirdperson_left;
this.thirdperson_right = transforms.thirdperson_right;
@@ -48,6 +53,7 @@
this.fixed = transforms.fixed;
}
+ @Deprecated
public ItemCameraTransforms(ItemTransformVec3f thirdperson_leftIn, ItemTransformVec3f thirdperson_rightIn, ItemTransformVec3f firstperson_leftIn, ItemTransformVec3f firstperson_rightIn, ItemTransformVec3f headIn, ItemTransformVec3f guiIn, ItemTransformVec3f groundIn, ItemTransformVec3f fixedIn) {
this.thirdperson_left = thirdperson_leftIn;
this.thirdperson_right = thirdperson_rightIn;
@@ -80,6 +86,7 @@
}
}
+ @Deprecated
public ItemTransformVec3f getTransform(ItemCameraTransforms.TransformType type) {
switch(type) {
case THIRD_PERSON_LEFT_HAND:
@@ -136,7 +143,7 @@
}
@OnlyIn(Dist.CLIENT)
- public static enum TransformType {
+ public static enum TransformType implements net.minecraftforge.common.model.IModelPart {
NONE,
THIRD_PERSON_LEFT_HAND,
THIRD_PERSON_RIGHT_HAND,

View file

@ -0,0 +1,21 @@
--- a/net/minecraft/client/renderer/block/model/ItemOverrideList.java
+++ b/net/minecraft/client/renderer/block/model/ItemOverrideList.java
@@ -25,7 +25,8 @@
this.field_209582_c = Collections.<IBakedModel>emptyList();
}
- public ItemOverrideList(ModelBlock p_i49525_1_, Function<ResourceLocation, IUnbakedModel> p_i49525_2_, Function<ResourceLocation, TextureAtlasSprite> p_i49525_3_, List<ItemOverride> p_i49525_4_) {
+ // FORGE: No reason for first param to be limited to ModelBlock
+ public ItemOverrideList(IUnbakedModel p_i49525_1_, Function<ResourceLocation, IUnbakedModel> p_i49525_2_, Function<ResourceLocation, TextureAtlasSprite> p_i49525_3_, List<ItemOverride> p_i49525_4_) {
this.field_209582_c = (List)p_i49525_4_.stream().<IBakedModel>map((p_209580_3_) -> {
IUnbakedModel iunbakedmodel = p_i49525_2_.apply(p_209580_3_.getLocation());
return Objects.equals(iunbakedmodel, p_i49525_1_) ? null : iunbakedmodel.func_209558_a(p_i49525_2_, p_i49525_3_, ModelRotation.X0_Y0, false);
@@ -56,4 +57,8 @@
return p_209581_1_;
}
+
+ public com.google.common.collect.ImmutableList<ItemOverride> getOverrides() {
+ return com.google.common.collect.ImmutableList.copyOf(overrides);
}
+}

View file

@ -0,0 +1,17 @@
--- a/net/minecraft/client/renderer/block/model/ItemTransformVec3f.java
+++ b/net/minecraft/client/renderer/block/model/ItemTransformVec3f.java
@@ -12,8 +12,13 @@
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.api.distmarker.OnlyIn;
+/**
+ * @deprecated use {@link net.minecraftforge.client.model.IModelState} and {@link net.minecraftforge.client.model.TRSRTransformation}
+ */
@OnlyIn(Dist.CLIENT)
-public class ItemTransformVec3f {
+@Deprecated
+public class ItemTransformVec3f implements net.minecraftforge.common.model.IModelState {
+ public java.util.Optional<net.minecraftforge.common.model.TRSRTransformation> apply(java.util.Optional<? extends net.minecraftforge.common.model.IModelPart> part) { return net.minecraftforge.client.ForgeHooksClient.applyTransform(this, part); }
public static final ItemTransformVec3f DEFAULT = new ItemTransformVec3f(new Vector3f(), new Vector3f(), new Vector3f(1.0F, 1.0F, 1.0F));
public final Vector3f rotation;
public final Vector3f translation;

View file

@ -0,0 +1,85 @@
--- a/net/minecraft/client/renderer/block/model/ModelBlock.java
+++ b/net/minecraft/client/renderer/block/model/ModelBlock.java
@@ -18,6 +18,7 @@
import java.util.List;
import java.util.Map;
import java.util.Objects;
+import java.util.Optional;
import java.util.Set;
import java.util.Map.Entry;
import java.util.function.Function;
@@ -25,11 +26,13 @@
import javax.annotation.Nullable;
import net.minecraft.client.renderer.texture.MissingTextureSprite;
import net.minecraft.client.renderer.texture.TextureAtlasSprite;
+import net.minecraft.client.renderer.vertex.VertexFormat;
import net.minecraft.util.EnumFacing;
import net.minecraft.util.JsonUtils;
import net.minecraft.util.ResourceLocation;
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.api.distmarker.OnlyIn;
+
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
@@ -79,6 +82,9 @@
return this.parent != null;
}
+ @Nullable
+ public ResourceLocation getParentLocation() { return parentLocation; }
+
public boolean isAmbientOcclusion() {
return this.hasParent() ? this.parent.isAmbientOcclusion() : this.ambientOcclusion;
}
@@ -178,14 +184,18 @@
return set1;
}
- public IBakedModel func_209558_a(Function<ResourceLocation, IUnbakedModel> p_209558_1_, Function<ResourceLocation, TextureAtlasSprite> p_209558_2_, ModelRotation p_209558_3_, boolean p_209558_4_) {
- return this.func_209565_a(this, p_209558_1_, p_209558_2_, p_209558_3_, p_209558_4_);
+ @Override
+ public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> p_209558_1_, Function<ResourceLocation, TextureAtlasSprite> p_209558_2_, net.minecraftforge.common.model.IModelState state, boolean uvlock, VertexFormat format) {
+ if (!net.minecraftforge.client.model.Attributes.moreSpecific(format, net.minecraftforge.client.model.Attributes.DEFAULT_BAKED_FORMAT)) {
+ throw new IllegalArgumentException("Cannot bake vanilla model to format other than BLOCK");
}
+ return func_209565_a(this, p_209558_1_, p_209558_2_, state, uvlock);
+ }
- private IBakedModel func_209565_a(ModelBlock p_209565_1_, Function<ResourceLocation, IUnbakedModel> p_209565_2_, Function<ResourceLocation, TextureAtlasSprite> p_209565_3_, ModelRotation p_209565_4_, boolean p_209565_5_) {
+ private IBakedModel func_209565_a(ModelBlock p_209565_1_, Function<ResourceLocation, IUnbakedModel> p_209565_2_, Function<ResourceLocation, TextureAtlasSprite> p_209565_3_, net.minecraftforge.common.model.IModelState state, boolean uvlock) {
ModelBlock modelblock = this.getRootModel();
if (modelblock == ModelBakery.MODEL_GENERATED) {
- return field_209571_g.func_209579_a(p_209565_3_, this).func_209565_a(p_209565_1_, p_209565_2_, p_209565_3_, p_209565_4_, p_209565_5_);
+ return field_209571_g.func_209579_a(p_209565_3_, this).func_209565_a(p_209565_1_, p_209565_2_, p_209565_3_, state, uvlock);
} else if (modelblock == ModelBakery.MODEL_ENTITY) {
return new BuiltInModel(this.getAllTransforms(), this.func_209568_a(p_209565_1_, p_209565_2_, p_209565_3_));
} else {
@@ -197,9 +207,10 @@
BlockPartFace blockpartface = blockpart.mapFaces.get(enumfacing);
TextureAtlasSprite textureatlassprite1 = p_209565_3_.apply(new ResourceLocation(this.resolveTextureName(blockpartface.texture)));
if (blockpartface.cullFace == null) {
- simplebakedmodel$builder.addGeneralQuad(func_209567_a(blockpart, blockpartface, textureatlassprite1, enumfacing, p_209565_4_, p_209565_5_));
+ simplebakedmodel$builder.addGeneralQuad(makeBakedQuad(blockpart, blockpartface, textureatlassprite1, enumfacing, state, uvlock));
} else {
- simplebakedmodel$builder.addFaceQuad(p_209565_4_.rotateFace(blockpartface.cullFace), func_209567_a(blockpart, blockpartface, textureatlassprite1, enumfacing, p_209565_4_, p_209565_5_));
+
+ simplebakedmodel$builder.addFaceQuad(state.apply(Optional.empty()).map(trsr -> trsr.rotate(enumfacing)).orElse(enumfacing), makeBakedQuad(blockpart, blockpartface, textureatlassprite1, enumfacing, state, uvlock));
}
}
}
@@ -209,9 +220,13 @@
}
private static BakedQuad func_209567_a(BlockPart p_209567_0_, BlockPartFace p_209567_1_, TextureAtlasSprite p_209567_2_, EnumFacing p_209567_3_, ModelRotation p_209567_4_, boolean p_209567_5_) {
- return field_209572_h.func_199332_a(p_209567_0_.positionFrom, p_209567_0_.positionTo, p_209567_1_, p_209567_2_, p_209567_3_, p_209567_4_, p_209567_0_.partRotation, p_209567_5_, p_209567_0_.shade);
+ return makeBakedQuad(p_209567_0_, p_209567_1_, p_209567_2_, p_209567_3_, (net.minecraftforge.common.model.IModelState) p_209567_4_, p_209567_5_);
}
+ public static BakedQuad makeBakedQuad(BlockPart p_209567_0_, BlockPartFace p_209567_1_, TextureAtlasSprite p_209567_2_, EnumFacing p_209567_3_, net.minecraftforge.common.model.IModelState p_209567_4_, boolean p_209567_5_) {
+ return field_209572_h.makeBakedQuad(p_209567_0_.positionFrom, p_209567_0_.positionTo, p_209567_1_, p_209567_2_, p_209567_3_, p_209567_4_.apply(Optional.empty()).orElse(net.minecraftforge.common.model.TRSRTransformation.identity()), p_209567_0_.partRotation, p_209567_5_, p_209567_0_.shade);
+ }
+
public boolean isTexturePresent(String textureName) {
return !MissingTextureSprite.func_195677_a().func_195668_m().toString().equals(this.resolveTextureName(textureName));
}

View file

@ -0,0 +1,24 @@
--- a/net/minecraft/client/renderer/block/model/ModelRotation.java
+++ b/net/minecraft/client/renderer/block/model/ModelRotation.java
@@ -10,9 +10,10 @@
import net.minecraft.util.math.MathHelper;
import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.api.distmarker.OnlyIn;
+import net.minecraftforge.client.model.IModel;
@OnlyIn(Dist.CLIENT)
-public enum ModelRotation {
+public enum ModelRotation implements net.minecraftforge.common.model.IModelState, net.minecraftforge.common.model.ITransformation {
X0_Y0(0, 0),
X0_Y90(0, 90),
X0_Y180(0, 180),
@@ -97,4 +98,9 @@
public static ModelRotation getModelRotation(int x, int y) {
return MAP_ROTATIONS.get(combineXY(MathHelper.normalizeAngle(x, 360), MathHelper.normalizeAngle(y, 360)));
}
+
+ public java.util.Optional<net.minecraftforge.common.model.TRSRTransformation> apply(java.util.Optional<? extends net.minecraftforge.common.model.IModelPart> part) { return net.minecraftforge.client.ForgeHooksClient.applyTransform(this, part); }
+ public javax.vecmath.Matrix4f getMatrix() { return net.minecraftforge.common.model.TRSRTransformation.from(this).getMatrix(); }
+ public EnumFacing rotate(EnumFacing facing) { return rotateFace(facing); }
+ public int rotate(EnumFacing facing, int vertexIndex) { return rotateVertex(facing, vertexIndex); }
}

View file

@ -0,0 +1,27 @@
--- a/net/minecraft/client/renderer/block/model/Variant.java
+++ b/net/minecraft/client/renderer/block/model/Variant.java
@@ -12,7 +12,7 @@
import net.minecraftforge.api.distmarker.OnlyIn;
@OnlyIn(Dist.CLIENT)
-public class Variant {
+public class Variant implements net.minecraftforge.client.model.ISmartVariant {
private final ResourceLocation modelLocation;
private final ModelRotation rotation;
private final boolean uvLock;
@@ -29,10 +29,15 @@
return this.modelLocation;
}
+ @Deprecated
public ModelRotation getRotation() {
return this.rotation;
}
+ public net.minecraftforge.common.model.IModelState getState() {
+ return this.rotation;
+ }
+
public boolean isUvLock() {
return this.uvLock;
}

View file

@ -0,0 +1,20 @@
--- a/net/minecraft/client/renderer/block/model/VariantList.java
+++ b/net/minecraft/client/renderer/block/model/VariantList.java
@@ -56,14 +56,15 @@
}
@Nullable
- public IBakedModel func_209558_a(Function<ResourceLocation, IUnbakedModel> p_209558_1_, Function<ResourceLocation, TextureAtlasSprite> p_209558_2_, ModelRotation p_209558_3_, boolean p_209558_4_) {
+ @Override
+ public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> p_209558_1_, Function<ResourceLocation, TextureAtlasSprite> p_209558_2_, net.minecraftforge.common.model.IModelState p_209558_3_, boolean p_209558_4_, net.minecraft.client.renderer.vertex.VertexFormat format) {
if (this.getVariantList().isEmpty()) {
return null;
} else {
WeightedBakedModel.Builder weightedbakedmodel$builder = new WeightedBakedModel.Builder();
for(Variant variant : this.getVariantList()) {
- IBakedModel ibakedmodel = (p_209558_1_.apply(variant.getModelLocation())).func_209558_a(p_209558_1_, p_209558_2_, variant.getRotation(), variant.isUvLock());
+ IBakedModel ibakedmodel = (p_209558_1_.apply(variant.getModelLocation())).bake(p_209558_1_, p_209558_2_, variant.getState(), variant.isUvLock(), format);
weightedbakedmodel$builder.add(ibakedmodel, variant.getWeight());
}

View file

@ -0,0 +1,17 @@
--- a/net/minecraft/client/renderer/block/model/multipart/Multipart.java
+++ b/net/minecraft/client/renderer/block/model/multipart/Multipart.java
@@ -81,11 +81,12 @@
}
@Nullable
- public IBakedModel func_209558_a(Function<ResourceLocation, IUnbakedModel> p_209558_1_, Function<ResourceLocation, TextureAtlasSprite> p_209558_2_, ModelRotation p_209558_3_, boolean p_209558_4_) {
+ @Override
+ public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> p_209558_1_, Function<ResourceLocation, TextureAtlasSprite> p_209558_2_, net.minecraftforge.common.model.IModelState p_209558_3_, boolean p_209558_4_, net.minecraft.client.renderer.vertex.VertexFormat format) {
MultipartBakedModel.Builder multipartbakedmodel$builder = new MultipartBakedModel.Builder();
for(Selector selector : this.getSelectors()) {
- IBakedModel ibakedmodel = selector.getVariantList().func_209558_a(p_209558_1_, p_209558_2_, p_209558_3_, p_209558_4_);
+ IBakedModel ibakedmodel = selector.getVariantList().bake(p_209558_1_, p_209558_2_, p_209558_3_, p_209558_4_, format);
if (ibakedmodel != null) {
multipartbakedmodel$builder.putModel(selector.getPredicate(this.stateContainer), ibakedmodel);
}

View file

@ -0,0 +1,13 @@
--- a/net/minecraft/client/renderer/texture/TextureAtlasSprite.java
+++ b/net/minecraft/client/renderer/texture/TextureAtlasSprite.java
@@ -439,4 +439,10 @@
public void func_195663_q() {
this.func_195659_d(0);
}
+
+ // Forge Start
+
+ public int getPixelRGBA(int frameIndex, int x, int y) {
+ return this.field_195670_c[frameIndex].func_195709_a(x + this.field_195671_d[frameIndex] * this.width, y + this.field_195672_e[frameIndex] * this.height);
}
+}

View file

@ -0,0 +1,11 @@
--- a/net/minecraft/client/renderer/tileentity/TileEntityRenderer.java
+++ b/net/minecraft/client/renderer/tileentity/TileEntityRenderer.java
@@ -63,6 +63,8 @@
return false;
}
+ public void renderTileEntityFast(T te, double x, double y, double z, float partialTicks, int destroyStage, net.minecraft.client.renderer.BufferBuilder buffer) {}
+
protected void drawNameplate(T te, String str, double x, double y, double z, int maxDistance) {
Entity entity = this.rendererDispatcher.entity;
double d0 = te.getDistanceSq(entity.posX, entity.posY, entity.posZ);

View file

@ -39,12 +39,12 @@ import net.minecraft.client.renderer.texture.DynamicTexture;
import net.minecraft.client.renderer.vertex.DefaultVertexFormats; import net.minecraft.client.renderer.vertex.DefaultVertexFormats;
import net.minecraft.client.renderer.vertex.VertexBuffer; import net.minecraft.client.renderer.vertex.VertexBuffer;
import net.minecraft.client.renderer.vertex.VertexFormat; import net.minecraft.client.renderer.vertex.VertexFormat;
import net.minecraft.client.resources.IReloadableResourceManager;
import net.minecraft.client.resources.IResourceManager;
import net.minecraft.entity.Entity; import net.minecraft.entity.Entity;
import net.minecraft.resources.IReloadableResourceManager;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraft.util.math.MathHelper; import net.minecraft.util.math.MathHelper;
import net.minecraft.util.math.Vec3d; import net.minecraft.util.math.Vec3d;
import net.minecraftforge.common.ForgeMod;
import net.minecraftforge.common.ForgeModContainer; import net.minecraftforge.common.ForgeModContainer;
import net.minecraftforge.client.resource.ISelectiveResourceReloadListener; import net.minecraftforge.client.resource.ISelectiveResourceReloadListener;
@ -80,7 +80,7 @@ public class CloudRenderer implements ISelectiveResourceReloadListener
public CloudRenderer() public CloudRenderer()
{ {
// Resource manager should always be reloadable. // Resource manager should always be reloadable.
((IReloadableResourceManager) mc.getResourceManager()).registerReloadListener(this); ((IReloadableResourceManager) mc.func_195551_G()).func_199006_a(this);
} }
private int getScale() private int getScale()
@ -345,24 +345,14 @@ public class CloudRenderer implements ISelectiveResourceReloadListener
float g = (float) color.y; float g = (float) color.y;
float b = (float) color.z; float b = (float) color.z;
if (mc.gameSettings.anaglyph)
{
float tempR = r * 0.3F + g * 0.59F + b * 0.11F;
float tempG = r * 0.3F + g * 0.7F;
float tempB = r * 0.3F + b * 0.7F;
r = tempR;
g = tempG;
b = tempB;
}
if (COLOR_TEX == null) if (COLOR_TEX == null)
COLOR_TEX = new DynamicTexture(1, 1); COLOR_TEX = new DynamicTexture(1, 1, false);
// Apply a color multiplier through a texture upload if shaders aren't supported. // Apply a color multiplier through a texture upload if shaders aren't supported.
COLOR_TEX.getTextureData()[0] = 255 << 24 COLOR_TEX.func_195414_e().func_195700_a(0, 0, 255 << 24
| ((int) (r * 255)) << 16 | ((int) (r * 255)) << 16
| ((int) (g * 255)) << 8 | ((int) (g * 255)) << 8
| (int) (b * 255); | (int) (b * 255));
COLOR_TEX.updateDynamicTexture(); COLOR_TEX.updateDynamicTexture();
GlStateManager.setActiveTexture(OpenGlHelper.lightmapTexUnit); GlStateManager.setActiveTexture(OpenGlHelper.lightmapTexUnit);
@ -404,22 +394,7 @@ public class CloudRenderer implements ISelectiveResourceReloadListener
GlStateManager.callList(displayList); GlStateManager.callList(displayList);
// Full render. // Full render.
if (!mc.gameSettings.anaglyph) GlStateManager.colorMask(true, true, true, true);
{
GlStateManager.colorMask(true, true, true, true);
}
else
{
switch (EntityRenderer.anaglyphField)
{
case 0:
GlStateManager.colorMask(false, true, true, true);
break;
case 1:
GlStateManager.colorMask(true, false, false, true);
break;
}
}
// Wireframe for debug. // Wireframe for debug.
if (WIREFRAME) if (WIREFRAME)

View file

@ -67,6 +67,7 @@ import net.minecraft.client.renderer.block.model.ModelRotation;
import net.minecraft.client.renderer.block.model.SimpleBakedModel; import net.minecraft.client.renderer.block.model.SimpleBakedModel;
import net.minecraft.client.renderer.color.BlockColors; import net.minecraft.client.renderer.color.BlockColors;
import net.minecraft.client.renderer.color.ItemColors; import net.minecraft.client.renderer.color.ItemColors;
import net.minecraft.client.renderer.entity.model.ModelBiped;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
import net.minecraft.client.renderer.texture.TextureManager; import net.minecraft.client.renderer.texture.TextureManager;
import net.minecraft.client.renderer.texture.TextureMap; import net.minecraft.client.renderer.texture.TextureMap;
@ -97,6 +98,7 @@ import net.minecraft.util.math.MathHelper;
import net.minecraft.util.math.RayTraceResult; import net.minecraft.util.math.RayTraceResult;
import net.minecraft.util.registry.IRegistry; import net.minecraft.util.registry.IRegistry;
import net.minecraft.util.text.TextFormatting; import net.minecraft.util.text.TextFormatting;
import net.minecraft.world.IWorldReader;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraft.world.biome.Biome; import net.minecraft.world.biome.Biome;
import net.minecraftforge.client.event.ColorHandlerEvent; import net.minecraftforge.client.event.ColorHandlerEvent;
@ -146,7 +148,7 @@ public class ForgeHooksClient
//Optifine Helper Functions u.u, these are here specifically for Optifine //Optifine Helper Functions u.u, these are here specifically for Optifine
//Note: When using Optifine, these methods are invoked using reflection, which //Note: When using Optifine, these methods are invoked using reflection, which
//incurs a major performance penalty. //incurs a major performance penalty.
public static void orientBedCamera(IBlockAccess world, BlockPos pos, IBlockState state, Entity entity) public static void orientBedCamera(IWorldReader world, BlockPos pos, IBlockState state, Entity entity)
{ {
Block block = state.getBlock(); Block block = state.getBlock();
@ -519,17 +521,17 @@ public class ForgeHooksClient
} }
} }
public static void transform(org.lwjgl.util.vector.Vector3f vec, Matrix4f m) public static void transform(net.minecraft.client.renderer.Vector3f vec, Matrix4f m)
{ {
Vector4f tmp = new Vector4f(vec.x, vec.y, vec.z, 1f); Vector4f tmp = new Vector4f(vec.func_195899_a(), vec.func_195900_b(), vec.func_195902_c(), 1f);
m.transform(tmp); m.transform(tmp);
if(Math.abs(tmp.w - 1f) > 1e-5) tmp.scale(1f / tmp.w); if(Math.abs(tmp.w - 1f) > 1e-5) tmp.scale(1f / tmp.w);
vec.set(tmp.x, tmp.y, tmp.z); vec.func_195905_a(tmp.x, tmp.y, tmp.z);
} }
public static Matrix4f getMatrix(ModelRotation modelRotation) public static Matrix4f getMatrix(ModelRotation modelRotation)
{ {
Matrix4f ret = new Matrix4f(TRSRTransformation.toVecmath(modelRotation.getMatrix4d())), tmp = new Matrix4f(); Matrix4f ret = new Matrix4f(TRSRTransformation.toVecmath(modelRotation.func_195820_a()), new Vector3f(), 1), tmp = new Matrix4f();
tmp.setIdentity(); tmp.setIdentity();
tmp.m03 = tmp.m13 = tmp.m23 = .5f; tmp.m03 = tmp.m13 = tmp.m23 = .5f;
ret.mul(tmp, ret); ret.mul(tmp, ret);

View file

@ -21,12 +21,11 @@ package net.minecraftforge.client;
import java.util.Map; import java.util.Map;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import com.google.common.collect.Maps; import com.google.common.collect.Maps;
import it.unimi.dsi.fastutil.ints.Int2ObjectMap;
import it.unimi.dsi.fastutil.ints.Int2ObjectOpenHashMap;
import net.minecraft.client.renderer.ItemMeshDefinition;
import net.minecraft.client.renderer.ItemModelMesher; import net.minecraft.client.renderer.ItemModelMesher;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.ModelBakery; import net.minecraft.client.renderer.block.model.ModelBakery;
@ -36,16 +35,13 @@ import net.minecraft.item.Item;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraftforge.registries.IRegistryDelegate; import net.minecraftforge.registries.IRegistryDelegate;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
/** /**
* Wrapper around ItemModeMesher that cleans up the internal maps to respect ID remapping. * Wrapper around ItemModeMesher that cleans up the internal maps to respect ID remapping.
*/ */
public class ItemModelMesherForge extends ItemModelMesher public class ItemModelMesherForge extends ItemModelMesher
{ {
final Map<IRegistryDelegate<Item>, Int2ObjectMap<ModelResourceLocation>> locations = Maps.newHashMap(); final Map<IRegistryDelegate<Item>, ModelResourceLocation> locations = Maps.newHashMap();
final Map<IRegistryDelegate<Item>, Int2ObjectMap<IBakedModel>> models = Maps.newHashMap(); final Map<IRegistryDelegate<Item>, IBakedModel> models = Maps.newHashMap();
public ItemModelMesherForge(ModelManager manager) public ItemModelMesherForge(ModelManager manager)
{ {
@ -54,74 +50,32 @@ public class ItemModelMesherForge extends ItemModelMesher
@Override @Override
@Nullable @Nullable
protected IBakedModel getItemModel(Item item, int meta) public IBakedModel func_199312_b(Item item)
{ {
Int2ObjectMap<IBakedModel> map = models.get(item.delegate); return models.get(item.delegate);
return map == null ? null : map.get(meta);
} }
@Override @Override
public void register(Item item, int meta, ModelResourceLocation location) public void func_199311_a(Item item, ModelResourceLocation location)
{ {
IRegistryDelegate<Item> key = item.delegate; IRegistryDelegate<Item> key = item.delegate;
Int2ObjectMap<ModelResourceLocation> locs = locations.get(key); locations.put(key, location);
Int2ObjectMap<IBakedModel> mods = models.get(key); models.put(key, getModelManager().getModel(location));
if (locs == null)
{
locs = new Int2ObjectOpenHashMap<>();
locations.put(key, locs);
}
if (mods == null)
{
mods = new Int2ObjectOpenHashMap<>();
models.put(key, mods);
}
locs.put(meta, location);
mods.put(meta, getModelManager().getModel(location));
} }
@Override @Override
public void rebuildCache() public void rebuildCache()
{ {
final ModelManager manager = this.getModelManager(); final ModelManager manager = this.getModelManager();
for (Map.Entry<IRegistryDelegate<Item>, Int2ObjectMap<ModelResourceLocation>> e : locations.entrySet()) for (Map.Entry<IRegistryDelegate<Item>, ModelResourceLocation> e : locations.entrySet())
{ {
Int2ObjectMap<IBakedModel> mods = models.get(e.getKey()); models.put(e.getKey(), manager.getModel(e.getValue()));
if (mods != null)
{
mods.clear();
}
else
{
mods = new Int2ObjectOpenHashMap<>();
models.put(e.getKey(), mods);
}
final Int2ObjectMap<IBakedModel> map = mods;
e.getValue().int2ObjectEntrySet().forEach(entry ->
map.put(entry.getIntKey(), manager.getModel(entry.getValue()))
);
} }
} }
public ModelResourceLocation getLocation(@Nonnull ItemStack stack) public ModelResourceLocation getLocation(@Nonnull ItemStack stack)
{ {
Item item = stack.getItem(); ModelResourceLocation location = locations.get(stack.getItem().delegate);
ModelResourceLocation location = null;
Int2ObjectMap<ModelResourceLocation> map = locations.get(item.delegate);
if (map != null)
{
location = map.get(getMetadata(stack));
}
if (location == null)
{
ItemMeshDefinition definition = shapers.get(item);
if (definition != null)
{
location = definition.getModelLocation(stack);
}
}
if (location == null) if (location == null)
{ {

View file

@ -23,6 +23,7 @@ import javax.annotation.Nullable;
import javax.vecmath.Matrix4f; import javax.vecmath.Matrix4f;
import java.util.List; import java.util.List;
import java.util.Random;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
@ -66,7 +67,7 @@ public class BakedItemModel implements IBakedModel
@Override public ItemOverrideList getOverrides() { return overrides; } @Override public ItemOverrideList getOverrides() { return overrides; }
@Override @Override
public List<BakedQuad> getQuads(@Nullable IBlockState state, @Nullable EnumFacing side, long rand) public List<BakedQuad> func_200117_a(@Nullable IBlockState state, @Nullable EnumFacing side, Random rand)
{ {
if (side == null) if (side == null)
{ {
@ -104,7 +105,7 @@ public class BakedItemModel implements IBakedModel
} }
@Override @Override
public List<BakedQuad> getQuads(@Nullable IBlockState state, @Nullable EnumFacing side, long rand) public List<BakedQuad> func_200117_a (@Nullable IBlockState state, @Nullable EnumFacing side, Random rand)
{ {
if(side == null) if(side == null)
{ {

View file

@ -22,6 +22,7 @@ package net.minecraftforge.client.model;
import javax.annotation.Nullable; import javax.annotation.Nullable;
import javax.vecmath.Matrix4f; import javax.vecmath.Matrix4f;
import java.util.List; import java.util.List;
import java.util.Random;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.client.renderer.block.model.BakedQuad; import net.minecraft.client.renderer.block.model.BakedQuad;
@ -42,9 +43,9 @@ public abstract class BakedModelWrapper<T extends IBakedModel> implements IBaked
} }
@Override @Override
public List<BakedQuad> getQuads(@Nullable IBlockState state, @Nullable EnumFacing side, long rand) public List<BakedQuad> func_200117_a(@Nullable IBlockState state, @Nullable EnumFacing side, Random rand)
{ {
return originalModel.getQuads(state, side, rand); return originalModel.func_200117_a(state, side, rand);
} }
@Override @Override

View file

@ -29,6 +29,7 @@ import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Map.Entry; import java.util.Map.Entry;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ModelBlockDefinition; import net.minecraft.client.renderer.block.model.ModelBlockDefinition;
import net.minecraft.client.renderer.block.model.ModelRotation; import net.minecraft.client.renderer.block.model.ModelRotation;
import net.minecraft.client.renderer.block.model.Variant; import net.minecraft.client.renderer.block.model.Variant;
@ -37,9 +38,10 @@ import net.minecraft.util.ResourceLocation;
import net.minecraftforge.common.model.IModelState; import net.minecraftforge.common.model.IModelState;
import net.minecraftforge.common.model.TRSRTransformation; import net.minecraftforge.common.model.TRSRTransformation;
import net.minecraftforge.fml.common.FMLLog;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.apache.commons.lang3.tuple.Pair; import org.apache.commons.lang3.tuple.Pair;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
import com.google.common.collect.Lists; import com.google.common.collect.Lists;
@ -56,6 +58,9 @@ public class BlockStateLoader
.registerTypeAdapter(ForgeBlockStateV1.Variant.class, ForgeBlockStateV1.Variant.Deserializer.INSTANCE) .registerTypeAdapter(ForgeBlockStateV1.Variant.class, ForgeBlockStateV1.Variant.Deserializer.INSTANCE)
.registerTypeAdapter(TRSRTransformation.class, ForgeBlockStateV1.TRSRDeserializer.INSTANCE) .registerTypeAdapter(TRSRTransformation.class, ForgeBlockStateV1.TRSRDeserializer.INSTANCE)
.create(); .create();
private static final Logger LOGGER = LogManager.getLogger();
/** /**
* Loads a BlockStates json file. * Loads a BlockStates json file.
* Will attempt to parse it as a Forge Enhanced version if possible. * Will attempt to parse it as a Forge Enhanced version if possible.
@ -172,13 +177,12 @@ public class BlockStateLoader
this.gui3d = gui3d; this.gui3d = gui3d;
} }
private IModel runModelHooks(IModel base, boolean smooth, boolean gui3d, boolean uvlock, ImmutableMap<String, String> textureMap, ImmutableMap<String, String> customData) private IUnbakedModel runModelHooks(IUnbakedModel base, boolean smooth, boolean gui3d, ImmutableMap<String, String> textureMap, ImmutableMap<String, String> customData)
{ {
base = base.process(customData); base = base.process(customData);
base = base.retexture(textureMap); base = base.retexture(textureMap);
base = base.smoothLighting(smooth); base = base.smoothLighting(smooth);
base = base.gui3d(gui3d); base = base.gui3d(gui3d);
base = base.uvlock(uvlock);
return base; return base;
} }
@ -186,7 +190,7 @@ public class BlockStateLoader
* Used to replace the base model with a re-textured model containing sub-models. * Used to replace the base model with a re-textured model containing sub-models.
*/ */
@Override @Override
public IModel process(IModel base) public IUnbakedModel process(IUnbakedModel base)
{ {
int size = parts.size(); int size = parts.size();
// FIXME: should missing base be handled this way? // FIXME: should missing base be handled this way?
@ -194,22 +198,22 @@ public class BlockStateLoader
if (hasBase) if (hasBase)
{ {
base = runModelHooks(base, smooth, gui3d, this.isUvLock(), textures, customData); base = runModelHooks(base, smooth, gui3d, textures, customData);
if (size <= 0) if (size <= 0)
return base; return base;
} }
ImmutableMap.Builder<String, Pair<IModel, IModelState>> models = ImmutableMap.builder(); ImmutableMap.Builder<String, Pair<IUnbakedModel, IModelState>> models = ImmutableMap.builder();
for (Entry<String, SubModel> entry : parts.entrySet()) for (Entry<String, SubModel> entry : parts.entrySet())
{ {
SubModel part = entry.getValue(); SubModel part = entry.getValue();
final ResourceLocation modelLocation = part.getModelLocation(); final ResourceLocation modelLocation = part.getModelLocation();
final IModel model; final IUnbakedModel model;
if (modelLocation == null) if (modelLocation == null)
{ {
FMLLog.log.error("model not found for variant {} for blockstate {}", entry.getKey(), blockstateLocation); LOGGER.error("model not found for variant {} for blockstate {}", entry.getKey(), blockstateLocation);
model = ModelLoaderRegistry.getMissingModel(blockstateLocation, new Throwable()); model = ModelLoaderRegistry.getMissingModel(blockstateLocation, new Throwable());
} }
else else
@ -217,7 +221,7 @@ public class BlockStateLoader
model = ModelLoaderRegistry.getModelOrLogError(modelLocation, "Unable to load block sub-model: \'" + modelLocation); model = ModelLoaderRegistry.getModelOrLogError(modelLocation, "Unable to load block sub-model: \'" + modelLocation);
} }
models.put(entry.getKey(), Pair.of(runModelHooks(model, part.smooth, part.gui3d, part.uvLock, part.getTextures(), part.getCustomData()), part.getState())); models.put(entry.getKey(), Pair.of(runModelHooks(model, part.smooth, part.gui3d, part.getTextures(), part.getCustomData()), part.getState()));
} }
return new MultiModel(getModelLocation(), hasBase ? base : null, models.build()); return new MultiModel(getModelLocation(), hasBase ? base : null, models.build());

View file

@ -30,6 +30,7 @@ import net.minecraft.block.state.IBlockState;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.client.renderer.block.model.BakedQuad; import net.minecraft.client.renderer.block.model.BakedQuad;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ItemCameraTransforms; import net.minecraft.client.renderer.block.model.ItemCameraTransforms;
import net.minecraft.client.renderer.block.model.ItemOverrideList; import net.minecraft.client.renderer.block.model.ItemOverrideList;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
@ -46,9 +47,12 @@ import javax.vecmath.Matrix4f;
import javax.vecmath.Quat4f; import javax.vecmath.Quat4f;
import javax.vecmath.Vector3f; import javax.vecmath.Vector3f;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.List; import java.util.List;
import java.util.Random;
import java.util.Set;
final class FancyMissingModel implements IModel final class FancyMissingModel implements IUnbakedModel
{ {
private static final ResourceLocation font = new ResourceLocation("minecraft", "textures/font/ascii.png"); private static final ResourceLocation font = new ResourceLocation("minecraft", "textures/font/ascii.png");
private static final ResourceLocation font2 = new ResourceLocation("minecraft", "font/ascii"); private static final ResourceLocation font2 = new ResourceLocation("minecraft", "font/ascii");
@ -70,37 +74,43 @@ final class FancyMissingModel implements IModel
false, false,
m, m,
format format
) { ) {/* TODO Implement once SimpleModelFontRenderer is fixed
@Override @Override
protected float renderUnicodeChar(char c, boolean italic) protected float renderUnicodeChar(char c, boolean italic)
{ {
return super.renderDefaultChar(126, italic); return super.renderDefaultChar(126, italic);
} }
}; */};
} }
}); });
private final IModel missingModel; private final IUnbakedModel missingModel;
private final String message; private final String message;
public FancyMissingModel(IModel missingModel, String message) public FancyMissingModel(IUnbakedModel missingModel, String message)
{ {
this.missingModel = missingModel; this.missingModel = missingModel;
this.message = message; this.message = message;
} }
@Override @Override
public Collection<ResourceLocation> getTextures() public Collection<ResourceLocation> func_209559_a(Function<ResourceLocation, IUnbakedModel> p_209559_1_, Set<String> p_209559_2_)
{ {
return ImmutableList.of(font2); return ImmutableList.of(font2);
} }
@Override @Override
public IBakedModel bake(IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) public Collection<ResourceLocation> getOverrideLocations()
{ {
IBakedModel bigMissing = missingModel.bake(state, format, bakedTextureGetter); return Collections.emptyList();
}
@Override
public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean uvlock, VertexFormat format)
{
IBakedModel bigMissing = missingModel.bake(modelGetter, bakedTextureGetter, state, uvlock, format);
IModelState smallState = new ModelStateComposition(state, smallTransformation); IModelState smallState = new ModelStateComposition(state, smallTransformation);
IBakedModel smallMissing = missingModel.bake(smallState, format, bakedTextureGetter); IBakedModel smallMissing = missingModel.bake(modelGetter, bakedTextureGetter, smallState, uvlock, format);
return new BakedModel(bigMissing, smallMissing, fontCache.getUnchecked(format), message, bakedTextureGetter.apply(font2)); return new BakedModel(bigMissing, smallMissing, fontCache.getUnchecked(format), message, bakedTextureGetter.apply(font2));
} }
@ -135,7 +145,7 @@ final class FancyMissingModel implements IModel
} }
@Override @Override
public List<BakedQuad> getQuads(@Nullable IBlockState state, @Nullable EnumFacing side, long rand) public List<BakedQuad> func_200117_a(@Nullable IBlockState state, @Nullable EnumFacing side, Random rand)
{ {
if (side == null) if (side == null)
{ {
@ -151,16 +161,16 @@ final class FancyMissingModel implements IModel
} }
for (int y = 0; y < splitLines.size(); y++) for (int y = 0; y < splitLines.size(); y++)
{ {
fontRenderer.drawString(splitLines.get(y), 0, (int)((y - splitLines.size() / 2f) * fontRenderer.FONT_HEIGHT) + 0x40, 0xFF00FFFF); fontRenderer.func_211126_b(splitLines.get(y), 0, ((y - splitLines.size() / 2f) * fontRenderer.FONT_HEIGHT) + 0x40, 0xFF00FFFF);
} }
ImmutableList.Builder<BakedQuad> builder = ImmutableList.builder(); ImmutableList.Builder<BakedQuad> builder = ImmutableList.builder();
builder.addAll(missingModel.getQuads(state, side, rand)); builder.addAll(missingModel.func_200117_a (state, side, rand));
builder.addAll(fontRenderer.build()); builder.addAll(fontRenderer.build());
quads = builder.build(); quads = builder.build();
} }
return quads; return quads;
} }
return missingModel.getQuads(state, side, rand); return missingModel.func_200117_a (state, side, rand);
} }
@Override @Override

View file

@ -24,6 +24,7 @@ import java.util.function.Predicate;
import net.minecraftforge.client.resource.IResourceType; import net.minecraftforge.client.resource.IResourceType;
import net.minecraftforge.client.resource.ISelectiveResourceReloadListener; import net.minecraftforge.client.resource.ISelectiveResourceReloadListener;
import net.minecraftforge.client.resource.VanillaResourceType; import net.minecraftforge.client.resource.VanillaResourceType;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.resources.IResourceManager; import net.minecraft.resources.IResourceManager;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
@ -50,5 +51,5 @@ public interface ICustomModelLoader extends ISelectiveResourceReloadListener
/* /*
* loads (or reloads) specified model * loads (or reloads) specified model
*/ */
IModel loadModel(ResourceLocation modelLocation) throws Exception; IUnbakedModel loadModel(ResourceLocation modelLocation) throws Exception;
} }

View file

@ -19,18 +19,19 @@
package net.minecraftforge.client.model; package net.minecraftforge.client.model;
import java.util.Collection;
import java.util.Optional; import java.util.Optional;
import com.google.common.collect.ImmutableList; import java.util.function.Function;
import javax.annotation.Nullable;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
import net.minecraft.client.renderer.vertex.VertexFormat; import net.minecraft.client.renderer.vertex.VertexFormat;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraftforge.common.model.IModelState; import net.minecraftforge.common.model.IModelState;
import java.util.function.Function;
import net.minecraftforge.common.model.TRSRTransformation; import net.minecraftforge.common.model.TRSRTransformation;
import net.minecraftforge.common.model.animation.IClip; import net.minecraftforge.common.model.animation.IClip;
@ -38,35 +39,11 @@ import net.minecraftforge.common.model.animation.IClip;
* Interface for models that can be baked * Interface for models that can be baked
* (possibly to different vertex formats and with different state). * (possibly to different vertex formats and with different state).
*/ */
public interface IModel @SuppressWarnings("unchecked")
public interface IModel<T extends IModel<T>>
{ {
/* @Nullable
* Returns all model locations that this model depends on. IBakedModel bake(Function<ResourceLocation, IUnbakedModel> p_209558_1_, Function<ResourceLocation, TextureAtlasSprite> p_209558_2_, IModelState state, boolean uvlock, VertexFormat format);
* Assume that returned collection is immutable.
* See ModelLoaderRegistry.getModel for dependency loading.
*/
default Collection<ResourceLocation> getDependencies() {
return ImmutableList.of();
}
/*
* Returns all texture locations that this model depends on.
* Assume that returned collection is immutable.
*/
default Collection<ResourceLocation> getTextures() {
return ImmutableList.of();
}
/*
* All model texture coordinates should be resolved at this method.
* Returned model should be in the simplest form possible, for performance
* reasons (if it's not ISmartBlock/ItemModel - then it should be
* represented by List<BakedQuad> internally).
* Returned model's getFormat() can me less specific than the passed
* format argument (some attributes can be replaced with padding),
* if there's no such info in this model.
*/
IBakedModel bake(IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter);
/* /*
* Default state this model will be baked with. * Default state this model will be baked with.
@ -85,20 +62,16 @@ public interface IModel
* If unknown data is encountered it should be skipped. * If unknown data is encountered it should be skipped.
* @return a new model, with data applied. * @return a new model, with data applied.
*/ */
default IModel process(ImmutableMap<String, String> customData) { default T process(ImmutableMap<String, String> customData) {
return this; return (T) this;
} }
default IModel smoothLighting(boolean value) { default T smoothLighting(boolean value) {
return this; return (T) this;
} }
default IModel gui3d(boolean value) { default T gui3d(boolean value) {
return this; return (T) this;
}
default IModel uvlock(boolean value) {
return this;
} }
/** /**
@ -118,7 +91,7 @@ public interface IModel
* @param textures New * @param textures New
* @return Model with textures applied. * @return Model with textures applied.
*/ */
default IModel retexture(ImmutableMap<String, String> textures) { default T retexture(ImmutableMap<String, String> textures) {
return this; return (T) this;
} }
} }

View file

@ -19,8 +19,11 @@
package net.minecraftforge.client.model; package net.minecraftforge.client.model;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
public interface ISmartVariant public interface ISmartVariant
{ {
IModel process(IModel base); default IUnbakedModel process(IUnbakedModel base) {
return base;
}
} }

View file

@ -25,9 +25,12 @@ import net.minecraftforge.common.ForgeVersion;
import net.minecraft.client.renderer.block.model.BakedQuad; import net.minecraft.client.renderer.block.model.BakedQuad;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType; import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType;
import net.minecraft.client.renderer.block.model.ItemOverrideList; import net.minecraft.client.renderer.block.model.ItemOverrideList;
import net.minecraft.client.renderer.block.model.ModelBlock; import net.minecraft.client.renderer.block.model.ModelBlock;
import net.minecraft.client.renderer.block.model.ModelRotation;
import net.minecraft.client.renderer.texture.NativeImage;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
import net.minecraft.client.renderer.vertex.VertexFormat; import net.minecraft.client.renderer.vertex.VertexFormat;
import net.minecraft.resources.IResourceManager; import net.minecraft.resources.IResourceManager;
@ -40,14 +43,16 @@ import net.minecraftforge.common.model.TRSRTransformation;
import java.util.Arrays; import java.util.Arrays;
import java.util.BitSet; import java.util.BitSet;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.EnumMap; import java.util.EnumMap;
import java.util.Optional; import java.util.Optional;
import java.util.Set;
import java.util.function.Function; import java.util.function.Function;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
public final class ItemLayerModel implements IModel public final class ItemLayerModel implements IUnbakedModel
{ {
public static final ItemLayerModel INSTANCE = new ItemLayerModel(ImmutableList.of()); public static final ItemLayerModel INSTANCE = new ItemLayerModel(ImmutableList.of());
@ -70,7 +75,7 @@ public final class ItemLayerModel implements IModel
public ItemLayerModel(ModelBlock model) public ItemLayerModel(ModelBlock model)
{ {
this(getTextures(model), model.createOverrides()); this(getTextures(model), model.func_209568_a(model, ModelLoader.defaultModelGetter(), ModelLoader.defaultTextureGetter()));
} }
private static ImmutableList<ResourceLocation> getTextures(ModelBlock model) private static ImmutableList<ResourceLocation> getTextures(ModelBlock model)
@ -83,11 +88,19 @@ public final class ItemLayerModel implements IModel
return builder.build(); return builder.build();
} }
public Collection<ResourceLocation> getTextures() @Override
public Collection<ResourceLocation> func_209559_a(Function<ResourceLocation, IUnbakedModel> p_209559_1_, Set<String> p_209559_2_)
{ {
return textures; return textures;
} }
@Override
public Collection<ResourceLocation> getOverrideLocations()
{
return Collections.emptyList();
}
@Override
public ItemLayerModel retexture(ImmutableMap<String, String> textures) public ItemLayerModel retexture(ImmutableMap<String, String> textures)
{ {
ImmutableList.Builder<ResourceLocation> builder = ImmutableList.builder(); ImmutableList.Builder<ResourceLocation> builder = ImmutableList.builder();
@ -106,8 +119,7 @@ public final class ItemLayerModel implements IModel
} }
@Override @Override
public IBakedModel bake(IModelState state, final VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> p_209558_1_, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean p_209558_4_, VertexFormat format) {
{
ImmutableList.Builder<BakedQuad> builder = ImmutableList.builder(); ImmutableList.Builder<BakedQuad> builder = ImmutableList.builder();
Optional<TRSRTransformation> transform = state.apply(Optional.empty()); Optional<TRSRTransformation> transform = state.apply(Optional.empty());
for(int i = 0; i < textures.size(); i++) for(int i = 0; i < textures.size(); i++)
@ -132,7 +144,6 @@ public final class ItemLayerModel implements IModel
for(int f = 0; f < sprite.getFrameCount(); f++) for(int f = 0; f < sprite.getFrameCount(); f++)
{ {
int[] pixels = sprite.getFrameTextureData(f)[0];
boolean ptu; boolean ptu;
boolean[] ptv = new boolean[uMax]; boolean[] ptv = new boolean[uMax];
Arrays.fill(ptv, true); Arrays.fill(ptv, true);
@ -141,7 +152,7 @@ public final class ItemLayerModel implements IModel
ptu = true; ptu = true;
for(int u = 0; u < uMax; u++) for(int u = 0; u < uMax; u++)
{ {
int alpha = getAlpha(pixels, uMax, vMax, u, v); int alpha = sprite.getPixelRGBA(f, u, v) >> 24 & 0xFF;
boolean t = alpha / 255f <= 0.1f; boolean t = alpha / 255f <= 0.1f;
if (!t && alpha < 255) if (!t && alpha < 255)
@ -328,11 +339,6 @@ public final class ItemLayerModel implements IModel
} }
} }
private static int getAlpha(int[] pixels, int uMax, int vMax, int u, int v)
{
return pixels[u + (vMax - 1 - v) * uMax] >> 24 & 0xFF;
}
private static BakedQuad buildSideQuad(VertexFormat format, Optional<TRSRTransformation> transform, EnumFacing side, int tint, TextureAtlasSprite sprite, int u, int v, int size) private static BakedQuad buildSideQuad(VertexFormat format, Optional<TRSRTransformation> transform, EnumFacing side, int tint, TextureAtlasSprite sprite, int u, int v, int size)
{ {
final float eps = 1e-2f; final float eps = 1e-2f;
@ -435,7 +441,7 @@ public final class ItemLayerModel implements IModel
break; break;
} }
case NORMAL: case NORMAL:
builder.put(e, (float)side.getFrontOffsetX(), (float)side.getFrontOffsetY(), (float)side.getFrontOffsetZ(), 0f); builder.put(e, (float)side.getXOffset(), (float)side.getYOffset(), (float)side.getZOffset(), 0f);
break; break;
default: default:
builder.put(e); builder.put(e);
@ -461,7 +467,7 @@ public final class ItemLayerModel implements IModel
} }
@Override @Override
public IModel loadModel(ResourceLocation modelLocation) public IUnbakedModel loadModel(ResourceLocation modelLocation)
{ {
return ItemLayerModel.INSTANCE; return ItemLayerModel.INSTANCE;
} }

View file

@ -21,6 +21,7 @@ package net.minecraftforge.client.model;
import com.google.common.collect.Lists; import com.google.common.collect.Lists;
import net.minecraft.client.renderer.texture.NativeImage;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
import net.minecraft.client.renderer.vertex.VertexFormat; import net.minecraft.client.renderer.vertex.VertexFormat;
import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumFacing;
@ -83,7 +84,6 @@ public final class ItemTextureQuadConverter
int h = template.getIconHeight(); int h = template.getIconHeight();
float wScale = 16f / (float)w; float wScale = 16f / (float)w;
float hScale = 16f / (float)h; float hScale = 16f / (float)h;
int[] data = template.getFrameTextureData(0)[0];
List<UnpackedBakedQuad> quads = Lists.newArrayList(); List<UnpackedBakedQuad> quads = Lists.newArrayList();
// the upper left x-position of the current quad // the upper left x-position of the current quad
@ -93,15 +93,15 @@ public final class ItemTextureQuadConverter
for (int x = 0; x < w; x++) for (int x = 0; x < w; x++)
{ {
// current pixel // current pixel
int pixel = data[y * w + x]; boolean isVisible = !template.func_195662_a(0, x, y);
// no current quad but found a new one // no current quad but found a new one
if (start < 0 && isVisible(pixel)) if (start < 0 && isVisible)
{ {
start = x; start = x;
} }
// got a current quad, but it ends here // got a current quad, but it ends here
if (start >= 0 && !isVisible(pixel)) if (start >= 0 && !isVisible)
{ {
// we now check if the visibility of the next row matches the one fo the current row // we now check if the visibility of the next row matches the one fo the current row
// if they are, we can extend the quad downwards // if they are, we can extend the quad downwards
@ -111,9 +111,7 @@ public final class ItemTextureQuadConverter
{ {
for (int i = 0; i < w; i++) for (int i = 0; i < w; i++)
{ {
int px1 = data[y * w + i]; if (template.func_195662_a(0, i, y) != template.func_195662_a(0, i, endY))
int px2 = data[endY * w + i];
if (isVisible(px1) != isVisible(px2))
{ {
sameRow = false; sameRow = false;
break; break;
@ -164,7 +162,6 @@ public final class ItemTextureQuadConverter
int h = template.getIconHeight(); int h = template.getIconHeight();
float wScale = 16f / (float)w; float wScale = 16f / (float)w;
float hScale = 16f / (float)h; float hScale = 16f / (float)h;
int[] data = template.getFrameTextureData(0)[0];
List<UnpackedBakedQuad> quads = Lists.newArrayList(); List<UnpackedBakedQuad> quads = Lists.newArrayList();
// the upper left y-position of the current quad // the upper left y-position of the current quad
@ -174,15 +171,15 @@ public final class ItemTextureQuadConverter
for (int y = 0; y < h; y++) for (int y = 0; y < h; y++)
{ {
// current pixel // current pixel
int pixel = data[y * w + x]; boolean isVisible = !sprite.func_195662_a(0, x, y);
// no current quad but found a new one // no current quad but found a new one
if (start < 0 && isVisible(pixel)) if (start < 0 && isVisible)
{ {
start = y; start = y;
} }
// got a current quad, but it ends here // got a current quad, but it ends here
if (start >= 0 && !isVisible(pixel)) if (start >= 0 && !isVisible)
{ {
// we now check if the visibility of the next column matches the one fo the current row // we now check if the visibility of the next column matches the one fo the current row
// if they are, we can extend the quad downwards // if they are, we can extend the quad downwards
@ -192,9 +189,7 @@ public final class ItemTextureQuadConverter
{ {
for (int i = 0; i < h; i++) for (int i = 0; i < h; i++)
{ {
int px1 = data[i * w + x]; if (sprite.func_195662_a(0, x, i) != sprite.func_195662_a(0, endX, i))
int px2 = data[i * w + endX];
if (isVisible(px1) != isVisible(px2))
{ {
sameColumn = false; sameColumn = false;
break; break;
@ -328,7 +323,7 @@ public final class ItemTextureQuadConverter
break; break;
} }
case NORMAL: case NORMAL:
builder.put(e, (float) side.getFrontOffsetX(), (float) side.getFrontOffsetY(), (float) side.getFrontOffsetZ(), 0f); builder.put(e, (float) side.getXOffset(), (float) side.getYOffset(), (float) side.getZOffset(), 0f);
break; break;
default: default:
builder.put(e); builder.put(e);

View file

@ -21,6 +21,7 @@ package net.minecraftforge.client.model;
import java.io.IOException; import java.io.IOException;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.Map; import java.util.Map;
import javax.annotation.Nonnull; import javax.annotation.Nonnull;
@ -30,12 +31,16 @@ import javax.vecmath.Quat4f;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.client.renderer.block.model.BakedQuad; import net.minecraft.client.renderer.block.model.BakedQuad;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType; import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType;
import net.minecraft.client.renderer.block.model.ItemOverrideList; import net.minecraft.client.renderer.block.model.ItemOverrideList;
import net.minecraft.client.renderer.block.model.ModelResourceLocation; import net.minecraft.client.renderer.block.model.ModelResourceLocation;
import net.minecraft.client.renderer.texture.PngSizeInfo;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
import net.minecraft.client.renderer.texture.TextureMap; import net.minecraft.client.renderer.texture.TextureMap;
import net.minecraft.client.renderer.vertex.VertexFormat; import net.minecraft.client.renderer.vertex.VertexFormat;
import net.minecraft.client.resources.data.AnimationMetadataSection;
import net.minecraft.client.resources.data.AnimationMetadataSectionSerializer;
import net.minecraft.entity.EntityLivingBase; import net.minecraft.entity.EntityLivingBase;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.resources.IResource; import net.minecraft.resources.IResource;
@ -54,8 +59,8 @@ import net.minecraftforge.fluids.FluidUtil;
import java.util.Objects; import java.util.Objects;
import java.util.function.Function; import java.util.function.Function;
import java.util.Optional; import java.util.Optional;
import java.util.Random;
import static net.minecraftforge.client.model.ModelDynBucket.LoaderDynBucket.getResource; import java.util.Set;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
@ -65,7 +70,7 @@ import org.apache.commons.io.IOUtils;
import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger; import org.apache.logging.log4j.Logger;
public final class ModelDynBucket implements IModel public final class ModelDynBucket implements IUnbakedModel
{ {
private static final Logger LOGGER = LogManager.getLogger(); private static final Logger LOGGER = LogManager.getLogger();
public static final ModelResourceLocation LOCATION = new ModelResourceLocation(new ResourceLocation(ForgeVersion.MOD_ID, "dynbucket"), "inventory"); public static final ModelResourceLocation LOCATION = new ModelResourceLocation(new ResourceLocation(ForgeVersion.MOD_ID, "dynbucket"), "inventory");
@ -76,7 +81,7 @@ public final class ModelDynBucket implements IModel
private static final float NORTH_Z_FLUID = 7.498f / 16f; private static final float NORTH_Z_FLUID = 7.498f / 16f;
private static final float SOUTH_Z_FLUID = 8.502f / 16f; private static final float SOUTH_Z_FLUID = 8.502f / 16f;
public static final IModel MODEL = new ModelDynBucket(); public static final IUnbakedModel MODEL = new ModelDynBucket();
@Nullable @Nullable
private final ResourceLocation baseLocation; private final ResourceLocation baseLocation;
@ -106,7 +111,7 @@ public final class ModelDynBucket implements IModel
} }
@Override @Override
public Collection<ResourceLocation> getTextures() public Collection<ResourceLocation> func_209559_a(Function<ResourceLocation, IUnbakedModel> p_209559_1_, Set<String> p_209559_2_)
{ {
ImmutableSet.Builder<ResourceLocation> builder = ImmutableSet.builder(); ImmutableSet.Builder<ResourceLocation> builder = ImmutableSet.builder();
@ -123,8 +128,13 @@ public final class ModelDynBucket implements IModel
} }
@Override @Override
public IBakedModel bake(IModelState state, VertexFormat format, public Collection<ResourceLocation> getOverrideLocations()
Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) {
return Collections.emptyList();
}
@Override
public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean uvlock, VertexFormat format)
{ {
ImmutableMap<TransformType, TRSRTransformation> transformMap = PerspectiveMapWrapper.getTransforms(state); ImmutableMap<TransformType, TRSRTransformation> transformMap = PerspectiveMapWrapper.getTransforms(state);
@ -144,11 +154,13 @@ public final class ModelDynBucket implements IModel
fluidSprite = bakedTextureGetter.apply(fluid.getStill()); fluidSprite = bakedTextureGetter.apply(fluid.getStill());
} }
Random random = new Random();
if (baseLocation != null) if (baseLocation != null)
{ {
// build base (insidest) // build base (insidest)
IBakedModel model = (new ItemLayerModel(ImmutableList.of(baseLocation))).bake(state, format, bakedTextureGetter); IBakedModel model = (new ItemLayerModel(ImmutableList.of(baseLocation))).bake(modelGetter, bakedTextureGetter, state, uvlock, format);
builder.addAll(model.getQuads(null, null, 0)); random.setSeed(42);
builder.addAll(model.func_200117_a(null, null, random));
particleSprite = model.getParticleTexture(); particleSprite = model.getParticleTexture();
} }
if (liquidLocation != null && fluidSprite != null) if (liquidLocation != null && fluidSprite != null)
@ -243,6 +255,32 @@ public final class ModelDynBucket implements IModel
return new ModelDynBucket(base, liquid, cover, fluid, flipGas, tint); return new ModelDynBucket(base, liquid, cover, fluid, flipGas, tint);
} }
@Nullable
protected static IResource getResource(ResourceLocation resourceLocation)
{
try
{
return Minecraft.getMinecraft().func_195551_G().func_199002_a(resourceLocation);
}
catch (IOException ignored)
{
return null;
}
}
@Nullable
protected static PngSizeInfo getSizeInfo(IResource resource)
{
try
{
return new PngSizeInfo(resource);
}
catch (IOException e)
{
throw new RuntimeException(e);
}
}
public enum LoaderDynBucket implements ICustomModelLoader public enum LoaderDynBucket implements ICustomModelLoader
{ {
INSTANCE; INSTANCE;
@ -254,7 +292,7 @@ public final class ModelDynBucket implements IModel
} }
@Override @Override
public IModel loadModel(ResourceLocation modelLocation) public IUnbakedModel loadModel(ResourceLocation modelLocation)
{ {
return MODEL; return MODEL;
} }
@ -269,31 +307,19 @@ public final class ModelDynBucket implements IModel
{ {
// only create these textures if they are not added by a resource pack // only create these textures if they are not added by a resource pack
IResource res;
if (getResource(new ResourceLocation(ForgeVersion.MOD_ID, "textures/items/bucket_cover.png")) == null) if (getResource(new ResourceLocation(ForgeVersion.MOD_ID, "textures/items/bucket_cover.png")) == null)
{ {
ResourceLocation bucketCover = new ResourceLocation(ForgeVersion.MOD_ID, "items/bucket_cover"); ResourceLocation bucketCover = new ResourceLocation(ForgeVersion.MOD_ID, "items/bucket_cover");
BucketCoverSprite bucketCoverSprite = new BucketCoverSprite(bucketCover); BucketCoverSprite bucketCoverSprite = new BucketCoverSprite(getResource(bucketCover));
map.setTextureEntry(bucketCoverSprite); // map.setTextureEntry(bucketCoverSprite);
} }
if (getResource(new ResourceLocation(ForgeVersion.MOD_ID, "textures/items/bucket_base.png")) == null) if (getResource(new ResourceLocation(ForgeVersion.MOD_ID, "textures/items/bucket_base.png")) == null)
{ {
ResourceLocation bucketBase = new ResourceLocation(ForgeVersion.MOD_ID, "items/bucket_base"); ResourceLocation bucketBase = new ResourceLocation(ForgeVersion.MOD_ID, "items/bucket_base");
BucketBaseSprite bucketBaseSprite = new BucketBaseSprite(bucketBase); BucketBaseSprite bucketBaseSprite = new BucketBaseSprite(getResource(bucketBase));
map.setTextureEntry(bucketBaseSprite); // map.setTextureEntry(bucketBaseSprite);
}
}
@Nullable
protected static IResource getResource(ResourceLocation resourceLocation)
{
try
{
return Minecraft.getMinecraft().getResourceManager().getResource(resourceLocation);
}
catch (IOException ignored)
{
return null;
} }
} }
} }
@ -303,11 +329,12 @@ public final class ModelDynBucket implements IModel
private final ResourceLocation bucket = new ResourceLocation("items/bucket_empty"); private final ResourceLocation bucket = new ResourceLocation("items/bucket_empty");
private final ImmutableList<ResourceLocation> dependencies = ImmutableList.of(bucket); private final ImmutableList<ResourceLocation> dependencies = ImmutableList.of(bucket);
private BucketBaseSprite(ResourceLocation resourceLocation) private BucketBaseSprite(IResource resource)
{ {
super(resourceLocation.toString()); super(resource.func_199029_a(), getSizeInfo(resource), resource.func_199028_a(AnimationMetadataSection.field_195817_a));
} }
/* TODO Custom TAS
@Override @Override
public boolean hasCustomLoader(@Nonnull IResourceManager manager, @Nonnull ResourceLocation location) public boolean hasCustomLoader(@Nonnull IResourceManager manager, @Nonnull ResourceLocation location)
{ {
@ -324,13 +351,15 @@ public final class ModelDynBucket implements IModel
public boolean load(@Nonnull IResourceManager manager, @Nonnull ResourceLocation location, @Nonnull Function<ResourceLocation, TextureAtlasSprite> textureGetter) public boolean load(@Nonnull IResourceManager manager, @Nonnull ResourceLocation location, @Nonnull Function<ResourceLocation, TextureAtlasSprite> textureGetter)
{ {
final TextureAtlasSprite sprite = textureGetter.apply(bucket); final TextureAtlasSprite sprite = textureGetter.apply(bucket);
// TODO custom sprites are gonna be a PITA, these are final
width = sprite.getIconWidth(); width = sprite.getIconWidth();
height = sprite.getIconHeight(); height = sprite.getIconHeight();
// TODO No easy way to dump pixels of one sprite into another without n^2 for loop, investigate patch?
final int[][] pixels = sprite.getFrameTextureData(0); final int[][] pixels = sprite.getFrameTextureData(0);
this.clearFramesTextureData(); this.clearFramesTextureData();
this.framesTextureData.add(pixels); this.framesTextureData.add(pixels);
return false; return false;
} }*/
} }
/** /**
@ -342,11 +371,12 @@ public final class ModelDynBucket implements IModel
private final ResourceLocation bucketCoverMask = new ResourceLocation(ForgeVersion.MOD_ID, "items/vanilla_bucket_cover_mask"); private final ResourceLocation bucketCoverMask = new ResourceLocation(ForgeVersion.MOD_ID, "items/vanilla_bucket_cover_mask");
private final ImmutableList<ResourceLocation> dependencies = ImmutableList.of(bucket, bucketCoverMask); private final ImmutableList<ResourceLocation> dependencies = ImmutableList.of(bucket, bucketCoverMask);
private BucketCoverSprite(ResourceLocation resourceLocation) private BucketCoverSprite(IResource resource)
{ {
super(resourceLocation.toString()); super(resource.func_199029_a(), getSizeInfo(resource), resource.func_199028_a(AnimationMetadataSection.field_195817_a));
} }
/* TODO Custom TAS
@Override @Override
public boolean hasCustomLoader(@Nonnull IResourceManager manager, @Nonnull ResourceLocation location) public boolean hasCustomLoader(@Nonnull IResourceManager manager, @Nonnull ResourceLocation location)
{ {
@ -374,7 +404,7 @@ public final class ModelDynBucket implements IModel
IResource mask = getResource(new ResourceLocation(ForgeVersion.MOD_ID, "textures/items/vanilla_bucket_cover_mask.png")) IResource mask = getResource(new ResourceLocation(ForgeVersion.MOD_ID, "textures/items/vanilla_bucket_cover_mask.png"))
) { ) {
// use the alpha mask if it fits, otherwise leave the cover texture blank // use the alpha mask if it fits, otherwise leave the cover texture blank
if (empty != null && mask != null && Objects.equals(empty.getResourcePackName(), mask.getResourcePackName()) && if (empty != null && mask != null && Objects.equals(empty.func_199026_d(), mask.func_199026_d()) &&
alphaMask.getIconWidth() == width && alphaMask.getIconHeight() == height) alphaMask.getIconWidth() == width && alphaMask.getIconHeight() == height)
{ {
final int[][] oldPixels = sprite.getFrameTextureData(0); final int[][] oldPixels = sprite.getFrameTextureData(0);
@ -398,19 +428,16 @@ public final class ModelDynBucket implements IModel
this.clearFramesTextureData(); this.clearFramesTextureData();
this.framesTextureData.add(pixels); this.framesTextureData.add(pixels);
return false; return false;
} }*/
} }
private static final class BakedDynBucketOverrideHandler extends ItemOverrideList private static final class BakedDynBucketOverrideHandler extends ItemOverrideList
{ {
public static final BakedDynBucketOverrideHandler INSTANCE = new BakedDynBucketOverrideHandler(); public static final BakedDynBucketOverrideHandler INSTANCE = new BakedDynBucketOverrideHandler();
private BakedDynBucketOverrideHandler() private BakedDynBucketOverrideHandler() {}
{
super(ImmutableList.of());
}
@Override @Override
public IBakedModel handleItemState(IBakedModel originalModel, ItemStack stack, @Nullable World world, @Nullable EntityLivingBase entity) public IBakedModel func_209581_a(IBakedModel originalModel, ItemStack stack, @Nullable World world, @Nullable EntityLivingBase entity)
{ {
FluidStack fluidStack = FluidUtil.getFluidContained(stack); FluidStack fluidStack = FluidUtil.getFluidContained(stack);
@ -428,11 +455,11 @@ public final class ModelDynBucket implements IModel
if (!model.cache.containsKey(name)) if (!model.cache.containsKey(name))
{ {
IModel parent = model.parent.process(ImmutableMap.of("fluid", name)); IUnbakedModel parent = model.parent.process(ImmutableMap.of("fluid", name));
Function<ResourceLocation, TextureAtlasSprite> textureGetter; Function<ResourceLocation, TextureAtlasSprite> textureGetter;
textureGetter = location -> Minecraft.getMinecraft().getTextureMapBlocks().getAtlasSprite(location.toString()); textureGetter = location -> Minecraft.getMinecraft().getTextureMapBlocks().getAtlasSprite(location.toString());
IBakedModel bakedModel = parent.bake(new SimpleModelState(model.transforms), model.format, textureGetter); IBakedModel bakedModel = parent.bake(ModelLoader.defaultModelGetter(), textureGetter, new SimpleModelState(model.transforms), false, model.format);
model.cache.put(name, bakedModel); model.cache.put(name, bakedModel);
return bakedModel; return bakedModel;
} }

View file

@ -21,9 +21,12 @@ package net.minecraftforge.client.model;
import java.util.function.Function; import java.util.function.Function;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.EnumMap; import java.util.EnumMap;
import java.util.List; import java.util.List;
import java.util.Optional; import java.util.Optional;
import java.util.Random;
import java.util.Set;
import javax.annotation.Nullable; import javax.annotation.Nullable;
import javax.vecmath.Matrix4f; import javax.vecmath.Matrix4f;
@ -32,6 +35,7 @@ import javax.vecmath.Vector4f;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.client.renderer.block.model.BakedQuad; import net.minecraft.client.renderer.block.model.BakedQuad;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType; import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType;
import net.minecraft.client.renderer.block.model.ItemOverrideList; import net.minecraft.client.renderer.block.model.ItemOverrideList;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
@ -62,7 +66,7 @@ import com.google.common.collect.ImmutableSet;
import com.google.gson.JsonElement; import com.google.gson.JsonElement;
import com.google.gson.JsonParser; import com.google.gson.JsonParser;
public final class ModelFluid implements IModel public final class ModelFluid implements IUnbakedModel
{ {
private static final Logger LOGGER = LogManager.getLogger(); private static final Logger LOGGER = LogManager.getLogger();
public static final ModelFluid WATER = new ModelFluid(FluidRegistry.WATER); public static final ModelFluid WATER = new ModelFluid(FluidRegistry.WATER);
@ -76,7 +80,7 @@ public final class ModelFluid implements IModel
} }
@Override @Override
public Collection<ResourceLocation> getTextures() public Collection<ResourceLocation> func_209559_a(Function<ResourceLocation, IUnbakedModel> modelGetter, Set<String> p_209559_2_)
{ {
return fluid.getOverlay() != null return fluid.getOverlay() != null
? ImmutableSet.of(fluid.getStill(), fluid.getFlowing(), fluid.getOverlay()) ? ImmutableSet.of(fluid.getStill(), fluid.getFlowing(), fluid.getOverlay())
@ -84,7 +88,12 @@ public final class ModelFluid implements IModel
} }
@Override @Override
public IBakedModel bake(IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) public Collection<ResourceLocation> getOverrideLocations() {
return Collections.emptyList();
}
@Override
public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean uvlock, VertexFormat format)
{ {
return new CachingBakedFluid( return new CachingBakedFluid(
state.apply(Optional.empty()), state.apply(Optional.empty()),
@ -116,7 +125,7 @@ public final class ModelFluid implements IModel
} }
@Override @Override
public IModel loadModel(ResourceLocation modelLocation) public IUnbakedModel loadModel(ResourceLocation modelLocation)
{ {
return WATER; return WATER;
} }
@ -221,7 +230,7 @@ public final class ModelFluid implements IModel
} }
@Override @Override
public List<BakedQuad> getQuads(@Nullable IBlockState state, @Nullable EnumFacing side, long rand) public List<BakedQuad> func_200117_a(@Nullable IBlockState state, @Nullable EnumFacing side, Random rand)
{ {
if (side != null && state instanceof IExtendedBlockState) if (side != null && state instanceof IExtendedBlockState)
{ {
@ -247,10 +256,10 @@ public final class ModelFluid implements IModel
key <<= 1; key <<= 1;
key |= 1; key |= 1;
return modelCache.getUnchecked(key).getQuads(state, side, rand); return modelCache.getUnchecked(key).func_200117_a(state, side, rand);
} }
return super.getQuads(state, side, rand); return super.func_200117_a(state, side, rand);
} }
} }
@ -442,7 +451,7 @@ public final class ModelFluid implements IModel
break; break;
} }
case NORMAL: case NORMAL:
builder.put(e, (float)side.getFrontOffsetX(), (float)side.getFrontOffsetY(), (float)side.getFrontOffsetZ(), 0f); builder.put(e, (float)side.getXOffset(), (float)side.getYOffset(), (float)side.getZOffset(), 0f);
break; break;
default: default:
builder.put(e); builder.put(e);
@ -476,7 +485,7 @@ public final class ModelFluid implements IModel
} }
@Override @Override
public List<BakedQuad> getQuads(@Nullable IBlockState state, @Nullable EnumFacing side, long rand) public List<BakedQuad> func_200117_a(@Nullable IBlockState state, @Nullable EnumFacing side, Random rand)
{ {
return side == null ? ImmutableList.of() : faceQuads.get(side); return side == null ? ImmutableList.of() : faceQuads.get(side);
} }

View file

@ -22,12 +22,17 @@ package net.minecraftforge.client.model;
import java.awt.Color; import java.awt.Color;
import java.awt.Graphics2D; import java.awt.Graphics2D;
import java.awt.image.BufferedImage; import java.awt.image.BufferedImage;
import java.io.IOException;
import java.io.InputStreamReader;
import java.nio.charset.StandardCharsets;
import java.util.ArrayList; import java.util.ArrayList;
import java.util.Collection; import java.util.Collection;
import java.util.Comparator; import java.util.Comparator;
import java.util.HashSet;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Map.Entry; import java.util.Map.Entry;
import java.util.NoSuchElementException;
import java.util.Set; import java.util.Set;
import java.util.concurrent.TimeUnit; import java.util.concurrent.TimeUnit;
@ -42,7 +47,9 @@ import net.minecraft.client.renderer.block.model.BlockPart;
import net.minecraft.client.renderer.block.model.BlockPartFace; import net.minecraft.client.renderer.block.model.BlockPartFace;
import net.minecraft.client.renderer.block.model.BlockPartRotation; import net.minecraft.client.renderer.block.model.BlockPartRotation;
import net.minecraft.client.renderer.block.model.BuiltInModel; import net.minecraft.client.renderer.block.model.BuiltInModel;
import net.minecraft.client.renderer.block.model.FaceBakery;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ItemCameraTransforms; import net.minecraft.client.renderer.block.model.ItemCameraTransforms;
import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType; import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType;
import net.minecraft.client.renderer.block.model.ItemModelGenerator; import net.minecraft.client.renderer.block.model.ItemModelGenerator;
@ -50,7 +57,9 @@ import net.minecraft.client.renderer.block.model.ItemOverrideList;
import net.minecraft.client.renderer.block.model.ModelBakery; import net.minecraft.client.renderer.block.model.ModelBakery;
import net.minecraft.client.renderer.block.model.ModelBlock; import net.minecraft.client.renderer.block.model.ModelBlock;
import net.minecraft.client.renderer.block.model.ModelBlockDefinition; import net.minecraft.client.renderer.block.model.ModelBlockDefinition;
import net.minecraft.client.renderer.block.model.ModelBlockDefinition.ContainerHolder;
import net.minecraft.client.renderer.block.model.ModelResourceLocation; import net.minecraft.client.renderer.block.model.ModelResourceLocation;
import net.minecraft.client.renderer.block.model.ModelRotation;
import net.minecraft.client.renderer.block.model.MultipartBakedModel; import net.minecraft.client.renderer.block.model.MultipartBakedModel;
import net.minecraft.client.renderer.block.model.SimpleBakedModel; import net.minecraft.client.renderer.block.model.SimpleBakedModel;
import net.minecraft.client.renderer.block.model.Variant; import net.minecraft.client.renderer.block.model.Variant;
@ -58,12 +67,14 @@ import net.minecraft.client.renderer.block.model.VariantList;
import net.minecraft.client.renderer.block.model.WeightedBakedModel; import net.minecraft.client.renderer.block.model.WeightedBakedModel;
import net.minecraft.client.renderer.block.model.multipart.Multipart; import net.minecraft.client.renderer.block.model.multipart.Multipart;
import net.minecraft.client.renderer.block.model.multipart.Selector; import net.minecraft.client.renderer.block.model.multipart.Selector;
import net.minecraft.client.renderer.texture.MissingTextureSprite;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
import net.minecraft.client.renderer.texture.TextureMap; import net.minecraft.client.renderer.texture.TextureMap;
import net.minecraft.client.renderer.vertex.DefaultVertexFormats; import net.minecraft.client.renderer.vertex.DefaultVertexFormats;
import net.minecraft.client.renderer.vertex.VertexFormat; import net.minecraft.client.renderer.vertex.VertexFormat;
import net.minecraft.item.Item; import net.minecraft.item.Item;
import net.minecraft.resources.IResourceManager; import net.minecraft.resources.IResourceManager;
import net.minecraft.state.StateContainer;
import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumFacing;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraft.util.registry.IRegistry; import net.minecraft.util.registry.IRegistry;
@ -90,6 +101,7 @@ import com.google.common.base.Joiner;
import com.google.common.base.Objects; import com.google.common.base.Objects;
import com.google.common.base.Preconditions; import com.google.common.base.Preconditions;
import java.util.Optional; import java.util.Optional;
import java.util.Random;
import java.util.stream.Collectors; import java.util.stream.Collectors;
import java.util.stream.StreamSupport; import java.util.stream.StreamSupport;
@ -115,13 +127,13 @@ import static net.minecraftforge.fml.Logging.MODELLOADING;
public final class ModelLoader extends ModelBakery public final class ModelLoader extends ModelBakery
{ {
private static final Logger LOGGER = LogManager.getLogger(); private static final Logger LOGGER = LogManager.getLogger();
private final Map<ModelResourceLocation, IModel> stateModels = Maps.newHashMap(); private final Map<ModelResourceLocation, IUnbakedModel> stateModels = Maps.newHashMap();
private final Map<ModelResourceLocation, ModelBlockDefinition> multipartDefinitions = Maps.newHashMap(); private final Map<ModelResourceLocation, ModelBlockDefinition> multipartDefinitions = Maps.newHashMap();
private final Map<ModelBlockDefinition, IModel> multipartModels = Maps.newHashMap(); private final Map<ModelBlockDefinition, IUnbakedModel> multipartModels = Maps.newHashMap();
// TODO: nothing adds to missingVariants, remove it? // TODO: nothing adds to missingVariants, remove it?
private final Set<ModelResourceLocation> missingVariants = Sets.newHashSet(); private final Set<ModelResourceLocation> missingVariants = Sets.newHashSet();
private final Map<ResourceLocation, Exception> loadingExceptions = Maps.newHashMap(); private final Map<ResourceLocation, Exception> loadingExceptions = Maps.newHashMap();
private IModel missingModel = null; private IUnbakedModel missingModel = null;
private boolean isLoading = false; private boolean isLoading = false;
public boolean isLoading() public boolean isLoading()
@ -129,41 +141,74 @@ public final class ModelLoader extends ModelBakery
return isLoading; return isLoading;
} }
public ModelLoader(IResourceManager manager, TextureMap map, BlockModelShapes shapes) public ModelLoader(IResourceManager manager, TextureMap map)
{ {
super(manager, map, shapes); super(manager, map);
VanillaLoader.INSTANCE.setLoader(this); VanillaLoader.INSTANCE.setLoader(this);
VariantLoader.INSTANCE.setLoader(this); VariantLoader.INSTANCE.setLoader(this);
ModelLoaderRegistry.clearModelCache(manager); ModelLoaderRegistry.clearModelCache(manager);
} }
// TODO lots of commented code here - we need to reevaluate what exactly this class needs to do in the new system, which is difficult with no mappings. So let's get everything compiling first.
// This code has mostly been ported to 1.13
/*
@Nonnull @Nonnull
@Override @Override
public IRegistry<ModelResourceLocation, IBakedModel> setupModelRegistry() public IRegistry<ModelResourceLocation, IBakedModel> setupModelRegistry()
{ {
Map<ModelResourceLocation, IUnbakedModel> map = Maps.<ModelResourceLocation, IUnbakedModel>newHashMap();
if (ClientModLoader.isErrored()) // skip loading models if we're just going to show a fatal error screen if (ClientModLoader.isErrored()) // skip loading models if we're just going to show a fatal error screen
return bakedRegistry; return bakedRegistry;
isLoading = true; isLoading = true;
loadBlocks();
loadVariantItemModels();
missingModel = ModelLoaderRegistry.getMissingModel(); missingModel = ModelLoaderRegistry.getMissingModel();
stateModels.put(MODEL_MISSING, missingModel); stateModels.put(MODEL_MISSING, missingModel);
final Set<ResourceLocation> textures = Sets.newHashSet(ModelLoaderRegistry.getTextures()); final Set<ResourceLocation> textures = Sets.newHashSet(ModelLoaderRegistry.getTextures());
textures.remove(TextureMap.LOCATION_MISSING_TEXTURE); textures.remove(MissingTextureSprite.func_195675_b());
textures.addAll(LOCATIONS_BUILTIN_TEXTURES); textures.addAll(LOCATIONS_BUILTIN_TEXTURES);
textureMap.loadSprites(resourceManager, map -> textures.forEach(map::registerSprite)); textureMap.func_195426_a(resourceManager, textures);
IBakedModel missingBaked = missingModel.bake(missingModel.getDefaultState(), DefaultVertexFormats.ITEM, DefaultTextureGetter.INSTANCE); field_209607_C.forEach((p_209602_2_, p_209602_3_) -> {
Map<IModel, IBakedModel> bakedModels = Maps.newHashMap(); p_209602_3_.getValidStates().forEach((p_209601_3_) -> {
HashMultimap<IModel, ModelResourceLocation> models = HashMultimap.create(); this.func_209594_a(map, BlockModelShapes.func_209553_a(p_209602_2_, p_209601_3_));
});
});
for(ResourceLocation resourcelocation : Item.REGISTRY.getKeys()) {
this.func_209594_a(map, new ModelResourceLocation(resourcelocation, "inventory"));
}
this.func_209594_a(map, new ModelResourceLocation("minecraft:trident_in_hand#inventory"));
Set<String> set = Sets.<String>newLinkedHashSet();
Set<ResourceLocation> set1 = (Set)map.values().stream().<ResourceLocation>flatMap((p_209595_2_) -> {
return p_209595_2_.func_209559_a(this::func_209597_a, set).stream();
}).collect(Collectors.toSet());
set1.addAll(LOCATIONS_BUILTIN_TEXTURES);
set.forEach((p_209588_0_) -> {
LOGGER.warn("Unable to resolve texture reference: {}", (Object)p_209588_0_);
});
this.textureMap.func_195426_a(this.resourceManager, set1);
map.forEach((p_209599_1_, p_209599_2_) -> {
IBakedModel ibakedmodel = p_209599_2_.func_209558_a(this::func_209597_a, this.textureMap::func_195424_a, ModelRotation.X0_Y0, false);
if (ibakedmodel != null) {
this.bakedRegistry.putObject(p_209599_1_, ibakedmodel);
}
});
return this.bakedRegistry;
IBakedModel missingBaked = missingModel.bake(defaultModelGetter(), defaultTextureGetter(), missingModel.getDefaultState(), false, DefaultVertexFormats.ITEM);
Map<IUnbakedModel, IBakedModel> bakedModels = Maps.newHashMap();
HashMultimap<IUnbakedModel, ModelResourceLocation> models = HashMultimap.create();
Multimaps.invertFrom(Multimaps.forMap(stateModels), models); Multimaps.invertFrom(Multimaps.forMap(stateModels), models);
ProgressBar bakeBar = ProgressManager.push("ModelLoader: baking", models.keySet().size()); ProgressBar bakeBar = ProgressManager.push("ModelLoader: baking", models.keySet().size());
for(IModel model : models.keySet()) for(IUnbakedModel model : models.keySet())
{ {
String modelLocations = "[" + Joiner.on(", ").join(models.get(model)) + "]"; String modelLocations = "[" + Joiner.on(", ").join(models.get(model)) + "]";
bakeBar.step(modelLocations); bakeBar.step(modelLocations);
@ -175,11 +220,11 @@ public final class ModelLoader extends ModelBakery
{ {
try try
{ {
bakedModels.put(model, model.bake(model.getDefaultState(), DefaultVertexFormats.ITEM, DefaultTextureGetter.INSTANCE)); bakedModels.put(model, model.bake(defaultModelGetter(), defaultTextureGetter(), model.getDefaultState(), false, DefaultVertexFormats.ITEM));
} }
catch (Exception e) catch (Exception e)
{ {
LOGGEr.error("Exception baking model for location(s) {}:", modelLocations, e); LOGGER.error("Exception baking model for location(s) {}:", modelLocations, e);
bakedModels.put(model, missingBaked); bakedModels.put(model, missingBaked);
} }
} }
@ -187,22 +232,13 @@ public final class ModelLoader extends ModelBakery
ProgressManager.pop(bakeBar); ProgressManager.pop(bakeBar);
for (Entry<ModelResourceLocation, IModel> e : stateModels.entrySet()) for (Entry<ModelResourceLocation, IUnbakedModel> e : stateModels.entrySet())
{ {
bakedRegistry.putObject(e.getKey(), bakedModels.get(e.getValue())); bakedRegistry.putObject(e.getKey(), bakedModels.get(e.getValue()));
} }
return bakedRegistry; return bakedRegistry;
} }
// NOOP, replaced by dependency resolution
@Override
protected void loadVariantModels() {}
// NOOP, replaced by dependency resolution
@Override
protected void loadMultipartVariantModels() {}
@Override
protected void loadBlocks() protected void loadBlocks()
{ {
List<Block> blocks = StreamSupport.stream(Block.REGISTRY.spliterator(), false) List<Block> blocks = StreamSupport.stream(Block.REGISTRY.spliterator(), false)
@ -211,8 +247,6 @@ public final class ModelLoader extends ModelBakery
.collect(Collectors.toList()); .collect(Collectors.toList());
ProgressBar blockBar = ProgressManager.push("ModelLoader: blocks", blocks.size()); ProgressBar blockBar = ProgressManager.push("ModelLoader: blocks", blocks.size());
BlockStateMapper mapper = this.blockModelShapes.getBlockStateMapper();
for(Block block : blocks) for(Block block : blocks)
{ {
blockBar.step(block.getRegistryName().toString()); blockBar.step(block.getRegistryName().toString());
@ -227,7 +261,7 @@ public final class ModelLoader extends ModelBakery
@Override @Override
protected void registerVariant(@Nullable ModelBlockDefinition definition, ModelResourceLocation location) protected void registerVariant(@Nullable ModelBlockDefinition definition, ModelResourceLocation location)
{ {
IModel model; IUnbakedModel model;
try try
{ {
model = ModelLoaderRegistry.getModel(location); model = ModelLoaderRegistry.getModel(location);
@ -255,19 +289,6 @@ public final class ModelLoader extends ModelBakery
loadingExceptions.put(location, exception); loadingExceptions.put(location, exception);
} }
@Override
protected ModelBlockDefinition getModelBlockDefinition(ResourceLocation location)
{
try
{
return super.getModelBlockDefinition(location);
}
catch (Exception exception)
{
storeException(location, new Exception("Could not load model definition for variant " + location, exception));
}
return new ModelBlockDefinition(new ArrayList<>());
}
@Override @Override
protected void loadItemModels() protected void loadItemModels()
@ -287,7 +308,7 @@ public final class ModelLoader extends ModelBakery
{ {
ResourceLocation file = getItemLocation(s); ResourceLocation file = getItemLocation(s);
ModelResourceLocation memory = getInventoryVariant(s); ModelResourceLocation memory = getInventoryVariant(s);
IModel model = ModelLoaderRegistry.getMissingModel(); IUnbakedModel model = ModelLoaderRegistry.getMissingModel();
Exception exception = null; Exception exception = null;
try try
{ {
@ -315,7 +336,7 @@ public final class ModelLoader extends ModelBakery
} }
ProgressManager.pop(itemBar); ProgressManager.pop(itemBar);
} }
*/
/** /**
* Hooked from ModelBakery, allows using MRLs that don't end with "inventory" for items. * Hooked from ModelBakery, allows using MRLs that don't end with "inventory" for items.
*/ */
@ -328,14 +349,15 @@ public final class ModelLoader extends ModelBakery
return new ModelResourceLocation(s, "inventory"); return new ModelResourceLocation(s, "inventory");
} }
@Override
protected ResourceLocation getModelLocation(ResourceLocation model) protected ResourceLocation getModelLocation(ResourceLocation model)
{ {
return new ResourceLocation(model.getNamespace(), model.getPath() + ".json"); return new ResourceLocation(model.getNamespace(), model.getPath() + ".json");
} }
private final class VanillaModelWrapper implements IModel private final class VanillaModelWrapper implements IUnbakedModel
{ {
private final FaceBakery faceBakery = new FaceBakery();
private final ResourceLocation location; private final ResourceLocation location;
private final ModelBlock model; private final ModelBlock model;
private final boolean uvlock; private final boolean uvlock;
@ -350,7 +372,7 @@ public final class ModelLoader extends ModelBakery
} }
@Override @Override
public Collection<ResourceLocation> getDependencies() public Collection<ResourceLocation> getOverrideLocations()
{ {
Set<ResourceLocation> set = Sets.newHashSet(); Set<ResourceLocation> set = Sets.newHashSet();
for(ResourceLocation dep : model.getOverrideLocations()) for(ResourceLocation dep : model.getOverrideLocations())
@ -362,7 +384,7 @@ public final class ModelLoader extends ModelBakery
stateModels.put(getInventoryVariant(dep.toString()), ModelLoaderRegistry.getModelOrLogError(dep, "Could not load override model " + dep + " for model " + location)); stateModels.put(getInventoryVariant(dep.toString()), ModelLoaderRegistry.getModelOrLogError(dep, "Could not load override model " + dep + " for model " + location));
} }
} }
if(model.getParentLocation() != null && !model.getParentLocation().getResourcePath().startsWith("builtin/")) if(model.getParentLocation() != null && !model.getParentLocation().getPath().startsWith("builtin/"))
{ {
set.add(model.getParentLocation()); set.add(model.getParentLocation());
} }
@ -370,18 +392,18 @@ public final class ModelLoader extends ModelBakery
} }
@Override @Override
public Collection<ResourceLocation> getTextures() public Collection<ResourceLocation> func_209559_a(Function<ResourceLocation, IUnbakedModel> p_209559_1_, Set<String> p_209559_2_)
{ {
// setting parent here to make textures resolve properly // setting parent here to make textures resolve properly
if(model.getParentLocation() != null) if(model.getParentLocation() != null)
{ {
if(model.getParentLocation().getResourcePath().equals("builtin/generated")) if(model.getParentLocation().getPath().equals("builtin/generated"))
{ {
model.parent = MODEL_GENERATED; model.parent = MODEL_GENERATED;
} }
else else
{ {
IModel parent = ModelLoaderRegistry.getModelOrLogError(model.getParentLocation(), "Could not load vanilla model parent '" + model.getParentLocation() + "' for '" + model); IUnbakedModel parent = ModelLoaderRegistry.getModelOrLogError(model.getParentLocation(), "Could not load vanilla model parent '" + model.getParentLocation() + "' for '" + model);
if(parent instanceof VanillaModelWrapper) if(parent instanceof VanillaModelWrapper)
{ {
model.parent = ((VanillaModelWrapper) parent).model; model.parent = ((VanillaModelWrapper) parent).model;
@ -395,7 +417,7 @@ public final class ModelLoader extends ModelBakery
ImmutableSet.Builder<ResourceLocation> builder = ImmutableSet.builder(); ImmutableSet.Builder<ResourceLocation> builder = ImmutableSet.builder();
if(hasItemModel(model)) if(model == ModelBakery.MODEL_GENERATED)
{ {
for(String s : ItemModelGenerator.LAYERS) for(String s : ItemModelGenerator.LAYERS)
{ {
@ -418,19 +440,19 @@ public final class ModelLoader extends ModelBakery
} }
@Override @Override
public IBakedModel bake(IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean uvlock, VertexFormat format)
{ {
return VanillaLoader.INSTANCE.modelCache.getUnchecked(new BakedModelCacheKey(this, state, format, bakedTextureGetter)); return VanillaLoader.INSTANCE.modelCache.getUnchecked(new BakedModelCacheKey(this, modelGetter, bakedTextureGetter, state, uvlock, format));
} }
public IBakedModel bakeImpl(IModelState state, final VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) public IBakedModel bakeImpl(Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean uvlock, VertexFormat format)
{ {
if(!Attributes.moreSpecific(format, Attributes.DEFAULT_BAKED_FORMAT)) if(!Attributes.moreSpecific(format, Attributes.DEFAULT_BAKED_FORMAT))
{ {
throw new IllegalArgumentException("can't bake vanilla models to the format that doesn't fit into the default one: " + format); throw new IllegalArgumentException("can't bake vanilla models to the format that doesn't fit into the default one: " + format);
} }
ModelBlock model = this.model; ModelBlock model = this.model;
if(model == null) return getMissingModel().bake(getMissingModel().getDefaultState(), format, bakedTextureGetter); if(model == null) return getMissingModel().bake(modelGetter, bakedTextureGetter, getMissingModel().getDefaultState(), uvlock, format);
List<TRSRTransformation> newTransforms = Lists.newArrayList(); List<TRSRTransformation> newTransforms = Lists.newArrayList();
for(int i = 0; i < model.getElements().size(); i++) for(int i = 0; i < model.getElements().size(); i++)
@ -445,19 +467,19 @@ public final class ModelLoader extends ModelBakery
tMap.putAll(PerspectiveMapWrapper.getTransforms(state)); tMap.putAll(PerspectiveMapWrapper.getTransforms(state));
IModelState perState = new SimpleModelState(ImmutableMap.copyOf(tMap)); IModelState perState = new SimpleModelState(ImmutableMap.copyOf(tMap));
if(hasItemModel(model)) if(model == ModelBakery.MODEL_GENERATED)
{ {
return new ItemLayerModel(model).bake(perState, format, bakedTextureGetter); return new ItemLayerModel(model).bake(modelGetter, bakedTextureGetter, perState, uvlock, format);
} }
if(isCustomRenderer(model)) return new BuiltInModel(transforms, model.createOverrides()); if(model == ModelBakery.MODEL_ENTITY) return new BuiltInModel(transforms, model.func_209568_a(model, modelGetter, bakedTextureGetter));
return bakeNormal(model, perState, state, newTransforms, format, bakedTextureGetter, uvlock); return bakeNormal(model, perState, state, newTransforms, format, modelGetter, bakedTextureGetter, uvlock);
} }
private IBakedModel bakeNormal(ModelBlock model, IModelState perState, final IModelState modelState, List<TRSRTransformation> newTransforms, final VertexFormat format, final Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, boolean uvLocked) private IBakedModel bakeNormal(ModelBlock model, IModelState perState, final IModelState modelState, List<TRSRTransformation> newTransforms, final VertexFormat format, final Function<ResourceLocation, IUnbakedModel> modelGetter, final Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, boolean uvLocked)
{ {
final TRSRTransformation baseState = modelState.apply(Optional.empty()).orElse(TRSRTransformation.identity()); final TRSRTransformation baseState = modelState.apply(Optional.empty()).orElse(TRSRTransformation.identity());
TextureAtlasSprite particle = bakedTextureGetter.apply(new ResourceLocation(model.resolveTextureName("particle"))); TextureAtlasSprite particle = bakedTextureGetter.apply(new ResourceLocation(model.resolveTextureName("particle")));
SimpleBakedModel.Builder builder = (new SimpleBakedModel.Builder(model, model.createOverrides())).setTexture(particle); SimpleBakedModel.Builder builder = (new SimpleBakedModel.Builder(model, model.func_209568_a(model, modelGetter, bakedTextureGetter))).setTexture(particle);
for(int i = 0; i < model.getElements().size(); i++) for(int i = 0; i < model.getElements().size(); i++)
{ {
if(modelState.apply(Optional.of(Models.getHiddenModelPart(ImmutableList.of(Integer.toString(i))))).isPresent()) if(modelState.apply(Optional.of(Models.getHiddenModelPart(ImmutableList.of(Integer.toString(i))))).isPresent())
@ -479,11 +501,11 @@ public final class ModelLoader extends ModelBakery
if (e.getValue().cullFace == null || !TRSRTransformation.isInteger(transformation.getMatrix())) if (e.getValue().cullFace == null || !TRSRTransformation.isInteger(transformation.getMatrix()))
{ {
builder.addGeneralQuad(makeBakedQuad(part, e.getValue(), textureatlassprite1, e.getKey(), transformation, uvLocked)); builder.addGeneralQuad(ModelBlock.makeBakedQuad(part, e.getValue(), textureatlassprite1, e.getKey(), transformation, uvLocked));
} }
else else
{ {
builder.addFaceQuad(baseState.rotate(e.getValue().cullFace), makeBakedQuad(part, e.getValue(), textureatlassprite1, e.getKey(), transformation, uvLocked)); builder.addFaceQuad(baseState.rotate(e.getValue().cullFace), ModelBlock.makeBakedQuad(part, e.getValue(), textureatlassprite1, e.getKey(), transformation, uvLocked));
} }
} }
} }
@ -493,7 +515,7 @@ public final class ModelLoader extends ModelBakery
private final ItemOverrideList overrides = new AnimationItemOverrideList(VanillaModelWrapper.this, modelState, format, bakedTextureGetter, super.getOverrides()); private final ItemOverrideList overrides = new AnimationItemOverrideList(VanillaModelWrapper.this, modelState, format, bakedTextureGetter, super.getOverrides());
@Override @Override
public List<BakedQuad> getQuads(@Nullable IBlockState state, @Nullable EnumFacing side, long rand) public List<BakedQuad> func_200117_a(@Nullable IBlockState state, @Nullable EnumFacing side, Random rand)
{ {
if(state instanceof IExtendedBlockState) if(state instanceof IExtendedBlockState)
{ {
@ -504,11 +526,11 @@ public final class ModelLoader extends ModelBakery
IExtendedBlockState newExState = exState.withProperty(Properties.AnimationProperty, null); IExtendedBlockState newExState = exState.withProperty(Properties.AnimationProperty, null);
if(newState != null) if(newState != null)
{ {
return VanillaModelWrapper.this.bake(new ModelStateComposition(modelState, newState), format, bakedTextureGetter).getQuads(newExState, side, rand); return VanillaModelWrapper.this.bake(modelGetter, bakedTextureGetter, new ModelStateComposition(modelState, newState), uvlock, format).func_200117_a(newExState, side, rand);
} }
} }
} }
return super.getQuads(state, side, rand); return super.func_200117_a(state, side, rand);
} }
@Override @Override
@ -609,24 +631,14 @@ public final class ModelLoader extends ModelBakery
newModel.name = model.name; newModel.name = model.name;
return new VanillaModelWrapper(location, newModel, uvlock, animation); return new VanillaModelWrapper(location, newModel, uvlock, animation);
} }
@Override
public IModel uvlock(boolean value)
{
if(uvlock == value)
{
return this;
}
return new VanillaModelWrapper(location, model, value, animation);
}
} }
private static final class WeightedRandomModel implements IModel private static final class WeightedRandomModel implements IUnbakedModel
{ {
private final List<Variant> variants; private final List<Variant> variants;
private final List<ResourceLocation> locations; private final List<ResourceLocation> locations;
private final Set<ResourceLocation> textures; private final Set<ResourceLocation> textures;
private final List<IModel> models; private final List<IUnbakedModel> models;
private final IModelState defaultState; private final IModelState defaultState;
public WeightedRandomModel(ResourceLocation parent, VariantList variants) throws Exception public WeightedRandomModel(ResourceLocation parent, VariantList variants) throws Exception
@ -635,7 +647,7 @@ public final class ModelLoader extends ModelBakery
this.locations = new ArrayList<>(); this.locations = new ArrayList<>();
this.textures = Sets.newHashSet(); this.textures = Sets.newHashSet();
this.models = new ArrayList<>(); this.models = new ArrayList<>();
ImmutableList.Builder<Pair<IModel, IModelState>> builder = ImmutableList.builder(); ImmutableList.Builder<Pair<IUnbakedModel, IModelState>> builder = ImmutableList.builder();
for (Variant v : this.variants) for (Variant v : this.variants)
{ {
ResourceLocation loc = v.getModelLocation(); ResourceLocation loc = v.getModelLocation();
@ -645,7 +657,7 @@ public final class ModelLoader extends ModelBakery
* Vanilla eats this, which makes it only show variants that have models. * Vanilla eats this, which makes it only show variants that have models.
* But that doesn't help debugging, so throw the exception * But that doesn't help debugging, so throw the exception
*/ */
IModel model; IUnbakedModel model;
if(loc.equals(MODEL_MISSING)) if(loc.equals(MODEL_MISSING))
{ {
// explicit missing location, happens if blockstate has "model"=null // explicit missing location, happens if blockstate has "model"=null
@ -658,12 +670,12 @@ public final class ModelLoader extends ModelBakery
// FIXME: is this the place? messes up dependency and texture resolution // FIXME: is this the place? messes up dependency and texture resolution
model = v.process(model); model = v.process(model);
for(ResourceLocation location : model.getDependencies()) for(ResourceLocation location : model.getOverrideLocations())
{ {
ModelLoaderRegistry.getModelOrMissing(location); ModelLoaderRegistry.getModelOrMissing(location);
} }
//FMLLog.getLogger().error("Exception resolving indirect dependencies for model" + loc, e); //FMLLog.getLogger().error("Exception resolving indirect dependencies for model" + loc, e);
textures.addAll(model.getTextures()); // Kick this, just in case. textures.addAll(model.func_209559_a(ModelLoader.defaultModelGetter(), new HashSet<>())); // Kick this, just in case.
models.add(model); models.add(model);
@ -675,7 +687,7 @@ public final class ModelLoader extends ModelBakery
if (models.size() == 0) //If all variants are missing, add one with the missing model and default rotation. if (models.size() == 0) //If all variants are missing, add one with the missing model and default rotation.
{ {
// FIXME: log this? // FIXME: log this?
IModel missing = ModelLoaderRegistry.getMissingModel(); IUnbakedModel missing = ModelLoaderRegistry.getMissingModel();
models.add(missing); models.add(missing);
builder.add(Pair.of(missing, TRSRTransformation.identity())); builder.add(Pair.of(missing, TRSRTransformation.identity()));
} }
@ -683,7 +695,7 @@ public final class ModelLoader extends ModelBakery
defaultState = new MultiModelState(builder.build()); defaultState = new MultiModelState(builder.build());
} }
private WeightedRandomModel(List<Variant> variants, List<ResourceLocation> locations, Set<ResourceLocation> textures, List<IModel> models, IModelState defaultState) private WeightedRandomModel(List<Variant> variants, List<ResourceLocation> locations, Set<ResourceLocation> textures, List<IUnbakedModel> models, IModelState defaultState)
{ {
this.variants = variants; this.variants = variants;
this.locations = locations; this.locations = locations;
@ -693,19 +705,19 @@ public final class ModelLoader extends ModelBakery
} }
@Override @Override
public Collection<ResourceLocation> getDependencies() public Collection<ResourceLocation> getOverrideLocations()
{ {
return ImmutableList.copyOf(locations); return ImmutableList.copyOf(locations);
} }
@Override @Override
public Collection<ResourceLocation> getTextures() public Collection<ResourceLocation> func_209559_a(Function<ResourceLocation, IUnbakedModel> p_209559_1_, Set<String> p_209559_2_)
{ {
return ImmutableSet.copyOf(textures); return ImmutableSet.copyOf(textures);
} }
@Override @Override
public IBakedModel bake(IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean uvlock, VertexFormat format)
{ {
if(!Attributes.moreSpecific(format, Attributes.DEFAULT_BAKED_FORMAT)) if(!Attributes.moreSpecific(format, Attributes.DEFAULT_BAKED_FORMAT))
{ {
@ -713,16 +725,16 @@ public final class ModelLoader extends ModelBakery
} }
if(variants.size() == 1) if(variants.size() == 1)
{ {
IModel model = models.get(0); IUnbakedModel model = models.get(0);
return model.bake(MultiModelState.getPartState(state, model, 0), format, bakedTextureGetter); return model.bake(modelGetter, bakedTextureGetter, MultiModelState.getPartState(state, model, 0), uvlock, format);
} }
WeightedBakedModel.Builder builder = new WeightedBakedModel.Builder(); WeightedBakedModel.Builder builder = new WeightedBakedModel.Builder();
for(int i = 0; i < variants.size(); i++) for(int i = 0; i < variants.size(); i++)
{ {
IModel model = models.get(i); IUnbakedModel model = models.get(i);
builder.add(model.bake(MultiModelState.getPartState(state, model, i), format, bakedTextureGetter), variants.get(i).getWeight()); builder.add(model.bake(modelGetter, bakedTextureGetter, MultiModelState.getPartState(state, model, i), uvlock, format), variants.get(i).getWeight());
} }
return builder.build(); return builder.func_209614_a();
} }
@Override @Override
@ -740,12 +752,12 @@ public final class ModelLoader extends ModelBakery
// rebuild the texture list taking into account new textures // rebuild the texture list taking into account new textures
Set<ResourceLocation> modelTextures = Sets.newHashSet(); Set<ResourceLocation> modelTextures = Sets.newHashSet();
// also recreate the MultiModelState so IModelState data is properly applied to the retextured model // also recreate the MultiModelState so IModelState data is properly applied to the retextured model
ImmutableList.Builder<Pair<IModel, IModelState>> builder = ImmutableList.builder(); ImmutableList.Builder<Pair<IUnbakedModel, IModelState>> builder = ImmutableList.builder();
List<IModel> retexturedModels = Lists.newArrayList(); List<IUnbakedModel> retexturedModels = Lists.newArrayList();
for(int i = 0; i < this.variants.size(); i++) for(int i = 0; i < this.variants.size(); i++)
{ {
IModel retextured = this.models.get(i).retexture(textures); IUnbakedModel retextured = this.models.get(i).retexture(textures);
modelTextures.addAll(retextured.getTextures()); modelTextures.addAll(retextured.func_209559_a(ModelLoader.defaultModelGetter(), new HashSet<>()));
retexturedModels.add(retextured); retexturedModels.add(retextured);
builder.add(Pair.of(retextured, this.variants.get(i).getState())); builder.add(Pair.of(retextured, this.variants.get(i).getState()));
} }
@ -754,7 +766,7 @@ public final class ModelLoader extends ModelBakery
} }
} }
protected IModel getMissingModel() protected IUnbakedModel getMissingModel()
{ {
if (missingModel == null) if (missingModel == null)
{ {
@ -773,16 +785,20 @@ public final class ModelLoader extends ModelBakery
protected final class BakedModelCacheKey protected final class BakedModelCacheKey
{ {
private final VanillaModelWrapper model; private final VanillaModelWrapper model;
private final IModelState state; private final Function<ResourceLocation, IUnbakedModel> modelGetter;
private final VertexFormat format;
private final Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter; private final Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter;
private final IModelState state;
private final boolean uvlock;
private final VertexFormat format;
public BakedModelCacheKey(VanillaModelWrapper model, IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) public BakedModelCacheKey(VanillaModelWrapper model, Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean uvlock, VertexFormat format)
{ {
this.model = model; this.model = model;
this.state = state; this.modelGetter = modelGetter;
this.format = format;
this.bakedTextureGetter = bakedTextureGetter; this.bakedTextureGetter = bakedTextureGetter;
this.state = state;
this.uvlock = uvlock;
this.format = format;
} }
@Override @Override
@ -797,7 +813,7 @@ public final class ModelLoader extends ModelBakery
return false; return false;
} }
BakedModelCacheKey that = (BakedModelCacheKey) o; BakedModelCacheKey that = (BakedModelCacheKey) o;
return Objects.equal(model, that.model) && Objects.equal(state, that.state) && Objects.equal(format, that.format) && Objects.equal(bakedTextureGetter, that.bakedTextureGetter); return Objects.equal(model, that.model) && Objects.equal(modelGetter, that.modelGetter) && Objects.equal(bakedTextureGetter, that.bakedTextureGetter) && Objects.equal(state, that.state) && uvlock == that.uvlock && Objects.equal(format, that.format);
} }
@Override @Override
@ -817,7 +833,7 @@ public final class ModelLoader extends ModelBakery
@Override @Override
public IBakedModel load(BakedModelCacheKey key) throws Exception public IBakedModel load(BakedModelCacheKey key) throws Exception
{ {
return key.model.bakeImpl(key.state, key.format, key.bakedTextureGetter); return key.model.bakeImpl(key.modelGetter, key.bakedTextureGetter, key.state, key.uvlock, key.format);
} }
}); });
@ -843,7 +859,7 @@ public final class ModelLoader extends ModelBakery
} }
@Override @Override
public IModel loadModel(ResourceLocation modelLocation) throws Exception public IUnbakedModel loadModel(ResourceLocation modelLocation) throws Exception
{ {
if(modelLocation.equals(MODEL_MISSING) && loader.missingModel != null) if(modelLocation.equals(MODEL_MISSING) && loader.missingModel != null)
{ {
@ -857,7 +873,7 @@ public final class ModelLoader extends ModelBakery
ResourceLocation armatureLocation = new ResourceLocation(modelLocation.getNamespace(), "armatures/" + modelPath + ".json"); ResourceLocation armatureLocation = new ResourceLocation(modelLocation.getNamespace(), "armatures/" + modelPath + ".json");
ModelBlockAnimation animation = ModelBlockAnimation.loadVanillaAnimation(loader.resourceManager, armatureLocation); ModelBlockAnimation animation = ModelBlockAnimation.loadVanillaAnimation(loader.resourceManager, armatureLocation);
ModelBlock model = loader.loadModel(modelLocation); ModelBlock model = loader.loadModel(modelLocation);
IModel iModel = loader.new VanillaModelWrapper(modelLocation, model, false, animation); IUnbakedModel iModel = loader.new VanillaModelWrapper(modelLocation, model, false, animation);
if(loader.missingModel == null && modelLocation.equals(MODEL_MISSING)) if(loader.missingModel == null && modelLocation.equals(MODEL_MISSING))
{ {
loader.missingModel = iModel; loader.missingModel = iModel;
@ -872,9 +888,16 @@ public final class ModelLoader extends ModelBakery
} }
} }
// Temporary to compile things
public static final class White {
public static final ResourceLocation LOCATION = new ResourceLocation("white");
public static final TextureAtlasSprite INSTANCE = MissingTextureSprite.func_195677_a();
}
/** /**
* 16x16 pure white sprite. * 16x16 pure white sprite.
*/ */
/*/ TODO Custom TAS
public static final class White extends TextureAtlasSprite public static final class White extends TextureAtlasSprite
{ {
public static final ResourceLocation LOCATION = new ResourceLocation("white"); public static final ResourceLocation LOCATION = new ResourceLocation("white");
@ -912,7 +935,7 @@ public final class ModelLoader extends ModelBakery
map.setTextureEntry(White.INSTANCE); map.setTextureEntry(White.INSTANCE);
} }
} }
*/
@SuppressWarnings("serial") @SuppressWarnings("serial")
public static class ItemLoadingException extends ModelLoaderRegistry.LoaderException public static class ItemLoadingException extends ModelLoaderRegistry.LoaderException
{ {
@ -938,7 +961,7 @@ public final class ModelLoader extends ModelBakery
// ignoring pure ResourceLocation arguments, all things we care about pass ModelResourceLocation // ignoring pure ResourceLocation arguments, all things we care about pass ModelResourceLocation
if(entry.getKey() instanceof ModelResourceLocation) if(entry.getKey() instanceof ModelResourceLocation)
{ {
LOGGER.debug(MODELLOADING, ()-> new ModelLoaderErrorMessage((ModelResourceLocation)entry.getKey(), entry.getValue(), modelRegistry, this.blockModelShapes, this::getVariantNames)); LOGGER.debug(MODELLOADING, ()-> new ModelLoaderErrorMessage((ModelResourceLocation)entry.getKey(), entry.getValue()));
final ModelResourceLocation location = (ModelResourceLocation)entry.getKey(); final ModelResourceLocation location = (ModelResourceLocation)entry.getKey();
final IBakedModel model = modelRegistry.getObject(location); final IBakedModel model = modelRegistry.getObject(location);
if(model == null) if(model == null)
@ -952,7 +975,7 @@ public final class ModelLoader extends ModelBakery
IBakedModel model = modelRegistry.getObject(missing); IBakedModel model = modelRegistry.getObject(missing);
if(model == null || model == missingModel) if(model == null || model == missingModel)
{ {
LOGGER.debug(MODELLOADING, ()-> new ModelLoaderErrorMessage(missing, null, modelRegistry, this.blockModelShapes, this::getVariantNames)); LOGGER.debug(MODELLOADING, ()-> new ModelLoaderErrorMessage(missing, null));
} }
if(model == null) if(model == null)
{ {
@ -964,11 +987,13 @@ public final class ModelLoader extends ModelBakery
isLoading = false; isLoading = false;
} }
/*
// TODO replace these if necessary, IStateMapper and ItemMeshDefinition are gone
private static final Map<IRegistryDelegate<Block>, IStateMapper> customStateMappers = Maps.newHashMap(); private static final Map<IRegistryDelegate<Block>, IStateMapper> customStateMappers = Maps.newHashMap();
/** /**
* Adds a custom IBlockState -> model variant logic. * Adds a custom IBlockState -> model variant logic.
*/ *//*
public static void setCustomStateMapper(Block block, IStateMapper mapper) public static void setCustomStateMapper(Block block, IStateMapper mapper)
{ {
customStateMappers.put(block.delegate, mapper); customStateMappers.put(block.delegate, mapper);
@ -976,7 +1001,7 @@ public final class ModelLoader extends ModelBakery
/** /**
* Internal, do not use. * Internal, do not use.
*/ *//*
public static void onRegisterAllBlocks(BlockModelShapes shapes) public static void onRegisterAllBlocks(BlockModelShapes shapes)
{ {
for (Entry<IRegistryDelegate<Block>, IStateMapper> e : customStateMappers.entrySet()) for (Entry<IRegistryDelegate<Block>, IStateMapper> e : customStateMappers.entrySet())
@ -991,7 +1016,7 @@ public final class ModelLoader extends ModelBakery
/** /**
* Adds a simple mapping from Item + metadata to the model variant. * Adds a simple mapping from Item + metadata to the model variant.
* Registers the variant with the ModelBakery too. * Registers the variant with the ModelBakery too.
*/ *//*
public static void setCustomModelResourceLocation(Item item, int metadata, ModelResourceLocation model) public static void setCustomModelResourceLocation(Item item, int metadata, ModelResourceLocation model)
{ {
customModels.put(Pair.of(item.delegate, metadata), model); customModels.put(Pair.of(item.delegate, metadata), model);
@ -1001,7 +1026,7 @@ public final class ModelLoader extends ModelBakery
/** /**
* Adds generic ItemStack -> model variant logic. * Adds generic ItemStack -> model variant logic.
* You still need to manually call ModelBakery.registerItemVariants with all values that meshDefinition can return. * You still need to manually call ModelBakery.registerItemVariants with all values that meshDefinition can return.
*/ *//*
public static void setCustomMeshDefinition(Item item, ItemMeshDefinition meshDefinition) public static void setCustomMeshDefinition(Item item, ItemMeshDefinition meshDefinition)
{ {
customMeshDefinitions.put(item.delegate, meshDefinition); customMeshDefinitions.put(item.delegate, meshDefinition);
@ -1009,7 +1034,7 @@ public final class ModelLoader extends ModelBakery
/** /**
* Helper method for registering all itemstacks for given item to map to universal bucket model. * Helper method for registering all itemstacks for given item to map to universal bucket model.
*/ *//*
public static void setBucketModelDefinition(Item item) { public static void setBucketModelDefinition(Item item) {
ModelLoader.setCustomMeshDefinition(item, stack -> ModelDynBucket.LOCATION); ModelLoader.setCustomMeshDefinition(item, stack -> ModelDynBucket.LOCATION);
ModelBakery.registerItemVariants(item, ModelDynBucket.LOCATION); ModelBakery.registerItemVariants(item, ModelDynBucket.LOCATION);
@ -1017,19 +1042,15 @@ public final class ModelLoader extends ModelBakery
/** /**
* Internal, do not use. * Internal, do not use.
*/ *//*
public static void onRegisterItems(ItemModelMesher mesher) public static void onRegisterItems(ItemModelMesher mesher)
{ {
for (Map.Entry<IRegistryDelegate<Item>, ItemMeshDefinition> e : customMeshDefinitions.entrySet())
{
mesher.register(e.getKey().get(), e.getValue());
}
for (Entry<Pair<IRegistryDelegate<Item>, Integer>, ModelResourceLocation> e : customModels.entrySet()) for (Entry<Pair<IRegistryDelegate<Item>, Integer>, ModelResourceLocation> e : customModels.entrySet())
{ {
mesher.register(e.getKey().getLeft().get(), e.getKey().getRight(), e.getValue()); mesher.func_199311_a(e.getKey().getLeft().get(), e.getValue());
} }
} }
*/
private static enum DefaultTextureGetter implements Function<ResourceLocation, TextureAtlasSprite> private static enum DefaultTextureGetter implements Function<ResourceLocation, TextureAtlasSprite>
{ {
INSTANCE; INSTANCE;
@ -1041,6 +1062,8 @@ public final class ModelLoader extends ModelBakery
} }
} }
private static final Function<ResourceLocation, IUnbakedModel> DEFAULT_MODEL_GETTER = ModelLoaderRegistry::getModelOrMissing;
/** /**
* Get the default texture getter the models will be baked with. * Get the default texture getter the models will be baked with.
*/ */
@ -1049,6 +1072,11 @@ public final class ModelLoader extends ModelBakery
return DefaultTextureGetter.INSTANCE; return DefaultTextureGetter.INSTANCE;
} }
public static Function<ResourceLocation, IUnbakedModel> defaultModelGetter()
{
return DEFAULT_MODEL_GETTER;
}
protected static enum VariantLoader implements ICustomModelLoader protected static enum VariantLoader implements ICustomModelLoader
{ {
INSTANCE; INSTANCE;
@ -1071,30 +1099,9 @@ public final class ModelLoader extends ModelBakery
} }
@Override @Override
public IModel loadModel(ResourceLocation modelLocation) throws Exception public IUnbakedModel loadModel(ResourceLocation modelLocation) throws Exception
{ {
ModelResourceLocation variant = (ModelResourceLocation) modelLocation; return loader.func_209597_a(modelLocation);
ModelBlockDefinition definition = loader.getModelBlockDefinition(variant);
try
{
VariantList variants = definition.getVariant(variant.getVariant());
return new WeightedRandomModel(variant, variants);
}
catch (MissingVariantException e)
{
if (definition.equals(loader.multipartDefinitions.get(variant)))
{
IModel model = loader.multipartModels.get(definition);
if (model == null)
{
model = new MultipartModel(new ResourceLocation(variant.getNamespace(), variant.getPath()), definition.getMultipartData());
loader.multipartModels.put(definition, model);
}
return model;
}
throw e;
}
} }
@Override @Override
@ -1103,61 +1110,4 @@ public final class ModelLoader extends ModelBakery
return "VariantLoader.INSTANCE"; return "VariantLoader.INSTANCE";
} }
} }
private static class MultipartModel implements IModel
{
private final ResourceLocation location;
private final Multipart multipart;
private final ImmutableMap<Selector, IModel> partModels;
public MultipartModel(ResourceLocation location, Multipart multipart) throws Exception
{
this.location = location;
this.multipart = multipart;
ImmutableMap.Builder<Selector, IModel> builder = ImmutableMap.builder();
for (Selector selector : multipart.getSelectors())
{
builder.put(selector, new WeightedRandomModel(location, selector.getVariantList()));
}
partModels = builder.build();
}
private MultipartModel(ResourceLocation location, Multipart multipart, ImmutableMap<Selector, IModel> partModels)
{
this.location = location;
this.multipart = multipart;
this.partModels = partModels;
}
// FIXME: represent selectors as dependencies?
// FIXME
@Override
public IBakedModel bake(IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter)
{
MultipartBakedModel.Builder builder = new MultipartBakedModel.Builder();
for (Selector selector : multipart.getSelectors())
{
builder.putModel(selector.getPredicate(multipart.getStateContainer()), partModels.get(selector).bake(partModels.get(selector).getDefaultState(), format, bakedTextureGetter));
}
IBakedModel bakedModel = builder.makeMultipartModel();
return bakedModel;
}
@Override
public IModel retexture(ImmutableMap<String, String> textures)
{
if (textures.isEmpty())
return this;
ImmutableMap.Builder<Selector, IModel> builder = ImmutableMap.builder();
for (Entry<Selector, IModel> partModel : this.partModels.entrySet())
{
builder.put(partModel.getKey(), partModel.getValue().retexture(textures));
}
return new MultipartModel(location, multipart, builder.build());
}
}
} }

View file

@ -20,13 +20,24 @@
package net.minecraftforge.client.model; package net.minecraftforge.client.model;
import java.util.Deque; import java.util.Deque;
import java.util.HashSet;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import com.google.common.base.Joiner;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.Maps;
import com.google.common.collect.Queues;
import com.google.common.collect.Sets;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ModelResourceLocation; import net.minecraft.client.renderer.block.model.ModelResourceLocation;
import net.minecraft.client.resources.IReloadableResourceManager; import net.minecraft.resources.IReloadableResourceManager;
import net.minecraft.client.resources.IResourceManager; import net.minecraft.resources.IResourceManager;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraftforge.client.model.ModelLoader.VanillaLoader; import net.minecraftforge.client.model.ModelLoader.VanillaLoader;
import net.minecraftforge.client.model.ModelLoader.VariantLoader; import net.minecraftforge.client.model.ModelLoader.VariantLoader;
@ -35,21 +46,16 @@ import net.minecraftforge.client.model.obj.OBJLoader;
import net.minecraftforge.common.animation.ITimeValue; import net.minecraftforge.common.animation.ITimeValue;
import net.minecraftforge.common.model.animation.AnimationStateMachine; import net.minecraftforge.common.model.animation.AnimationStateMachine;
import net.minecraftforge.common.model.animation.IAnimationStateMachine; import net.minecraftforge.common.model.animation.IAnimationStateMachine;
import net.minecraftforge.fml.common.FMLLog;
import com.google.common.base.Joiner;
import com.google.common.collect.ImmutableMap;
import com.google.common.collect.Maps;
import com.google.common.collect.Queues;
import com.google.common.collect.Sets;
/* /*
* Central hub for custom model loaders. * Central hub for custom model loaders.
*/ */
public class ModelLoaderRegistry public class ModelLoaderRegistry
{ {
private static final Logger LOGGER = LogManager.getLogger();
private static final Set<ICustomModelLoader> loaders = Sets.newHashSet(); private static final Set<ICustomModelLoader> loaders = Sets.newHashSet();
private static final Map<ResourceLocation, IModel> cache = Maps.newHashMap(); private static final Map<ResourceLocation, IUnbakedModel> cache = Maps.newHashMap();
private static final Deque<ResourceLocation> loadingModels = Queues.newArrayDeque(); private static final Deque<ResourceLocation> loadingModels = Queues.newArrayDeque();
private static final Set<ResourceLocation> textures = Sets.newHashSet(); private static final Set<ResourceLocation> textures = Sets.newHashSet();
private static final Map<ResourceLocation, ResourceLocation> aliases = Maps.newHashMap(); private static final Map<ResourceLocation, ResourceLocation> aliases = Maps.newHashMap();
@ -73,7 +79,7 @@ public class ModelLoaderRegistry
public static void registerLoader(ICustomModelLoader loader) public static void registerLoader(ICustomModelLoader loader)
{ {
loaders.add(loader); loaders.add(loader);
((IReloadableResourceManager) Minecraft.getMinecraft().getResourceManager()).registerReloadListener(loader); ((IReloadableResourceManager) Minecraft.getMinecraft().func_195551_G()).func_199006_a(loader);
} }
public static boolean loaded(ResourceLocation location) public static boolean loaded(ResourceLocation location)
@ -85,8 +91,8 @@ public class ModelLoaderRegistry
public static ResourceLocation getActualLocation(ResourceLocation location) public static ResourceLocation getActualLocation(ResourceLocation location)
{ {
if(location instanceof ModelResourceLocation) return location; if(location instanceof ModelResourceLocation) return location;
if(location.getResourcePath().startsWith("builtin/")) return location; if(location.getPath().startsWith("builtin/")) return location;
return new ResourceLocation(location.getResourceDomain(), "models/" + location.getResourcePath()); return new ResourceLocation(location.getNamespace(), "models/" + location.getPath());
} }
/** /**
@ -94,11 +100,11 @@ public class ModelLoaderRegistry
* ResourceLocation argument will be passed directly to the custom model loaders, * ResourceLocation argument will be passed directly to the custom model loaders,
* ModelResourceLocation argument will be loaded through the blockstate system. * ModelResourceLocation argument will be loaded through the blockstate system.
*/ */
public static IModel getModel(ResourceLocation location) throws Exception public static IUnbakedModel getModel(ResourceLocation location) throws Exception
{ {
IModel model; IUnbakedModel model;
IModel cached = cache.get(location); IUnbakedModel cached = cache.get(location);
if (cached != null) return cached; if (cached != null) return cached;
for(ResourceLocation loading : loadingModels) for(ResourceLocation loading : loadingModels)
@ -168,7 +174,7 @@ public class ModelLoaderRegistry
{ {
throw new LoaderException(String.format("Loader %s returned null while loading model %s", accepted, location)); throw new LoaderException(String.format("Loader %s returned null while loading model %s", accepted, location));
} }
textures.addAll(model.getTextures()); textures.addAll(model.func_209559_a(ModelLoader.defaultModelGetter(), new HashSet<>()));
} }
finally finally
{ {
@ -179,7 +185,7 @@ public class ModelLoaderRegistry
} }
} }
cache.put(location, model); cache.put(location, model);
for (ResourceLocation dep : model.getDependencies()) for (ResourceLocation dep : model.getOverrideLocations())
{ {
getModelOrMissing(dep); getModelOrMissing(dep);
} }
@ -189,7 +195,7 @@ public class ModelLoaderRegistry
/** /**
* Use this if you don't care about the exception and want some model anyway. * Use this if you don't care about the exception and want some model anyway.
*/ */
public static IModel getModelOrMissing(ResourceLocation location) public static IUnbakedModel getModelOrMissing(ResourceLocation location)
{ {
try try
{ {
@ -204,7 +210,7 @@ public class ModelLoaderRegistry
/** /**
* Use this if you want the model, but need to log the error. * Use this if you want the model, but need to log the error.
*/ */
public static IModel getModelOrLogError(ResourceLocation location, String error) public static IUnbakedModel getModelOrLogError(ResourceLocation location, String error)
{ {
try try
{ {
@ -212,12 +218,12 @@ public class ModelLoaderRegistry
} }
catch(Exception e) catch(Exception e)
{ {
FMLLog.log.error(error, e); LOGGER.error(error, e);
return getMissingModel(location, e); return getMissingModel(location, e);
} }
} }
public static IModel getMissingModel() public static IUnbakedModel getMissingModel()
{ {
final ModelLoader loader = VanillaLoader.INSTANCE.getLoader(); final ModelLoader loader = VanillaLoader.INSTANCE.getLoader();
if(loader == null) if(loader == null)
@ -227,11 +233,11 @@ public class ModelLoaderRegistry
return loader.getMissingModel(); return loader.getMissingModel();
} }
static IModel getMissingModel(ResourceLocation location, Throwable cause) static IUnbakedModel getMissingModel(ResourceLocation location, Throwable cause)
{ {
//IModel model = new FancyMissingModel(ExceptionUtils.getStackTrace(cause).replaceAll("\\t", " ")); //IModel model = new FancyMissingModel(ExceptionUtils.getStackTrace(cause).replaceAll("\\t", " "));
IModel model = new FancyMissingModel(getMissingModel(), location.toString()); IUnbakedModel model = new FancyMissingModel(getMissingModel(), location.toString());
textures.addAll(model.getTextures()); textures.addAll(model.func_209559_a(null, null));
return model; return model;
} }

View file

@ -20,6 +20,7 @@
package net.minecraftforge.client.model; package net.minecraftforge.client.model;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.List; import java.util.List;
import javax.annotation.Nullable; import javax.annotation.Nullable;
@ -28,6 +29,7 @@ import javax.vecmath.Matrix4f;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.client.renderer.block.model.BakedQuad; import net.minecraft.client.renderer.block.model.BakedQuad;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType; import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType;
import net.minecraft.client.renderer.block.model.ItemOverrideList; import net.minecraft.client.renderer.block.model.ItemOverrideList;
import net.minecraft.client.renderer.block.model.ModelResourceLocation; import net.minecraft.client.renderer.block.model.ModelResourceLocation;
@ -48,12 +50,15 @@ import org.apache.logging.log4j.Logger;
import java.util.function.Function; import java.util.function.Function;
import java.util.Optional; import java.util.Optional;
import java.util.Random;
import java.util.Set;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
import com.google.gson.JsonElement; import com.google.gson.JsonElement;
import com.google.gson.JsonParser; import com.google.gson.JsonParser;
public final class MultiLayerModel implements IModel public final class MultiLayerModel implements IUnbakedModel
{ {
private static final Logger LOGGER = LogManager.getLogger(); private static final Logger LOGGER = LogManager.getLogger();
public static final MultiLayerModel INSTANCE = new MultiLayerModel(ImmutableMap.of()); public static final MultiLayerModel INSTANCE = new MultiLayerModel(ImmutableMap.of());
@ -66,29 +71,35 @@ public final class MultiLayerModel implements IModel
} }
@Override @Override
public Collection<ResourceLocation> getDependencies() public Collection<ResourceLocation> getOverrideLocations()
{ {
return ImmutableList.copyOf(models.values()); return ImmutableList.copyOf(models.values());
} }
private static ImmutableMap<Optional<BlockRenderLayer>, IBakedModel> buildModels(ImmutableMap<Optional<BlockRenderLayer>, ModelResourceLocation> models, IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) @Override
public Collection<ResourceLocation> func_209559_a(Function<ResourceLocation, IUnbakedModel> p_209559_1_, Set<String> p_209559_2_)
{
return Collections.emptyList();
}
private static ImmutableMap<Optional<BlockRenderLayer>, IBakedModel> buildModels(ImmutableMap<Optional<BlockRenderLayer>, ModelResourceLocation> models, IModelState state, boolean uvlock, VertexFormat format, Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter)
{ {
ImmutableMap.Builder<Optional<BlockRenderLayer>, IBakedModel> builder = ImmutableMap.builder(); ImmutableMap.Builder<Optional<BlockRenderLayer>, IBakedModel> builder = ImmutableMap.builder();
for(Optional<BlockRenderLayer> key : models.keySet()) for(Optional<BlockRenderLayer> key : models.keySet())
{ {
IModel model = ModelLoaderRegistry.getModelOrLogError(models.get(key), "Couldn't load MultiLayerModel dependency: " + models.get(key)); IUnbakedModel model = ModelLoaderRegistry.getModelOrLogError(models.get(key), "Couldn't load MultiLayerModel dependency: " + models.get(key));
builder.put(key, model.bake(new ModelStateComposition(state, model.getDefaultState()), format, bakedTextureGetter)); builder.put(key, model.bake(modelGetter, bakedTextureGetter, new ModelStateComposition(state, model.getDefaultState()), uvlock, format));
} }
return builder.build(); return builder.build();
} }
@Override @Override
public IBakedModel bake(IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean uvlock, VertexFormat format)
{ {
IModel missing = ModelLoaderRegistry.getMissingModel(); IUnbakedModel missing = ModelLoaderRegistry.getMissingModel();
return new MultiLayerBakedModel( return new MultiLayerBakedModel(
buildModels(models, state, format, bakedTextureGetter), buildModels(models, state, uvlock, format, modelGetter, bakedTextureGetter),
missing.bake(missing.getDefaultState(), format, bakedTextureGetter), missing.bake(modelGetter, bakedTextureGetter, missing.getDefaultState(), uvlock, format),
PerspectiveMapWrapper.getTransforms(state) PerspectiveMapWrapper.getTransforms(state)
); );
} }
@ -143,7 +154,7 @@ public final class MultiLayerModel implements IModel
} }
@Override @Override
public List<BakedQuad> getQuads(@Nullable IBlockState state, @Nullable EnumFacing side, long rand) public List<BakedQuad> func_200117_a(@Nullable IBlockState state, @Nullable EnumFacing side, Random rand)
{ {
BlockRenderLayer layer = MinecraftForgeClient.getRenderLayer(); BlockRenderLayer layer = MinecraftForgeClient.getRenderLayer();
if (layer == null) if (layer == null)
@ -151,12 +162,12 @@ public final class MultiLayerModel implements IModel
ImmutableList.Builder<BakedQuad> builder = ImmutableList.builder(); ImmutableList.Builder<BakedQuad> builder = ImmutableList.builder();
for (IBakedModel model : models.values()) for (IBakedModel model : models.values())
{ {
builder.addAll(model.getQuads(state, side, rand)); builder.addAll(model.func_200117_a(state, side, rand));
} }
return builder.build(); return builder.build();
} }
// assumes that child model will handle this state properly. FIXME? // assumes that child model will handle this state properly. FIXME?
return models.getOrDefault(Optional.of(layer), missing).getQuads(state, side, rand); return models.getOrDefault(Optional.of(layer), missing).func_200117_a(state, side, rand);
} }
@Override @Override
@ -219,7 +230,7 @@ public final class MultiLayerModel implements IModel
} }
@Override @Override
public IModel loadModel(ResourceLocation modelLocation) public IUnbakedModel loadModel(ResourceLocation modelLocation)
{ {
return MultiLayerModel.INSTANCE; return MultiLayerModel.INSTANCE;
} }

View file

@ -24,6 +24,7 @@ import java.util.EnumMap;
import java.util.Iterator; import java.util.Iterator;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Random;
import java.util.Map.Entry; import java.util.Map.Entry;
import java.util.Set; import java.util.Set;
@ -33,6 +34,7 @@ import javax.vecmath.Matrix4f;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.client.renderer.block.model.BakedQuad; import net.minecraft.client.renderer.block.model.BakedQuad;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ItemCameraTransforms; import net.minecraft.client.renderer.block.model.ItemCameraTransforms;
import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType; import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType;
import net.minecraft.client.renderer.block.model.ItemOverrideList; import net.minecraft.client.renderer.block.model.ItemOverrideList;
@ -45,9 +47,10 @@ import net.minecraft.util.ResourceLocation;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraftforge.common.model.IModelState; import net.minecraftforge.common.model.IModelState;
import net.minecraftforge.common.model.TRSRTransformation; import net.minecraftforge.common.model.TRSRTransformation;
import net.minecraftforge.fml.common.FMLLog;
import org.apache.commons.lang3.tuple.Pair; import org.apache.commons.lang3.tuple.Pair;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import java.util.function.Function; import java.util.function.Function;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
@ -57,8 +60,10 @@ import com.google.common.collect.Sets;
// TODO: Switch to vanilla class, or to something similar // TODO: Switch to vanilla class, or to something similar
@Deprecated @Deprecated
public final class MultiModel implements IModel public final class MultiModel implements IUnbakedModel
{ {
private static final Logger LOGGER = LogManager.getLogger();
private static final class Baked implements IBakedModel private static final class Baked implements IBakedModel
{ {
private final ResourceLocation location; private final ResourceLocation location;
@ -68,10 +73,10 @@ public final class MultiModel implements IModel
private final IBakedModel internalBase; private final IBakedModel internalBase;
private final ImmutableMap<TransformType, Pair<Baked, TRSRTransformation>> transforms; private final ImmutableMap<TransformType, Pair<Baked, TRSRTransformation>> transforms;
private final ItemOverrideList overrides = new ItemOverrideList(Lists.newArrayList()) private final ItemOverrideList overrides = new ItemOverrideList()
{ {
@Override @Override
public IBakedModel handleItemState(IBakedModel originalModel, ItemStack stack, @Nullable World world, @Nullable EntityLivingBase entity) public IBakedModel func_209581_a(IBakedModel originalModel, ItemStack stack, @Nullable World world, @Nullable EntityLivingBase entity)
{ {
if(originalModel != Baked.this) if(originalModel != Baked.this)
{ {
@ -82,7 +87,7 @@ public final class MultiModel implements IModel
if(base != null) if(base != null)
{ {
newBase = base.getOverrides().handleItemState(base, stack, world, entity); newBase = base.getOverrides().func_209581_a(base, stack, world, entity);
if(base != newBase) if(base != newBase)
{ {
dirty = true; dirty = true;
@ -91,7 +96,7 @@ public final class MultiModel implements IModel
ImmutableMap.Builder<String, IBakedModel> builder = ImmutableMap.builder(); ImmutableMap.Builder<String, IBakedModel> builder = ImmutableMap.builder();
for(Map.Entry<String, IBakedModel> entry : parts.entrySet()) for(Map.Entry<String, IBakedModel> entry : parts.entrySet())
{ {
IBakedModel newPart = entry.getValue().getOverrides().handleItemState(entry.getValue(), stack, world, entity); IBakedModel newPart = entry.getValue().getOverrides().func_209581_a(entry.getValue(), stack, world, entity);
builder.put(entry.getKey(), newPart); builder.put(entry.getKey(), newPart);
if(entry.getValue() != newPart) if(entry.getValue() != newPart)
{ {
@ -183,16 +188,16 @@ public final class MultiModel implements IModel
} }
@Override @Override
public List<BakedQuad> getQuads(@Nullable IBlockState state, @Nullable EnumFacing side, long rand) public List<BakedQuad> func_200117_a(@Nullable IBlockState state, @Nullable EnumFacing side, Random rand)
{ {
ImmutableList.Builder<BakedQuad> quads = ImmutableList.builder(); ImmutableList.Builder<BakedQuad> quads = ImmutableList.builder();
if (base != null) if (base != null)
{ {
quads.addAll(base.getQuads(state, side, rand)); quads.addAll(base.func_200117_a(state, side, rand));
} }
for (IBakedModel bakedPart : parts.values()) for (IBakedModel bakedPart : parts.values())
{ {
quads.addAll(bakedPart.getQuads(state, side, rand)); quads.addAll(bakedPart.func_200117_a(state, side, rand));
} }
return quads.build(); return quads.build();
} }
@ -214,17 +219,17 @@ public final class MultiModel implements IModel
private final ResourceLocation location; private final ResourceLocation location;
@Nullable @Nullable
private final IModel base; private final IUnbakedModel base;
private final Map<String, Pair<IModel, IModelState>> parts; private final Map<String, Pair<IUnbakedModel, IModelState>> parts;
// TODO 1.13 remove, kept for binary compatibility // TODO 1.13 remove, kept for binary compatibility
@Deprecated @Deprecated
public MultiModel(ResourceLocation location, @Nullable IModel base, IModelState baseState, ImmutableMap<String, Pair<IModel, IModelState>> parts) public MultiModel(ResourceLocation location, @Nullable IUnbakedModel base, IModelState baseState, ImmutableMap<String, Pair<IUnbakedModel, IModelState>> parts)
{ {
this(location, base, parts); this(location, base, parts);
} }
public MultiModel(ResourceLocation location, @Nullable IModel base, ImmutableMap<String, Pair<IModel, IModelState>> parts) public MultiModel(ResourceLocation location, @Nullable IUnbakedModel base, ImmutableMap<String, Pair<IUnbakedModel, IModelState>> parts)
{ {
this.location = location; this.location = location;
this.base = base; this.base = base;
@ -233,65 +238,65 @@ public final class MultiModel implements IModel
// TODO 1.13 remove, kept for binary compatibility // TODO 1.13 remove, kept for binary compatibility
@Deprecated @Deprecated
public MultiModel(ResourceLocation location, IModel base, IModelState baseState, Map<String, Pair<IModel, IModelState>> parts) public MultiModel(ResourceLocation location, IUnbakedModel base, IModelState baseState, Map<String, Pair<IUnbakedModel, IModelState>> parts)
{ {
this(location, base, parts); this(location, base, parts);
} }
public MultiModel(ResourceLocation location, IModel base, Map<String, Pair<IModel, IModelState>> parts) public MultiModel(ResourceLocation location, IUnbakedModel base, Map<String, Pair<IUnbakedModel, IModelState>> parts)
{ {
this(location, base, ImmutableMap.copyOf(parts)); this(location, base, ImmutableMap.copyOf(parts));
} }
@Override @Override
public Collection<ResourceLocation> getDependencies() public Collection<ResourceLocation> getOverrideLocations()
{ {
Set<ResourceLocation> deps = Sets.newHashSet(); Set<ResourceLocation> deps = Sets.newHashSet();
if (base != null) if (base != null)
deps.addAll(base.getDependencies()); deps.addAll(base.getOverrideLocations());
for (Pair<IModel, IModelState> pair : parts.values()) for (Pair<IUnbakedModel, IModelState> pair : parts.values())
deps.addAll(pair.getLeft().getDependencies()); deps.addAll(pair.getLeft().getOverrideLocations());
return deps; return deps;
} }
@Override @Override
public Collection<ResourceLocation> getTextures() public Collection<ResourceLocation> func_209559_a(Function<ResourceLocation, IUnbakedModel> modelGetter, Set<String> missingTextures)
{ {
Set<ResourceLocation> deps = Sets.newHashSet(); Set<ResourceLocation> deps = Sets.newHashSet();
if (base != null) if (base != null)
deps.addAll(base.getTextures()); deps.addAll(base.func_209559_a(modelGetter, missingTextures));
for (Pair<IModel, IModelState> pair : parts.values()) for (Pair<IUnbakedModel, IModelState> pair : parts.values())
deps.addAll(pair.getLeft().getTextures()); deps.addAll(pair.getLeft().func_209559_a(modelGetter, missingTextures));
return deps; return deps;
} }
@Override @Override
public IBakedModel bake(IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean uvlock, VertexFormat format)
{ {
IBakedModel bakedBase = null; IBakedModel bakedBase = null;
if (base != null) if (base != null)
bakedBase = base.bake(state, format, bakedTextureGetter); bakedBase = base.bake(modelGetter, bakedTextureGetter, state, uvlock, format);
ImmutableMap.Builder<String, IBakedModel> mapBuilder = ImmutableMap.builder(); ImmutableMap.Builder<String, IBakedModel> mapBuilder = ImmutableMap.builder();
for (Entry<String, Pair<IModel, IModelState>> entry : parts.entrySet()) for (Entry<String, Pair<IUnbakedModel, IModelState>> entry : parts.entrySet())
{ {
Pair<IModel, IModelState> pair = entry.getValue(); Pair<IUnbakedModel, IModelState> pair = entry.getValue();
mapBuilder.put(entry.getKey(), pair.getLeft().bake(new ModelStateComposition(state, pair.getRight()), format, bakedTextureGetter)); mapBuilder.put(entry.getKey(), pair.getLeft().bake(modelGetter, bakedTextureGetter, new ModelStateComposition(state, pair.getRight()), uvlock, format));
} }
if(bakedBase == null && parts.isEmpty()) if(bakedBase == null && parts.isEmpty())
{ {
FMLLog.log.error("MultiModel {} is empty (no base model or parts were provided/resolved)", location); LOGGER.error("MultiModel {} is empty (no base model or parts were provided/resolved)", location);
IModel missing = ModelLoaderRegistry.getMissingModel(); IUnbakedModel missing = ModelLoaderRegistry.getMissingModel();
return missing.bake(missing.getDefaultState(), format, bakedTextureGetter); return missing.bake(modelGetter, bakedTextureGetter, missing.getDefaultState(), uvlock, format);
} }
return new Baked(location, true, bakedBase, mapBuilder.build()); return new Baked(location, true, bakedBase, mapBuilder.build());
} }

View file

@ -21,6 +21,8 @@ package net.minecraftforge.client.model;
import java.util.EnumMap; import java.util.EnumMap;
import java.util.Optional; import java.util.Optional;
import java.util.Random;
import com.google.common.collect.ImmutableMap; import com.google.common.collect.ImmutableMap;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.client.renderer.block.model.BakedQuad; import net.minecraft.client.renderer.block.model.BakedQuad;
@ -108,7 +110,7 @@ public class PerspectiveMapWrapper implements IBakedModel
@Override public TextureAtlasSprite getParticleTexture() { return parent.getParticleTexture(); } @Override public TextureAtlasSprite getParticleTexture() { return parent.getParticleTexture(); }
@SuppressWarnings("deprecation") @SuppressWarnings("deprecation")
@Override public ItemCameraTransforms getItemCameraTransforms() { return parent.getItemCameraTransforms(); } @Override public ItemCameraTransforms getItemCameraTransforms() { return parent.getItemCameraTransforms(); }
@Override public List<BakedQuad> getQuads(@Nullable IBlockState state, @Nullable EnumFacing side, long rand) { return parent.getQuads(state, side, rand); } @Override public List<BakedQuad> func_200117_a(@Nullable IBlockState state, @Nullable EnumFacing side, Random rand) { return parent.func_200117_a(state, side, rand); }
@Override public ItemOverrideList getOverrides() { return parent.getOverrides(); } @Override public ItemOverrideList getOverrides() { return parent.getOverrides(); }
@Override @Override

View file

@ -52,7 +52,8 @@ public abstract class SimpleModelFontRenderer extends FontRenderer {
public SimpleModelFontRenderer(GameSettings settings, ResourceLocation font, TextureManager manager, boolean isUnicode, Matrix4f matrix, VertexFormat format) public SimpleModelFontRenderer(GameSettings settings, ResourceLocation font, TextureManager manager, boolean isUnicode, Matrix4f matrix, VertexFormat format)
{ {
super(settings, font, manager, isUnicode); super(manager, null);
// super(settings, font, manager, isUnicode);
this.matrix = new Matrix4f(matrix); this.matrix = new Matrix4f(matrix);
Matrix3f nm = new Matrix3f(); Matrix3f nm = new Matrix3f();
this.matrix.getRotationScale(nm); this.matrix.getRotationScale(nm);
@ -67,7 +68,6 @@ public abstract class SimpleModelFontRenderer extends FontRenderer {
public void setSprite(TextureAtlasSprite sprite) public void setSprite(TextureAtlasSprite sprite)
{ {
this.sprite = sprite; this.sprite = sprite;
super.onResourceManagerReload(null);
} }
public void setFillBlanks(boolean fillBlanks) public void setFillBlanks(boolean fillBlanks)
@ -75,54 +75,6 @@ public abstract class SimpleModelFontRenderer extends FontRenderer {
this.fillBlanks = fillBlanks; this.fillBlanks = fillBlanks;
} }
@Override
protected float renderDefaultChar(int pos, boolean italic)
{
float x = (pos % 16) / 16f;
float y = (pos / 16) / 16f;
float sh = italic ? 1f : 0f;
float w = charWidth[pos] - 1.01f;
float h = FONT_HEIGHT - 1.01f;
float wt = w / 128f;
float ht = h / 128f;
UnpackedBakedQuad.Builder quadBuilder = new UnpackedBakedQuad.Builder(format);
quadBuilder.setTexture(sprite);
quadBuilder.setQuadOrientation(orientation);
addVertex(quadBuilder, posX + sh, posY, x, y);
addVertex(quadBuilder, posX - sh, posY + h, x, y + ht);
addVertex(quadBuilder, posX + w + sh, posY + h, x + wt, y + ht);
addVertex(quadBuilder, posX + w - sh, posY, x + wt, y);
builder.add(quadBuilder.build());
if(fillBlanks)
{
float cuv = 15f / 16f;
quadBuilder = new UnpackedBakedQuad.Builder(format);
quadBuilder.setTexture(sprite);
quadBuilder.setQuadOrientation(orientation);
addVertex(quadBuilder, posX + w + sh, posY, cuv, cuv);
addVertex(quadBuilder, posX + w - sh, posY + h, cuv, cuv);
addVertex(quadBuilder, posX + charWidth[pos] + sh, posY + h, cuv, cuv);
addVertex(quadBuilder, posX + charWidth[pos] - sh, posY, cuv, cuv);
builder.add(quadBuilder.build());
quadBuilder = new UnpackedBakedQuad.Builder(format);
quadBuilder.setTexture(sprite);
quadBuilder.setQuadOrientation(orientation);
addVertex(quadBuilder, posX + sh, posY + h, cuv, cuv);
addVertex(quadBuilder, posX - sh, posY + FONT_HEIGHT, cuv, cuv);
addVertex(quadBuilder, posX + charWidth[pos] + sh, posY + FONT_HEIGHT, cuv, cuv);
addVertex(quadBuilder, posX + charWidth[pos] - sh, posY + h, cuv, cuv);
builder.add(quadBuilder.build());
}
return charWidth[pos];
}
private final Vector4f vec = new Vector4f(); private final Vector4f vec = new Vector4f();
private void addVertex(UnpackedBakedQuad.Builder quadBuilder, float x, float y, float u, float v) private void addVertex(UnpackedBakedQuad.Builder quadBuilder, float x, float y, float u, float v)
@ -156,44 +108,6 @@ public abstract class SimpleModelFontRenderer extends FontRenderer {
} }
} }
@Override
public void onResourceManagerReload(IResourceManager resourceManager)
{
super.onResourceManagerReload(resourceManager);
String p = locationFontTexture.getResourcePath();
if(p.startsWith("textures/")) p = p.substring("textures/".length(), p.length());
if(p.endsWith(".png")) p = p.substring(0, p.length() - ".png".length());
String f = locationFontTexture.getResourceDomain() + ":" + p;
sprite = Minecraft.getMinecraft().getTextureMapBlocks().getAtlasSprite(f);
}
@Override
protected abstract float renderUnicodeChar(char c, boolean italic);
@Override
protected void doDraw(float shift)
{
posX += (int)shift;
}
@Override
protected void setColor(float r, float g, float b, float a)
{
this.r = r;
this.g = g;
this.b = b;
this.a = a;
}
@Override public void enableAlpha()
{
}
@Override
protected void bindTexture(ResourceLocation location)
{
}
public ImmutableList<BakedQuad> build() public ImmutableList<BakedQuad> build()
{ {
ImmutableList<BakedQuad> ret = builder.build(); ImmutableList<BakedQuad> ret = builder.build();

View file

@ -23,6 +23,7 @@ import java.util.List;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ItemOverride; import net.minecraft.client.renderer.block.model.ItemOverride;
import net.minecraft.client.renderer.block.model.ItemOverrideList; import net.minecraft.client.renderer.block.model.ItemOverrideList;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
@ -31,7 +32,8 @@ import net.minecraft.entity.EntityLivingBase;
import net.minecraft.item.ItemStack; import net.minecraft.item.ItemStack;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraftforge.client.model.IModel; import net.minecraftforge.client.model.ModelLoader;
import net.minecraftforge.client.model.ModelLoaderRegistry;
import net.minecraftforge.client.model.ModelStateComposition; import net.minecraftforge.client.model.ModelStateComposition;
import net.minecraftforge.common.model.IModelState; import net.minecraftforge.common.model.IModelState;
import net.minecraftforge.common.model.animation.CapabilityAnimation; import net.minecraftforge.common.model.animation.CapabilityAnimation;
@ -43,19 +45,19 @@ import javax.annotation.Nullable;
public final class AnimationItemOverrideList extends ItemOverrideList public final class AnimationItemOverrideList extends ItemOverrideList
{ {
private final IModel model; private final IUnbakedModel model;
private final IModelState state; private final IModelState state;
private final VertexFormat format; private final VertexFormat format;
private final Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter; private final Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter;
public AnimationItemOverrideList(IModel model, IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, ItemOverrideList overrides) public AnimationItemOverrideList(IUnbakedModel model, IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, ItemOverrideList overrides)
{ {
this(model, state, format, bakedTextureGetter, overrides.getOverrides().reverse()); this(model, state, format, bakedTextureGetter, overrides.getOverrides().reverse());
} }
public AnimationItemOverrideList(IModel model, IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, List<ItemOverride> overrides) public AnimationItemOverrideList(IUnbakedModel model, IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, List<ItemOverride> overrides)
{ {
super(overrides); super(model, ModelLoader.defaultModelGetter(), bakedTextureGetter, overrides);
this.model = model; this.model = model;
this.state = state; this.state = state;
this.format = format; this.format = format;
@ -63,7 +65,7 @@ public final class AnimationItemOverrideList extends ItemOverrideList
} }
@Override @Override
public IBakedModel handleItemState(IBakedModel originalModel, ItemStack stack, @Nullable World world, @Nullable EntityLivingBase entity) public IBakedModel func_209581_a(IBakedModel originalModel, ItemStack stack, @Nullable World world, @Nullable EntityLivingBase entity)
{ {
IAnimationStateMachine asm = stack.getCapability(CapabilityAnimation.ANIMATION_CAPABILITY, null); IAnimationStateMachine asm = stack.getCapability(CapabilityAnimation.ANIMATION_CAPABILITY, null);
if (asm != null) if (asm != null)
@ -78,8 +80,9 @@ public final class AnimationItemOverrideList extends ItemOverrideList
world = Minecraft.getMinecraft().world; world = Minecraft.getMinecraft().world;
} }
IModelState state = asm.apply(Animation.getWorldTime(world, Animation.getPartialTickTime())).getLeft(); IModelState state = asm.apply(Animation.getWorldTime(world, Animation.getPartialTickTime())).getLeft();
return model.bake(new ModelStateComposition(state, this.state), format, bakedTextureGetter); // TODO where should uvlock data come from?
return model.bake(ModelLoader.defaultModelGetter(), bakedTextureGetter, new ModelStateComposition(state, this.state), false, format);
} }
return super.handleItemState(originalModel, stack, world, entity); return super.func_209581_a(originalModel, stack, world, entity);
} }
} }

View file

@ -20,8 +20,8 @@
package net.minecraftforge.client.model.animation; package net.minecraftforge.client.model.animation;
import java.util.List; import java.util.List;
import java.util.Random;
import net.minecraft.client.model.ModelBase;
import net.minecraft.client.renderer.BufferBuilder; import net.minecraft.client.renderer.BufferBuilder;
import net.minecraft.client.renderer.GlStateManager; import net.minecraft.client.renderer.GlStateManager;
import net.minecraft.client.renderer.RenderHelper; import net.minecraft.client.renderer.RenderHelper;
@ -29,12 +29,13 @@ import net.minecraft.client.renderer.Tessellator;
import net.minecraft.client.renderer.block.model.BakedQuad; import net.minecraft.client.renderer.block.model.BakedQuad;
import net.minecraft.client.renderer.vertex.DefaultVertexFormats; import net.minecraft.client.renderer.vertex.DefaultVertexFormats;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.entity.model.ModelBase;
import net.minecraft.entity.Entity; import net.minecraft.entity.Entity;
import net.minecraft.init.Blocks; import net.minecraft.init.Blocks;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumFacing;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraftforge.client.model.IModel;
import net.minecraftforge.client.model.ModelLoader; import net.minecraftforge.client.model.ModelLoader;
import net.minecraftforge.client.model.ModelLoaderRegistry; import net.minecraftforge.client.model.ModelLoaderRegistry;
import net.minecraftforge.client.model.pipeline.VertexLighterFlat; import net.minecraftforge.client.model.pipeline.VertexLighterFlat;
@ -75,8 +76,9 @@ public class AnimationModelBase<T extends Entity> extends ModelBase implements I
} }
Pair<IModelState, Iterable<Event>> pair = capability.apply(timeAlive / 20); Pair<IModelState, Iterable<Event>> pair = capability.apply(timeAlive / 20);
handleEvents((T)entity, timeAlive / 20, pair.getRight()); handleEvents((T)entity, timeAlive / 20, pair.getRight());
IModel model = ModelLoaderRegistry.getModelOrMissing(modelLocation); IUnbakedModel model = ModelLoaderRegistry.getModelOrMissing(modelLocation);
IBakedModel bakedModel = model.bake(pair.getLeft(), DefaultVertexFormats.ITEM, ModelLoader.defaultTextureGetter()); // TODO where should uvlock data come from?
IBakedModel bakedModel = model.bake(ModelLoader.defaultModelGetter(), ModelLoader.defaultTextureGetter(), pair.getLeft(), false, DefaultVertexFormats.ITEM);
BlockPos pos = new BlockPos(entity.posX, entity.posY + entity.height, entity.posZ); BlockPos pos = new BlockPos(entity.posX, entity.posY + entity.height, entity.posZ);
@ -93,7 +95,9 @@ public class AnimationModelBase<T extends Entity> extends ModelBase implements I
lighter.setState(Blocks.AIR.getDefaultState()); lighter.setState(Blocks.AIR.getDefaultState());
lighter.setBlockPos(pos); lighter.setBlockPos(pos);
boolean empty = true; boolean empty = true;
List<BakedQuad> quads = bakedModel.getQuads(null, null, 0); Random random = new Random();
random.setSeed(42);
List<BakedQuad> quads = bakedModel.func_200117_a(null, null, random);
if(!quads.isEmpty()) if(!quads.isEmpty())
{ {
lighter.updateBlockInfo(); lighter.updateBlockInfo();
@ -105,7 +109,8 @@ public class AnimationModelBase<T extends Entity> extends ModelBase implements I
} }
for(EnumFacing side : EnumFacing.values()) for(EnumFacing side : EnumFacing.values())
{ {
quads = bakedModel.getQuads(null, side, 0); random.setSeed(42);
quads = bakedModel.func_200117_a(null, side, random);
if(!quads.isEmpty()) if(!quads.isEmpty())
{ {
if(empty) lighter.updateBlockInfo(); if(empty) lighter.updateBlockInfo();

View file

@ -26,7 +26,7 @@ import net.minecraft.client.renderer.BufferBuilder;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.world.IBlockAccess; import net.minecraft.world.IWorldReader;
import net.minecraftforge.client.MinecraftForgeClient; import net.minecraftforge.client.MinecraftForgeClient;
import net.minecraftforge.common.animation.Event; import net.minecraftforge.common.animation.Event;
import net.minecraftforge.common.animation.IEventHandler; import net.minecraftforge.common.animation.IEventHandler;
@ -36,6 +36,8 @@ import net.minecraftforge.common.model.animation.IAnimationStateMachine;
import net.minecraftforge.common.property.IExtendedBlockState; import net.minecraftforge.common.property.IExtendedBlockState;
import net.minecraftforge.common.property.Properties; import net.minecraftforge.common.property.Properties;
import java.util.Random;
import org.apache.commons.lang3.tuple.Pair; import org.apache.commons.lang3.tuple.Pair;
/** /**
@ -46,7 +48,7 @@ public class AnimationTESR<T extends TileEntity> extends FastTESR<T> implements
protected static BlockRendererDispatcher blockRenderer; protected static BlockRendererDispatcher blockRenderer;
@Override @Override
public void renderTileEntityFast(T te, double x, double y, double z, float partialTick, int breakStage, float partial, BufferBuilder renderer) public void renderTileEntityFast(T te, double x, double y, double z, float partialTick, int breakStage, BufferBuilder renderer)
{ {
if(!te.hasCapability(CapabilityAnimation.ANIMATION_CAPABILITY, null)) if(!te.hasCapability(CapabilityAnimation.ANIMATION_CAPABILITY, null))
{ {
@ -54,9 +56,9 @@ public class AnimationTESR<T extends TileEntity> extends FastTESR<T> implements
} }
if(blockRenderer == null) blockRenderer = Minecraft.getMinecraft().getBlockRendererDispatcher(); if(blockRenderer == null) blockRenderer = Minecraft.getMinecraft().getBlockRendererDispatcher();
BlockPos pos = te.getPos(); BlockPos pos = te.getPos();
IBlockAccess world = MinecraftForgeClient.getRegionRenderCache(te.getWorld(), pos); IWorldReader world = MinecraftForgeClient.getRegionRenderCache(te.getWorld(), pos);
IBlockState state = world.getBlockState(pos); IBlockState state = world.getBlockState(pos);
if(state.getPropertyKeys().contains(Properties.StaticProperty)) if(state.getBlock().getBlockState().getProperties().contains(Properties.StaticProperty))
{ {
state = state.withProperty(Properties.StaticProperty, false); state = state.withProperty(Properties.StaticProperty, false);
} }
@ -78,7 +80,7 @@ public class AnimationTESR<T extends TileEntity> extends FastTESR<T> implements
renderer.setTranslation(x - pos.getX(), y - pos.getY(), z - pos.getZ()); renderer.setTranslation(x - pos.getX(), y - pos.getY(), z - pos.getZ());
blockRenderer.getBlockModelRenderer().renderModel(world, model, exState, pos, renderer, false); blockRenderer.getBlockModelRenderer().func_199324_a(world, model, exState, pos, renderer, false, new Random(), 42);
} }
} }
} }

View file

@ -27,14 +27,14 @@ import net.minecraft.client.renderer.RenderHelper;
import net.minecraft.client.renderer.Tessellator; import net.minecraft.client.renderer.Tessellator;
import net.minecraft.client.renderer.BufferBuilder; import net.minecraft.client.renderer.BufferBuilder;
import net.minecraft.client.renderer.texture.TextureMap; import net.minecraft.client.renderer.texture.TextureMap;
import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer; import net.minecraft.client.renderer.tileentity.TileEntityRenderer;
import net.minecraft.client.renderer.vertex.DefaultVertexFormats; import net.minecraft.client.renderer.vertex.DefaultVertexFormats;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
public abstract class FastTESR<T extends TileEntity> extends TileEntitySpecialRenderer<T> public abstract class FastTESR<T extends TileEntity> extends TileEntityRenderer<T>
{ {
@Override @Override
public final void render(T te, double x, double y, double z, float partialTicks, int destroyStage, float partial) public final void func_199341_a(T te, double x, double y, double z, float partialTicks, int destroyStage)
{ {
Tessellator tessellator = Tessellator.getInstance(); Tessellator tessellator = Tessellator.getInstance();
BufferBuilder buffer = tessellator.getBuffer(); BufferBuilder buffer = tessellator.getBuffer();
@ -55,7 +55,7 @@ public abstract class FastTESR<T extends TileEntity> extends TileEntitySpecialRe
buffer.begin(GL11.GL_QUADS, DefaultVertexFormats.BLOCK); buffer.begin(GL11.GL_QUADS, DefaultVertexFormats.BLOCK);
renderTileEntityFast(te, x, y, z, partialTicks, destroyStage, partial, buffer); renderTileEntityFast(te, x, y, z, partialTicks, destroyStage, buffer);
buffer.setTranslation(0, 0, 0); buffer.setTranslation(0, 0, 0);
tessellator.draw(); tessellator.draw();
@ -64,5 +64,5 @@ public abstract class FastTESR<T extends TileEntity> extends TileEntitySpecialRe
} }
@Override @Override
public abstract void renderTileEntityFast(T te, double x, double y, double z, float partialTicks, int destroyStage, float partial, BufferBuilder buffer); public abstract void renderTileEntityFast(T te, double x, double y, double z, float partialTicks, int destroyStage, BufferBuilder buffer);
} }

View file

@ -37,9 +37,12 @@ import javax.vecmath.Matrix4f;
import javax.vecmath.Quat4f; import javax.vecmath.Quat4f;
import javax.vecmath.Vector3f; import javax.vecmath.Vector3f;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import net.minecraft.client.renderer.block.model.BlockPart; import net.minecraft.client.renderer.block.model.BlockPart;
import net.minecraft.client.resources.IResource; import net.minecraft.resources.IResource;
import net.minecraft.client.resources.IResourceManager; import net.minecraft.resources.IResourceManager;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraft.util.math.MathHelper; import net.minecraft.util.math.MathHelper;
import net.minecraftforge.client.model.animation.ModelBlockAnimation.Parameter.Interpolation; import net.minecraftforge.client.model.animation.ModelBlockAnimation.Parameter.Interpolation;
@ -53,7 +56,6 @@ import net.minecraftforge.common.model.animation.IJoint;
import net.minecraftforge.common.model.animation.IJointClip; import net.minecraftforge.common.model.animation.IJointClip;
import net.minecraftforge.common.model.animation.JointClips; import net.minecraftforge.common.model.animation.JointClips;
import net.minecraftforge.common.util.JsonUtils; import net.minecraftforge.common.util.JsonUtils;
import net.minecraftforge.fml.common.FMLLog;
import com.google.common.collect.ImmutableCollection; import com.google.common.collect.ImmutableCollection;
import com.google.common.collect.ImmutableList; import com.google.common.collect.ImmutableList;
@ -69,6 +71,8 @@ import com.google.gson.annotations.SerializedName;
public class ModelBlockAnimation public class ModelBlockAnimation
{ {
private static final Logger LOGGER = LogManager.getLogger();
private final ImmutableMap<String, ImmutableMap<String, float[]>> joints; private final ImmutableMap<String, ImmutableMap<String, float[]>> joints;
private final ImmutableMap<String, MBClip> clips; private final ImmutableMap<String, MBClip> clips;
private transient ImmutableMultimap<Integer, MBJointWeight> jointIndexMap; private transient ImmutableMultimap<Integer, MBJointWeight> jointIndexMap;
@ -553,9 +557,9 @@ public class ModelBlockAnimation
{ {
try try
{ {
try (IResource resource = manager.getResource(armatureLocation)) try (IResource resource = manager.func_199002_a(armatureLocation))
{ {
ModelBlockAnimation mba = mbaGson.fromJson(new InputStreamReader(resource.getInputStream(), StandardCharsets.UTF_8), ModelBlockAnimation.class); ModelBlockAnimation mba = mbaGson.fromJson(new InputStreamReader(resource.func_199027_b(), StandardCharsets.UTF_8), ModelBlockAnimation.class);
//String json = mbaGson.toJson(mba); //String json = mbaGson.toJson(mba);
return mba; return mba;
} }
@ -567,7 +571,7 @@ public class ModelBlockAnimation
} }
catch(IOException | JsonParseException e) catch(IOException | JsonParseException e)
{ {
FMLLog.log.error("Exception loading vanilla model animation {}, skipping", armatureLocation, e); LOGGER.error("Exception loading vanilla model animation {}, skipping", armatureLocation, e);
return defaultModelBlockAnimation; return defaultModelBlockAnimation;
} }
} }

View file

@ -22,6 +22,7 @@ package net.minecraftforge.client.model.b3d;
import java.io.FileNotFoundException; import java.io.FileNotFoundException;
import java.io.IOException; import java.io.IOException;
import java.util.Collection; import java.util.Collection;
import java.util.Collections;
import java.util.HashMap; import java.util.HashMap;
import java.util.HashSet; import java.util.HashSet;
import java.util.List; import java.util.List;
@ -36,6 +37,7 @@ import javax.vecmath.Vector3f;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.client.renderer.block.model.BakedQuad; import net.minecraft.client.renderer.block.model.BakedQuad;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType; import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType;
import net.minecraft.client.renderer.block.model.ItemOverrideList; import net.minecraft.client.renderer.block.model.ItemOverrideList;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
@ -46,7 +48,6 @@ import net.minecraft.util.EnumFacing;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraft.util.math.MathHelper; import net.minecraft.util.math.MathHelper;
import net.minecraftforge.client.model.ICustomModelLoader; import net.minecraftforge.client.model.ICustomModelLoader;
import net.minecraftforge.client.model.IModel;
import net.minecraftforge.client.model.ModelLoader; import net.minecraftforge.client.model.ModelLoader;
import net.minecraftforge.client.model.ModelLoaderRegistry; import net.minecraftforge.client.model.ModelLoaderRegistry;
import net.minecraftforge.client.model.ModelStateComposition; import net.minecraftforge.client.model.ModelStateComposition;
@ -72,10 +73,14 @@ import net.minecraftforge.common.property.Properties;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
import org.apache.commons.lang3.tuple.Pair; import org.apache.commons.lang3.tuple.Pair;
import org.apache.commons.lang3.tuple.Triple; import org.apache.commons.lang3.tuple.Triple;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import java.util.function.Function; import java.util.function.Function;
import com.google.common.base.Objects; import com.google.common.base.Objects;
import java.util.Optional; import java.util.Optional;
import java.util.Random;
import com.google.common.base.Predicate; import com.google.common.base.Predicate;
import com.google.common.cache.CacheBuilder; import com.google.common.cache.CacheBuilder;
import com.google.common.cache.CacheLoader; import com.google.common.cache.CacheLoader;
@ -96,6 +101,8 @@ public enum B3DLoader implements ICustomModelLoader
{ {
INSTANCE; INSTANCE;
private static final Logger LOGGER = LogManager.getLogger();
private IResourceManager manager; private IResourceManager manager;
private final Set<String> enabledDomains = new HashSet<>(); private final Set<String> enabledDomains = new HashSet<>();
@ -121,7 +128,7 @@ public enum B3DLoader implements ICustomModelLoader
@Override @Override
@SuppressWarnings("unchecked") @SuppressWarnings("unchecked")
public IModel loadModel(ResourceLocation modelLocation) throws Exception public IUnbakedModel loadModel(ResourceLocation modelLocation) throws Exception
{ {
ResourceLocation file = new ResourceLocation(modelLocation.getNamespace(), modelLocation.getPath()); ResourceLocation file = new ResourceLocation(modelLocation.getNamespace(), modelLocation.getPath());
if(!cache.containsKey(file)) if(!cache.containsKey(file))
@ -131,17 +138,17 @@ public enum B3DLoader implements ICustomModelLoader
{ {
try try
{ {
resource = manager.getResource(file); resource = manager.func_199002_a(file);
} }
catch(FileNotFoundException e) catch(FileNotFoundException e)
{ {
if(modelLocation.getPath().startsWith("models/block/")) if(modelLocation.getPath().startsWith("models/block/"))
resource = manager.getResource(new ResourceLocation(file.getNamespace(), "models/item/" + file.getPath().substring("models/block/".length()))); resource = manager.func_199002_a(new ResourceLocation(file.getNamespace(), "models/item/" + file.getPath().substring("models/block/".length())));
else if(modelLocation.getPath().startsWith("models/item/")) else if(modelLocation.getPath().startsWith("models/item/"))
resource = manager.getResource(new ResourceLocation(file.getNamespace(), "models/block/" + file.getPath().substring("models/item/".length()))); resource = manager.func_199002_a(new ResourceLocation(file.getNamespace(), "models/block/" + file.getPath().substring("models/item/".length())));
else throw e; else throw e;
} }
B3DModel.Parser parser = new B3DModel.Parser(resource.getInputStream()); B3DModel.Parser parser = new B3DModel.Parser(resource.func_199027_b());
B3DModel model = parser.parse(); B3DModel model = parser.parse();
cache.put(file, model); cache.put(file, model);
} }
@ -402,7 +409,7 @@ public enum B3DLoader implements ICustomModelLoader
} }
} }
private static final class ModelWrapper implements IModel private static final class ModelWrapper implements IUnbakedModel
{ {
private final ResourceLocation modelLocation; private final ResourceLocation modelLocation;
private final B3DModel model; private final B3DModel model;
@ -449,13 +456,19 @@ public enum B3DLoader implements ICustomModelLoader
} }
@Override @Override
public Collection<ResourceLocation> getTextures() public Collection<ResourceLocation> func_209559_a(Function<ResourceLocation, IUnbakedModel> p_209559_1_, Set<String> p_209559_2_)
{ {
return Collections2.filter(textures.values(), loc -> !loc.getPath().startsWith("#")); return Collections2.filter(textures.values(), loc -> !loc.getPath().startsWith("#"));
} }
@Override @Override
public IBakedModel bake(IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) public Collection<ResourceLocation> getOverrideLocations()
{
return Collections.emptyList();
}
@Override
public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean uvlock, VertexFormat format)
{ {
ImmutableMap.Builder<String, TextureAtlasSprite> builder = ImmutableMap.builder(); ImmutableMap.Builder<String, TextureAtlasSprite> builder = ImmutableMap.builder();
TextureAtlasSprite missing = bakedTextureGetter.apply(new ResourceLocation("missingno")); TextureAtlasSprite missing = bakedTextureGetter.apply(new ResourceLocation("missingno"));
@ -463,7 +476,7 @@ public enum B3DLoader implements ICustomModelLoader
{ {
if(e.getValue().getPath().startsWith("#")) if(e.getValue().getPath().startsWith("#"))
{ {
FMLLog.log.fatal("unresolved texture '{}' for b3d model '{}'", e.getValue().getPath(), modelLocation); LOGGER.fatal("unresolved texture '{}' for b3d model '{}'", e.getValue().getPath(), modelLocation);
builder.put(e.getKey(), missing); builder.put(e.getKey(), missing);
} }
else else
@ -521,7 +534,7 @@ public enum B3DLoader implements ICustomModelLoader
} }
else else
{ {
FMLLog.log.fatal("unknown mesh definition '{}' in array for b3d model '{}'", s.toString(), modelLocation); LOGGER.fatal("unknown mesh definition '{}' in array for b3d model '{}'", s.toString(), modelLocation);
return this; return this;
} }
} }
@ -530,7 +543,7 @@ public enum B3DLoader implements ICustomModelLoader
} }
else else
{ {
FMLLog.log.fatal("unknown mesh definition '{}' for b3d model '{}'", e.toString(), modelLocation); LOGGER.fatal("unknown mesh definition '{}' for b3d model '{}'", e.toString(), modelLocation);
return this; return this;
} }
} }
@ -544,7 +557,7 @@ public enum B3DLoader implements ICustomModelLoader
} }
else else
{ {
FMLLog.log.fatal("unknown keyframe definition '{}' for b3d model '{}'", e.toString(), modelLocation); LOGGER.fatal("unknown keyframe definition '{}' for b3d model '{}'", e.toString(), modelLocation);
return this; return this;
} }
} }
@ -636,7 +649,7 @@ public enum B3DLoader implements ICustomModelLoader
} }
@Override @Override
public List<BakedQuad> getQuads(@Nullable IBlockState state, @Nullable EnumFacing side, long rand) public List<BakedQuad> func_200117_a(@Nullable IBlockState state, @Nullable EnumFacing side, Random rand)
{ {
if(side != null) return ImmutableList.of(); if(side != null) return ImmutableList.of();
IModelState modelState = this.state; IModelState modelState = this.state;

View file

@ -25,11 +25,11 @@ import java.util.HashSet;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.resources.IResource; import net.minecraft.resources.IResource;
import net.minecraft.resources.IResourceManager; import net.minecraft.resources.IResourceManager;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraftforge.client.model.ICustomModelLoader; import net.minecraftforge.client.model.ICustomModelLoader;
import net.minecraftforge.client.model.IModel;
import net.minecraftforge.client.model.ModelLoaderRegistry; import net.minecraftforge.client.model.ModelLoaderRegistry;
import org.apache.commons.io.IOUtils; import org.apache.commons.io.IOUtils;
@ -72,7 +72,7 @@ public enum OBJLoader implements ICustomModelLoader {
} }
@Override @Override
public IModel loadModel(ResourceLocation modelLocation) throws Exception public IUnbakedModel loadModel(ResourceLocation modelLocation) throws Exception
{ {
ResourceLocation file = new ResourceLocation(modelLocation.getNamespace(), modelLocation.getPath()); ResourceLocation file = new ResourceLocation(modelLocation.getNamespace(), modelLocation.getPath());
if (!cache.containsKey(file)) if (!cache.containsKey(file))
@ -82,14 +82,14 @@ public enum OBJLoader implements ICustomModelLoader {
{ {
try try
{ {
resource = manager.getResource(file); resource = manager.func_199002_a(file);
} }
catch (FileNotFoundException e) catch (FileNotFoundException e)
{ {
if (modelLocation.getPath().startsWith("models/block/")) if (modelLocation.getPath().startsWith("models/block/"))
resource = manager.getResource(new ResourceLocation(file.getNamespace(), "models/item/" + file.getPath().substring("models/block/".length()))); resource = manager.func_199002_a(new ResourceLocation(file.getNamespace(), "models/item/" + file.getPath().substring("models/block/".length())));
else if (modelLocation.getPath().startsWith("models/item/")) else if (modelLocation.getPath().startsWith("models/item/"))
resource = manager.getResource(new ResourceLocation(file.getNamespace(), "models/block/" + file.getPath().substring("models/item/".length()))); resource = manager.func_199002_a(new ResourceLocation(file.getNamespace(), "models/block/" + file.getPath().substring("models/item/".length())));
else throw e; else throw e;
} }
OBJModel.Parser parser = new OBJModel.Parser(resource, manager); OBJModel.Parser parser = new OBJModel.Parser(resource, manager);

View file

@ -44,12 +44,13 @@ import javax.vecmath.Vector4f;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.client.renderer.block.model.BakedQuad; import net.minecraft.client.renderer.block.model.BakedQuad;
import net.minecraft.client.renderer.block.model.IBakedModel; import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType; import net.minecraft.client.renderer.block.model.ItemCameraTransforms.TransformType;
import net.minecraft.client.renderer.block.model.ItemOverrideList; import net.minecraft.client.renderer.block.model.ItemOverrideList;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
import net.minecraft.client.renderer.vertex.VertexFormat; import net.minecraft.client.renderer.vertex.VertexFormat;
import net.minecraft.client.resources.IResource; import net.minecraft.resources.IResource;
import net.minecraft.client.resources.IResourceManager; import net.minecraft.resources.IResourceManager;
import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumFacing;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraftforge.client.model.*; import net.minecraftforge.client.model.*;
@ -61,13 +62,16 @@ import net.minecraftforge.common.model.TRSRTransformation;
import net.minecraftforge.common.property.IExtendedBlockState; import net.minecraftforge.common.property.IExtendedBlockState;
import net.minecraftforge.common.property.IUnlistedProperty; import net.minecraftforge.common.property.IUnlistedProperty;
import net.minecraftforge.common.property.Properties; import net.minecraftforge.common.property.Properties;
import net.minecraftforge.fml.common.FMLLog;
import org.apache.commons.lang3.tuple.Pair; import org.apache.commons.lang3.tuple.Pair;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import java.util.function.Function; import java.util.function.Function;
import com.google.common.base.Objects; import com.google.common.base.Objects;
import java.util.Optional; import java.util.Optional;
import java.util.Random;
import com.google.common.base.Strings; import com.google.common.base.Strings;
import com.google.common.cache.CacheBuilder; import com.google.common.cache.CacheBuilder;
import com.google.common.cache.CacheLoader; import com.google.common.cache.CacheLoader;
@ -77,8 +81,10 @@ import com.google.common.collect.ImmutableMap;
import com.google.common.collect.Lists; import com.google.common.collect.Lists;
import com.google.common.collect.Maps; import com.google.common.collect.Maps;
public class OBJModel implements IModel public class OBJModel implements IUnbakedModel
{ {
private static final Logger LOGGER = LogManager.getLogger();
//private Gson GSON = new GsonBuilder().create(); //private Gson GSON = new GsonBuilder().create();
private MaterialLibrary matLib; private MaterialLibrary matLib;
private final ResourceLocation modelLocation; private final ResourceLocation modelLocation;
@ -97,7 +103,7 @@ public class OBJModel implements IModel
} }
@Override @Override
public Collection<ResourceLocation> getTextures() public Collection<ResourceLocation> func_209559_a(Function<ResourceLocation, IUnbakedModel> p_209559_1_, Set<String> p_209559_2_)
{ {
Iterator<Material> materialIterator = this.matLib.materials.values().iterator(); Iterator<Material> materialIterator = this.matLib.materials.values().iterator();
List<ResourceLocation> textures = Lists.newArrayList(); List<ResourceLocation> textures = Lists.newArrayList();
@ -112,16 +118,22 @@ public class OBJModel implements IModel
} }
@Override @Override
public IBakedModel bake(IModelState state, VertexFormat format, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter) public Collection<ResourceLocation> getOverrideLocations()
{
return Collections.emptyList();
}
@Override
public IBakedModel bake(Function<ResourceLocation, IUnbakedModel> modelGetter, Function<ResourceLocation, TextureAtlasSprite> bakedTextureGetter, IModelState state, boolean uvlock, VertexFormat format)
{ {
ImmutableMap.Builder<String, TextureAtlasSprite> builder = ImmutableMap.builder(); ImmutableMap.Builder<String, TextureAtlasSprite> builder = ImmutableMap.builder();
builder.put(ModelLoader.White.LOCATION.toString(), ModelLoader.White.INSTANCE); builder.put(ModelLoader.White.LOCATION.toString(), ModelLoader.White.INSTANCE);
TextureAtlasSprite missing = bakedTextureGetter.apply(new ResourceLocation("missingno")); TextureAtlasSprite missing = bakedTextureGetter.apply(new ResourceLocation("missingno"));
for (Map.Entry<String, Material> e : matLib.materials.entrySet()) for (Map.Entry<String, Material> e : matLib.materials.entrySet())
{ {
if (e.getValue().getTexture().getTextureLocation().getResourcePath().startsWith("#")) if (e.getValue().getTexture().getTextureLocation().getPath().startsWith("#"))
{ {
FMLLog.log.fatal("OBJLoader: Unresolved texture '{}' for obj model '{}'", e.getValue().getTexture().getTextureLocation().getResourcePath(), modelLocation); LOGGER.fatal("OBJLoader: Unresolved texture '{}' for obj model '{}'", e.getValue().getTexture().getTextureLocation().getPath(), modelLocation);
builder.put(e.getKey(), missing); builder.put(e.getKey(), missing);
} }
else else
@ -139,14 +151,14 @@ public class OBJModel implements IModel
} }
@Override @Override
public IModel process(ImmutableMap<String, String> customData) public IUnbakedModel process(ImmutableMap<String, String> customData)
{ {
OBJModel ret = new OBJModel(this.matLib, this.modelLocation, new CustomData(this.customData, customData)); OBJModel ret = new OBJModel(this.matLib, this.modelLocation, new CustomData(this.customData, customData));
return ret; return ret;
} }
@Override @Override
public IModel retexture(ImmutableMap<String, String> textures) public IUnbakedModel retexture(ImmutableMap<String, String> textures)
{ {
OBJModel ret = new OBJModel(this.matLib.makeLibWithReplacements(textures), this.modelLocation, this.customData); OBJModel ret = new OBJModel(this.matLib.makeLibWithReplacements(textures), this.modelLocation, this.customData);
return ret; return ret;
@ -204,8 +216,8 @@ public class OBJModel implements IModel
public Parser(IResource from, IResourceManager manager) throws IOException public Parser(IResource from, IResourceManager manager) throws IOException
{ {
this.manager = manager; this.manager = manager;
this.objFrom = from.getResourceLocation(); this.objFrom = from.func_199029_a();
this.objStream = new InputStreamReader(from.getInputStream(), StandardCharsets.UTF_8); this.objStream = new InputStreamReader(from.func_199027_b(), StandardCharsets.UTF_8);
this.objReader = new BufferedReader(objStream); this.objReader = new BufferedReader(objStream);
} }
@ -258,7 +270,7 @@ public class OBJModel implements IModel
} }
else else
{ {
FMLLog.log.error("OBJModel.Parser: (Model: '{}', Line: {}) material '{}' referenced but was not found", objFrom, lineNum, data); LOGGER.error("OBJModel.Parser: (Model: '{}', Line: {}) material '{}' referenced but was not found", objFrom, lineNum, data);
} }
usemtlCounter++; usemtlCounter++;
} }
@ -285,7 +297,7 @@ public class OBJModel implements IModel
else if (key.equalsIgnoreCase("f")) // Face Elements: f v1[/vt1][/vn1] ... else if (key.equalsIgnoreCase("f")) // Face Elements: f v1[/vt1][/vn1] ...
{ {
if (splitData.length > 4) if (splitData.length > 4)
FMLLog.log.warn("OBJModel.Parser: found a face ('f') with more than 4 vertices, only the first 4 of these vertices will be rendered!"); LOGGER.warn("OBJModel.Parser: found a face ('f') with more than 4 vertices, only the first 4 of these vertices will be rendered!");
List<Vertex> v = Lists.newArrayListWithCapacity(splitData.length); List<Vertex> v = Lists.newArrayListWithCapacity(splitData.length);
@ -368,7 +380,7 @@ public class OBJModel implements IModel
if (!unknownObjectCommands.contains(key)) if (!unknownObjectCommands.contains(key))
{ {
unknownObjectCommands.add(key); unknownObjectCommands.add(key);
FMLLog.log.info("OBJLoader.Parser: command '{}' (model: '{}') is not currently supported, skipping. Line: {} '{}'", key, objFrom, lineNum, currentLine); LOGGER.info("OBJLoader.Parser: command '{}' (model: '{}') is not currently supported, skipping. Line: {} '{}'", key, objFrom, lineNum, currentLine);
} }
} }
} }
@ -502,10 +514,10 @@ public class OBJModel implements IModel
this.materials.clear(); this.materials.clear();
boolean hasSetTexture = false; boolean hasSetTexture = false;
boolean hasSetColor = false; boolean hasSetColor = false;
String domain = from.getResourceDomain(); String domain = from.getNamespace();
if (!path.contains("/")) if (!path.contains("/"))
path = from.getResourcePath().substring(0, from.getResourcePath().lastIndexOf("/") + 1) + path; path = from.getPath().substring(0, from.getPath().lastIndexOf("/") + 1) + path;
mtlStream = new InputStreamReader(manager.getResource(new ResourceLocation(domain, path)).getInputStream(), StandardCharsets.UTF_8); mtlStream = new InputStreamReader(manager.func_199002_a(new ResourceLocation(domain, path)).func_199027_b(), StandardCharsets.UTF_8);
mtlReader = new BufferedReader(mtlStream); mtlReader = new BufferedReader(mtlStream);
String currentLine = ""; String currentLine = "";
@ -545,7 +557,7 @@ public class OBJModel implements IModel
} }
else else
{ {
FMLLog.log.info("OBJModel: A color has already been defined for material '{}' in '{}'. The color defined by key '{}' will not be applied!", material.getName(), new ResourceLocation(domain, path).toString(), key); LOGGER.info("OBJModel: A color has already been defined for material '{}' in '{}'. The color defined by key '{}' will not be applied!", material.getName(), new ResourceLocation(domain, path).toString(), key);
} }
} }
else if (key.equalsIgnoreCase("map_Ka") || key.equalsIgnoreCase("map_Kd") || key.equalsIgnoreCase("map_Ks")) else if (key.equalsIgnoreCase("map_Ka") || key.equalsIgnoreCase("map_Kd") || key.equalsIgnoreCase("map_Ks"))
@ -569,7 +581,7 @@ public class OBJModel implements IModel
} }
else else
{ {
FMLLog.log.info("OBJModel: A texture has already been defined for material '{}' in '{}'. The texture defined by key '{}' will not be applied!", material.getName(), new ResourceLocation(domain, path).toString(), key); LOGGER.info("OBJModel: A texture has already been defined for material '{}' in '{}'. The texture defined by key '{}' will not be applied!", material.getName(), new ResourceLocation(domain, path).toString(), key);
} }
} }
else if (key.equalsIgnoreCase("d") || key.equalsIgnoreCase("Tr")) else if (key.equalsIgnoreCase("d") || key.equalsIgnoreCase("Tr"))
@ -585,7 +597,7 @@ public class OBJModel implements IModel
if (!unknownMaterialCommands.contains(key)) if (!unknownMaterialCommands.contains(key))
{ {
unknownMaterialCommands.add(key); unknownMaterialCommands.add(key);
FMLLog.log.info("OBJLoader.MaterialLibrary: key '{}' (model: '{}') is not currently supported, skipping", key, new ResourceLocation(domain, path)); LOGGER.info("OBJLoader.MaterialLibrary: key '{}' (model: '{}') is not currently supported, skipping", key, new ResourceLocation(domain, path));
} }
} }
} }
@ -1306,7 +1318,7 @@ public class OBJModel implements IModel
// FIXME: merge with getQuads // FIXME: merge with getQuads
@Override @Override
public List<BakedQuad> getQuads(IBlockState blockState, EnumFacing side, long rand) public List<BakedQuad> func_200117_a(IBlockState blockState, EnumFacing side, Random rand)
{ {
if (side != null) return ImmutableList.of(); if (side != null) return ImmutableList.of();
if (quads == null) if (quads == null)

View file

@ -24,14 +24,14 @@ import net.minecraft.client.renderer.color.BlockColors;
import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumFacing;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.util.math.Vec3d; import net.minecraft.util.math.Vec3d;
import net.minecraft.world.IBlockAccess; import net.minecraft.world.IWorldReader;
public class BlockInfo public class BlockInfo
{ {
private static final EnumFacing[] SIDES = EnumFacing.values(); private static final EnumFacing[] SIDES = EnumFacing.values();
private final BlockColors colors; private final BlockColors colors;
private IBlockAccess world; private IWorldReader world;
private IBlockState state; private IBlockState state;
private BlockPos blockPos; private BlockPos blockPos;
@ -72,7 +72,7 @@ public class BlockInfo
shz = (float) offset.z; shz = (float) offset.z;
} }
public void setWorld(IBlockAccess world) public void setWorld(IWorldReader world)
{ {
this.world = world; this.world = world;
cachedTint = -1; cachedTint = -1;
@ -135,9 +135,9 @@ public class BlockInfo
{ {
if(!state.doesSideBlockRendering(world, blockPos, side)) if(!state.doesSideBlockRendering(world, blockPos, side))
{ {
int x = side.getFrontOffsetX() + 1; int x = side.getXOffset() + 1;
int y = side.getFrontOffsetY() + 1; int y = side.getYOffset() + 1;
int z = side.getFrontOffsetZ() + 1; int z = side.getZOffset() + 1;
s[x][y][z] = Math.max(s[1][1][1] - 1, s[x][y][z]); s[x][y][z] = Math.max(s[1][1][1] - 1, s[x][y][z]);
b[x][y][z] = Math.max(b[1][1][1] - 1, b[x][y][z]); b[x][y][z] = Math.max(b[1][1][1] - 1, b[x][y][z]);
} }
@ -195,7 +195,7 @@ public class BlockInfo
} }
} }
public IBlockAccess getWorld() public IWorldReader getWorld()
{ {
return world; return world;
} }

View file

@ -20,6 +20,7 @@
package net.minecraftforge.client.model.pipeline; package net.minecraftforge.client.model.pipeline;
import java.util.List; import java.util.List;
import java.util.Random;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.client.renderer.BlockModelRenderer; import net.minecraft.client.renderer.BlockModelRenderer;
@ -29,7 +30,8 @@ import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.color.BlockColors; import net.minecraft.client.renderer.color.BlockColors;
import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumFacing;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.world.IBlockAccess; import net.minecraft.world.IWorldReader;
import net.minecraft.world.IWorldReader;
import net.minecraftforge.common.ForgeMod; import net.minecraftforge.common.ForgeMod;
public class ForgeBlockModelRenderer extends BlockModelRenderer public class ForgeBlockModelRenderer extends BlockModelRenderer
@ -49,7 +51,7 @@ public class ForgeBlockModelRenderer extends BlockModelRenderer
} }
@Override @Override
public boolean renderModelFlat(IBlockAccess world, IBakedModel model, IBlockState state, BlockPos pos, BufferBuilder buffer, boolean checkSides, long rand) public boolean func_199325_c(IWorldReader world, IBakedModel model, IBlockState state, BlockPos pos, BufferBuilder buffer, boolean checkSides, Random rand, long seed)
{ {
if(ForgeMod.forgeLightPipelineEnabled) if(ForgeMod.forgeLightPipelineEnabled)
{ {
@ -61,16 +63,16 @@ public class ForgeBlockModelRenderer extends BlockModelRenderer
lighterFlat.get().setParent(newCons); lighterFlat.get().setParent(newCons);
} }
wrFlat.get().setOffset(pos); wrFlat.get().setOffset(pos);
return render(lighterFlat.get(), world, model, state, pos, buffer, checkSides, rand); return render(lighterFlat.get(), world, model, state, pos, buffer, checkSides, rand, seed);
} }
else else
{ {
return super.renderModelFlat(world, model, state, pos, buffer, checkSides, rand); return super.func_199325_c(world, model, state, pos, buffer, checkSides, rand, seed);
} }
} }
@Override @Override
public boolean renderModelSmooth(IBlockAccess world, IBakedModel model, IBlockState state, BlockPos pos, BufferBuilder buffer, boolean checkSides, long rand) public boolean func_199326_b(IWorldReader world, IBakedModel model, IBlockState state, BlockPos pos, BufferBuilder buffer, boolean checkSides, Random rand, long seed)
{ {
if(ForgeMod.forgeLightPipelineEnabled) if(ForgeMod.forgeLightPipelineEnabled)
{ {
@ -82,21 +84,21 @@ public class ForgeBlockModelRenderer extends BlockModelRenderer
lighterSmooth.get().setParent(newCons); lighterSmooth.get().setParent(newCons);
} }
wrSmooth.get().setOffset(pos); wrSmooth.get().setOffset(pos);
return render(lighterSmooth.get(), world, model, state, pos, buffer, checkSides, rand); return render(lighterSmooth.get(), world, model, state, pos, buffer, checkSides, rand, seed);
} }
else else
{ {
return super.renderModelSmooth(world, model, state, pos, buffer, checkSides, rand); return super.func_199326_b(world, model, state, pos, buffer, checkSides, rand, seed);
} }
} }
public static boolean render(VertexLighterFlat lighter, IBlockAccess world, IBakedModel model, IBlockState state, BlockPos pos, BufferBuilder wr, boolean checkSides, long rand) public static boolean render(VertexLighterFlat lighter, IWorldReader world, IBakedModel model, IBlockState state, BlockPos pos, BufferBuilder wr, boolean checkSides, Random rand, long seed)
{ {
lighter.setWorld(world); lighter.setWorld(world);
lighter.setState(state); lighter.setState(state);
lighter.setBlockPos(pos); lighter.setBlockPos(pos);
boolean empty = true; boolean empty = true;
List<BakedQuad> quads = model.getQuads(state, null, rand); List<BakedQuad> quads = model.func_200117_a(state, null, rand);
if(!quads.isEmpty()) if(!quads.isEmpty())
{ {
lighter.updateBlockInfo(); lighter.updateBlockInfo();
@ -108,7 +110,7 @@ public class ForgeBlockModelRenderer extends BlockModelRenderer
} }
for(EnumFacing side : EnumFacing.values()) for(EnumFacing side : EnumFacing.values())
{ {
quads = model.getQuads(state, side, rand); quads = model.func_200117_a(state, side, rand);
if(!quads.isEmpty()) if(!quads.isEmpty())
{ {
if(!checkSides || state.shouldSideBeRendered(world, pos, side)) if(!checkSides || state.shouldSideBeRendered(world, pos, side))

View file

@ -152,7 +152,7 @@ public class LightUtil
{ {
int length = 4 < to.length ? 4 : to.length; int length = 4 < to.length ? 4 : to.length;
VertexFormatElement element = formatFrom.getElement(e); VertexFormatElement element = formatFrom.getElement(e);
int vertexStart = v * formatFrom.getNextOffset() + formatFrom.getOffset(e); int vertexStart = v * formatFrom.getSize() + formatFrom.getOffset(e);
int count = element.getElementCount(); int count = element.getElementCount();
VertexFormatElement.EnumType type = element.getType(); VertexFormatElement.EnumType type = element.getType();
int size = type.getSize(); int size = type.getSize();
@ -206,7 +206,7 @@ public class LightUtil
public static void pack(float[] from, int[] to, VertexFormat formatTo, int v, int e) public static void pack(float[] from, int[] to, VertexFormat formatTo, int v, int e)
{ {
VertexFormatElement element = formatTo.getElement(e); VertexFormatElement element = formatTo.getElement(e);
int vertexStart = v * formatTo.getNextOffset() + formatTo.getOffset(e); int vertexStart = v * formatTo.getSize() + formatTo.getOffset(e);
int count = element.getElementCount(); int count = element.getElementCount();
VertexFormatElement.EnumType type = element.getType(); VertexFormatElement.EnumType type = element.getType();
int size = type.getSize(); int size = type.getSize();

View file

@ -35,7 +35,7 @@ public class UnpackedBakedQuad extends BakedQuad
public UnpackedBakedQuad(float[][][] unpackedData, int tint, EnumFacing orientation, TextureAtlasSprite texture, boolean applyDiffuseLighting, VertexFormat format) public UnpackedBakedQuad(float[][][] unpackedData, int tint, EnumFacing orientation, TextureAtlasSprite texture, boolean applyDiffuseLighting, VertexFormat format)
{ {
super(new int[format.getNextOffset() /* / 4 * 4 */], tint, orientation, texture, applyDiffuseLighting, format); super(new int[format.getSize() /* / 4 * 4 */], tint, orientation, texture, applyDiffuseLighting, format);
this.unpackedData = unpackedData; this.unpackedData = unpackedData;
this.format = format; this.format = format;
} }

View file

@ -41,7 +41,7 @@ public class VertexBufferConsumer implements IVertexConsumer
{ {
super(); super();
this.renderer = renderer; this.renderer = renderer;
quadData = new int[renderer.getVertexFormat().getNextOffset()/* / 4 * 4 */]; quadData = new int[renderer.getVertexFormat().getSize()/* / 4 * 4 */];
} }
@Override @Override

View file

@ -29,7 +29,7 @@ import net.minecraft.client.renderer.vertex.VertexFormat;
import net.minecraft.client.renderer.vertex.VertexFormatElement; import net.minecraft.client.renderer.vertex.VertexFormatElement;
import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumFacing;
import net.minecraft.util.math.BlockPos; import net.minecraft.util.math.BlockPos;
import net.minecraft.world.IBlockAccess; import net.minecraft.world.IWorldReader;
import java.util.Objects; import java.util.Objects;
@ -109,7 +109,7 @@ public class VertexLighterFlat extends QuadGatheringTransformer
private static VertexFormat withNormal(VertexFormat format) private static VertexFormat withNormal(VertexFormat format)
{ {
if (format == null || format.hasNormal()) return format; if (format == null || format.func_207751_b()) return format;
return new VertexFormat(format).addElement(NORMAL_4F); return new VertexFormat(format).addElement(NORMAL_4F);
} }
@ -190,10 +190,6 @@ public class VertexLighterFlat extends QuadGatheringTransformer
color[v][i] *= d; color[v][i] *= d;
} }
} }
if(EntityRenderer.anaglyphEnable)
{
applyAnaglyph(color[v]);
}
// no need for remapping cause all we could've done is add 1 element to the end // no need for remapping cause all we could've done is add 1 element to the end
for(int e = 0; e < count; e++) for(int e = 0; e < count; e++)
@ -231,14 +227,6 @@ public class VertexLighterFlat extends QuadGatheringTransformer
tint = -1; tint = -1;
} }
protected void applyAnaglyph(float[] color)
{
float r = color[0];
color[0] = (r * 30 + color[1] * 59 + color[2] * 11) / 100;
color[1] = (r * 3 + color[1] * 7) / 10;
color[2] = (r * 3 + color[2] * 7) / 10;
}
protected void updateLightmap(float[] normal, float[] lightmap, float x, float y, float z) protected void updateLightmap(float[] normal, float[] lightmap, float x, float y, float z)
{ {
final float e1 = 1f - 1e-2f; final float e1 = 1f - 1e-2f;
@ -287,7 +275,7 @@ public class VertexLighterFlat extends QuadGatheringTransformer
this.diffuse = diffuse; this.diffuse = diffuse;
} }
public void setWorld(IBlockAccess world) public void setWorld(IWorldReader world)
{ {
blockInfo.setWorld(world); blockInfo.setWorld(world);
} }

View file

@ -19,14 +19,14 @@
package net.minecraftforge.client.resource; package net.minecraftforge.client.resource;
import net.minecraftforge.fml.relauncher.Side; import net.minecraftforge.api.distmarker.Dist;
import net.minecraftforge.fml.relauncher.SideOnly; import net.minecraftforge.api.distmarker.OnlyIn;
/** /**
* An enum of all {@link IResourceType}s used by the Vanilla game. These should be used if handling vanilla-related * An enum of all {@link IResourceType}s used by the Vanilla game. These should be used if handling vanilla-related
* resources. * resources.
*/ */
@SideOnly(Side.CLIENT) @OnlyIn(Dist.CLIENT)
public enum VanillaResourceType implements IResourceType public enum VanillaResourceType implements IResourceType
{ {
/** /**

View file

@ -98,7 +98,7 @@ public final class TRSRTransformation implements IModelState, ITransformation
@OnlyIn(Dist.CLIENT) @OnlyIn(Dist.CLIENT)
public static TRSRTransformation from(ItemTransformVec3f transform) public static TRSRTransformation from(ItemTransformVec3f transform)
{ {
return transform.equals(ItemTransformVec3f.DEFAULT) ? identity : new TRSRTransformation(transform); return transform.equals(ItemTransformVec3f.DEFAULT) ? identity : new TRSRTransformation(toVecmath(transform.translation), quatFromXYZDegrees(toVecmath(transform.rotation)), toVecmath(transform.scale), null);
} }
@OnlyIn(Dist.CLIENT) @OnlyIn(Dist.CLIENT)
@ -711,6 +711,10 @@ public final class TRSRTransformation implements IModelState, ITransformation
m.func_195885_a(0, 3), m.func_195885_a(1, 3), m.func_195885_a(2, 3), m.func_195885_a(3, 3)); m.func_195885_a(0, 3), m.func_195885_a(1, 3), m.func_195885_a(2, 3), m.func_195885_a(3, 3));
} }
public static Quat4f toVecmath(net.minecraft.client.renderer.Quaternion q)
{
return new Quat4f(q.func_195889_a(), q.func_195891_b(), q.func_195893_c(), q.func_195894_d());
}
@OnlyIn(Dist.CLIENT) @OnlyIn(Dist.CLIENT)
public static net.minecraft.client.renderer.Vector3f toMojang(Vector3f vec) public static net.minecraft.client.renderer.Vector3f toMojang(Vector3f vec)

View file

@ -218,13 +218,13 @@ public final class AnimationStateMachine implements IAnimationStateMachine
@OnlyIn(Dist.CLIENT) @OnlyIn(Dist.CLIENT)
public static IAnimationStateMachine load(IResourceManager manager, ResourceLocation location, ImmutableMap<String, ITimeValue> customParameters) public static IAnimationStateMachine load(IResourceManager manager, ResourceLocation location, ImmutableMap<String, ITimeValue> customParameters)
{ {
try (IResource resource = manager.getResource(location)) try (IResource resource = manager.func_199002_a(location))
{ {
ClipResolver clipResolver = new ClipResolver(); ClipResolver clipResolver = new ClipResolver();
ParameterResolver parameterResolver = new ParameterResolver(customParameters); ParameterResolver parameterResolver = new ParameterResolver(customParameters);
Clips.CommonClipTypeAdapterFactory.INSTANCE.setClipResolver(clipResolver); Clips.CommonClipTypeAdapterFactory.INSTANCE.setClipResolver(clipResolver);
TimeValues.CommonTimeValueTypeAdapterFactory.INSTANCE.setValueResolver(parameterResolver); TimeValues.CommonTimeValueTypeAdapterFactory.INSTANCE.setValueResolver(parameterResolver);
AnimationStateMachine asm = asmGson.fromJson(new InputStreamReader(resource.getInputStream(), StandardCharsets.UTF_8), AnimationStateMachine.class); AnimationStateMachine asm = asmGson.fromJson(new InputStreamReader(resource.func_199027_b(), StandardCharsets.UTF_8), AnimationStateMachine.class);
clipResolver.asm = asm; clipResolver.asm = asm;
parameterResolver.asm = asm; parameterResolver.asm = asm;
asm.initialize(); asm.initialize();

View file

@ -19,14 +19,13 @@
package net.minecraftforge.common.model.animation; package net.minecraftforge.common.model.animation;
import java.util.concurrent.Callable;
import net.minecraft.nbt.INBTBase; import net.minecraft.nbt.INBTBase;
import net.minecraft.util.EnumFacing; import net.minecraft.util.EnumFacing;
import net.minecraftforge.common.capabilities.Capability; import net.minecraftforge.common.capabilities.Capability;
import net.minecraftforge.common.capabilities.CapabilityInject; import net.minecraftforge.common.capabilities.CapabilityInject;
import net.minecraftforge.common.capabilities.CapabilityManager; import net.minecraftforge.common.capabilities.CapabilityManager;
import net.minecraftforge.common.capabilities.ICapabilityProvider; import net.minecraftforge.common.capabilities.ICapabilityProvider;
import net.minecraftforge.common.capabilities.OptionalCapabilityInstance;
import javax.annotation.Nonnull; import javax.annotation.Nonnull;
import javax.annotation.Nullable; import javax.annotation.Nullable;
@ -60,15 +59,9 @@ public class CapabilityAnimation
this.asm = asm; this.asm = asm;
} }
@Override
public boolean hasCapability(@Nonnull Capability<?> capability, @Nullable EnumFacing facing)
{
return capability == ANIMATION_CAPABILITY;
}
@Override @Override
@Nullable @Nullable
public <T> T getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing) public <T> OptionalCapabilityInstance<T> getCapability(@Nonnull Capability<T> capability, @Nullable EnumFacing facing)
{ {
if(capability == ANIMATION_CAPABILITY) if(capability == ANIMATION_CAPABILITY)
{ {

View file

@ -21,6 +21,7 @@ package net.minecraftforge.common.model.animation;
import java.io.IOException; import java.io.IOException;
import net.minecraft.client.renderer.block.model.IUnbakedModel;
import net.minecraft.client.renderer.block.model.ModelResourceLocation; import net.minecraft.client.renderer.block.model.ModelResourceLocation;
import net.minecraft.util.IStringSerializable; import net.minecraft.util.IStringSerializable;
import net.minecraft.util.math.MathHelper; import net.minecraft.util.math.MathHelper;
@ -33,11 +34,12 @@ import net.minecraftforge.common.animation.ITimeValue;
import net.minecraftforge.common.model.IModelPart; import net.minecraftforge.common.model.IModelPart;
import net.minecraftforge.common.model.IModelState; import net.minecraftforge.common.model.IModelState;
import net.minecraftforge.common.model.TRSRTransformation; import net.minecraftforge.common.model.TRSRTransformation;
import net.minecraftforge.fml.common.FMLLog;
import net.minecraftforge.api.distmarker.Dist; import net.minecraftforge.api.distmarker.Dist;
import org.apache.commons.lang3.NotImplementedException; import org.apache.commons.lang3.NotImplementedException;
import org.apache.commons.lang3.tuple.Pair; import org.apache.commons.lang3.tuple.Pair;
import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger;
import java.util.function.Function; import java.util.function.Function;
import com.google.common.base.Objects; import com.google.common.base.Objects;
@ -59,6 +61,8 @@ import javax.annotation.Nullable;
*/ */
public final class Clips public final class Clips
{ {
private static final Logger LOGGER = LogManager.getLogger();
/** /**
* Clip that does nothing. * Clip that does nothing.
*/ */
@ -91,13 +95,13 @@ public final class Clips
@OnlyIn(Dist.CLIENT) @OnlyIn(Dist.CLIENT)
public static IClip getModelClipNode(ResourceLocation modelLocation, String clipName) public static IClip getModelClipNode(ResourceLocation modelLocation, String clipName)
{ {
IModel model = ModelLoaderRegistry.getModelOrMissing(modelLocation); IUnbakedModel model = ModelLoaderRegistry.getModelOrMissing(modelLocation);
Optional<? extends IClip> clip = model.getClip(clipName); Optional<? extends IClip> clip = model.getClip(clipName);
if (clip.isPresent()) if (clip.isPresent())
{ {
return new ModelClip(clip.get(), modelLocation, clipName); return new ModelClip(clip.get(), modelLocation, clipName);
} }
FMLLog.log.error("Unable to find clip {} in the model {}", clipName, modelLocation); LOGGER.error("Unable to find clip {} in the model {}", clipName, modelLocation);
// FIXME: missing clip? // FIXME: missing clip?
return new ModelClip(IdentityClip.INSTANCE, modelLocation, clipName); return new ModelClip(IdentityClip.INSTANCE, modelLocation, clipName);
} }

View file

@ -24,19 +24,14 @@ import com.google.common.collect.HashMultimap;
import com.google.common.collect.Multimap; import com.google.common.collect.Multimap;
import net.minecraft.block.state.IBlockState; import net.minecraft.block.state.IBlockState;
import net.minecraft.client.renderer.BlockModelShapes; import net.minecraft.client.renderer.BlockModelShapes;
import net.minecraft.client.renderer.block.model.IBakedModel;
import net.minecraft.client.renderer.block.model.ModelResourceLocation; import net.minecraft.client.renderer.block.model.ModelResourceLocation;
import net.minecraft.item.Item; import net.minecraft.item.Item;
import net.minecraft.util.ResourceLocation;
import net.minecraft.util.registry.IRegistry;
import net.minecraftforge.client.model.ModelLoader; import net.minecraftforge.client.model.ModelLoader;
import net.minecraftforge.fml.common.FMLLog;
import net.minecraftforge.registries.ForgeRegistries; import net.minecraftforge.registries.ForgeRegistries;
import org.apache.logging.log4j.message.SimpleMessage; import org.apache.logging.log4j.message.SimpleMessage;
import java.util.Collection; import java.util.Collection;
import java.util.Map;
import java.util.function.Function; import java.util.function.Function;
import static net.minecraftforge.client.model.ModelLoader.getInventoryVariant; import static net.minecraftforge.client.model.ModelLoader.getInventoryVariant;
@ -45,39 +40,35 @@ public class ModelLoaderErrorMessage extends SimpleMessage
{ {
private final ModelResourceLocation resourceLocation; private final ModelResourceLocation resourceLocation;
private final Exception exception; private final Exception exception;
private final IRegistry<ModelResourceLocation, IBakedModel> modelRegistry;
private static Multimap<ModelResourceLocation, IBlockState> reverseBlockMap = HashMultimap.create(); private static Multimap<ModelResourceLocation, IBlockState> reverseBlockMap = HashMultimap.create();
private static Multimap<ModelResourceLocation, String> reverseItemMap = HashMultimap.create(); private static Multimap<ModelResourceLocation, String> reverseItemMap = HashMultimap.create();
private static void buildLookups(final BlockModelShapes blockModelShapes, Function<Item,Iterable<String>> itemNameLookup) { private static void buildLookups() {
if (!reverseBlockMap.isEmpty()) return; if (!reverseBlockMap.isEmpty()) return;
for(Map.Entry<IBlockState, ModelResourceLocation> entry : blockModelShapes.getBlockStateMapper().putAllStateModelLocations().entrySet())
{ ForgeRegistries.BLOCKS.getValues().stream()
reverseBlockMap.put(entry.getValue(), entry.getKey()); .flatMap(block -> block.getBlockState().getValidStates().stream())
} .forEach(state -> reverseBlockMap.put(BlockModelShapes.func_209554_c(state), state));
ForgeRegistries.ITEMS.forEach(item -> ForgeRegistries.ITEMS.forEach(item ->
{ {
for(String s : itemNameLookup.apply(item)) ModelResourceLocation memory = getInventoryVariant(ForgeRegistries.ITEMS.getKey(item).toString());
{ reverseItemMap.put(memory, item.getRegistryName().toString());
ModelResourceLocation memory = getInventoryVariant(s);
reverseItemMap.put(memory, item.getRegistryName().toString());
}
}); });
} }
public ModelLoaderErrorMessage(ModelResourceLocation resourceLocation, Exception exception, IRegistry<ModelResourceLocation, IBakedModel> modelRegistry, BlockModelShapes blockModelShapes, Function<Item, Iterable<String>> itemNameLookup) public ModelLoaderErrorMessage(ModelResourceLocation resourceLocation, Exception exception)
{ {
// if we're logging these error messages, this will get built for reference // if we're logging these error messages, this will get built for reference
buildLookups(blockModelShapes, itemNameLookup); buildLookups();
this.resourceLocation = resourceLocation; this.resourceLocation = resourceLocation;
this.exception = exception; this.exception = exception;
this.modelRegistry = modelRegistry;
} }
private void stuffs() { private void stuffs() {
String domain = resourceLocation.getResourceDomain(); String domain = resourceLocation.getNamespace();
String errorMsg = "Exception loading model for variant " + resourceLocation; String errorMsg = "Exception loading model for variant " + resourceLocation;
Collection<IBlockState> blocks = reverseBlockMap.get(resourceLocation); Collection<IBlockState> blocks = reverseBlockMap.get(resourceLocation);
if(!blocks.isEmpty()) if(!blocks.isEmpty())

View file

@ -107,9 +107,12 @@ public net.minecraft.item.crafting.RecipesBanners$RecipeDuplicatePattern
public net.minecraft.block.state.BlockStateContainer$StateImplementation public net.minecraft.block.state.BlockStateContainer$StateImplementation
protected net.minecraft.block.state.BlockStateContainer$StateImplementation <init>(Lnet/minecraft/block/Block;Lcom/google/common/collect/ImmutableMap;)V protected net.minecraft.block.state.BlockStateContainer$StateImplementation <init>(Lnet/minecraft/block/Block;Lcom/google/common/collect/ImmutableMap;)V
protected net.minecraft.block.state.BlockStateContainer$StateImplementation field_177238_c # propertyValueTable protected net.minecraft.block.state.BlockStateContainer$StateImplementation field_177238_c # propertyValueTable
# ModelBlock
public net.minecraft.client.renderer.block.model.ModelBlock field_178318_c # textures public net.minecraft.client.renderer.block.model.ModelBlock field_178318_c # textures
public net.minecraft.client.renderer.block.model.ModelBlock field_178315_d # parent public net.minecraft.client.renderer.block.model.ModelBlock field_178315_d # parent
public net.minecraft.client.renderer.block.model.ModelBlock field_178322_i # ambientOcclusion public net.minecraft.client.renderer.block.model.ModelBlock field_178322_i # ambientOcclusion
public net.minecraft.client.renderer.block.model.ModelBlock func_209568_a(Lnet/minecraft/client/renderer/block/model/ModelBlock;Ljava/util/function/Function;Ljava/util/function/Function;)Lnet/minecraft/client/renderer/block/model/ItemOverrideList; # getOverrides
public net.minecraft.client.renderer.block.model.ModelBlock func_187966_f()Ljava/util/List; # getOverrides public net.minecraft.client.renderer.block.model.ModelBlock func_187966_f()Ljava/util/List; # getOverrides
# ModelBakery # ModelBakery
@ -145,7 +148,11 @@ protected net.minecraft.client.renderer.block.model.ModelBakery func_188638_a(Ln
#public net.minecraft.client.renderer.block.model.WeightedBakedModel field_177565_b # models #public net.minecraft.client.renderer.block.model.WeightedBakedModel field_177565_b # models
# ItemModelMesher # ItemModelMesher
protected net.minecraft.client.renderer.ItemModelMesher field_178092_c # shapers # This field is public and uses int IDs, so we hide it and expose ItemModelMesherForge methods instead
private net.minecraft.client.renderer.ItemModelMesher field_199313_a
# ItemOverrideList
protected net.minecraft.client.renderer.block.model.ItemOverrideList <init>()V
# EnumFacing # EnumFacing
public net.minecraft.util.EnumFacing field_82609_l # VALUES public net.minecraft.util.EnumFacing field_82609_l # VALUES