164 lines
4.5 KiB
Java
164 lines
4.5 KiB
Java
|
package biomesoplenty.blocks;
|
||
|
|
||
|
import java.util.Random;
|
||
|
|
||
|
import biomesoplenty.BiomesOPlenty;
|
||
|
import biomesoplenty.configuration.BOPBlocks;
|
||
|
|
||
|
import net.minecraft.block.Block;
|
||
|
import net.minecraft.block.material.Material;
|
||
|
import net.minecraft.client.renderer.texture.IconRegister;
|
||
|
import net.minecraft.item.ItemStack;
|
||
|
import net.minecraft.util.Icon;
|
||
|
import net.minecraft.world.World;
|
||
|
|
||
|
@Deprecated
|
||
|
public class BlockAcaciaLog extends Block
|
||
|
{
|
||
|
/** The type of tree this log came from. */
|
||
|
public static final String[] woodType = new String[] {"acacia"};
|
||
|
private Icon[] blockIcon = new Icon[2];
|
||
|
|
||
|
public BlockAcaciaLog(int par1)
|
||
|
{
|
||
|
super(par1, Material.wood);
|
||
|
this.setBurnProperties(this.blockID, 5, 5);
|
||
|
this.setCreativeTab(BiomesOPlenty.tabBiomesOPlenty);
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
public void registerIcons(IconRegister par1IconRegister)
|
||
|
{
|
||
|
this.blockIcon[0] = par1IconRegister.registerIcon("BiomesOPlenty:logTopBottum");
|
||
|
this.blockIcon[1] = par1IconRegister.registerIcon("BiomesOPlenty:acacialog");
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
public Icon getIcon(int par1, int par2)
|
||
|
{
|
||
|
int pos = par2 & 12;
|
||
|
if (pos == 0 && (par1 == 1 || par1 == 0) || pos == 4 && (par1 == 5 || par1 == 4) || pos == 8 && (par1 == 2 || par1 == 3))
|
||
|
return blockIcon[0];
|
||
|
return blockIcon[1];
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* The type of render function that is called for this block
|
||
|
*/
|
||
|
public int getRenderType()
|
||
|
{
|
||
|
return 31;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the quantity of items to drop on block destruction.
|
||
|
*/
|
||
|
public int quantityDropped(Random par1Random)
|
||
|
{
|
||
|
return 1;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns the ID of the items to drop on destruction.
|
||
|
*/
|
||
|
public int idDropped(int par1, Random par2Random, int par3)
|
||
|
{
|
||
|
return BOPBlocks.acaciaWood.blockID;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* ejects contained items into the world, and notifies neighbours of an update, as appropriate
|
||
|
*/
|
||
|
public void breakBlock(World par1World, int par2, int par3, int par4, int par5, int par6)
|
||
|
{
|
||
|
byte var7 = 4;
|
||
|
int var8 = var7 + 1;
|
||
|
|
||
|
if (par1World.checkChunksExist(par2 - var8, par3 - var8, par4 - var8, par2 + var8, par3 + var8, par4 + var8))
|
||
|
{
|
||
|
for (int var9 = -var7; var9 <= var7; ++var9)
|
||
|
{
|
||
|
for (int var10 = -var7; var10 <= var7; ++var10)
|
||
|
{
|
||
|
for (int var11 = -var7; var11 <= var7; ++var11)
|
||
|
{
|
||
|
int var12 = par1World.getBlockId(par2 + var9, par3 + var10, par4 + var11);
|
||
|
|
||
|
if (var12 == BOPBlocks.acaciaLeaves.blockID)
|
||
|
{
|
||
|
int var13 = par1World.getBlockMetadata(par2 + var9, par3 + var10, par4 + var11);
|
||
|
|
||
|
if ((var13 & 8) == 0)
|
||
|
{
|
||
|
par1World.setBlockMetadataWithNotify(par2 + var9, par3 + var10, par4 + var11, var13 | 8, 2);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
public int onBlockPlaced(World par1World, int par2, int par3, int par4, int par5, float par6, float par7, float par8, int par9)
|
||
|
{
|
||
|
int var10 = par9 & 3;
|
||
|
byte var11 = 0;
|
||
|
|
||
|
switch (par5)
|
||
|
{
|
||
|
case 0:
|
||
|
case 1:
|
||
|
var11 = 0;
|
||
|
break;
|
||
|
|
||
|
case 2:
|
||
|
case 3:
|
||
|
var11 = 8;
|
||
|
break;
|
||
|
|
||
|
case 4:
|
||
|
case 5:
|
||
|
var11 = 4;
|
||
|
}
|
||
|
|
||
|
return var10 | var11;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Determines the damage on the item the block drops. Used in cloth and wood.
|
||
|
*/
|
||
|
public int damageDropped(int par1)
|
||
|
{
|
||
|
return par1 & 3;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* returns a number between 0 and 3
|
||
|
*/
|
||
|
public static int limitToValidMetadata(int par0)
|
||
|
{
|
||
|
return par0 & 3;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Returns an item stack containing a single instance of the current block type. 'i' is the block's subtype/damage
|
||
|
* and is ignored for blocks which do not support subtypes. Blocks which cannot be harvested should return null.
|
||
|
*/
|
||
|
protected ItemStack createStackedBlock(int par1)
|
||
|
{
|
||
|
return new ItemStack(this.blockID, 1, limitToValidMetadata(par1));
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
public boolean canSustainLeaves(World world, int x, int y, int z)
|
||
|
{
|
||
|
return true;
|
||
|
}
|
||
|
|
||
|
@Override
|
||
|
public boolean isWood(World world, int x, int y, int z)
|
||
|
{
|
||
|
return true;
|
||
|
}
|
||
|
}
|