Fix CompositeModel not respecting "display" transforms.

Remove leftovers from discarded feature.
This commit is contained in:
David Quintana 2020-01-02 06:21:43 +01:00
parent ecb56054bc
commit ca031ca33f
5 changed files with 36 additions and 211 deletions

View file

@ -23,6 +23,7 @@ import com.google.common.collect.ImmutableMap;
import com.google.gson.JsonDeserializationContext;
import com.google.gson.JsonElement;
import com.google.gson.JsonObject;
import com.mojang.blaze3d.matrix.MatrixStack;
import com.mojang.datafixers.util.Pair;
import net.minecraft.block.BlockState;
import net.minecraft.client.renderer.model.*;
@ -51,14 +52,16 @@ public class CompositeModel implements IBakedModel
private final boolean isGui3d;
private final TextureAtlasSprite particle;
private final ItemOverrideList overrides;
private final IModelTransform transforms;
public CompositeModel(boolean isGui3d, boolean isAmbientOcclusion, TextureAtlasSprite particle, ImmutableMap<String, IBakedModel> bakedParts, ItemOverrideList overrides)
public CompositeModel(boolean isGui3d, boolean isAmbientOcclusion, TextureAtlasSprite particle, ImmutableMap<String, IBakedModel> bakedParts, IModelTransform combinedTransform, ItemOverrideList overrides)
{
this.bakedParts = bakedParts;
this.isAmbientOcclusion = isAmbientOcclusion;
this.isGui3d = isGui3d;
this.particle = particle;
this.overrides = overrides;
this.transforms = combinedTransform;
}
@Nonnull
@ -116,6 +119,18 @@ public class CompositeModel implements IBakedModel
return overrides;
}
@Override
public boolean doesHandlePerspectives()
{
return true;
}
@Override
public IBakedModel handlePerspective(ItemCameraTransforms.TransformType cameraTransformType, MatrixStack mat)
{
return PerspectiveMapWrapper.handlePerspective(this, transforms, cameraTransformType, mat);
}
@Nullable
public IBakedModel getPart(String name)
{
@ -218,7 +233,7 @@ public class CompositeModel implements IBakedModel
continue;
bakedParts.put(part.getKey(), submodel.func_225613_a_(bakery, spriteGetter, modelTransform, modelLocation));
}
return new CompositeModel(owner.isShadedInGui(), owner.useSmoothLighting(), particle, bakedParts.build(), overrides);
return new CompositeModel(owner.isShadedInGui(), owner.useSmoothLighting(), particle, bakedParts.build(), owner.getCombinedTransform(), overrides);
}
@Override

View file

@ -338,46 +338,6 @@ public class OBJModel implements IMultipartModelGeometry<OBJModel>
return Optional.ofNullable(parts.get(name));
}
public VertexFormat calculateBestVertexFormat(@Nullable VertexFormat base)
{
List<VertexFormatElement> elements = Lists.newArrayList(base.func_227894_c_());
addElementIfNotPresent(elements, DefaultVertexFormats.POSITION_3F);
if (texCoords.size() > 0)
{
addElementIfNotPresent(elements, DefaultVertexFormats.TEX_2F);
}
if (normals.size() > 0)
{
addElementIfNotPresent(elements, DefaultVertexFormats.NORMAL_3B);
addElementIfNotPresent(elements, DefaultVertexFormats.PADDING_1B);
}
if (colors.size() > 0)
{
addElementIfNotPresent(elements, DefaultVertexFormats.COLOR_4UB);
}
if (ambientToFullbright && parts.values().stream().anyMatch(ModelGroup::hasAnyFullBright))
{
addElementIfNotPresent(elements, DefaultVertexFormats.TEX_2S);
}
return new VertexFormat(ImmutableList.copyOf(elements));
}
private static void addElementIfNotPresent(List<VertexFormatElement> fmt, VertexFormatElement element)
{
for(VertexFormatElement e : fmt)
{
if (e.getUsage() == element.getUsage() && e.getIndex() == element.getIndex())
return;
}
fmt.add(element);
}
private Pair<BakedQuad,Direction> makeQuad(int[][] indices, int tintIndex, Vector4f colorTint, Vector4f ambientColor, boolean isFullbright, TextureAtlasSprite texture, VertexFormat format, TransformationMatrix transform)
{
boolean needsNormalRecalculation = false;
@ -539,23 +499,6 @@ public class OBJModel implements IMultipartModelGeometry<OBJModel>
}
}
/*
public BakedGeometryRenderable<Void> bakeRenderable()
{
return bakeRenderable(DummyAtlasSprite.GETTER);
}
public BakedGeometryRenderable<Void> bakeRenderable(Function<ResourceLocation, TextureAtlasSprite> spriteGetter)
{
return BakedGeometryRenderable.of(GL11.GL_QUADS, calculateBestVertexFormat(null), ((bufferBuilder, fmt) -> {
this.addQuads(
new StandaloneModelConfiguration("", true, diffuseLighting),
new VertexBufferModelBuilder(bufferBuilder),
null, spriteGetter, SimpleModelTransform.IDENTITY, fmt);
}));
}
*/
public class ModelObject implements IModelGeometryPart
{
public final String name;
@ -668,86 +611,4 @@ public class OBJModel implements IMultipartModelGeometry<OBJModel>
return mat != null && TransformationHelper.epsilonEquals(mat.ambientColor, new Vector4f(1,1,1,1), 1/256f);
}
}
/*
private static class VertexBufferModelBuilder implements IModelBuilder<VertexBufferModelBuilder>
{
private final BufferBuilder bufferBuilder;
public VertexBufferModelBuilder(BufferBuilder bufferBuilder)
{
this.bufferBuilder = bufferBuilder;
}
@Override
public VertexBufferModelBuilder addFaceQuad(Direction facing, BakedQuad quad)
{
LightUtil.renderQuadColor(bufferBuilder, quad, -1);
return this;
}
@Override
public VertexBufferModelBuilder addGeneralQuad(BakedQuad quad)
{
LightUtil.renderQuadColor(bufferBuilder, quad, -1);
return this;
}
@Override
public IBakedModel build()
{
return null;
}
}
private static class StandaloneModelConfiguration implements IModelConfiguration
{
private final String modelName;
private final boolean diffuseLighting;
private final boolean directionalLighting;
private StandaloneModelConfiguration(String modelName, boolean directionalLighting, boolean diffuseLighting)
{
this.modelName = modelName;
this.directionalLighting = directionalLighting;
this.diffuseLighting = diffuseLighting;
}
@Override
public String getModelName()
{
return modelName;
}
@Override
public Material resolveTexture(String name)
{
return "";
}
@Override
public boolean isShadedInGui()
{
return directionalLighting;
}
@Override
public boolean useSmoothLighting()
{
return diffuseLighting;
}
@Override
public ItemCameraTransforms getCameraTransforms()
{
return ItemCameraTransforms.DEFAULT;
}
@Override
public IModelTransform getCombinedTransform()
{
return SimpleModelTransform.IDENTITY;
}
}
*/
}

