ActuallyAdditions/src/main/java/de/ellpeck/actuallyadditions/mod/tile/TileEntityFermentingBarrel.java

156 lines
5.1 KiB
Java
Raw Normal View History

2015-08-29 14:33:25 +02:00
/*
2016-05-16 22:52:27 +02:00
* This file ("TileEntityFermentingBarrel.java") is part of the Actually Additions mod for Minecraft.
2015-08-29 14:33:25 +02:00
* It is created and owned by Ellpeck and distributed
* under the Actually Additions License to be found at
2016-05-16 22:52:27 +02:00
* http://ellpeck.de/actaddlicense
2015-08-29 14:33:25 +02:00
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
*
2016-05-16 22:54:42 +02:00
* © 2015-2016 Ellpeck
2015-08-29 14:33:25 +02:00
*/
2016-01-05 04:47:35 +01:00
package de.ellpeck.actuallyadditions.mod.tile;
2015-05-20 22:39:43 +02:00
2016-01-29 17:38:31 +01:00
import de.ellpeck.actuallyadditions.mod.fluids.InitFluids;
import de.ellpeck.actuallyadditions.mod.util.Util;
2015-05-20 22:39:43 +02:00
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.util.EnumFacing;
2016-11-26 21:32:27 +01:00
import net.minecraftforge.fluids.FluidStack;
import net.minecraftforge.fluids.FluidTank;
2016-06-05 02:16:52 +02:00
import net.minecraftforge.fluids.capability.IFluidHandler;
import net.minecraftforge.fluids.capability.templates.FluidHandlerFluidMap;
2016-01-07 18:20:59 +01:00
import net.minecraftforge.fml.relauncher.Side;
import net.minecraftforge.fml.relauncher.SideOnly;
2015-05-20 22:39:43 +02:00
public class TileEntityFermentingBarrel extends TileEntityBase implements ISharingFluidHandler{
2015-05-20 22:39:43 +02:00
2015-12-01 19:48:09 +01:00
private static final int PROCESS_TIME = 100;
2016-06-05 02:16:52 +02:00
public final FluidTank canolaTank = new FluidTank(2*Util.BUCKET){
@Override
public boolean canDrain(){
return false;
}
@Override
public boolean canFillFluidType(FluidStack fluid){
return fluid.getFluid() == InitFluids.fluidCanolaOil;
}
};
public final FluidTank oilTank = new FluidTank(2*Util.BUCKET){
@Override
public boolean canFill(){
return false;
}
};
2015-05-20 22:39:43 +02:00
public int currentProcessTime;
2015-10-03 10:16:18 +02:00
private int lastCanola;
private int lastOil;
private int lastProcessTime;
2016-11-28 13:11:29 +01:00
private int lastCompare;
2015-05-20 22:39:43 +02:00
public TileEntityFermentingBarrel(){
super("fermentingBarrel");
2015-05-20 22:39:43 +02:00
}
2016-02-01 17:49:55 +01:00
@Override
public void writeSyncableNBT(NBTTagCompound compound, NBTType type){
2016-02-01 17:49:55 +01:00
compound.setInteger("ProcessTime", this.currentProcessTime);
this.canolaTank.writeToNBT(compound);
NBTTagCompound tag = new NBTTagCompound();
this.oilTank.writeToNBT(tag);
compound.setTag("OilTank", tag);
super.writeSyncableNBT(compound, type);
2016-02-01 17:49:55 +01:00
}
@Override
public void readSyncableNBT(NBTTagCompound compound, NBTType type){
2016-02-01 17:49:55 +01:00
this.currentProcessTime = compound.getInteger("ProcessTime");
this.canolaTank.readFromNBT(compound);
NBTTagCompound tag = compound.getCompoundTag("OilTank");
if(tag != null){
this.oilTank.readFromNBT(tag);
}
super.readSyncableNBT(compound, type);
2016-02-01 17:49:55 +01:00
}
2015-05-20 22:39:43 +02:00
@Override
public void updateEntity(){
super.updateEntity();
2016-11-26 21:32:27 +01:00
if(!this.world.isRemote){
int produce = 80;
if(this.canolaTank.getFluidAmount() >= produce && produce <= this.oilTank.getCapacity()-this.oilTank.getFluidAmount()){
2015-05-20 22:39:43 +02:00
this.currentProcessTime++;
if(this.currentProcessTime >= PROCESS_TIME){
2015-05-20 22:39:43 +02:00
this.currentProcessTime = 0;
2016-06-05 02:16:52 +02:00
this.oilTank.fillInternal(new FluidStack(InitFluids.fluidOil, produce), true);
this.canolaTank.drainInternal(produce, true);
2015-05-20 22:39:43 +02:00
}
}
2015-10-02 16:48:01 +02:00
else{
this.currentProcessTime = 0;
}
2015-05-20 22:39:43 +02:00
2016-11-28 13:11:29 +01:00
int compare = this.getComparatorStrength();
if(compare != this.lastCompare){
this.lastCompare = compare;
this.markDirty();
}
if((this.canolaTank.getFluidAmount() != this.lastCanola || this.oilTank.getFluidAmount() != this.lastOil || this.currentProcessTime != this.lastProcessTime) && this.sendUpdateWithInterval()){
this.lastProcessTime = this.currentProcessTime;
this.lastCanola = this.canolaTank.getFluidAmount();
this.lastOil = this.oilTank.getFluidAmount();
}
2015-05-20 22:39:43 +02:00
}
}
2016-11-28 13:11:29 +01:00
@Override
public int getComparatorStrength(){
float calc = ((float)this.oilTank.getFluidAmount()/(float)this.oilTank.getCapacity())*15F;
return (int)calc;
}
2015-12-01 19:48:09 +01:00
@SideOnly(Side.CLIENT)
public int getProcessScaled(int i){
return this.currentProcessTime*i/PROCESS_TIME;
}
2015-05-20 22:39:43 +02:00
@SideOnly(Side.CLIENT)
public int getOilTankScaled(int i){
2015-10-02 16:48:01 +02:00
return this.oilTank.getFluidAmount()*i/this.oilTank.getCapacity();
2015-05-20 22:39:43 +02:00
}
@SideOnly(Side.CLIENT)
public int getCanolaTankScaled(int i){
2015-10-02 16:48:01 +02:00
return this.canolaTank.getFluidAmount()*i/this.canolaTank.getCapacity();
2015-05-20 22:39:43 +02:00
}
@Override
2016-06-05 02:16:52 +02:00
public IFluidHandler getFluidHandler(EnumFacing facing){
FluidHandlerFluidMap map = new FluidHandlerFluidMap();
if(facing != EnumFacing.DOWN){
map.addHandler(InitFluids.fluidCanolaOil, this.canolaTank);
2015-10-02 16:48:01 +02:00
}
2016-06-05 02:16:52 +02:00
if(facing != EnumFacing.UP){
map.addHandler(InitFluids.fluidOil, this.oilTank);
2015-10-03 10:16:18 +02:00
}
2016-06-05 02:16:52 +02:00
return map;
2015-05-20 22:39:43 +02:00
}
@Override
2016-11-19 21:11:17 +01:00
public int getMaxFluidAmountToSplitShare(){
return this.oilTank.getFluidAmount();
}
@Override
public boolean doesShareFluid(){
return true;
}
@Override
public EnumFacing[] getFluidShareSides(){
return EnumFacing.values();
}
2015-05-20 22:39:43 +02:00
}