2013-08-23 16:59:50 +02:00
|
|
|
package com.pahimar.ee3.block;
|
|
|
|
|
|
|
|
import java.util.Random;
|
|
|
|
|
|
|
|
import net.minecraft.block.material.Material;
|
|
|
|
import net.minecraft.entity.item.EntityItem;
|
|
|
|
import net.minecraft.entity.player.EntityPlayer;
|
|
|
|
import net.minecraft.inventory.IInventory;
|
|
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
|
|
|
import net.minecraft.tileentity.TileEntity;
|
|
|
|
import net.minecraft.world.World;
|
|
|
|
|
|
|
|
import com.pahimar.ee3.EquivalentExchange3;
|
|
|
|
import com.pahimar.ee3.lib.GuiIds;
|
|
|
|
import com.pahimar.ee3.lib.RenderIds;
|
|
|
|
import com.pahimar.ee3.lib.Strings;
|
|
|
|
import com.pahimar.ee3.tileentity.TileCalcinator;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Equivalent-Exchange-3
|
|
|
|
*
|
|
|
|
* BlockCalcinator
|
|
|
|
*
|
|
|
|
* @author pahimar
|
|
|
|
* @license Lesser GNU Public License v3 (http://www.gnu.org/licenses/lgpl.html)
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public class BlockCalcinator extends BlockEE {
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Is the random generator used by calcinator to drop the inventory contents
|
|
|
|
* in random directions.
|
|
|
|
*/
|
|
|
|
private Random rand = new Random();
|
|
|
|
|
|
|
|
public BlockCalcinator(int id) {
|
|
|
|
|
|
|
|
super(id, Material.rock);
|
|
|
|
this.setUnlocalizedName(Strings.CALCINATOR_NAME);
|
|
|
|
this.setCreativeTab(EquivalentExchange3.tabsEE3);
|
|
|
|
this.setHardness(5F);
|
|
|
|
this.setBlockBounds(0.1F, 0.0F, 0.1F, 0.9F, 1.0F, 0.9F);
|
|
|
|
}
|
2013-09-07 04:47:12 +02:00
|
|
|
|
2013-08-26 00:12:29 +02:00
|
|
|
@Override
|
|
|
|
public String getUnlocalizedName() {
|
2013-09-07 04:47:12 +02:00
|
|
|
|
2013-08-26 00:12:29 +02:00
|
|
|
StringBuilder unlocalizedName = new StringBuilder();
|
2013-09-07 04:47:12 +02:00
|
|
|
|
2013-08-26 00:12:29 +02:00
|
|
|
unlocalizedName.append("tile.");
|
|
|
|
unlocalizedName.append(Strings.RESOURCE_PREFIX);
|
|
|
|
unlocalizedName.append(Strings.CALCINATOR_NAME);
|
2013-09-07 04:47:12 +02:00
|
|
|
|
2013-08-26 00:12:29 +02:00
|
|
|
return unlocalizedName.toString();
|
|
|
|
}
|
2013-08-23 16:59:50 +02:00
|
|
|
|
|
|
|
@Override
|
|
|
|
public TileEntity createNewTileEntity(World world) {
|
|
|
|
|
|
|
|
return new TileCalcinator();
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean renderAsNormalBlock() {
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public boolean isOpaqueCube() {
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int getRenderType() {
|
|
|
|
|
2013-09-03 22:01:25 +02:00
|
|
|
return RenderIds.calcinatorRender;
|
2013-08-23 16:59:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void breakBlock(World world, int x, int y, int z, int id, int meta) {
|
|
|
|
|
|
|
|
dropInventory(world, x, y, z);
|
|
|
|
super.breakBlock(world, x, y, z, id, meta);
|
|
|
|
}
|
|
|
|
|
|
|
|
@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())
|
|
|
|
return false;
|
|
|
|
else {
|
|
|
|
if (!world.isRemote) {
|
|
|
|
TileCalcinator tileCalcinator = (TileCalcinator) world.getBlockTileEntity(x, y, z);
|
|
|
|
|
|
|
|
if (tileCalcinator != null) {
|
|
|
|
player.openGui(EquivalentExchange3.instance, GuiIds.CALCINATOR, world, x, y, z);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
private void dropInventory(World world, int x, int y, int z) {
|
|
|
|
|
|
|
|
TileEntity tileEntity = world.getBlockTileEntity(x, y, z);
|
|
|
|
|
|
|
|
if (!(tileEntity instanceof IInventory))
|
|
|
|
return;
|
|
|
|
|
|
|
|
IInventory inventory = (IInventory) tileEntity;
|
|
|
|
|
|
|
|
for (int i = 0; i < inventory.getSizeInventory(); i++) {
|
|
|
|
|
|
|
|
ItemStack itemStack = inventory.getStackInSlot(i);
|
|
|
|
|
|
|
|
if (itemStack != null && itemStack.stackSize > 0) {
|
|
|
|
float dX = rand.nextFloat() * 0.8F + 0.1F;
|
|
|
|
float dY = rand.nextFloat() * 0.8F + 0.1F;
|
|
|
|
float dZ = rand.nextFloat() * 0.8F + 0.1F;
|
|
|
|
|
|
|
|
EntityItem entityItem = new EntityItem(world, x + dX, y + dY, z + dZ, new ItemStack(itemStack.itemID, itemStack.stackSize, itemStack.getItemDamage()));
|
|
|
|
|
|
|
|
if (itemStack.hasTagCompound()) {
|
|
|
|
entityItem.getEntityItem().setTagCompound((NBTTagCompound) itemStack.getTagCompound().copy());
|
|
|
|
}
|
|
|
|
|
|
|
|
float factor = 0.05F;
|
|
|
|
entityItem.motionX = rand.nextGaussian() * factor;
|
|
|
|
entityItem.motionY = rand.nextGaussian() * factor + 0.2F;
|
|
|
|
entityItem.motionZ = rand.nextGaussian() * factor;
|
|
|
|
world.spawnEntityInWorld(entityItem);
|
|
|
|
itemStack.stackSize = 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|