View file

@ -98,37 +98,5 @@ public class NewModelLoaderTest
BLOCKS.register(modEventBus);
ITEMS.register(modEventBus);
/*DistExecutor.runWhenOn(Dist.CLIENT, () -> () -> {
MinecraftForge.EVENT_BUS.addListener(this::renderGuiOverlay);
});*/
}
/*
private NonNullLazy<IRenderable.Configured<?>> modelRenderer = NonNullLazy.of(() -> {
OBJModel model = OBJLoader.INSTANCE.loadModel(new ResourceLocation("new_model_loader_test", "models/item/sugar_glider.obj"), false, false, true, false);
return IRenderable.withParameter(model.bakeRenderable(ModelLoader.defaultTextureGetter()), null);
});
private NonNullLazy<BakedModelRenderable> modelRenderer2 = NonNullLazy.of(() -> {
return BakedModelRenderable.of(new ItemStack(Items.COAL));
});
public void renderGuiOverlay(RenderGameOverlayEvent.Post event)
{
if (event.getType() == RenderGameOverlayEvent.ElementType.ALL)
{
Minecraft mc = Minecraft.getInstance();
mc.getTextureManager().bindTexture(AtlasTexture.LOCATION_BLOCKS_TEXTURE);
RenderSystem.pushMatrix();
RenderSystem.translatef(event.getWindow().getScaledWidth() / 2.0f, event.getWindow().getScaledHeight() / 2.0f, 200);
RenderSystem.scalef(16,16,16);
//mc.getItemRenderer().renderItemAndEffectIntoGUI(new ItemStack(Items.COAL),0,0);
modelRenderer.get().render();
RenderSystem.translatef(1,1,1);
modelRenderer2.get().render(new BakedModelRenderable.Context().withPerspective(ItemCameraTransforms.TransformType.GUI).withStack(new ItemStack(Items.COAL)));
RenderSystem.popMatrix();
}
}
*/
}

View file

@ -1,14 +0,0 @@
{
"parent": "forge:item/default",
"loader": "forge:composite",
"models": [
{
"loader": "...",
"transform": {}
},
{
"loader": "...",
"transform": {}
}
]
}

View file

@ -16,39 +16,34 @@
},
"display": {
"gui": {
"rotation": [ 30, 45, 0 ],
"translation": [ 0, 3, 0 ],
"scale": [ 1, 1, 1 ]
},
"fixed": {
"rotation": [ 22, 180, 0 ],
"translation": [ 0, 4, 0],
"scale":[ 1, 1, 1 ]
"rotation": [ 30, 225, 0 ],
"translation": [ 0, 0, 0],
"scale":[ 0.625, 1.625, 0.625 ]
},
"ground": {
"rotation": [ 0, 0, 0 ],
"translation": [ 0, 3, 0 ],
"scale": [ 0.5, 0.5, 0.5 ]
"translation": [ 0, 3, 0],
"scale":[ 0.25, 0.25, 0.25 ]
},
"head": {
"rotation": [ 0, 180, 0 ],
"translation": [ 0, 5, 0 ],
"scale":[ 1.5, 1.5, 1.5 ]
"fixed": {
"rotation": [ 0, 0, 0 ],
"translation": [ 0, 0, 0],
"scale":[ 0.5, 0.5, 0.5 ]
},
"thirdperson_righthand": {
"rotation": [ 45, 45, 0 ],
"translation": [ 0, 3, 0 ],
"scale": [ 0.5, 0.5, 0.5 ]
}
"rotation": [ 75, 45, 0 ],
"translation": [ 0, 2.5, 0],
"scale": [ 0.375, 0.375, 0.375 ]
},
"transform": {
"firstperson_righthand": {
"scale": 2.0,
"translation": [0,0.5,0]
"rotation": [ 0, 45, 0 ],
"translation": [ 0, 0, 0 ],
"scale": [ 0.40, 0.40, 0.40 ]
},
"firstperson_lefthand": {
"scale": 0.5,
"translation": [0,1.5,1.5]
"rotation": [ 0, 225, 0 ],
"translation": [ 0, 0, 0 ],
"scale": [ 0.40, 0.40, 0.40 ]
}
},
"visibility": {