2013-04-28 15:23:08 -04:00
|
|
|
package mekanism.client;
|
|
|
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.Map;
|
|
|
|
|
|
|
|
import mekanism.api.Object3D;
|
2013-05-23 13:30:12 -04:00
|
|
|
import mekanism.client.MekanismRenderer.DisplayInteger;
|
2013-05-19 18:43:01 -04:00
|
|
|
import mekanism.client.MekanismRenderer.Model3D;
|
2013-04-28 15:23:08 -04:00
|
|
|
import mekanism.common.SynchronizedTankData.ValveData;
|
|
|
|
import mekanism.common.TileEntityDynamicTank;
|
|
|
|
import net.minecraft.block.Block;
|
|
|
|
import net.minecraft.client.renderer.GLAllocation;
|
|
|
|
import net.minecraft.client.renderer.tileentity.TileEntityRenderer;
|
|
|
|
import net.minecraft.client.renderer.tileentity.TileEntitySpecialRenderer;
|
2013-06-25 12:28:40 -04:00
|
|
|
import net.minecraft.item.Item;
|
2013-06-26 17:49:47 -04:00
|
|
|
import net.minecraft.item.ItemBlock;
|
|
|
|
import net.minecraft.item.ItemStack;
|
2013-04-28 15:23:08 -04:00
|
|
|
import net.minecraft.tileentity.TileEntity;
|
2013-06-26 17:49:47 -04:00
|
|
|
import net.minecraft.util.Icon;
|
2013-04-28 15:23:08 -04:00
|
|
|
import net.minecraft.world.World;
|
|
|
|
import net.minecraftforge.common.ForgeDirection;
|
|
|
|
import net.minecraftforge.liquids.LiquidStack;
|
|
|
|
|
|
|
|
import org.lwjgl.opengl.GL11;
|
|
|
|
|
2013-05-29 11:35:30 -04:00
|
|
|
import cpw.mods.fml.relauncher.Side;
|
|
|
|
import cpw.mods.fml.relauncher.SideOnly;
|
|
|
|
|
|
|
|
@SideOnly(Side.CLIENT)
|
2013-04-28 15:23:08 -04:00
|
|
|
public class RenderDynamicTank extends TileEntitySpecialRenderer
|
|
|
|
{
|
|
|
|
private static Map<RenderData, HashMap<LiquidStack, int[]>> cachedCenterLiquids = new HashMap<RenderData, HashMap<LiquidStack, int[]>>();
|
2013-05-23 13:30:12 -04:00
|
|
|
private static Map<ValveRenderData, HashMap<LiquidStack, DisplayInteger>> cachedValveLiquids = new HashMap<ValveRenderData, HashMap<LiquidStack, DisplayInteger>>();
|
2013-04-28 15:23:08 -04:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public void renderTileEntityAt(TileEntity tileEntity, double x, double y, double z, float partialTick)
|
|
|
|
{
|
|
|
|
renderAModelAt((TileEntityDynamicTank)tileEntity, x, y, z, partialTick);
|
|
|
|
}
|
|
|
|
|
|
|
|
public void renderAModelAt(TileEntityDynamicTank tileEntity, double x, double y, double z, float partialTick)
|
|
|
|
{
|
|
|
|
if(tileEntity.clientHasStructure && tileEntity.isRendering && tileEntity.structure != null && tileEntity.structure.liquidStored != null && tileEntity.structure.liquidStored.amount != 0)
|
|
|
|
{
|
|
|
|
RenderData data = new RenderData();
|
|
|
|
|
|
|
|
data.location = tileEntity.structure.renderLocation;
|
|
|
|
data.height = tileEntity.structure.volHeight;
|
|
|
|
data.length = tileEntity.structure.volLength;
|
|
|
|
data.width = tileEntity.structure.volWidth;
|
|
|
|
|
|
|
|
bindTextureByName(tileEntity.structure.liquidStored.canonical().getTextureSheet());
|
|
|
|
|
2013-06-25 12:28:40 -04:00
|
|
|
if(data.location != null && data.height > 0 && Item.itemsList[tileEntity.structure.liquidStored.itemID] != null)
|
2013-04-28 15:23:08 -04:00
|
|
|
{
|
|
|
|
push();
|
2013-06-15 11:35:14 -04:00
|
|
|
|
2013-04-28 15:23:08 -04:00
|
|
|
GL11.glTranslated(getX(data.location.xCoord), getY(data.location.yCoord), getZ(data.location.zCoord));
|
|
|
|
|
|
|
|
int[] displayList = getListAndRender(data, tileEntity.structure.liquidStored.canonical(), tileEntity.worldObj);
|
|
|
|
GL11.glCallList(displayList[(int)(((float)tileEntity.structure.liquidStored.amount/(float)tileEntity.clientCapacity)*((float)getStages(data.height)-1))]);
|
2013-06-15 11:35:14 -04:00
|
|
|
|
2013-04-28 15:23:08 -04:00
|
|
|
pop();
|
|
|
|
|
|
|
|
for(ValveData valveData : tileEntity.valveViewing.keySet())
|
|
|
|
{
|
|
|
|
if(tileEntity.valveViewing.get(valveData) > 0)
|
|
|
|
{
|
|
|
|
push();
|
|
|
|
|
|
|
|
GL11.glTranslated(getX(valveData.location.xCoord), getY(valveData.location.yCoord), getZ(valveData.location.zCoord));
|
|
|
|
|
|
|
|
int display = getValveDisplay(ValveRenderData.get(data, valveData), tileEntity.structure.liquidStored, tileEntity.worldObj).display;
|
|
|
|
GL11.glCallList(display);
|
|
|
|
|
|
|
|
pop();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void pop()
|
|
|
|
{
|
|
|
|
GL11.glPopAttrib();
|
|
|
|
GL11.glPopMatrix();
|
|
|
|
}
|
|
|
|
|
|
|
|
private void push()
|
|
|
|
{
|
|
|
|
GL11.glPushMatrix();
|
|
|
|
GL11.glPushAttrib(GL11.GL_ENABLE_BIT);
|
|
|
|
GL11.glEnable(GL11.GL_CULL_FACE);
|
|
|
|
GL11.glEnable(GL11.GL_BLEND);
|
|
|
|
GL11.glDisable(GL11.GL_LIGHTING);
|
|
|
|
GL11.glBlendFunc(GL11.GL_SRC_ALPHA, GL11.GL_ONE_MINUS_SRC_ALPHA);
|
|
|
|
}
|
|
|
|
|
|
|
|
private int[] getListAndRender(RenderData data, LiquidStack stack, World world)
|
|
|
|
{
|
|
|
|
if(cachedCenterLiquids.containsKey(data) && cachedCenterLiquids.get(data).containsKey(stack))
|
|
|
|
{
|
|
|
|
return cachedCenterLiquids.get(data).get(stack);
|
|
|
|
}
|
|
|
|
|
|
|
|
Model3D toReturn = new Model3D();
|
|
|
|
toReturn.baseBlock = Block.waterStill;
|
2013-06-26 17:49:47 -04:00
|
|
|
toReturn.setTexture(stack.getRenderingIcon());
|
2013-04-28 15:23:08 -04:00
|
|
|
|
|
|
|
if(stack.itemID < Block.blocksList.length && Block.blocksList[stack.itemID] != null)
|
|
|
|
{
|
|
|
|
toReturn.baseBlock = Block.blocksList[stack.itemID];
|
|
|
|
}
|
|
|
|
|
|
|
|
final int stages = getStages(data.height);
|
|
|
|
int[] displays = new int[stages];
|
|
|
|
|
|
|
|
if(cachedCenterLiquids.containsKey(data))
|
|
|
|
{
|
|
|
|
cachedCenterLiquids.get(data).put(stack, displays);
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
HashMap<LiquidStack, int[]> map = new HashMap<LiquidStack, int[]>();
|
|
|
|
map.put(stack, displays);
|
|
|
|
cachedCenterLiquids.put(data, map);
|
|
|
|
}
|
|
|
|
|
2013-06-27 11:03:50 -04:00
|
|
|
MekanismRenderer.colorLiquid(stack);
|
2013-06-25 12:28:40 -04:00
|
|
|
|
2013-04-28 15:23:08 -04:00
|
|
|
for(int i = 0; i < stages; i++)
|
|
|
|
{
|
|
|
|
displays[i] = GLAllocation.generateDisplayLists(1);
|
|
|
|
GL11.glNewList(displays[i], 4864);
|
|
|
|
|
|
|
|
toReturn.minX = 0 + .01;
|
|
|
|
toReturn.minY = 0 + .01;
|
|
|
|
toReturn.minZ = 0 + .01;
|
|
|
|
|
|
|
|
toReturn.maxX = data.length-2 - .01;
|
|
|
|
toReturn.maxY = ((float)i/(float)stages)*(data.height-2) - .01;
|
|
|
|
toReturn.maxZ = data.width-2 - .01;
|
|
|
|
|
2013-06-02 17:44:59 -04:00
|
|
|
MekanismRenderer.renderObject(toReturn);
|
2013-04-28 15:23:08 -04:00
|
|
|
GL11.glEndList();
|
|
|
|
}
|
|
|
|
|
2013-06-25 12:28:40 -04:00
|
|
|
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
|
|
|
|
2013-04-28 15:23:08 -04:00
|
|
|
return displays;
|
|
|
|
}
|
|
|
|
|
2013-06-27 11:03:50 -04:00
|
|
|
private void setFlowingTexture(LiquidStack liquidStack, Model3D model)
|
2013-06-26 17:49:47 -04:00
|
|
|
{
|
2013-06-27 11:03:50 -04:00
|
|
|
if((liquidStack == null) || (liquidStack.amount <= 0) || (liquidStack.itemID <= 0))
|
2013-06-26 17:49:47 -04:00
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2013-06-27 11:03:50 -04:00
|
|
|
ItemStack itemStack = liquidStack.asItemStack();
|
|
|
|
String texturePath = liquidStack.canonical().getTextureSheet();
|
2013-06-26 17:49:47 -04:00
|
|
|
|
2013-06-27 11:03:50 -04:00
|
|
|
Icon flatIcon = liquidStack.canonical().getRenderingIcon();
|
|
|
|
Icon sideIcon = flatIcon;
|
2013-06-26 17:49:47 -04:00
|
|
|
|
2013-06-27 11:03:50 -04:00
|
|
|
if((itemStack.getItem() instanceof ItemBlock))
|
2013-06-26 17:49:47 -04:00
|
|
|
{
|
2013-06-27 11:03:50 -04:00
|
|
|
flatIcon = Block.blocksList[itemStack.itemID].getIcon(0, 0);
|
|
|
|
sideIcon = Block.blocksList[itemStack.itemID].getIcon(2, 0);
|
2013-06-26 17:49:47 -04:00
|
|
|
texturePath = "/terrain.png";
|
|
|
|
}
|
|
|
|
|
2013-06-27 11:03:50 -04:00
|
|
|
model.setTextures(flatIcon, flatIcon, sideIcon, sideIcon, sideIcon, sideIcon);
|
2013-06-26 17:49:47 -04:00
|
|
|
|
|
|
|
bindTextureByName(texturePath);
|
|
|
|
}
|
|
|
|
|
2013-05-23 13:30:12 -04:00
|
|
|
private DisplayInteger getValveDisplay(ValveRenderData data, LiquidStack stack, World world)
|
2013-04-28 15:23:08 -04:00
|
|
|
{
|
|
|
|
if(cachedValveLiquids.containsKey(data) && cachedValveLiquids.get(data).containsKey(stack))
|
|
|
|
{
|
|
|
|
return cachedValveLiquids.get(data).get(stack);
|
|
|
|
}
|
|
|
|
|
|
|
|
Model3D toReturn = new Model3D();
|
|
|
|
toReturn.baseBlock = Block.waterStill;
|
2013-06-26 17:49:47 -04:00
|
|
|
setFlowingTexture(stack, toReturn);
|
2013-04-28 15:23:08 -04:00
|
|
|
|
|
|
|
if(stack.itemID < Block.blocksList.length && Block.blocksList[stack.itemID] != null)
|
|
|
|
{
|
|
|
|
toReturn.baseBlock = Block.blocksList[stack.itemID];
|
|
|
|
}
|
|
|
|
|
2013-05-23 13:30:12 -04:00
|
|
|
DisplayInteger display = new DisplayInteger();
|
2013-04-28 15:23:08 -04:00
|
|
|
|
|
|
|
if(cachedValveLiquids.containsKey(data))
|
|
|
|
{
|
|
|
|
cachedValveLiquids.get(data).put(stack, display);
|
|
|
|
}
|
|
|
|
else {
|
2013-05-23 13:30:12 -04:00
|
|
|
HashMap<LiquidStack, DisplayInteger> map = new HashMap<LiquidStack, DisplayInteger>();
|
2013-04-28 15:23:08 -04:00
|
|
|
map.put(stack, display);
|
|
|
|
cachedValveLiquids.put(data, map);
|
|
|
|
}
|
|
|
|
|
2013-06-27 11:03:50 -04:00
|
|
|
MekanismRenderer.colorLiquid(stack);
|
2013-06-26 17:49:47 -04:00
|
|
|
|
2013-04-28 15:23:08 -04:00
|
|
|
display.display = GLAllocation.generateDisplayLists(1);
|
|
|
|
GL11.glNewList(display.display, 4864);
|
|
|
|
|
|
|
|
switch(data.side)
|
|
|
|
{
|
|
|
|
case DOWN:
|
|
|
|
{
|
|
|
|
toReturn.minX = .3;
|
|
|
|
toReturn.minY = 1 + .01;
|
|
|
|
toReturn.minZ = .3;
|
|
|
|
|
|
|
|
toReturn.maxX = .7;
|
|
|
|
toReturn.maxY = 1.4 + .1;
|
|
|
|
toReturn.maxZ = .7;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case UP:
|
|
|
|
{
|
|
|
|
toReturn.minX = .3;
|
|
|
|
toReturn.minY = -(data.height-2) - .01;
|
|
|
|
toReturn.minZ = .3;
|
|
|
|
|
|
|
|
toReturn.maxX = .7;
|
|
|
|
toReturn.maxY = -.01;
|
|
|
|
toReturn.maxZ = .7;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case NORTH:
|
|
|
|
{
|
|
|
|
toReturn.minX = .3;
|
|
|
|
toReturn.minY = -(getValveLiquidHeight(data)) + .01;
|
|
|
|
toReturn.minZ = 1 + .02;
|
|
|
|
|
|
|
|
toReturn.maxX = .7;
|
|
|
|
toReturn.maxY = .7;
|
|
|
|
toReturn.maxZ = 1.4;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case SOUTH:
|
|
|
|
{
|
|
|
|
toReturn.minX = .3;
|
|
|
|
toReturn.minY = -(getValveLiquidHeight(data)) + .01;
|
|
|
|
toReturn.minZ = -.4;
|
|
|
|
|
|
|
|
toReturn.maxX = .7;
|
|
|
|
toReturn.maxY = .7;
|
|
|
|
toReturn.maxZ = -.02;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case WEST:
|
|
|
|
{
|
|
|
|
toReturn.minX = 1 + .02;
|
|
|
|
toReturn.minY = -(getValveLiquidHeight(data)) + .01;
|
|
|
|
toReturn.minZ = .3;
|
|
|
|
|
|
|
|
toReturn.maxX = 1.4;
|
|
|
|
toReturn.maxY = .7;
|
|
|
|
toReturn.maxZ = .7;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case EAST:
|
|
|
|
{
|
|
|
|
toReturn.minX = -.4;
|
|
|
|
toReturn.minY = -(getValveLiquidHeight(data)) + .01;
|
|
|
|
toReturn.minZ = .3;
|
|
|
|
|
|
|
|
toReturn.maxX = -.02;
|
|
|
|
toReturn.maxY = .7;
|
|
|
|
toReturn.maxZ = .7;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-06-02 17:44:59 -04:00
|
|
|
MekanismRenderer.renderObject(toReturn);
|
2013-04-28 15:23:08 -04:00
|
|
|
GL11.glEndList();
|
|
|
|
|
2013-06-27 11:03:50 -04:00
|
|
|
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
|
|
|
|
2013-04-28 15:23:08 -04:00
|
|
|
return display;
|
|
|
|
}
|
|
|
|
|
|
|
|
private int getValveLiquidHeight(ValveRenderData data)
|
|
|
|
{
|
|
|
|
return data.valveLocation.yCoord - data.location.yCoord;
|
|
|
|
}
|
|
|
|
|
|
|
|
private int getStages(int height)
|
|
|
|
{
|
2013-05-06 19:42:03 -04:00
|
|
|
return (height-2)*1600;
|
2013-04-28 15:23:08 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
private double getX(int x)
|
|
|
|
{
|
|
|
|
return x - TileEntityRenderer.staticPlayerX;
|
|
|
|
}
|
|
|
|
|
|
|
|
private double getY(int y)
|
|
|
|
{
|
|
|
|
return y - TileEntityRenderer.staticPlayerY;
|
|
|
|
}
|
|
|
|
|
|
|
|
private double getZ(int z)
|
|
|
|
{
|
|
|
|
return z - TileEntityRenderer.staticPlayerZ;
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class RenderData
|
|
|
|
{
|
|
|
|
public Object3D location;
|
|
|
|
|
|
|
|
public int height;
|
|
|
|
public int length;
|
|
|
|
public int width;
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int hashCode()
|
|
|
|
{
|
|
|
|
int code = 1;
|
|
|
|
code = 31 * code + location.hashCode();
|
|
|
|
code = 31 * code + height;
|
|
|
|
code = 31 * code + length;
|
|
|
|
code = 31 * code + width;
|
|
|
|
return code;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean equals(Object data)
|
|
|
|
{
|
|
|
|
return data instanceof RenderData && ((RenderData)data).location.equals(location) && ((RenderData)data).height == height;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static class ValveRenderData extends RenderData
|
|
|
|
{
|
|
|
|
public ForgeDirection side;
|
|
|
|
public Object3D valveLocation;
|
|
|
|
|
|
|
|
public static ValveRenderData get(RenderData renderData, ValveData valveData)
|
|
|
|
{
|
|
|
|
ValveRenderData data = new ValveRenderData();
|
|
|
|
|
|
|
|
data.location = renderData.location;
|
|
|
|
data.height = renderData.height;
|
|
|
|
data.length = renderData.length;
|
|
|
|
data.width = renderData.width;
|
|
|
|
|
|
|
|
data.side = valveData.side;
|
|
|
|
data.valveLocation = valveData.location;
|
|
|
|
|
|
|
|
return data;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean equals(Object data)
|
|
|
|
{
|
|
|
|
return data instanceof ValveRenderData && super.equals(data) && ((ValveRenderData)data).side.equals(side);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int hashCode()
|
|
|
|
{
|
|
|
|
int code = 1;
|
|
|
|
code = 31 * code + super.hashCode();
|
|
|
|
code = 31 * code + side.ordinal();
|
|
|
|
code = 31 * code + valveLocation.hashCode();
|
|
|
|
return code;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|