package rtg.world.biome.deco;
import java.util.Random;
import net.minecraft.init.Blocks;
import net.minecraft.util.math.BlockPos;
import net.minecraft.world.gen.feature.WorldGenerator;
import net.minecraftforge.event.terraingen.TerrainGen;
import static net.minecraftforge.event.terraingen.DecorateBiomeEvent.Decorate.EventType.GRASS;
import rtg.api.world.RTGWorld;
import rtg.world.biome.realistic.RealisticBiomeBase;
import rtg.world.gen.feature.WorldGenGrass;
/**
* @author WhichOnesPink
*/
public class DecoGrassDoubleTallgrass extends DecoBase {
private float strengthFactor;
private int maxY;
private int loops;
private int grassChance;
private int doubleGrassChance;
public DecoGrassDoubleTallgrass() {
super();
/*
* Default values.
* These can be overridden when configuring the Deco object in the realistic biome.
*/
this.setMaxY(255); // No height limit by default.
this.setStrengthFactor(0f); // Not sure why it was done like this, but... the higher the value, the more there will be.
this.setLoops(1);
this.grassChance = 0; // 50% chance for both grass & double grass by default.
this.setDoubleGrassChance(0); // 50% chance for both grass & double grass by default. (If set, overrides grass chance.)
this.addDecoTypes(DecoType.GRASS, DecoType.GRASS_DOUBLE);
}
@Override
public void generate(RealisticBiomeBase biome, RTGWorld rtgWorld, Random rand, int worldX, int worldZ, float strength, float river, boolean hasPlacedVillageBlocks) {
if (this.allowed) {
if (TerrainGen.decorate(rtgWorld.world, rand, new BlockPos(worldX, 0, worldZ), GRASS)) {
WorldGenerator worldGenerator = null;
if (this.doubleGrassChance > 0) {
if (rand.nextInt(this.doubleGrassChance) == 0) {
worldGenerator = new WorldGenGrass(Blocks.DOUBLE_PLANT.getStateFromMeta(2), 2);
}
else {
worldGenerator = new WorldGenGrass(Blocks.TALLGRASS.getStateFromMeta(1), 1);
}
}
else if (this.grassChance > 0) {
if (rand.nextInt(this.grassChance) == 0) {
worldGenerator = new WorldGenGrass(Blocks.TALLGRASS.getStateFromMeta(1), 1);
}
else {
worldGenerator = new WorldGenGrass(Blocks.DOUBLE_PLANT.getStateFromMeta(2), 2);
}
}
else {
if (rand.nextBoolean()) {
worldGenerator = new WorldGenGrass(Blocks.TALLGRASS.getStateFromMeta(1), 1);
}
else {
worldGenerator = new WorldGenGrass(Blocks.DOUBLE_PLANT.getStateFromMeta(2), 2);
}
}
this.setLoops((this.strengthFactor > 0f) ? (int) (this.strengthFactor * strength) : this.loops);
for (int i = 0; i < this.loops; i++) {
int intX = worldX + rand.nextInt(16) + 8;
int intY = rand.nextInt(this.maxY);
int intZ = worldZ + rand.nextInt(16) + 8;
if (intY <= this.maxY) {
worldGenerator.generate(rtgWorld.world, rand, new BlockPos(intX, intY, intZ));
}
}
}
}
}
public float getStrengthFactor() {
return strengthFactor;
}
public DecoGrassDoubleTallgrass setStrengthFactor(float strengthFactor) {
this.strengthFactor = strengthFactor;
return this;
}
public int getMaxY() {
return maxY;
}
public DecoGrassDoubleTallgrass setMaxY(int maxY) {
this.maxY = maxY;
return this;
}
public int getLoops() {
return loops;
}
public DecoGrassDoubleTallgrass setLoops(int loops) {
this.loops = loops;
return this;
}
public int getGrassChance() {
return grassChance;
}
public DecoGrassDoubleTallgrass setGrassChance(int grassChance) {
this.grassChance = grassChance;
return this;
}
public int getDoubleGrassChance() {
return doubleGrassChance;
}
public DecoGrassDoubleTallgrass setDoubleGrassChance(int doubleGrassChance) {
this.doubleGrassChance = doubleGrassChance;
return this;
}
}