Add helper functions for paged block classes BOPLeaves BOPLog BOPSapling

This commit is contained in:
Cheeserolls 2015-04-19 18:23:42 +01:00
parent bd33408d07
commit fc05c996c3
6 changed files with 99 additions and 9 deletions

View file

@ -22,9 +22,7 @@ import biomesoplenty.api.block.BOPWoodEnums.AllWoods;
import biomesoplenty.common.block.BlockBOPFlower2;
import biomesoplenty.common.block.BlockBOPFlower2.FlowerType;
import biomesoplenty.common.block.BlockBOPLeaves;
import biomesoplenty.common.block.BlockBOPLeaves3;
import biomesoplenty.common.block.BlockBOPLog;
import biomesoplenty.common.block.BlockBOPLog3;
import biomesoplenty.common.block.BlockBOPPlant;
import biomesoplenty.common.block.BlockGem;
import biomesoplenty.common.block.BlockGem.GemType;
@ -49,7 +47,7 @@ public class BiomeGenLavenderFields extends BOPBiome
this.addGenerator("lavender", GeneratorStage.FLOWERS, new GeneratorFlora(999, BOPBlocks.flower2.getDefaultState().withProperty(BlockBOPFlower2.VARIANT, FlowerType.LAVENDER)));
GeneratorWeighted treeGenerator = new GeneratorWeighted(1);
treeGenerator.add(3, new GeneratorBasicTree(1, false, 4, 7, BOPBlocks.log_3.getDefaultState().withProperty(BlockBOPLog.getVariantProperty(BlockBOPLog3.PAGENUM), AllWoods.JACARANDA), BOPBlocks.leaves_3.getDefaultState().withProperty(BlockBOPLeaves.getVariantProperty(BlockBOPLeaves3.PAGENUM), AllTrees.JACARANDA)));
treeGenerator.add(3, new GeneratorBasicTree(1, false, 4, 7, BlockBOPLog.getVariantState(AllWoods.JACARANDA), BlockBOPLeaves.getVariantState(AllTrees.JACARANDA)));
treeGenerator.add(1, new GeneratorBigTree(1, false, Blocks.log.getDefaultState(), Blocks.leaves.getDefaultState()));
this.addGenerator("trees", GeneratorStage.TREE, treeGenerator);

View file

@ -20,7 +20,6 @@ import biomesoplenty.common.block.BlockBOPFlower2;
import biomesoplenty.common.block.BlockBOPFlower2.FlowerType;
import biomesoplenty.common.block.BlockBOPGrass;
import biomesoplenty.common.block.BlockBOPLeaves;
import biomesoplenty.common.block.BlockBOPLeaves2;
import biomesoplenty.common.block.BlockBOPGrass.BOPGrassType;
import biomesoplenty.common.config.MiscConfigurationHandler;
import biomesoplenty.common.world.feature.GeneratorFlora;
@ -40,8 +39,7 @@ public class BiomeGenOriginValley extends BOPBiome
this.topBlock = BOPBlocks.grass.getDefaultState().withProperty(BlockBOPGrass.VARIANT, BOPGrassType.ORIGIN);
GeneratorBasicTree treeGenerator = new GeneratorBasicTree(4, false, 5, 8, Blocks.log.getDefaultState(),
BOPBlocks.leaves_2.getDefaultState().withProperty(BlockBOPLeaves.getVariantProperty(BlockBOPLeaves2.PAGENUM), AllTrees.ORIGIN));
GeneratorBasicTree treeGenerator = new GeneratorBasicTree(4, false, 5, 8, Blocks.log.getDefaultState(), BlockBOPLeaves.getVariantState(AllTrees.ORIGIN));
this.addGenerator("trees", GeneratorStage.TREE, treeGenerator);
GeneratorWeighted flowerGenerator = new GeneratorWeighted(4);

View file

