mirror of
https://github.com/Creators-of-Create/Create.git
synced 2025-01-01 01:47:02 +01:00
Copper armor fixes
- Add backtank layer to all player models - Only add backtank layer if entity renderer returns BipedModel - Make copper armor considered to be worn only when in the correct armor slot
This commit is contained in:
parent
74d57f38fe
commit
1d6da03799
3 changed files with 30 additions and 21 deletions
|
@ -35,6 +35,7 @@ import net.minecraft.block.Block;
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
import net.minecraft.client.gui.screen.Screen;
|
import net.minecraft.client.gui.screen.Screen;
|
||||||
import net.minecraft.client.renderer.BlockModelShapes;
|
import net.minecraft.client.renderer.BlockModelShapes;
|
||||||
|
import net.minecraft.client.renderer.entity.EntityRendererManager;
|
||||||
import net.minecraft.client.renderer.model.IBakedModel;
|
import net.minecraft.client.renderer.model.IBakedModel;
|
||||||
import net.minecraft.client.renderer.model.ModelResourceLocation;
|
import net.minecraft.client.renderer.model.ModelResourceLocation;
|
||||||
import net.minecraft.client.settings.GraphicsFanciness;
|
import net.minecraft.client.settings.GraphicsFanciness;
|
||||||
|
@ -112,7 +113,8 @@ public class CreateClient {
|
||||||
((IReloadableResourceManager) resourceManager).registerReloadListener(new ResourceReloadHandler());
|
((IReloadableResourceManager) resourceManager).registerReloadListener(new ResourceReloadHandler());
|
||||||
|
|
||||||
event.enqueueWork(() -> {
|
event.enqueueWork(() -> {
|
||||||
CopperBacktankArmorLayer.register();
|
registerLayerRenderers(Minecraft.getInstance()
|
||||||
|
.getEntityRenderDispatcher());
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -174,6 +176,10 @@ public class CreateClient {
|
||||||
modelRegistry.put(location, factory.apply(modelRegistry.get(location)));
|
modelRegistry.put(location, factory.apply(modelRegistry.get(location)));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected static void registerLayerRenderers(EntityRendererManager renderManager) {
|
||||||
|
CopperBacktankArmorLayer.registerOnAll(renderManager);
|
||||||
|
}
|
||||||
|
|
||||||
public static CustomItemModels getCustomItemModels() {
|
public static CustomItemModels getCustomItemModels() {
|
||||||
if (customItemModels == null)
|
if (customItemModels == null)
|
||||||
customItemModels = new CustomItemModels();
|
customItemModels = new CustomItemModels();
|
||||||
|
|
|
@ -3,6 +3,7 @@ package com.simibubi.create.content.curiosities.armor;
|
||||||
import com.simibubi.create.Create;
|
import com.simibubi.create.Create;
|
||||||
|
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
|
import net.minecraft.entity.LivingEntity;
|
||||||
import net.minecraft.inventory.EquipmentSlotType;
|
import net.minecraft.inventory.EquipmentSlotType;
|
||||||
import net.minecraft.item.ArmorItem;
|
import net.minecraft.item.ArmorItem;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
@ -14,10 +15,10 @@ public class CopperArmorItem extends ArmorItem {
|
||||||
}
|
}
|
||||||
|
|
||||||
public boolean isWornBy(Entity entity) {
|
public boolean isWornBy(Entity entity) {
|
||||||
for (ItemStack itemStack : entity.getArmorSlots())
|
if (!(entity instanceof LivingEntity))
|
||||||
if (itemStack.getItem() == this)
|
|
||||||
return true;
|
|
||||||
return false;
|
return false;
|
||||||
|
LivingEntity livingEntity = (LivingEntity) entity;
|
||||||
|
return livingEntity.getItemBySlot(slot).getItem() == this;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -21,7 +21,9 @@ import net.minecraft.client.renderer.IRenderTypeBuffer.Impl;
|
||||||
import net.minecraft.client.renderer.RenderType;
|
import net.minecraft.client.renderer.RenderType;
|
||||||
import net.minecraft.client.renderer.entity.EntityRenderer;
|
import net.minecraft.client.renderer.entity.EntityRenderer;
|
||||||
import net.minecraft.client.renderer.entity.EntityRendererManager;
|
import net.minecraft.client.renderer.entity.EntityRendererManager;
|
||||||
|
import net.minecraft.client.renderer.entity.IEntityRenderer;
|
||||||
import net.minecraft.client.renderer.entity.LivingRenderer;
|
import net.minecraft.client.renderer.entity.LivingRenderer;
|
||||||
|
import net.minecraft.client.renderer.entity.PlayerRenderer;
|
||||||
import net.minecraft.client.renderer.entity.layers.LayerRenderer;
|
import net.minecraft.client.renderer.entity.layers.LayerRenderer;
|
||||||
import net.minecraft.client.renderer.entity.model.BipedModel;
|
import net.minecraft.client.renderer.entity.model.BipedModel;
|
||||||
import net.minecraft.client.renderer.entity.model.EntityModel;
|
import net.minecraft.client.renderer.entity.model.EntityModel;
|
||||||
|
@ -35,41 +37,37 @@ import net.minecraft.util.text.StringTextComponent;
|
||||||
|
|
||||||
public class CopperBacktankArmorLayer<T extends LivingEntity, M extends EntityModel<T>> extends LayerRenderer<T, M> {
|
public class CopperBacktankArmorLayer<T extends LivingEntity, M extends EntityModel<T>> extends LayerRenderer<T, M> {
|
||||||
|
|
||||||
private LivingRenderer<T, M> renderer;
|
public CopperBacktankArmorLayer(IEntityRenderer<T, M> renderer) {
|
||||||
|
|
||||||
public CopperBacktankArmorLayer(LivingRenderer<T, M> renderer) {
|
|
||||||
super(renderer);
|
super(renderer);
|
||||||
this.renderer = renderer;
|
|
||||||
renderer.addLayer(this);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void render(MatrixStack ms, IRenderTypeBuffer buffer, int light, LivingEntity entity, float yaw, float pitch,
|
public void render(MatrixStack ms, IRenderTypeBuffer buffer, int light, LivingEntity entity, float yaw, float pitch,
|
||||||
float pt, float p_225628_8_, float p_225628_9_, float p_225628_10_) {
|
float pt, float p_225628_8_, float p_225628_9_, float p_225628_10_) {
|
||||||
|
|
||||||
if (entity.getPose() == Pose.SLEEPING)
|
if (entity.getPose() == Pose.SLEEPING)
|
||||||
return;
|
return;
|
||||||
if (!AllItems.COPPER_BACKTANK.get()
|
if (!AllItems.COPPER_BACKTANK.get()
|
||||||
.isWornBy(entity))
|
.isWornBy(entity))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
M entityModel = renderer.getModel();
|
M entityModel = getParentModel();
|
||||||
if (!(entityModel instanceof BipedModel))
|
if (!(entityModel instanceof BipedModel))
|
||||||
return;
|
return;
|
||||||
|
|
||||||
ms.pushPose();
|
|
||||||
BipedModel<?> model = (BipedModel<?>) entityModel;
|
BipedModel<?> model = (BipedModel<?>) entityModel;
|
||||||
|
RenderType renderType = Atlases.cutoutBlockSheet();
|
||||||
BlockState renderedState = AllBlocks.COPPER_BACKTANK.getDefaultState()
|
BlockState renderedState = AllBlocks.COPPER_BACKTANK.getDefaultState()
|
||||||
.setValue(CopperBacktankBlock.HORIZONTAL_FACING, Direction.SOUTH);
|
.setValue(CopperBacktankBlock.HORIZONTAL_FACING, Direction.SOUTH);
|
||||||
RenderType renderType = Atlases.cutoutBlockSheet();
|
|
||||||
|
|
||||||
SuperByteBuffer backtank = CreateClient.BUFFER_CACHE.renderBlock(renderedState);
|
SuperByteBuffer backtank = CreateClient.BUFFER_CACHE.renderBlock(renderedState);
|
||||||
SuperByteBuffer cogs =
|
SuperByteBuffer cogs =
|
||||||
CreateClient.BUFFER_CACHE.renderPartial(AllBlockPartials.COPPER_BACKTANK_COGS, renderedState);
|
CreateClient.BUFFER_CACHE.renderPartial(AllBlockPartials.COPPER_BACKTANK_COGS, renderedState);
|
||||||
|
|
||||||
|
ms.pushPose();
|
||||||
|
|
||||||
model.body.translateAndRotate(ms);
|
model.body.translateAndRotate(ms);
|
||||||
ms.translate(-1 / 2f, 10 / 16f, 1f);
|
ms.translate(-1 / 2f, 10 / 16f, 1f);
|
||||||
ms.scale(1, -1, -1);
|
ms.scale(1, -1, -1);
|
||||||
|
|
||||||
backtank.forEntityRender()
|
backtank.forEntityRender()
|
||||||
.light(light)
|
.light(light)
|
||||||
.renderInto(ms, buffer.getBuffer(renderType));
|
.renderInto(ms, buffer.getBuffer(renderType));
|
||||||
|
@ -89,18 +87,22 @@ public class CopperBacktankArmorLayer<T extends LivingEntity, M extends EntityMo
|
||||||
ms.popPose();
|
ms.popPose();
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void register() {
|
public static void registerOnAll(EntityRendererManager renderManager) {
|
||||||
EntityRendererManager renderManager = Minecraft.getInstance()
|
for (PlayerRenderer renderer : renderManager.getSkinMap().values())
|
||||||
.getEntityRenderDispatcher();
|
registerOn(renderer);
|
||||||
registerOn(renderManager.defaultPlayerRenderer);
|
|
||||||
for (EntityRenderer<?> renderer : renderManager.renderers.values())
|
for (EntityRenderer<?> renderer : renderManager.renderers.values())
|
||||||
registerOn(renderer);
|
registerOn(renderer);
|
||||||
}
|
}
|
||||||
|
|
||||||
private static void registerOn(EntityRenderer<?> entityRenderer) {
|
@SuppressWarnings({ "rawtypes", "unchecked" })
|
||||||
|
public static void registerOn(EntityRenderer<?> entityRenderer) {
|
||||||
if (!(entityRenderer instanceof LivingRenderer))
|
if (!(entityRenderer instanceof LivingRenderer))
|
||||||
return;
|
return;
|
||||||
new CopperBacktankArmorLayer<>((LivingRenderer<?, ?>) entityRenderer);
|
LivingRenderer<?, ?> livingRenderer = (LivingRenderer<?, ?>) entityRenderer;
|
||||||
|
if (!(livingRenderer.getModel() instanceof BipedModel))
|
||||||
|
return;
|
||||||
|
CopperBacktankArmorLayer<?, ?> layer = new CopperBacktankArmorLayer<>(livingRenderer);
|
||||||
|
livingRenderer.addLayer((CopperBacktankArmorLayer) layer);
|
||||||
}
|
}
|
||||||
|
|
||||||
public static void renderRemainingAirOverlay(MatrixStack ms, Impl buffers, int light, int overlay, float pt) {
|
public static void renderRemainingAirOverlay(MatrixStack ms, Impl buffers, int light, int overlay, float pt) {
|
||||||
|
|
Loading…
Reference in a new issue