2014-04-11 01:59:04 +02:00
|
|
|
package com.pahimar.ee3.block;
|
|
|
|
|
|
|
|
import com.pahimar.ee3.EquivalentExchange3;
|
2014-09-19 21:55:28 +02:00
|
|
|
import com.pahimar.ee3.reference.GUIs;
|
2014-04-11 01:59:04 +02:00
|
|
|
import com.pahimar.ee3.reference.Names;
|
|
|
|
import com.pahimar.ee3.reference.RenderIds;
|
2014-04-30 03:46:59 +02:00
|
|
|
import com.pahimar.ee3.tileentity.TileEntityAlchemicalChest;
|
|
|
|
import com.pahimar.ee3.tileentity.TileEntityAlchemicalChestLarge;
|
|
|
|
import com.pahimar.ee3.tileentity.TileEntityAlchemicalChestMedium;
|
|
|
|
import com.pahimar.ee3.tileentity.TileEntityAlchemicalChestSmall;
|
2014-04-11 01:59:04 +02:00
|
|
|
import cpw.mods.fml.relauncher.Side;
|
|
|
|
import cpw.mods.fml.relauncher.SideOnly;
|
|
|
|
import net.minecraft.block.ITileEntityProvider;
|
|
|
|
import net.minecraft.block.material.Material;
|
|
|
|
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;
|
|
|
|
import net.minecraftforge.common.util.ForgeDirection;
|
|
|
|
|
|
|
|
import java.util.List;
|
|
|
|
|
|
|
|
public class BlockAlchemicalChest extends BlockEE implements ITileEntityProvider
|
|
|
|
{
|
|
|
|
public BlockAlchemicalChest()
|
|
|
|
{
|
|
|
|
super(Material.wood);
|
|
|
|
this.setHardness(2.5f);
|
|
|
|
this.setBlockName(Names.Blocks.ALCHEMICAL_CHEST);
|
|
|
|
this.setBlockBounds(0.0625f, 0.0f, 0.0625f, 0.9375f, 0.875f, 0.9375f);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2014-04-11 22:01:11 +02:00
|
|
|
public TileEntity createNewTileEntity(World world, int metaData)
|
2014-04-11 01:59:04 +02:00
|
|
|
{
|
|
|
|
if (metaData == 0)
|
|
|
|
{
|
2014-04-30 03:46:59 +02:00
|
|
|
return new TileEntityAlchemicalChestSmall();
|
2014-04-11 01:59:04 +02:00
|
|
|
}
|
|
|
|
else if (metaData == 1)
|
|
|
|
{
|
2014-04-30 03:46:59 +02:00
|
|
|
return new TileEntityAlchemicalChestMedium();
|
2014-04-11 01:59:04 +02:00
|
|
|
}
|
|
|
|
else if (metaData == 2)
|
|
|
|
{
|
2014-04-30 03:46:59 +02:00
|
|
|
return new TileEntityAlchemicalChestLarge();
|
2014-04-11 01:59:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int damageDropped(int metaData)
|
|
|
|
{
|
|
|
|
return metaData;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean renderAsNormalBlock()
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean isOpaqueCube()
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int getRenderType()
|
|
|
|
{
|
|
|
|
return RenderIds.alchemicalChest;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean onBlockActivated(World world, int x, int y, int z, EntityPlayer player, int par6, float par7, float par8, float par9)
|
|
|
|
{
|
|
|
|
if (player.isSneaking() || world.isSideSolid(x, y + 1, z, ForgeDirection.DOWN))
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2014-04-30 03:46:59 +02:00
|
|
|
if (!world.isRemote && world.getTileEntity(x, y, z) instanceof TileEntityAlchemicalChest)
|
2014-04-11 01:59:04 +02:00
|
|
|
{
|
2014-09-19 21:55:28 +02:00
|
|
|
player.openGui(EquivalentExchange3.instance, GUIs.ALCHEMICAL_CHEST.ordinal(), world, x, y, z);
|
2014-04-11 01:59:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2014-05-01 00:01:35 +02:00
|
|
|
@Override
|
|
|
|
public boolean onBlockEventReceived(World world, int x, int y, int z, int eventId, int eventData)
|
|
|
|
{
|
|
|
|
super.onBlockEventReceived(world, x, y, z, eventId, eventData);
|
|
|
|
TileEntity tileentity = world.getTileEntity(x, y, z);
|
2014-07-14 18:04:20 +02:00
|
|
|
return tileentity != null && tileentity.receiveClientEvent(eventId, eventData);
|
2014-05-01 00:01:35 +02:00
|
|
|
}
|
|
|
|
|
2014-04-11 01:59:04 +02:00
|
|
|
@Override
|
|
|
|
@SideOnly(Side.CLIENT)
|
|
|
|
public void getSubBlocks(Item item, CreativeTabs creativeTabs, List list)
|
|
|
|
{
|
|
|
|
for (int meta = 0; meta < 3; meta++)
|
|
|
|
{
|
|
|
|
list.add(new ItemStack(item, 1, meta));
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|