Added ability to display capacity with multimeter

This commit is contained in:
Calclavia 2014-01-31 11:27:09 +08:00
parent 0178cb0b73
commit d2bb7b870d
6 changed files with 71 additions and 30 deletions

View file

@ -57,13 +57,15 @@ public abstract class RenderItemOverlayTile extends TileEntitySpecialRenderer
if (inventory[i] != null) if (inventory[i] != null)
{ {
Vector3 translation = new Vector3((double) (i / matrixX) / ((double) matrixX) + (0.5 / (matrixX)), 1.1, (double) (i % matrixZ) / ((double) matrixZ) + (0.5 / (matrixZ))).translate(-0.5); Vector3 translation = new Vector3((double) (i / matrixX) / ((double) matrixX) + (0.5 / (matrixX)), 1.1, (double) (i % matrixZ) / ((double) matrixZ) + (0.5 / (matrixZ))).translate(-0.5);
translation.scale(0.9);
translation.translate(0, 0, 0.06);
GL11.glPushMatrix(); GL11.glPushMatrix();
GL11.glTranslated(x + 0.5f, y + 0.5f, z + 0.5f); GL11.glTranslated(x + 0.5f, y + 0.5f, z + 0.5f);
RenderUtility.rotateBlockBasedOnDirection(dir); RenderUtility.rotateBlockBasedOnDirection(dir);
GL11.glTranslated(translation.x, translation.y, translation.z); GL11.glTranslated(translation.x, translation.y, translation.z);
GL11.glScalef(0.7f, 0.7f, 0.7f); GL11.glScalef(0.7f, 0.7f, 0.7f);
OpenGlHelper.setLightmapTextureCoords(OpenGlHelper.lightmapTexUnit, 240, 240); OpenGlHelper.setLightmapTextureCoords(OpenGlHelper.lightmapTexUnit, 240, 240);
this.renderItem(tileEntity.worldObj, ForgeDirection.UP, inventory[i], new Vector3(0, 0, 0.2f), 0, 1); this.renderItem(tileEntity.worldObj, ForgeDirection.UP, inventory[i], new Vector3(0, 0, 0), 0, 1);
GL11.glPopMatrix(); GL11.glPopMatrix();
if (isLooking) if (isLooking)
@ -187,13 +189,10 @@ public abstract class RenderItemOverlayTile extends TileEntitySpecialRenderer
RenderItem renderItem = ((RenderItem) RenderManager.instance.getEntityClassRenderObject(EntityItem.class)); RenderItem renderItem = ((RenderItem) RenderManager.instance.getEntityClassRenderObject(EntityItem.class));
if (entityItem != null) boolean fancyGraphics = RenderManager.instance.options.fancyGraphics;
{ RenderManager.instance.options.fancyGraphics = true;
boolean fancyGraphics = RenderManager.instance.options.fancyGraphics; renderItem.doRenderItem(entityItem, 0, 0, 0, 0, 0);
RenderManager.instance.options.fancyGraphics = true; RenderManager.instance.options.fancyGraphics = fancyGraphics;
renderItem.doRenderItem(entityItem, 0, 0, 0, 0, 0);
RenderManager.instance.options.fancyGraphics = fancyGraphics;
}
GL11.glPopMatrix(); GL11.glPopMatrix();
} }

View file

@ -64,7 +64,7 @@ public class Graph
for (int i = 0; i < nbtList.tagCount(); ++i) for (int i = 0; i < nbtList.tagCount(); ++i)
{ {
NBTTagCompound nbtPoint = (NBTTagCompound) nbtList.tagAt(i); NBTTagCompound nbtPoint = (NBTTagCompound) nbtList.tagAt(i);
add(nbtPoint.getLong("data")); points.add(nbtPoint.getLong("data"));
} }
} }

View file

@ -74,9 +74,9 @@ public class GuiMultimeter extends GuiContainerBase
String s = LanguageUtility.getLocal("tile.resonantinduction:multimeter.name"); String s = LanguageUtility.getLocal("tile.resonantinduction:multimeter.name");
this.fontRenderer.drawString(s, this.xSize / 2 - this.fontRenderer.getStringWidth(s) / 2, 15, 4210752); this.fontRenderer.drawString(s, this.xSize / 2 - this.fontRenderer.getStringWidth(s) / 2, 15, 4210752);
this.fontRenderer.drawString(EnumColor.INDIGO + LanguageUtility.getLocal("gui.resonantinduction.multimeter.energy"), 35, 15, 4210752); this.fontRenderer.drawString(EnumColor.INDIGO + LanguageUtility.getLocal("gui.resonantinduction.multimeter.energy"), 35, 15, 4210752);
this.renderUniversalDisplay(35, 25, this.multimeter.getNetwork().graph.get(0), mouseX, mouseY, Unit.JOULES); this.renderUniversalDisplay(35, 25, this.multimeter.getNetwork().valueGraph.get(0), mouseX, mouseY, Unit.JOULES);
this.fontRenderer.drawString(EnumColor.INDIGO + LanguageUtility.getLocal("gui.resonantinduction.multimeter.capacity"), 35, 35, 4210752); this.fontRenderer.drawString(EnumColor.INDIGO + LanguageUtility.getLocal("gui.resonantinduction.multimeter.capacity"), 35, 35, 4210752);
this.renderUniversalDisplay(35, 45, this.multimeter.getNetwork().graph.getPeak(), mouseX, mouseY, Unit.JOULES); this.renderUniversalDisplay(35, 45, this.multimeter.getNetwork().valueGraph.getPeak(), mouseX, mouseY, Unit.JOULES);
this.fontRenderer.drawString(EnumColor.ORANGE + LanguageUtility.getLocal("gui.resonantinduction.multimeter.redstone"), 35, 58, 4210752); this.fontRenderer.drawString(EnumColor.ORANGE + LanguageUtility.getLocal("gui.resonantinduction.multimeter.redstone"), 35, 58, 4210752);
this.fontRenderer.drawString(EnumColor.RED + LanguageUtility.getLocal("gui.resonantinduction.multimeter." + this.multimeter.getMode().display), 35, 68, 4210752); this.fontRenderer.drawString(EnumColor.RED + LanguageUtility.getLocal("gui.resonantinduction.multimeter." + this.multimeter.getMode().display), 35, 68, 4210752);
this.fontRenderer.drawString(Unit.JOULES.name + "(s)", 35, 100, 4210752); this.fontRenderer.drawString(Unit.JOULES.name + "(s)", 35, 100, 4210752);

View file

