2015-08-29 14:33:25 +02:00
|
|
|
|
/*
|
|
|
|
|
* This file ("TileEntityDropper.java") is part of the Actually Additions Mod for Minecraft.
|
|
|
|
|
* It is created and owned by Ellpeck and distributed
|
|
|
|
|
* under the Actually Additions License to be found at
|
|
|
|
|
* http://github.com/Ellpeck/ActuallyAdditions/blob/master/README.md
|
|
|
|
|
* View the source code at https://github.com/Ellpeck/ActuallyAdditions
|
|
|
|
|
*
|
|
|
|
|
* <EFBFBD> 2015 Ellpeck
|
|
|
|
|
*/
|
|
|
|
|
|
2015-05-04 17:26:50 +02:00
|
|
|
|
package ellpeck.actuallyadditions.tile;
|
|
|
|
|
|
|
|
|
|
import ellpeck.actuallyadditions.config.values.ConfigIntValues;
|
|
|
|
|
import ellpeck.actuallyadditions.util.WorldUtil;
|
|
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
|
|
|
import net.minecraftforge.common.util.ForgeDirection;
|
|
|
|
|
|
|
|
|
|
public class TileEntityDropper extends TileEntityInventoryBase{
|
|
|
|
|
|
|
|
|
|
private int currentTime;
|
|
|
|
|
|
|
|
|
|
public TileEntityDropper(){
|
|
|
|
|
super(9, "dropper");
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
@SuppressWarnings("unchecked")
|
|
|
|
|
public void updateEntity(){
|
|
|
|
|
if(!worldObj.isRemote){
|
|
|
|
|
if(!worldObj.isBlockIndirectlyGettingPowered(xCoord, yCoord, zCoord)){
|
|
|
|
|
if(this.currentTime > 0){
|
|
|
|
|
this.currentTime--;
|
|
|
|
|
if(this.currentTime <= 0){
|
|
|
|
|
if(this.removeFromInventory(false) != null){
|
|
|
|
|
ItemStack stack = this.removeFromInventory(true);
|
|
|
|
|
stack.stackSize = 1;
|
|
|
|
|
WorldUtil.dropItemAtSide(ForgeDirection.getOrientation(worldObj.getBlockMetadata(xCoord, yCoord, zCoord)), worldObj, xCoord, yCoord, zCoord, stack);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2015-10-02 16:48:01 +02:00
|
|
|
|
else{
|
|
|
|
|
this.currentTime = ConfigIntValues.DROPPER_TIME_NEEDED.getValue();
|
|
|
|
|
}
|
2015-05-04 17:26:50 +02:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
public ItemStack removeFromInventory(boolean actuallyDo){
|
|
|
|
|
for(int i = 0; i < this.slots.length; i++){
|
|
|
|
|
if(this.slots[i] != null){
|
|
|
|
|
ItemStack slot = this.slots[i].copy();
|
|
|
|
|
if(actuallyDo){
|
|
|
|
|
this.slots[i].stackSize--;
|
2015-10-03 10:16:18 +02:00
|
|
|
|
if(this.slots[i].stackSize <= 0){
|
|
|
|
|
this.slots[i] = null;
|
|
|
|
|
}
|
2015-05-04 17:26:50 +02:00
|
|
|
|
}
|
|
|
|
|
return slot;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
|
2015-10-03 10:19:40 +02:00
|
|
|
|
@Override
|
|
|
|
|
public void writeToNBT(NBTTagCompound compound){
|
|
|
|
|
super.writeToNBT(compound);
|
|
|
|
|
compound.setInteger("CurrentTime", this.currentTime);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public void readFromNBT(NBTTagCompound compound){
|
|
|
|
|
super.readFromNBT(compound);
|
|
|
|
|
this.currentTime = compound.getInteger("CurrentTime");
|
|
|
|
|
}
|
|
|
|
|
|
2015-05-04 17:26:50 +02:00
|
|
|
|
@Override
|
|
|
|
|
public boolean isItemValidForSlot(int i, ItemStack stack){
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public boolean canInsertItem(int slot, ItemStack stack, int side){
|
|
|
|
|
return this.isItemValidForSlot(slot, stack);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
@Override
|
|
|
|
|
public boolean canExtractItem(int slot, ItemStack stack, int side){
|
|
|
|
|
return true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
}
|