Quantum gates now transport fluids!

This commit is contained in:
Calclavia 2014-03-10 06:22:37 +08:00
parent 15c1b565ca
commit 45207ae2bb
7 changed files with 156 additions and 17 deletions

View file

@ -52,7 +52,7 @@ import cpw.mods.fml.common.registry.GameRegistry;
* @author Calclavia
*
*/
@Mod(modid = Electrical.ID, name = Electrical.NAME, version = Reference.VERSION, dependencies = "before:ThermalExpansion;after:ResonantInduction|Mechanical;required-after:" + ResonantInduction.ID)
@Mod(modid = Electrical.ID, name = Electrical.NAME, version = Reference.VERSION, dependencies = "before:ThermalExpansion;before:Mekanism;after:ResonantInduction|Mechanical;required-after:" + ResonantInduction.ID)
@NetworkMod(channels = Reference.CHANNEL, clientSideRequired = true, serverSideRequired = false, packetHandler = PacketHandler.class)
public class Electrical
{

View file

@ -1,7 +1,9 @@
package resonantinduction.quantum.gate;
import net.minecraft.entity.Entity;
import icbm.api.IBlockFrequency;
import net.minecraft.entity.Entity;
import net.minecraftforge.fluids.FluidTank;
import net.minecraftforge.fluids.IFluidHandler;
/**
* Only TileEntities should implement this.
@ -9,7 +11,9 @@ import icbm.api.IBlockFrequency;
* @author Calclavia
*
*/
public interface IQuantumGate extends IBlockFrequency
public interface IQuantumGate extends IBlockFrequency, IFluidHandler
{
public void transport(Entity entity);
FluidTank getQuantumTank();
}

View file

@ -68,7 +68,7 @@ public class ItemQuantumGlyph extends JItemMultiPart implements IHighlight
}
else
{
pos.offset(side);
//pos.offset(side);
}
}

View file

@ -4,6 +4,7 @@ import icbm.api.IBlockFrequency;
import java.util.ArrayList;
import java.util.Arrays;
import java.util.HashMap;
import java.util.List;
import java.util.Set;
@ -14,6 +15,14 @@ import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.MovingObjectPosition;
import net.minecraftforge.common.ForgeDirection;
import net.minecraftforge.fluids.Fluid;
import net.minecraftforge.fluids.FluidContainerRegistry;
import net.minecraftforge.fluids.FluidStack;
import net.minecraftforge.fluids.FluidTank;
import net.minecraftforge.fluids.FluidTankInfo;
import net.minecraftforge.fluids.IFluidHandler;
import net.minecraftforge.fluids.IFluidTank;
import resonantinduction.electrical.Electrical;
import universalelectricity.api.vector.VectorWorld;
import codechicken.lib.data.MCDataInput;
@ -60,8 +69,10 @@ public class PartQuantumGlyph extends JCuboidPart implements TSlottedPart, JNorm
public void onWorldJoin()
{
if (((IQuantumGate) tile()).getFrequency() != -1)
{
FrequencyGrid.instance().register((IQuantumGate) tile());
}
}
@Override
public void onWorldSeparate()
@ -133,25 +144,26 @@ public class PartQuantumGlyph extends JCuboidPart implements TSlottedPart, JNorm
@Override
public boolean activate(EntityPlayer player, MovingObjectPosition hit, ItemStack itemStack)
{
if (!world().isRemote)
{
if (player.isSneaking())
{
if (!world().isRemote)
{
transport(player);
}
}
else
{
int frequency = ((IBlockFrequency) tile()).getFrequency();
if (frequency > -1)
{
if (!world().isRemote)
{
System.out.println(getQuantumTank());
player.addChatMessage("Quantum Gate Frequency: " + frequency);
}
else
{
player.addChatMessage("Quantum Gate not set up.");
}
return false;
}
}
@ -254,4 +266,67 @@ public class PartQuantumGlyph extends JCuboidPart implements TSlottedPart, JNorm
}
/**
* Synced Fluid
*/
static final HashMap<Integer, FluidTank> quantumTanks = new HashMap<Integer, FluidTank>();
@Override
public FluidTank getQuantumTank()
{
int frequency = ((IQuantumGate) tile()).getFrequency();
if (frequency > -1)
{
if (!quantumTanks.containsKey(frequency))
quantumTanks.put(frequency, new FluidTank(FluidContainerRegistry.BUCKET_VOLUME));
return quantumTanks.get(frequency);
}
return null;
}
@Override
public int fill(ForgeDirection from, FluidStack resource, boolean doFill)
{
if (((IQuantumGate) tile()).getFrequency() != -1)
return getQuantumTank().fill(resource, doFill);
return 0;
}
@Override
public FluidStack drain(ForgeDirection from, FluidStack resource, boolean doDrain)
{
if (((IQuantumGate) tile()).getFrequency() != -1)
return getQuantumTank().drain(resource.amount, doDrain);
return null;
}
@Override
public FluidStack drain(ForgeDirection from, int maxDrain, boolean doDrain)
{
if (((IQuantumGate) tile()).getFrequency() != -1)
return getQuantumTank().drain(maxDrain, doDrain);
return null;
}
@Override
public boolean canFill(ForgeDirection from, Fluid fluid)
{
return ((IQuantumGate) tile()).getFrequency() != -1;
}
@Override
public boolean canDrain(ForgeDirection from, Fluid fluid)
{
return ((IQuantumGate) tile()).getFrequency() != -1;
}
@Override
public FluidTankInfo[] getTankInfo(ForgeDirection from)
{
return new FluidTankInfo[] { getQuantumTank().getInfo() };
}
}