@ -12,7 +12,8 @@ import universalelectricity.core.net.NetworkTickHandler;
public class MultimeterNetwork extends Network<MultimeterNetwork, PartMultimeter> implements IUpdate public class MultimeterNetwork extends Network<MultimeterNetwork, PartMultimeter> implements IUpdate
{ {
public final List<String> displayInformation = new ArrayList<String>(); public final List<String> displayInformation = new ArrayList<String>();
public Graph graph = new Graph(20 * 10); public Graph valueGraph = new Graph(20 * 10);
public Graph capacityGraph = new Graph(20 * 10);
/** /**
* The absolute center of the multimeter screens. * The absolute center of the multimeter screens.
@ -49,8 +50,9 @@ public class MultimeterNetwork extends Network<MultimeterNetwork, PartMultimeter
@Override @Override
public void update() public void update()
{ {
graph.add(queueGraphValue); valueGraph.add(queueGraphValue);
queueGraphValue = 0; queueGraphValue = 0;
capacityGraph.add(queueGraphCapacity);
queueGraphCapacity = 0; queueGraphCapacity = 0;
displayInformation.clear(); displayInformation.clear();
doUpdate = false; doUpdate = false;
@ -107,6 +109,7 @@ public class MultimeterNetwork extends Network<MultimeterNetwork, PartMultimeter
{ {
PartMultimeter connector = it.next(); PartMultimeter connector = it.next();
connector.updateDesc(); connector.updateDesc();
connector.updateGraph();
} }
doUpdate = true; doUpdate = true;

View file

@ -121,6 +121,11 @@ public class PartMultimeter extends JCuboidPart implements IConnector<Multimeter
writeDesc(getWriteStream()); writeDesc(getWriteStream());
} }
public void updateGraph()
{
writeGraph(getWriteStream());
}
@Override @Override
public void onWorldJoin() public void onWorldJoin()
{ {
@ -176,7 +181,7 @@ public class PartMultimeter extends JCuboidPart implements IConnector<Multimeter
if (!world().isRemote) if (!world().isRemote)
{ {
long detectedEnergy = doGetDetectedEnergy(); long detectedEnergy = getDetectedEnergy();
boolean outputRedstone = false; boolean outputRedstone = false;
@ -201,7 +206,7 @@ public class PartMultimeter extends JCuboidPart implements IConnector<Multimeter
break; break;
} }
getNetwork().updateGraph(detectedEnergy, 0); getNetwork().updateGraph(detectedEnergy, getDetectedCapacity());
if (ticks % 10 == 0) if (ticks % 10 == 0)
{ {
@ -211,9 +216,9 @@ public class PartMultimeter extends JCuboidPart implements IConnector<Multimeter
tile().notifyPartChange(this); tile().notifyPartChange(this);
} }
if (getNetwork().graph.get(1) != detectedEnergy) if (getNetwork().valueGraph.get(1) != detectedEnergy)
{ {
writeGraph(getWriteStream()); updateGraph();
} }
} }
} }
@ -222,7 +227,7 @@ public class PartMultimeter extends JCuboidPart implements IConnector<Multimeter
{ {
for (EntityPlayer player : playersUsing) for (EntityPlayer player : playersUsing)
{ {
writeGraph(getWriteStream()); updateGraph();
} }
} }
} }
@ -252,7 +257,8 @@ public class PartMultimeter extends JCuboidPart implements IConnector<Multimeter
public void writeGraph(MCDataOutput packet) public void writeGraph(MCDataOutput packet)
{ {
packet.writeByte(2); packet.writeByte(2);
packet.writeNBTTagCompound(getNetwork().graph.save()); packet.writeNBTTagCompound(getNetwork().valueGraph.save());
packet.writeNBTTagCompound(getNetwork().capacityGraph.save());
} }
@Override @Override
@ -278,7 +284,8 @@ public class PartMultimeter extends JCuboidPart implements IConnector<Multimeter
} }
else if (packetID == 2) else if (packetID == 2)
{ {
getNetwork().graph.load(packet.readNBTTagCompound()); getNetwork().valueGraph.load(packet.readNBTTagCompound());
getNetwork().capacityGraph.load(packet.readNBTTagCompound());
} }
} }
@ -288,7 +295,7 @@ public class PartMultimeter extends JCuboidPart implements IConnector<Multimeter
toggleMode(); toggleMode();
} }
public long doGetDetectedEnergy() public long getDetectedEnergy()
{ {
return getDetectedEnergy(getDirection().getOpposite(), getDetectedTile()); return getDetectedEnergy(getDirection().getOpposite(), getDetectedTile());
} }
@ -326,6 +333,16 @@ public class PartMultimeter extends JCuboidPart implements IConnector<Multimeter
return CompatibilityModule.getEnergy(tileEntity, side); return CompatibilityModule.getEnergy(tileEntity, side);
} }
public long getDetectedCapacity()
{
return getDetectedCapacity(getDirection().getOpposite(), getDetectedTile());
}
public static long getDetectedCapacity(ForgeDirection side, TileEntity tileEntity)
{
return CompatibilityModule.getMaxEnergy(tileEntity, side);
}
public void toggleMode() public void toggleMode()
{ {
if (!this.world().isRemote) if (!this.world().isRemote)

View file

@ -1,5 +1,8 @@
package resonantinduction.electrical.multimeter; package resonantinduction.electrical.multimeter;
import java.util.ArrayList;
import java.util.List;
import net.minecraft.client.renderer.texture.TextureMap; import net.minecraft.client.renderer.texture.TextureMap;
import net.minecraft.util.ResourceLocation; import net.minecraft.util.ResourceLocation;
import net.minecraftforge.common.ForgeDirection; import net.minecraftforge.common.ForgeDirection;
@ -78,13 +81,17 @@ public class RenderMultimeter
public static void render(PartMultimeter part, double x, double y, double z) public static void render(PartMultimeter part, double x, double y, double z)
{ {
ForgeDirection dir = part.getDirection();
/**
* Render the shell of the multimeter.
*/
GL11.glPushMatrix(); GL11.glPushMatrix();
GL11.glTranslated(x + 0.5, y + 0.5, z + 0.5); GL11.glTranslated(x + 0.5, y + 0.5, z + 0.5);
RenderUtility.rotateFaceBlockToSideOutwards(part.getDirection().getOpposite()); RenderUtility.rotateFaceBlockToSideOutwards(part.getDirection().getOpposite());
RenderUtility.bind(TextureMap.locationBlocksTexture); RenderUtility.bind(TextureMap.locationBlocksTexture);
// Render the main panel // Render the main panel
RenderUtility.renderCube(-0.5, -0.05, -0.5, 0.5, 0.05, 0.5, Archaic.blockMachinePart, ResonantInduction.loadedIconMap.get(Reference.PREFIX + "multimeter_screen")); RenderUtility.renderCube(-0.5, -0.05, -0.5, 0.5, 0.05, 0.5, Archaic.blockMachinePart, ResonantInduction.loadedIconMap.get(Reference.PREFIX + "multimeter_screen"));
ForgeDirection dir = part.getDirection();
final int metadata = 8; final int metadata = 8;
// Render edges // Render edges
// UP // UP
@ -140,18 +147,33 @@ public class RenderMultimeter
RenderUtility.rotateFaceBlockToSideOutwards(part.getDirection().getOpposite()); RenderUtility.rotateFaceBlockToSideOutwards(part.getDirection().getOpposite());
GL11.glTranslated(0, 0.05, 0); GL11.glTranslated(0, 0.05, 0);
for (int i = 0; i < 1; i++) // TODO: Add other dispaly info support.
{ List<String> information = new ArrayList<String>();
// TODO: Add other dispaly info support. information.add(UnitDisplay.getDisplay(part.getNetwork().valueGraph.get(0), Unit.JOULES));
String display = UnitDisplay.getDisplay(part.getNetwork().graph.get(0), Unit.JOULES);
if (dir.offsetX == 0) if (part.getNetwork().capacityGraph.get(0) > 0)
RenderUtility.renderText(display, (float) (part.getNetwork().size.x * 0.9f), 0.5f); {
if (dir.offsetZ == 0) String str = information.get(0);
RenderUtility.renderText(display, (float) (part.getNetwork().size.z * 0.9f), 0.5f); str = str + "/" + UnitDisplay.getDisplay(part.getNetwork().capacityGraph.get(0), Unit.JOULES);
information.set(0, str);
} }
for (int i = 0; i < information.size(); i++)
{
String info = information.get(i);
GL11.glPushMatrix();
GL11.glTranslatef(0, 0, 0.3f * i);
if (dir.offsetX == 0)
RenderUtility.renderText(info, (float) (part.getNetwork().size.x * 0.9f), 0.5f);
if (dir.offsetZ == 0)
RenderUtility.renderText(info, (float) (part.getNetwork().size.z * 0.9f), 0.5f);
GL11.glPopMatrix();
}
GL11.glPopMatrix(); GL11.glPopMatrix();
} }
} }
} }