Fixed tree decay
This commit is contained in:
parent
e31d46c2af
commit
9281f5df44
1 changed files with 12 additions and 5 deletions
|
@ -17,6 +17,7 @@ import net.minecraft.util.Direction;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
import net.minecraft.util.math.MutableBoundingBox;
|
import net.minecraft.util.math.MutableBoundingBox;
|
||||||
import net.minecraft.world.IWorld;
|
import net.minecraft.world.IWorld;
|
||||||
|
import net.minecraft.world.IWorldWriter;
|
||||||
import net.minecraft.world.gen.IWorldGenerationReader;
|
import net.minecraft.world.gen.IWorldGenerationReader;
|
||||||
import net.minecraft.world.gen.feature.BaseTreeFeatureConfig;
|
import net.minecraft.world.gen.feature.BaseTreeFeatureConfig;
|
||||||
import net.minecraft.world.gen.feature.TreeFeature;
|
import net.minecraft.world.gen.feature.TreeFeature;
|
||||||
|
@ -149,7 +150,7 @@ public abstract class TreeFeatureBase extends TreeFeature
|
||||||
boolean setOne = false;
|
boolean setOne = false;
|
||||||
while (world.getBlockState(pos).getBlock().isAir(world.getBlockState(pos), world, pos) && length > 0 && rand.nextInt(12) > 0)
|
while (world.getBlockState(pos).getBlock().isAir(world.getBlockState(pos), world, pos) && length > 0 && rand.nextInt(12) > 0)
|
||||||
{
|
{
|
||||||
this.setBlock(world, pos, vineState);
|
setBlock(world, pos, vineState);
|
||||||
setOne = true;
|
setOne = true;
|
||||||
length--;
|
length--;
|
||||||
pos = pos.below();
|
pos = pos.below();
|
||||||
|
@ -161,7 +162,7 @@ public abstract class TreeFeatureBase extends TreeFeature
|
||||||
{
|
{
|
||||||
if (this.replace.matches(world, pos))
|
if (this.replace.matches(world, pos))
|
||||||
{
|
{
|
||||||
this.setBlock(world, pos, this.hanging);
|
setBlock(world, pos, this.hanging);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -171,7 +172,7 @@ public abstract class TreeFeatureBase extends TreeFeature
|
||||||
if (this.trunkFruit == null) {return false;}
|
if (this.trunkFruit == null) {return false;}
|
||||||
if (this.replace.matches(world, pos))
|
if (this.replace.matches(world, pos))
|
||||||
{
|
{
|
||||||
this.setBlock(world, pos, this.trunkFruit);
|
setBlock(world, pos, this.trunkFruit);
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -199,15 +200,21 @@ public abstract class TreeFeatureBase extends TreeFeature
|
||||||
|
|
||||||
protected boolean placeBlock(IWorld world, BlockPos pos, BlockState state, Set<BlockPos> changedBlocks, MutableBoundingBox boundingBox)
|
protected boolean placeBlock(IWorld world, BlockPos pos, BlockState state, Set<BlockPos> changedBlocks, MutableBoundingBox boundingBox)
|
||||||
{
|
{
|
||||||
if (!isAirOrLeaves(world, pos) && !isReplaceablePlant(world, pos) && !isBlockWater(world, pos))
|
if (!isFree(world, pos))
|
||||||
{
|
{
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
this.setBlock(world, pos, state);
|
setBlock(world, pos, state, boundingBox);
|
||||||
changedBlocks.add(pos.immutable());
|
changedBlocks.add(pos.immutable());
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
protected static void setBlock(IWorldWriter world, BlockPos pos, BlockState state, MutableBoundingBox boundingBox)
|
||||||
|
{
|
||||||
|
setBlockKnownShape(world, pos, state);
|
||||||
|
boundingBox.expand(new MutableBoundingBox(pos, pos));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue