Fix bucket model. Some mask textures were not added to the repository, and the bucket override generation was broken.

Fix OBJ loading crash due to a float value being parsed as int.
Fixes 6377
This commit is contained in:
David Quintana 2019-12-20 02:42:01 +01:00
parent 40de19f16e
commit 503d277033
15 changed files with 70 additions and 82 deletions

View file

@ -1,6 +1,13 @@
--- a/net/minecraft/client/renderer/model/BakedQuad.java --- a/net/minecraft/client/renderer/model/BakedQuad.java
+++ b/net/minecraft/client/renderer/model/BakedQuad.java +++ b/net/minecraft/client/renderer/model/BakedQuad.java
@@ -12,7 +12,17 @@ @@ -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[] field_178215_a;
protected final int field_178213_b;
protected final Direction field_178214_c; protected final Direction field_178214_c;
protected final TextureAtlasSprite field_187509_d; protected final TextureAtlasSprite field_187509_d;
@ -18,14 +25,20 @@
this.field_178215_a = p_i46574_1_; this.field_178215_a = p_i46574_1_;
this.field_178213_b = p_i46574_2_; this.field_178213_b = p_i46574_2_;
this.field_178214_c = p_i46574_3_; this.field_178214_c = p_i46574_3_;
@@ -34,4 +44,19 @@ @@ -34,4 +44,25 @@
public Direction func_178210_d() { public Direction func_178210_d() {
return this.field_178214_c; return this.field_178214_c;
} }
+ +
+ // Forge start
+ protected final net.minecraft.client.renderer.vertex.VertexFormat format; + protected final net.minecraft.client.renderer.vertex.VertexFormat format;
+ protected final boolean applyDiffuseLighting; + 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() { + public net.minecraft.client.renderer.vertex.VertexFormat getFormat() {
+ return format; + return format;
+ } + }

View file