@ -8,7 +8,9 @@
package biomesoplenty.common.block;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Random;
import biomesoplenty.api.block.BOPBlocks;
@ -68,6 +70,32 @@ public abstract class BlockBOPLeaves extends BlockLeaves implements IBOPBlock
return AllTrees.values()[i];
}
// store reference to each created instance, indexed by page num, so that later we can look up the right BlockFoliage instance for a particular variant
private static Map<Integer, BlockBOPLeaves> instances = new HashMap<Integer, BlockBOPLeaves>();
// get the BlockBOPLeaves instance for the given variant
public static BlockBOPLeaves getVariantBlock(AllTrees tree)
{
int pageNum = tree.ordinal() / VARIANTS_PER_PAGE;
BlockBOPLeaves block = instances.get(pageNum);
if (block == null) {throw new IllegalArgumentException("No BlockBOPLeaves instance created yet for page "+pageNum);}
return block;
}
// get the default block state for the given variant
public static IBlockState getVariantState(AllTrees tree)
{
BlockBOPLeaves block = getVariantBlock(tree);
return block.getDefaultState().withProperty(block.getMyVariantProperty() , tree);
}
// get the item representation of the given variant
public static ItemStack getVariantItem(AllTrees tree, int howMany)
{
return new ItemStack(getVariantBlock(tree), howMany, getVariantBlock(tree).getMetaFromState(getVariantState(tree)));
}
public static ItemStack getVariantItem(AllTrees tree)
{
return getVariantItem(tree, 1);
}
// add properties - note CHECK_DECAY and DECAYABLE are both inherited from BlockLeaves
@Override
protected BlockState createBlockState() {return new BlockState(this, new IProperty[] { CHECK_DECAY, DECAYABLE, getMyVariantProperty() });}
@ -98,6 +126,8 @@ public abstract class BlockBOPLeaves extends BlockLeaves implements IBOPBlock
public BlockBOPLeaves()
{
super();
// save a reference to this instance so that later we can look up the right BlockFoliage instance for a particular variant
instances.put(this.getPageNum(), this);
this.setDefaultState(this.blockState.getBaseState().withProperty(CHECK_DECAY, Boolean.valueOf(true)).withProperty(DECAYABLE, Boolean.valueOf(true)));
}

View file

@ -8,6 +8,9 @@
package biomesoplenty.common.block;
import java.util.HashMap;
import java.util.Map;
import biomesoplenty.api.block.BOPWoodEnums.AllWoods;
import biomesoplenty.api.block.BOPWoodEnums;
import biomesoplenty.api.block.IBOPBlock;
@ -18,6 +21,7 @@ import net.minecraft.block.properties.PropertyEnum;
import net.minecraft.block.state.BlockState;
import net.minecraft.block.state.IBlockState;
import net.minecraft.item.ItemBlock;
import net.minecraft.item.ItemStack;
public abstract class BlockBOPLog extends BlockLog implements IBOPBlock
{
@ -50,6 +54,33 @@ public abstract class BlockBOPLog extends BlockLog implements IBOPBlock
return AllWoods.values()[i];
}
// store reference to each created instance, indexed by page num, so that later we can look up the right BlockBOPLog instance for a particular variant
private static Map<Integer, BlockBOPLog> instances = new HashMap<Integer, BlockBOPLog>();
// get the BlockFoliage instance for the given variant
public static BlockBOPLog getVariantBlock(AllWoods wood)
{
int pageNum = wood.ordinal() / VARIANTS_PER_PAGE;
BlockBOPLog block = instances.get(pageNum);
if (block == null) {throw new IllegalArgumentException("No BlockBOPLog instance created yet for page "+pageNum);}
return block;
}
// get the default block state for the given variant
public static IBlockState getVariantState(AllWoods wood)
{
BlockBOPLog block = getVariantBlock(wood);
return block.getDefaultState().withProperty(block.getMyVariantProperty() , wood);
}
// get the item representation of the given variant
public static ItemStack getVariantItem(AllWoods wood, int howMany)
{
return new ItemStack(getVariantBlock(wood), howMany, getVariantBlock(wood).getMetaFromState(getVariantState(wood)));
}
public static ItemStack getVariantItem(AllWoods wood)
{
return getVariantItem(wood, 1);
}
@Override
protected BlockState createBlockState() {return new BlockState(this, new IProperty[] { LOG_AXIS, getMyVariantProperty() });}
@ -80,6 +111,8 @@ public abstract class BlockBOPLog extends BlockLog implements IBOPBlock
public BlockBOPLog()
{
super();
// save a reference to this instance so that later we can look up the right BlockBOPLog instance for a particular variant
instances.put(this.getPageNum(), this);
this.setDefaultState(this.blockState.getBaseState().withProperty(LOG_AXIS, BlockLog.EnumAxis.Y));
this.setHarvestLevel("axe", 0);
}