View file

@ -32,7 +32,7 @@ public class QuantumGateManager
if (currentEntity instanceof EntityPlayerMP)
{
if (playerCooldown.get(((EntityPlayerMP) currentEntity).username) == null || (System.currentTimeMillis() - playerCooldown.get(((EntityPlayerMP) currentEntity).username) > 2000))
if (playerCooldown.get(((EntityPlayerMP) currentEntity).username) == null || (System.currentTimeMillis() - playerCooldown.get(((EntityPlayerMP) currentEntity).username) > 1000))
{
EntityPlayerMP player = (EntityPlayerMP) currentEntity;

View file

@ -10,16 +10,40 @@ import mffs.api.fortron.FrequencyGrid;
import net.minecraft.entity.Entity;
import net.minecraft.tileentity.TileEntity;
import net.minecraftforge.common.ForgeDirection;
import net.minecraftforge.fluids.Fluid;
import net.minecraftforge.fluids.FluidContainerRegistry;
import net.minecraftforge.fluids.FluidStack;
import net.minecraftforge.fluids.FluidTank;
import net.minecraftforge.fluids.FluidTankInfo;
import universalelectricity.api.vector.VectorWorld;
import codechicken.multipart.TMultiPart;
import codechicken.multipart.TileMultipart;
public class TraitQuantumGate extends TileMultipart implements IQuantumGate
{
public PartQuantumGlyph get()
{
for (TMultiPart part : jPartList())
{
if (part instanceof PartQuantumGlyph)
{
return ((PartQuantumGlyph) part);
}
}
return null;
}
@Override
public FluidTank getQuantumTank()
{
return get().getQuantumTank();
}
@Override
public void transport(Entity entity)
{
get().transport(entity);
}
@Override
@ -49,4 +73,40 @@ public class TraitQuantumGate extends TileMultipart implements IQuantumGate
}
@Override
public int fill(ForgeDirection from, FluidStack resource, boolean doFill)
{
return get().fill(from, resource, doFill);
}
@Override
public FluidStack drain(ForgeDirection from, FluidStack resource, boolean doDrain)
{
return get().drain(from, resource, doDrain);
}
@Override
public FluidStack drain(ForgeDirection from, int maxDrain, boolean doDrain)
{
return get().drain(from, maxDrain, doDrain);
}
@Override
public boolean canFill(ForgeDirection from, Fluid fluid)
{
return get().canFill(from, fluid);
}
@Override
public boolean canDrain(ForgeDirection from, Fluid fluid)
{
return get().canDrain(from, fluid);
}
@Override
public FluidTankInfo[] getTankInfo(ForgeDirection from)
{
return get().getTankInfo(from);
}
}

View file

@ -47,7 +47,7 @@ import cpw.mods.fml.common.registry.GameRegistry;
*
* @author Calclavia
*/
@Mod(modid = ResonantInduction.ID, name = ResonantInduction.NAME, version = Reference.VERSION, dependencies = "required-after:ForgeMultipart@[1.0.0.244,);required-after:CalclaviaCore;before:IC2")
@Mod(modid = ResonantInduction.ID, name = ResonantInduction.NAME, version = Reference.VERSION, dependencies = "required-after:ForgeMultipart@[1.0.0.244,);required-after:CalclaviaCore;before:ThermalExpansion;before:Mekanism")
@NetworkMod(channels = Reference.CHANNEL, clientSideRequired = true, serverSideRequired = false, packetHandler = PacketHandler.class)
@ModstatInfo(prefix = "resonantin")
public class ResonantInduction