@ -19,17 +19,18 @@
package net.minecraftforge.client.model; package net.minecraftforge.client.model;
import com.google.common.collect.ImmutableList;
import com.google.common.collect.ImmutableMap;
import com.mojang.datafixers.util.Pair; import com.mojang.datafixers.util.Pair;
import net.minecraft.client.renderer.TransformationMatrix; import net.minecraft.client.renderer.TransformationMatrix;
import net.minecraft.client.renderer.model.*; import net.minecraft.client.renderer.model.*;
import net.minecraft.client.renderer.vertex.DefaultVertexFormats;
import net.minecraftforge.client.model.geometry.IModelGeometry;
import net.minecraft.client.renderer.model.ItemCameraTransforms.TransformType; import net.minecraft.client.renderer.model.ItemCameraTransforms.TransformType;
import net.minecraft.client.renderer.texture.TextureAtlasSprite; import net.minecraft.client.renderer.texture.TextureAtlasSprite;
import net.minecraft.client.renderer.vertex.DefaultVertexFormats;
import net.minecraft.client.renderer.vertex.VertexFormat; import net.minecraft.client.renderer.vertex.VertexFormat;
import net.minecraft.util.Direction; import net.minecraft.util.Direction;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraftforge.client.model.geometry.IModelGeometry;
import net.minecraftforge.client.model.pipeline.IVertexConsumer; import net.minecraftforge.client.model.pipeline.IVertexConsumer;
import net.minecraftforge.client.model.pipeline.TRSRTransformer; import net.minecraftforge.client.model.pipeline.TRSRTransformer;
import net.minecraftforge.client.model.pipeline.UnpackedBakedQuad; import net.minecraftforge.client.model.pipeline.UnpackedBakedQuad;
@ -38,12 +39,10 @@ import java.util.Arrays;
import java.util.BitSet; import java.util.BitSet;
import java.util.Collection; import java.util.Collection;
import java.util.EnumMap; import java.util.EnumMap;
import java.util.List;
import java.util.Set; 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.ImmutableMap;
/** /**
* Forge reimplementation of vanilla {@link ItemModelGenerator}, i.e. builtin/generated models, * Forge reimplementation of vanilla {@link ItemModelGenerator}, i.e. builtin/generated models,
* with the following changes: * with the following changes:
@ -86,19 +85,24 @@ public final class ItemLayerModel implements IModelGeometry<ItemLayerModel>
public IBakedModel bake(IModelConfiguration owner, ModelBakery bakery, Function<Material, TextureAtlasSprite> spriteGetter, IModelTransform sprite, ItemOverrideList overrides, ResourceLocation modelLocation) public IBakedModel bake(IModelConfiguration owner, ModelBakery bakery, Function<Material, TextureAtlasSprite> spriteGetter, IModelTransform sprite, ItemOverrideList overrides, ResourceLocation modelLocation)
{ {
//TODO: Verify //TODO: Verify
ImmutableList.Builder<BakedQuad> builder = ImmutableList.builder();
TransformationMatrix transform = sprite.func_225615_b_(); TransformationMatrix transform = sprite.func_225615_b_();
boolean identity = transform.isIdentity(); ImmutableList<BakedQuad> quads = getQuadsForSprites(textures, DefaultVertexFormats.BLOCK, transform, spriteGetter);
for(int i = 0; i < textures.size(); i++)
{
TextureAtlasSprite tas = spriteGetter.apply(textures.get(i));
builder.addAll(getQuadsForSprite(i, tas, DefaultVertexFormats.BLOCK, transform));
}
TextureAtlasSprite particle = spriteGetter.apply( TextureAtlasSprite particle = spriteGetter.apply(
owner.isTexturePresent("particle") ? owner.resolveTexture("particle") : textures.get(0) owner.isTexturePresent("particle") ? owner.resolveTexture("particle") : textures.get(0)
); );
ImmutableMap<TransformType, TransformationMatrix> map = PerspectiveMapWrapper.getTransforms(sprite); ImmutableMap<TransformType, TransformationMatrix> map = PerspectiveMapWrapper.getTransforms(sprite);
return new BakedItemModel(builder.build(), particle, map, overrides, identity); return new BakedItemModel(quads, particle, map, overrides, transform.isIdentity());
}
public static ImmutableList<BakedQuad> getQuadsForSprites(List<Material> textures, VertexFormat format, TransformationMatrix transform, Function<Material, TextureAtlasSprite> spriteGetter)
{
ImmutableList.Builder<BakedQuad> builder = ImmutableList.builder();
for(int i = 0; i < textures.size(); i++)
{
TextureAtlasSprite tas = spriteGetter.apply(textures.get(i));
builder.addAll(getQuadsForSprite(i, tas, format, transform));
}
return builder.build();
} }
public static ImmutableList<BakedQuad> getQuadsForSprite(int tint, TextureAtlasSprite sprite, VertexFormat format, TransformationMatrix transform) public static ImmutableList<BakedQuad> getQuadsForSprite(int tint, TextureAtlasSprite sprite, VertexFormat format, TransformationMatrix transform)

View file

@ -19,13 +19,10 @@
package net.minecraftforge.client.model; package net.minecraftforge.client.model;
import java.io.IOException; import com.google.common.collect.ImmutableList;
import java.util.*; import com.google.common.collect.ImmutableMap;
import com.google.common.collect.Maps;
import javax.annotation.Nonnull; import com.google.common.collect.Sets;
import javax.annotation.Nullable;
import com.google.common.collect.*;
import com.google.gson.JsonDeserializationContext; import com.google.gson.JsonDeserializationContext;
import com.google.gson.JsonObject; import com.google.gson.JsonObject;
import com.mojang.datafixers.util.Pair; import com.mojang.datafixers.util.Pair;
@ -34,7 +31,9 @@ import net.minecraft.client.renderer.Quaternion;
import net.minecraft.client.renderer.TransformationMatrix; import net.minecraft.client.renderer.TransformationMatrix;
import net.minecraft.client.renderer.model.*; import net.minecraft.client.renderer.model.*;
import net.minecraft.client.renderer.model.ItemCameraTransforms.TransformType; import net.minecraft.client.renderer.model.ItemCameraTransforms.TransformType;
import net.minecraft.client.renderer.texture.*; import net.minecraft.client.renderer.texture.MissingTextureSprite;
import net.minecraft.client.renderer.texture.PngSizeInfo;
import net.minecraft.client.renderer.texture.TextureAtlasSprite;
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.entity.LivingEntity; import net.minecraft.entity.LivingEntity;
@ -48,19 +47,23 @@ import net.minecraft.util.ResourceLocation;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraftforge.client.ForgeHooksClient; import net.minecraftforge.client.ForgeHooksClient;
import net.minecraftforge.client.model.geometry.IModelGeometry; import net.minecraftforge.client.model.geometry.IModelGeometry;
import net.minecraftforge.fluids.FluidUtil;
import net.minecraftforge.registries.ForgeRegistries; import net.minecraftforge.registries.ForgeRegistries;
import net.minecraftforge.resource.IResourceType; import net.minecraftforge.resource.IResourceType;
import net.minecraftforge.resource.VanillaResourceType; import net.minecraftforge.resource.VanillaResourceType;
import net.minecraftforge.versions.forge.ForgeVersion; import net.minecraftforge.versions.forge.ForgeVersion;
import net.minecraftforge.common.model.TransformationHelper;
import net.minecraftforge.fluids.FluidUtil;
import java.util.function.Function;
import java.util.function.Predicate;
import org.apache.logging.log4j.LogManager; import org.apache.logging.log4j.LogManager;
import org.apache.logging.log4j.Logger; import org.apache.logging.log4j.Logger;
import javax.annotation.Nonnull;
import javax.annotation.Nullable;
import java.io.IOException;
import java.util.Collection;
import java.util.Map;
import java.util.Set;
import java.util.function.Function;
import java.util.function.Predicate;
public final class ModelDynBucket implements IModelGeometry<ModelDynBucket> public final class ModelDynBucket implements IModelGeometry<ModelDynBucket>
{ {
private static final Logger LOGGER = LogManager.getLogger(); private static final Logger LOGGER = LogManager.getLogger();
@ -123,7 +126,7 @@ public final class ModelDynBucket implements IModelGeometry<ModelDynBucket>
} }
@Override @Override
public IBakedModel bake(IModelConfiguration owner, ModelBakery bakery, Function<Material, TextureAtlasSprite> spriteGetter, IModelTransform sprite, ItemOverrideList overrides, ResourceLocation modelLocation) public IBakedModel bake(IModelConfiguration owner, ModelBakery bakery, Function<Material, TextureAtlasSprite> spriteGetter, IModelTransform modelTransform, ItemOverrideList overrides, ResourceLocation modelLocation)
{ {
Material particleLocation = owner.resolveTexture("particle"); Material particleLocation = owner.resolveTexture("particle");
if (MissingTextureSprite.getLocation().toString().equals(particleLocation)) if (MissingTextureSprite.getLocation().toString().equals(particleLocation))
@ -152,35 +155,30 @@ public final class ModelDynBucket implements IModelGeometry<ModelDynBucket>
IModelTransform transformsFromModel = owner.getCombinedTransform(); IModelTransform transformsFromModel = owner.getCombinedTransform();
IModelTransform state = sprite;
ImmutableMap<TransformType, TransformationMatrix> transformMap = transformsFromModel != null ? ImmutableMap<TransformType, TransformationMatrix> transformMap = transformsFromModel != null ?
PerspectiveMapWrapper.getTransforms(new ModelTransformComposition(transformsFromModel, state)) : PerspectiveMapWrapper.getTransforms(new ModelTransformComposition(transformsFromModel, modelTransform)) :
PerspectiveMapWrapper.getTransforms(state); PerspectiveMapWrapper.getTransforms(modelTransform);
TextureAtlasSprite particleSprite = particleLocation != null ? spriteGetter.apply(particleLocation) : null; TextureAtlasSprite particleSprite = particleLocation != null ? spriteGetter.apply(particleLocation) : null;
// if the fluid is lighter than air, will manipulate the initial state to be rotated 180deg to turn it upside down // if the fluid is lighter than air, will manipulate the initial state to be rotated 180deg to turn it upside down
if (flipGas && fluid != Fluids.EMPTY && fluid.getAttributes().isLighterThanAir()) if (flipGas && fluid != Fluids.EMPTY && fluid.getAttributes().isLighterThanAir())
{ {
sprite = new ModelTransformComposition(state, new SimpleModelTransform(new TransformationMatrix(null, new Quaternion(0, 0, 1, 0), null, null).blockCenterToCorner())); modelTransform = new ModelTransformComposition(modelTransform, new SimpleModelTransform(new TransformationMatrix(null, new Quaternion(0, 0, 1, 0), null, null)));
state = sprite;
} }
TransformationMatrix transform = state.func_225615_b_(); TransformationMatrix transform = modelTransform.func_225615_b_();
TextureAtlasSprite fluidSprite = fluid != Fluids.EMPTY ? spriteGetter.apply(ForgeHooksClient.getBlockMaterial(fluid.getAttributes().getStillTexture())) : null; TextureAtlasSprite fluidSprite = fluid != Fluids.EMPTY ? spriteGetter.apply(ForgeHooksClient.getBlockMaterial(fluid.getAttributes().getStillTexture())) : null;
if (particleSprite == null) particleSprite = fluidSprite; if (particleSprite == null) particleSprite = fluidSprite;
Random random = new Random();
ImmutableList.Builder<BakedQuad> builder = ImmutableList.builder(); ImmutableList.Builder<BakedQuad> builder = ImmutableList.builder();
if (baseLocation != null) if (baseLocation != null)
{ {
// build base (insidest) // build base (insidest)
IBakedModel model = new ItemLayerModel(ImmutableList.of(baseLocation)).bake(owner, bakery, spriteGetter, sprite, ItemOverrideList.EMPTY, modelLocation); builder.addAll(ItemLayerModel.getQuadsForSprites(ImmutableList.of(baseLocation), DefaultVertexFormats.BLOCK, transform, spriteGetter));
random.setSeed(42);
builder.addAll(model.getQuads(null, null, random));
} }
if (fluidMaskLocation != null && fluidSprite != null) if (fluidMaskLocation != null && fluidSprite != null)
@ -218,7 +216,7 @@ public final class ModelDynBucket implements IModelGeometry<ModelDynBucket>
} }
} }
return new BakedDynBucket(bakery, owner, this, builder.build(), particleSprite, DefaultVertexFormats.BLOCK, Maps.immutableEnumMap(transformMap), Maps.newHashMap(), transform.isIdentity()); return new BakedDynBucket(bakery, owner, this, builder.build(), particleSprite, DefaultVertexFormats.BLOCK, Maps.immutableEnumMap(transformMap), Maps.newHashMap(), transform.isIdentity(), modelTransform);
} }
@Override @Override
@ -418,7 +416,7 @@ public final class ModelDynBucket implements IModelGeometry<ModelDynBucket>
if (!model.cache.containsKey(name)) if (!model.cache.containsKey(name))
{ {
ModelDynBucket parent = model.parent.withFluid(fluid); ModelDynBucket parent = model.parent.withFluid(fluid);
IBakedModel bakedModel = parent.bake(model.owner, bakery, ModelLoader.defaultTextureGetter(), new SimpleModelTransform(model.transforms), model.getOverrides(), new ResourceLocation("forge:bucket_override")); IBakedModel bakedModel = parent.bake(model.owner, bakery, ModelLoader.defaultTextureGetter(), model.originalTransform, model.getOverrides(), new ResourceLocation("forge:bucket_override"));
model.cache.put(name, bakedModel); model.cache.put(name, bakedModel);
return bakedModel; return bakedModel;
} }
@ -437,6 +435,7 @@ public final class ModelDynBucket implements IModelGeometry<ModelDynBucket>
private final ModelDynBucket parent; private final ModelDynBucket parent;
private final Map<String, IBakedModel> cache; // contains all the baked models since they'll never change private final Map<String, IBakedModel> cache; // contains all the baked models since they'll never change
private final VertexFormat format; private final VertexFormat format;
private final IModelTransform originalTransform;
BakedDynBucket(ModelBakery bakery, BakedDynBucket(ModelBakery bakery,
IModelConfiguration owner, ModelDynBucket parent, IModelConfiguration owner, ModelDynBucket parent,
@ -445,13 +444,15 @@ public final class ModelDynBucket implements IModelGeometry<ModelDynBucket>
VertexFormat format, VertexFormat format,
ImmutableMap<TransformType, TransformationMatrix> transforms, ImmutableMap<TransformType, TransformationMatrix> transforms,
Map<String, IBakedModel> cache, Map<String, IBakedModel> cache,
boolean untransformed) boolean untransformed,
IModelTransform originalTransform)
{ {
super(quads, particle, transforms, new BakedDynBucketOverrideHandler(bakery), untransformed); super(quads, particle, transforms, new BakedDynBucketOverrideHandler(bakery), untransformed);
this.owner = owner; this.owner = owner;
this.format = format; this.format = format;
this.parent = parent; this.parent = parent;
this.cache = cache; this.cache = cache;
this.originalTransform = originalTransform;
} }
} }

View file

@ -77,7 +77,7 @@ public class PerspectiveMapWrapper implements IBakedModel
{ {
if (transforms.hasCustomTransform(type)) if (transforms.hasCustomTransform(type))
{ {
map.put(type, TransformationHelper.toTransformation(transforms.getTransform(type)).blockCenterToCorner()); map.put(type, TransformationHelper.toTransformation(transforms.getTransform(type)));
} }
} }
return ImmutableMap.copyOf(map); return ImmutableMap.copyOf(map);
@ -96,7 +96,7 @@ public class PerspectiveMapWrapper implements IBakedModel
} }
else if (transforms.hasCustomTransform(type)) else if (transforms.hasCustomTransform(type))
{ {
map.put(type, TransformationHelper.toTransformation(transforms.getTransform(type)).blockCenterToCorner()); map.put(type, TransformationHelper.toTransformation(transforms.getTransform(type)));
} }
} }
return ImmutableMap.copyOf(map); return ImmutableMap.copyOf(map);
@ -107,9 +107,7 @@ public class PerspectiveMapWrapper implements IBakedModel
TransformationMatrix tr = transforms.getOrDefault(cameraTransformType, TransformationMatrix.func_227983_a_()); TransformationMatrix tr = transforms.getOrDefault(cameraTransformType, TransformationMatrix.func_227983_a_());
if (!tr.isIdentity()) if (!tr.isIdentity())
{ {
// Push to the matrix to make it not empty and indicate that we want to transform things tr.push(mat);
mat.func_227860_a_();
mat.func_227866_c_().func_227870_a_().func_226595_a_(tr.blockCornerToCenter().func_227988_c_());
} }
return model; return model;
} }
@ -119,9 +117,7 @@ public class PerspectiveMapWrapper implements IBakedModel
TransformationMatrix tr = state.getPartTransformation(cameraTransformType); TransformationMatrix tr = state.getPartTransformation(cameraTransformType);
if (!tr.isIdentity()) if (!tr.isIdentity())
{ {
// Push to the matrix to make it not empty and indicate that we want to transform things tr.push(mat);
mat.func_227860_a_();
mat.func_227866_c_().func_227870_a_().func_226595_a_(tr.blockCornerToCenter().func_227988_c_());
} }
return model; return model;
} }

View file

@ -49,7 +49,7 @@ public class QuadTransformer
private void processVertices(int[] inData, int[] outData) private void processVertices(int[] inData, int[] outData)
{ {
// TODO: Extract rotation matrix and fix NORMALs if present. // TODO: Extract rotation matrix and fix NORMALs if present.
int stride = format.getSize() / 4; int stride = format.getIntegerSize();
for (int i=0;i<4;i++) for (int i=0;i<4;i++)
{ {
int offset = positionOffset + i * stride; int offset = positionOffset + i * stride;

View file

@ -75,7 +75,7 @@ public class MaterialLibrary
break; break;
case "Ns": case "Ns":
currentMaterial.specularHighlight = Integer.parseInt(line[1]); currentMaterial.specularHighlight = Float.parseFloat(line[1]);
break; break;
case "map_Ks": case "map_Ks":

View file

@ -58,7 +58,7 @@ public class UnpackedBakedQuad extends BakedQuad
return vertexData; return vertexData;
} }
//@Override @Override
public void pipe(IVertexConsumer consumer) public void pipe(IVertexConsumer consumer)
{ {
int[] eMap = LightUtil.mapFormats(consumer.getVertexFormat(), format); int[] eMap = LightUtil.mapFormats(consumer.getVertexFormat(), format);

Binary file not shown.

After

Width:  |  Height:  |  Size: 158 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 168 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 181 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 172 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 175 B

Binary file not shown.

Before

Width:  |  Height:  |  Size: 179 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 139 B

View file

@ -1,31 +1,5 @@
{ {
"parent": "forge:item/bucket_drip", "parent": "forge:item/bucket_drip",
"loader": "forge:bucket", "loader": "forge:bucket",
"fluid": "new_fluid_test:test_fluid", "fluid": "new_fluid_test:test_fluid"
"display": {
"ground": {
"rotation": [ 0, 0, 0 ],
"translation": [ 0, 2, 0],
"scale":[ 0.5, 0.5, 0.5 ]
},
"head": {
"rotation": [ 0, 180, 0 ],
"translation": [ 0, 13, 7],
"scale":[ 1, 1, 1]
},
"thirdperson_righthand": {
"rotation": [ 0, 0, 0 ],
"translation": [ 0, 3, 1 ],
"scale": [ 0.55, 0.55, 0.55 ]
},
"firstperson_righthand": {
"rotation": [ 0, -90, 25 ],
"translation": [ 1.13, 3.2, 1.13],
"scale": [ 0.68, 0.68, 0.68 ]
},
"fixed": {
"rotation": [ 0, 180, 0 ],
"scale": [ 1, 1, 1 ]
}
}
} }