View file

@ -86,9 +86,9 @@ public abstract class BlockBOPPlant extends BlockDecoration implements IShearabl
int i = Math.max(0, Math.min(meta + (this.getPageNum() * VARIANTS_PER_PAGE), AllPlants.values().length));
return AllPlants.values()[i];
}
// store reference to each created instance, indexed by page num, so that later we can look up the right BlockFoliage instance for a particular variant
private static Map<Integer, BlockBOPPlant> instances = new HashMap<Integer, BlockBOPPlant>();
// get the BlockFoliage instance for the given variant
public static BlockBOPPlant getVariantBlock(AllPlants plant)
{

View file

@ -8,6 +8,8 @@
package biomesoplenty.common.block;
import java.util.HashMap;
import java.util.Map;
import java.util.Random;
import biomesoplenty.api.block.BOPBlocks;
@ -21,6 +23,7 @@ import net.minecraft.block.properties.PropertyInteger;
import net.minecraft.block.state.BlockState;
import net.minecraft.block.state.IBlockState;
import net.minecraft.init.Blocks;
import net.minecraft.item.ItemStack;
import net.minecraft.util.BlockPos;
import net.minecraft.world.World;
import net.minecraft.world.gen.feature.WorldGenAbstractTree;
@ -60,6 +63,32 @@ public abstract class BlockBOPSapling extends BlockDecoration implements IGrowab
return AllTrees.values()[i];
}
// store reference to each created instance, indexed by page num, so that later we can look up the right BlockFoliage instance for a particular variant
private static Map<Integer, BlockBOPSapling> instances = new HashMap<Integer, BlockBOPSapling>();
// get the BlockBOPLeaves instance for the given variant
public static BlockBOPSapling getVariantBlock(AllTrees tree)
{
int pageNum = tree.ordinal() / VARIANTS_PER_PAGE;
BlockBOPSapling block = instances.get(pageNum);
if (block == null) {throw new IllegalArgumentException("No BlockBOPLeaves instance created yet for page "+pageNum);}
return block;
}
// get the default block state for the given variant
public static IBlockState getVariantState(AllTrees tree)
{
BlockBOPSapling block = getVariantBlock(tree);
return block.getDefaultState().withProperty(block.getMyVariantProperty() , tree);
}
// get the item representation of the given variant
public static ItemStack getVariantItem(AllTrees tree, int howMany)
{
return new ItemStack(getVariantBlock(tree), howMany, getVariantBlock(tree).getMetaFromState(getVariantState(tree)));
}
public static ItemStack getVariantItem(AllTrees tree)
{
return getVariantItem(tree, 1);
}
// add properties
public static final PropertyInteger STAGE = PropertyInteger.create("stage", 0, 1);
@ -82,6 +111,8 @@ public abstract class BlockBOPSapling extends BlockDecoration implements IGrowab
public BlockBOPSapling()
{
super();
// save a reference to this instance so that later we can look up the right BlockBOPSapling instance for a particular variant
instances.put(this.getPageNum(), this);
this.setStepSound(Block.soundTypeGrass);
this.setBlockBoundsByRadiusAndHeight(0.4F, 0.8F);
this.setDefaultState(this.blockState.getBaseState().withProperty(STAGE, Integer.valueOf(0)));