Mekanism-tilera-Edition/src/main/java/mekanism/common/tile/TileEntityInductionPort.java

477 lines
10 KiB
Java
Raw Normal View History

2015-03-03 05:05:54 +01:00
package mekanism.common.tile;
2015-03-03 17:41:46 +01:00
import ic2.api.energy.EnergyNet;
import ic2.api.energy.event.EnergyTileLoadEvent;
import ic2.api.energy.event.EnergyTileUnloadEvent;
import ic2.api.energy.tile.IEnergyConductor;
import ic2.api.energy.tile.IEnergyTile;
import io.netty.buffer.ByteBuf;
import java.util.ArrayList;
import java.util.EnumSet;
2015-03-03 17:41:46 +01:00
import mekanism.api.Coord4D;
2015-03-03 19:16:58 +01:00
import mekanism.api.EnumColor;
import mekanism.api.IConfigurable;
2015-03-03 17:41:46 +01:00
import mekanism.api.MekanismConfig.general;
import mekanism.api.Range4D;
import mekanism.api.transmitters.ITransmitterTile;
import mekanism.common.Mekanism;
import mekanism.common.base.IActiveState;
import mekanism.common.base.IEnergyWrapper;
import mekanism.common.network.PacketTileEntity.TileEntityMessage;
import mekanism.common.util.CableUtils;
2015-03-03 19:16:58 +01:00
import mekanism.common.util.LangUtils;
2015-03-03 17:41:46 +01:00
import mekanism.common.util.MekanismUtils;
2015-03-03 19:16:58 +01:00
import net.minecraft.entity.player.EntityPlayer;
2015-03-03 17:41:46 +01:00
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.tileentity.TileEntity;
2015-03-03 19:16:58 +01:00
import net.minecraft.util.ChatComponentText;
2015-03-03 17:41:46 +01:00
import net.minecraftforge.common.MinecraftForge;
import net.minecraftforge.common.util.ForgeDirection;
import universalelectricity.core.electricity.ElectricityPack;
2015-03-03 17:41:46 +01:00
import cpw.mods.fml.common.Optional.Interface;
import cpw.mods.fml.common.Optional.InterfaceList;
import cpw.mods.fml.common.Optional.Method;
@InterfaceList({
2020-07-29 14:28:49 +02:00
@Interface(iface = "ic2.api.energy.tile.IEnergySink", modid = "IC2"),
@Interface(iface = "ic2.api.energy.tile.IEnergySource", modid = "IC2"),
@Interface(iface = "ic2.api.tile.IEnergyStorage", modid = "IC2")
2015-03-03 17:41:46 +01:00
})
public class TileEntityInductionPort extends TileEntityInductionCasing implements IEnergyWrapper, IConfigurable, IActiveState
2015-03-03 05:05:54 +01:00
{
2015-03-03 17:41:46 +01:00
public boolean ic2Registered = false;
2020-07-29 14:28:49 +02:00
2015-03-03 17:41:46 +01:00
/** false = input, true = output */
public boolean mode;
2020-07-29 14:28:49 +02:00
public TileEntityInductionPort()
{
super("InductionPort");
}
2020-07-29 14:28:49 +02:00
2015-03-03 17:41:46 +01:00
@Override
public void onUpdate()
{
super.onUpdate();
2020-07-29 14:28:49 +02:00
2015-03-03 17:41:46 +01:00
if(!ic2Registered && MekanismUtils.useIC2())
{
register();
}
2020-07-29 14:28:49 +02:00
if(!worldObj.isRemote)
{
if(structure != null && mode == true)
{
double prev = getEnergy();
CableUtils.emit(this);
structure.remainingOutput -= (prev-getEnergy());
}
}
}
2020-07-29 14:28:49 +02:00
@Override
public EnumSet<ForgeDirection> getOutputtingSides()
{
if(structure != null && mode == true)
{
EnumSet set = EnumSet.allOf(ForgeDirection.class);
set.remove(ForgeDirection.UNKNOWN);
2020-07-29 14:28:49 +02:00
for(ForgeDirection side : ForgeDirection.VALID_DIRECTIONS)
{
if(structure.locations.contains(Coord4D.get(this).getFromSide(side)))
{
set.remove(side);
}
}
2020-07-29 14:28:49 +02:00
return set;
}
2020-07-29 14:28:49 +02:00
return EnumSet.noneOf(ForgeDirection.class);
}
@Override
public EnumSet<ForgeDirection> getConsumingSides()
{
if(structure != null && mode == false)
{
EnumSet set = EnumSet.allOf(ForgeDirection.class);
set.remove(ForgeDirection.UNKNOWN);
return set;
}
2020-07-29 14:28:49 +02:00
return EnumSet.noneOf(ForgeDirection.class);
2015-03-03 17:41:46 +01:00
}
2020-07-29 14:28:49 +02:00
2015-03-03 17:41:46 +01:00
@Method(modid = "IC2")
public void register()
{
if(!worldObj.isRemote)
{
TileEntity registered = EnergyNet.instance.getTileEntity(worldObj, xCoord, yCoord, zCoord);
2020-07-29 14:28:49 +02:00
2015-03-03 17:41:46 +01:00
if(registered != this)
{
if(registered instanceof IEnergyTile)
{
MinecraftForge.EVENT_BUS.post(new EnergyTileUnloadEvent((IEnergyTile)registered));
}
else if(registered == null)
{
MinecraftForge.EVENT_BUS.post(new EnergyTileLoadEvent(this));
ic2Registered = true;
}
}
}
}
@Method(modid = "IC2")
public void deregister()
{
if(!worldObj.isRemote)
{
TileEntity registered = EnergyNet.instance.getTileEntity(worldObj, xCoord, yCoord, zCoord);
2020-07-29 14:28:49 +02:00
2015-03-03 17:41:46 +01:00
if(registered instanceof IEnergyTile)
{
MinecraftForge.EVENT_BUS.post(new EnergyTileUnloadEvent((IEnergyTile)registered));
}
}
}
@Override
public double getMaxOutput()
2015-03-03 17:41:46 +01:00
{
return structure != null ? structure.remainingOutput : 0;
2015-03-03 17:41:46 +01:00
}
2020-07-29 14:28:49 +02:00
private double getMaxInput()
{
return structure != null ? structure.remainingInput : 0;
}
2015-03-03 17:41:46 +01:00
@Override
public void handlePacketData(ByteBuf dataStream)
{
super.handlePacketData(dataStream);
2020-07-29 14:28:49 +02:00
2016-05-17 19:49:55 +02:00
if(worldObj.isRemote)
{
mode = dataStream.readBoolean();
2020-07-29 14:28:49 +02:00
2016-05-17 19:49:55 +02:00
MekanismUtils.updateBlock(worldObj, xCoord, yCoord, zCoord);
}
2015-03-03 17:41:46 +01:00
}
@Override
public ArrayList getNetworkedData(ArrayList data)
{
super.getNetworkedData(data);
2020-07-29 14:28:49 +02:00
data.add(mode);
2020-07-29 14:28:49 +02:00
2015-03-03 17:41:46 +01:00
return data;
}
2020-07-29 14:28:49 +02:00
2015-03-03 17:41:46 +01:00
@Override
public void onAdded()
{
super.onAdded();
2020-07-29 14:28:49 +02:00
2015-03-03 17:41:46 +01:00
if(MekanismUtils.useIC2())
{
register();
}
}
@Override
public void onChunkUnload()
{
if(MekanismUtils.useIC2())
{
deregister();
}
super.onChunkUnload();
}
@Override
public void invalidate()
{
super.invalidate();
if(MekanismUtils.useIC2())
{
deregister();
}
}
@Override
public void readFromNBT(NBTTagCompound nbtTags)
{
super.readFromNBT(nbtTags);
mode = nbtTags.getBoolean("mode");
}
@Override
public void writeToNBT(NBTTagCompound nbtTags)
{
super.writeToNBT(nbtTags);
nbtTags.setBoolean("mode", mode);
}
@Override
public int receiveEnergy(ForgeDirection from, int maxReceive, boolean simulate)
{
if(getConsumingSides().contains(from))
2015-03-03 17:41:46 +01:00
{
double toAdd = (int)Math.min(Math.min(getMaxInput(), getMaxEnergy()-getEnergy()), maxReceive* general.FROM_TE);
2015-03-03 17:41:46 +01:00
if(!simulate)
{
setEnergy(getEnergy() + toAdd);
structure.remainingInput -= toAdd;
2015-03-03 17:41:46 +01:00
}
return (int)Math.round(toAdd*general.TO_TE);
2015-03-03 17:41:46 +01:00
}
return 0;
}
@Override
public int extractEnergy(ForgeDirection from, int maxExtract, boolean simulate)
{
if(getOutputtingSides().contains(from))
2015-03-03 17:41:46 +01:00
{
double toSend = Math.min(getEnergy(), Math.min(getMaxOutput(), maxExtract*general.FROM_TE));
2015-03-03 17:41:46 +01:00
if(!simulate)
{
setEnergy(getEnergy() - toSend);
structure.remainingOutput -= toSend;
2015-03-03 17:41:46 +01:00
}
return (int)Math.round(toSend*general.TO_TE);
2015-03-03 17:41:46 +01:00
}
return 0;
}
@Override
public boolean canConnectEnergy(ForgeDirection from)
{
return structure != null;
}
@Override
public int getEnergyStored(ForgeDirection from)
{
return (int)Math.round(getEnergy()*general.TO_TE);
2015-03-03 17:41:46 +01:00
}
@Override
public int getMaxEnergyStored(ForgeDirection from)
{
return (int)Math.round(getMaxEnergy()*general.TO_TE);
2015-03-03 17:41:46 +01:00
}
@Override
@Method(modid = "IC2")
public int getSinkTier()
{
return 4;
}
@Override
@Method(modid = "IC2")
public int getSourceTier()
{
return 4;
}
@Override
@Method(modid = "IC2")
public void setStored(int energy)
{
setEnergy(energy*general.FROM_IC2);
}
@Override
@Method(modid = "IC2")
public int addEnergy(int amount)
{
double toUse = Math.min(Math.min(getMaxInput(), getMaxEnergy()-getEnergy()), amount*general.FROM_IC2);
setEnergy(getEnergy() + toUse);
structure.remainingInput -= toUse;
2015-03-03 17:41:46 +01:00
return (int)Math.round(getEnergy()*general.TO_IC2);
}
@Override
@Method(modid = "IC2")
public boolean isTeleporterCompatible(ForgeDirection side)
{
return canOutputTo(side);
2015-03-03 17:41:46 +01:00
}
@Override
public boolean canOutputTo(ForgeDirection side)
{
return getOutputtingSides().contains(side);
2015-03-03 17:41:46 +01:00
}
@Override
@Method(modid = "IC2")
public boolean acceptsEnergyFrom(TileEntity emitter, ForgeDirection direction)
{
2020-07-29 14:28:49 +02:00
return false;
//return getConsumingSides().contains(direction);
2015-03-03 17:41:46 +01:00
}
@Override
@Method(modid = "IC2")
public boolean emitsEnergyTo(TileEntity receiver, ForgeDirection direction)
{
return getOutputtingSides().contains(direction) && receiver instanceof IEnergyConductor;
2015-03-03 17:41:46 +01:00
}
@Override
@Method(modid = "IC2")
public int getStored()
{
return (int)Math.round(getEnergy()*general.TO_IC2);
}
@Override
@Method(modid = "IC2")
public int getCapacity()
{
return (int)Math.round(getMaxEnergy()*general.TO_IC2);
}
@Override
@Method(modid = "IC2")
public int getOutput()
{
return (int)Math.round(getMaxOutput()*general.TO_IC2);
}
@Override
@Method(modid = "IC2")
public double getDemandedEnergy()
{
return (getMaxEnergy() - getEnergy())*general.TO_IC2;
}
@Override
@Method(modid = "IC2")
public double getOfferedEnergy()
{
return Math.min(getEnergy(), getMaxOutput())*general.TO_IC2;
}
@Override
public boolean canReceiveEnergy(ForgeDirection side)
{
return getConsumingSides().contains(side);
2015-03-03 17:41:46 +01:00
}
@Override
@Method(modid = "IC2")
public double getOutputEnergyUnitsPerTick()
{
return getMaxOutput()*general.TO_IC2;
}
@Override
@Method(modid = "IC2")
public double injectEnergy(ForgeDirection direction, double amount, double voltage)
{
if(Coord4D.get(this).getFromSide(direction).getTileEntity(worldObj) instanceof ITransmitterTile)
2015-03-03 17:41:46 +01:00
{
return amount;
}
return amount-transferEnergyToAcceptor(direction, amount*general.FROM_IC2)*general.TO_IC2;
}
@Override
@Method(modid = "IC2")
public void drawEnergy(double amount)
{
if(structure != null)
{
double toDraw = Math.min(amount*general.FROM_IC2, getMaxOutput());
setEnergy(Math.max(getEnergy() - toDraw, 0));
structure.remainingOutput -= toDraw;
}
2015-03-03 17:41:46 +01:00
}
@Override
public double transferEnergyToAcceptor(ForgeDirection side, double amount)
{
if(!getConsumingSides().contains(side))
2015-03-03 17:41:46 +01:00
{
return 0;
}
double toUse = Math.min(Math.min(getMaxInput(), getMaxEnergy()-getEnergy()), amount);
2015-03-03 17:41:46 +01:00
setEnergy(getEnergy() + toUse);
structure.remainingInput -= toUse;
2015-03-03 17:41:46 +01:00
return toUse;
}
2015-03-03 19:16:58 +01:00
@Override
2020-07-29 14:28:49 +02:00
public boolean onSneakRightClick(EntityPlayer player, int side)
2015-03-03 19:16:58 +01:00
{
if(!worldObj.isRemote)
{
mode = !mode;
String modeText = " " + (mode ? EnumColor.DARK_RED : EnumColor.DARK_GREEN) + LangUtils.transOutputInput(mode) + ".";
2015-05-11 01:04:42 +02:00
player.addChatMessage(new ChatComponentText(EnumColor.DARK_BLUE + "[Mekanism] " + EnumColor.GREY + LangUtils.localize("tooltip.configurator.inductionPortMode") + modeText));
2020-07-29 14:28:49 +02:00
Mekanism.packetHandler.sendToReceivers(new TileEntityMessage(Coord4D.get(this), getNetworkedData(new ArrayList())), new Range4D(Coord4D.get(this)));
2015-03-03 19:16:58 +01:00
markDirty();
}
2020-07-29 14:28:49 +02:00
2015-03-03 19:16:58 +01:00
return true;
}
@Override
2020-07-29 14:28:49 +02:00
public boolean onRightClick(EntityPlayer player, int side)
2015-03-03 19:16:58 +01:00
{
return false;
}
@Override
public boolean getActive()
{
return mode;
}
@Override
public void setActive(boolean active)
{
mode = active;
}
@Override
public boolean renderUpdate()
{
return true;
}
@Override
public boolean lightUpdate()
{
return false;
}
2020-07-29 14:28:49 +02:00
}