Robot now show they contents, for #1986.

This commit is contained in:
SpaceToad 2014-08-15 19:33:59 +02:00
parent 4b5e9aa23e
commit fd777f9b67
2 changed files with 72 additions and 1 deletions

View file

@ -17,8 +17,10 @@ import net.minecraft.client.model.ModelBase;
import net.minecraft.client.model.ModelRenderer; import net.minecraft.client.model.ModelRenderer;
import net.minecraft.client.renderer.RenderBlocks; import net.minecraft.client.renderer.RenderBlocks;
import net.minecraft.client.renderer.entity.Render; import net.minecraft.client.renderer.entity.Render;
import net.minecraft.client.renderer.entity.RenderItem;
import net.minecraft.client.renderer.entity.RenderManager; import net.minecraft.client.renderer.entity.RenderManager;
import net.minecraft.entity.Entity; import net.minecraft.entity.Entity;
import net.minecraft.entity.item.EntityItem;
import net.minecraft.init.Items; import net.minecraft.init.Items;
import net.minecraft.item.EnumAction; import net.minecraft.item.EnumAction;
import net.minecraft.item.ItemBlock; import net.minecraft.item.ItemBlock;
@ -35,11 +37,27 @@ import buildcraft.core.robots.EntityRobot;
public class RenderRobot extends Render implements IItemRenderer { public class RenderRobot extends Render implements IItemRenderer {
private final EntityItem dummyEntityItem = new EntityItem(null);
private final RenderItem customRenderItem;
protected ModelBase model = new ModelBase() { protected ModelBase model = new ModelBase() {
}; };
private ModelRenderer box; private ModelRenderer box;
public RenderRobot() { public RenderRobot() {
customRenderItem = new RenderItem() {
@Override
public boolean shouldBob() {
return false;
}
@Override
public boolean shouldSpreadItems() {
return false;
}
};
customRenderItem.setRenderManager(RenderManager.instance);
box = new ModelRenderer(model, 0, 0); box = new ModelRenderer(model, 0, 0);
box.addBox(-4F, -4F, -4F, 8, 8, 8); box.addBox(-4F, -4F, -4F, 8, 8, 8);
box.rotationPointX = 0; box.rotationPointX = 0;
@ -63,6 +81,34 @@ public class RenderRobot extends Render implements IItemRenderer {
box.render(factor); box.render(factor);
if (robot.getStackInSlot(0) != null) {
GL11.glPushMatrix();
GL11.glTranslatef(-0.125F, 0, -0.125F);
doRenderItem(robot.getStackInSlot(0), 1.0F);
GL11.glPopMatrix();
}
if (robot.getStackInSlot(1) != null) {
GL11.glPushMatrix();
GL11.glTranslatef(+0.125F, 0, -0.125F);
doRenderItem(robot.getStackInSlot(1), 1.0F);
GL11.glPopMatrix();
}
if (robot.getStackInSlot(2) != null) {
GL11.glPushMatrix();
GL11.glTranslatef(+0.125F, 0, +0.125F);
doRenderItem(robot.getStackInSlot(2), 1.0F);
GL11.glPopMatrix();
}
if (robot.getStackInSlot(3) != null) {
GL11.glPushMatrix();
GL11.glTranslatef(-0.125F, 0, +0.125F);
doRenderItem(robot.getStackInSlot(3), 1.0F);
GL11.glPopMatrix();
}
if (robot.itemInUse != null) { if (robot.itemInUse != null) {
GL11.glPushMatrix(); GL11.glPushMatrix();
@ -267,4 +313,16 @@ public class RenderRobot extends Render implements IItemRenderer {
} }
} }
private void doRenderItem(ItemStack stack, float light) {
float renderScale = 0.5f;
GL11.glPushMatrix();
GL11.glTranslatef(0, 0.28F, 0);
GL11.glScalef(renderScale, renderScale, renderScale);
dummyEntityItem.setEntityItemStack(stack);
customRenderItem.doRender(dummyEntityItem, 0, 0, 0, 0, 0);
GL11.glPopMatrix();
}
} }

View file

@ -251,7 +251,7 @@ public class EntityRobot extends EntityRobotBase implements
if (energyFX >= 10) { if (energyFX >= 10) {
energyFX = 0; energyFX = 0;
ForgeDirection dir = ForgeDirection.values()[worldObj.rand.nextInt(6)]; ForgeDirection dir = ForgeDirection.values()[worldObj.rand.nextInt(6)];
dir = ForgeDirection.UP; dir = ForgeDirection.DOWN;
Minecraft.getMinecraft().effectRenderer.addEffect(new EntityRobotEnergyFX( Minecraft.getMinecraft().effectRenderer.addEffect(new EntityRobotEnergyFX(
worldObj, worldObj,
posX + dir.offsetX * 0.25, posY + dir.offsetY * 0.25, posZ + dir.offsetZ * 0.25, posX + dir.offsetX * 0.25, posY + dir.offsetY * 0.25, posZ + dir.offsetZ * 0.25,
@ -567,6 +567,8 @@ public class EntityRobot extends EntityRobotBase implements
inv[var1] = null; inv[var1] = null;
} }
RPCHandler.rpcBroadcastAllPlayers(this, "rpcClientSetInventory", var1, inv[var1]);
return result; return result;
} }
@ -578,6 +580,8 @@ public class EntityRobot extends EntityRobotBase implements
@Override @Override
public void setInventorySlotContents(int var1, ItemStack var2) { public void setInventorySlotContents(int var1, ItemStack var2) {
inv[var1] = var2; inv[var1] = var2;
RPCHandler.rpcBroadcastAllPlayers(this, "rpcClientSetInventory", var1, inv[var1]);
} }
@Override @Override
@ -635,9 +639,18 @@ public class EntityRobot extends EntityRobotBase implements
itemInUse = stack; itemInUse = stack;
} }
@RPC(RPCSide.CLIENT)
private void rpcClientSetInventory(int i, ItemStack stack) {
inv[i] = stack;
}
@RPC(RPCSide.SERVER) @RPC(RPCSide.SERVER)
public void requestInitialization(RPCMessageInfo info) { public void requestInitialization(RPCMessageInfo info) {
RPCHandler.rpcPlayer(info.sender, this, "rpcInitialize", itemInUse, itemActive); RPCHandler.rpcPlayer(info.sender, this, "rpcInitialize", itemInUse, itemActive);
for (int i = 0; i < inv.length; ++i) {
RPCHandler.rpcPlayer(info.sender, this, "rpcClientSetInventory", i, inv[i]);
}
} }
@RPC(RPCSide.CLIENT) @RPC(RPCSide.CLIENT)