2013-01-02 19:55:29 +01:00
|
|
|
package liquidmechanics.common.item;
|
|
|
|
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
import liquidmechanics.common.LiquidMechanics;
|
|
|
|
import liquidmechanics.common.TabLiquidMechanics;
|
2013-01-03 18:18:47 +01:00
|
|
|
import liquidmechanics.common.handlers.LiquidHandler;
|
2013-01-02 19:55:29 +01:00
|
|
|
import liquidmechanics.common.tileentity.TileEntityPipe;
|
|
|
|
import net.minecraft.block.Block;
|
|
|
|
import net.minecraft.creativetab.CreativeTabs;
|
|
|
|
import net.minecraft.entity.player.EntityPlayer;
|
|
|
|
import net.minecraft.item.Item;
|
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
import net.minecraft.tileentity.TileEntity;
|
|
|
|
import net.minecraft.world.World;
|
|
|
|
|
|
|
|
public class ItemPipe extends Item
|
|
|
|
{
|
2013-01-05 01:03:20 +01:00
|
|
|
int index = 32;
|
|
|
|
private int spawnID;
|
|
|
|
|
|
|
|
public ItemPipe(int id)
|
|
|
|
{
|
|
|
|
super(id);
|
|
|
|
this.setMaxDamage(0);
|
|
|
|
this.setHasSubtypes(true);
|
|
|
|
this.setIconIndex(10);
|
|
|
|
this.setItemName("itemPipe");
|
|
|
|
this.setCreativeTab(TabLiquidMechanics.INSTANCE);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int getIconFromDamage(int par1)
|
|
|
|
{
|
|
|
|
|
|
|
|
return par1 + index;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getItemNameIS(ItemStack itemstack)
|
|
|
|
{
|
|
|
|
return "pipe";
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void getSubItems(int par1, CreativeTabs par2CreativeTabs, List par3List)
|
|
|
|
{
|
|
|
|
for (int i = 0; i < LiquidHandler.allowedLiquids.size() - 1; i++)
|
2013-01-03 18:18:47 +01:00
|
|
|
{
|
|
|
|
par3List.add(new ItemStack(this, 1, i));
|
|
|
|
}
|
2013-01-05 01:03:20 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public String getTextureFile()
|
|
|
|
{
|
|
|
|
return LiquidMechanics.ITEM_TEXTURE_FILE;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getItemName()
|
|
|
|
{
|
|
|
|
return "Pipes";
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean onItemUse(ItemStack itemstack, EntityPlayer par2EntityPlayer, World par3World, int par4, int par5, int par6, int par7, float par8, float par9, float par10)
|
|
|
|
{
|
|
|
|
int blockID = par3World.getBlockId(par4, par5, par6);
|
|
|
|
spawnID = LiquidMechanics.blockPipe.blockID;
|
|
|
|
if (blockID == Block.snow.blockID)
|
|
|
|
{
|
|
|
|
par7 = 1;
|
|
|
|
}
|
|
|
|
else if (blockID != Block.vine.blockID && blockID != Block.tallGrass.blockID && blockID != Block.deadBush.blockID)
|
|
|
|
{
|
|
|
|
if (par7 == 0)
|
|
|
|
{
|
|
|
|
--par5;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (par7 == 1)
|
|
|
|
{
|
|
|
|
++par5;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (par7 == 2)
|
|
|
|
{
|
|
|
|
--par6;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (par7 == 3)
|
|
|
|
{
|
|
|
|
++par6;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (par7 == 4)
|
|
|
|
{
|
|
|
|
--par4;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (par7 == 5)
|
|
|
|
{
|
|
|
|
++par4;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (LiquidMechanics.blockPipe.canPlaceBlockAt(par3World, par4, par5, par6))
|
|
|
|
{
|
|
|
|
Block var9 = Block.blocksList[this.spawnID];
|
|
|
|
par3World.editingBlocks = true;
|
|
|
|
if (par3World.setBlockWithNotify(par4, par5, par6, var9.blockID))
|
|
|
|
{
|
|
|
|
if (par3World.getBlockId(par4, par5, par6) == var9.blockID)
|
|
|
|
{
|
|
|
|
|
|
|
|
Block.blocksList[this.spawnID].onBlockAdded(par3World, par4, par5, par6);
|
|
|
|
Block.blocksList[this.spawnID].onBlockPlacedBy(par3World, par4, par5, par6, par2EntityPlayer);
|
|
|
|
TileEntity blockEntity = par3World.getBlockTileEntity(par4, par5, par6);
|
|
|
|
if (blockEntity instanceof TileEntityPipe)
|
|
|
|
{
|
|
|
|
TileEntityPipe pipeEntity = (TileEntityPipe) blockEntity;
|
|
|
|
pipeEntity.setType(LiquidHandler.getFromMeta(itemstack.getItemDamage()));
|
|
|
|
pipeEntity.converted = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
--itemstack.stackSize;
|
|
|
|
par3World.editingBlocks = false;
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
par3World.editingBlocks = false;
|
|
|
|
return false;
|
|
|
|
}
|
2013-01-02 19:55:29 +01:00
|
|
|
|
|
|
|
}
|