This commit is contained in:
paulevsGitch 2020-10-13 15:13:49 +03:00
parent d8ed4fcea2
commit 6f99cdf3a7
3 changed files with 30 additions and 13 deletions

View file

@ -63,7 +63,7 @@ public class BlockRegistry {
public static final WoodenMaterial MOSSY_GLOWSHROOM = new WoodenMaterial("mossy_glowshroom", MaterialColor.GRAY, MaterialColor.WOOD); public static final WoodenMaterial MOSSY_GLOWSHROOM = new WoodenMaterial("mossy_glowshroom", MaterialColor.GRAY, MaterialColor.WOOD);
public static final Block PYTHADENDRON_SAPLING = registerBlock("pythadendron_sapling", new BlockMossyPythadendronSapling()); public static final Block PYTHADENDRON_SAPLING = registerBlock("pythadendron_sapling", new BlockMossyPythadendronSapling());
public static final Block PYTHADENDRON_LEAVES = registerBlock("pythadendron_leaves", new BlockLeaves(MaterialColor.MAGENTA, 8)); public static final Block PYTHADENDRON_LEAVES = registerBlock("pythadendron_leaves", new BlockLeaves(MaterialColor.MAGENTA));
public static final WoodenMaterial PYTHADENDRON = new WoodenMaterial("pythadendron", MaterialColor.MAGENTA, MaterialColor.PURPLE); public static final WoodenMaterial PYTHADENDRON = new WoodenMaterial("pythadendron", MaterialColor.MAGENTA, MaterialColor.PURPLE);
// Small Plants // // Small Plants //

View file

@ -13,13 +13,17 @@ import net.minecraft.util.math.BlockPos;
import net.minecraft.world.StructureWorldAccess; import net.minecraft.world.StructureWorldAccess;
import net.minecraft.world.gen.chunk.ChunkGenerator; import net.minecraft.world.gen.chunk.ChunkGenerator;
import net.minecraft.world.gen.feature.DefaultFeatureConfig; import net.minecraft.world.gen.feature.DefaultFeatureConfig;
import ru.betterend.noise.OpenSimplexNoise;
import ru.betterend.registry.BlockRegistry; import ru.betterend.registry.BlockRegistry;
import ru.betterend.registry.BlockTagRegistry; import ru.betterend.registry.BlockTagRegistry;
import ru.betterend.util.MHelper; import ru.betterend.util.MHelper;
import ru.betterend.util.SplineHelper; import ru.betterend.util.SplineHelper;
import ru.betterend.util.sdf.SDF; import ru.betterend.util.sdf.SDF;
import ru.betterend.util.sdf.operator.SDFDisplacement;
import ru.betterend.util.sdf.operator.SDFScale; import ru.betterend.util.sdf.operator.SDFScale;
import ru.betterend.util.sdf.operator.SDFTranslate;
import ru.betterend.util.sdf.operator.SDFUnion; import ru.betterend.util.sdf.operator.SDFUnion;
import ru.betterend.util.sdf.primitive.SDFSphere;
public class PythadendronTreeFeature extends DefaultFeature { public class PythadendronTreeFeature extends DefaultFeature {
private static final Function<BlockState, Boolean> REPLACE; private static final Function<BlockState, Boolean> REPLACE;
@ -28,12 +32,13 @@ public class PythadendronTreeFeature extends DefaultFeature {
public boolean generate(StructureWorldAccess world, ChunkGenerator chunkGenerator, Random random, BlockPos pos, DefaultFeatureConfig config) { public boolean generate(StructureWorldAccess world, ChunkGenerator chunkGenerator, Random random, BlockPos pos, DefaultFeatureConfig config) {
if (world.getBlockState(pos.down()).getBlock() != BlockRegistry.CHORUS_NYLIUM) return false; if (world.getBlockState(pos.down()).getBlock() != BlockRegistry.CHORUS_NYLIUM) return false;
float size = MHelper.randRange(10, 20, random); float size = MHelper.randRange(10, 13, random);
List<List<Vector3f>> splines = Lists.newArrayList(); List<List<Vector3f>> splines = Lists.newArrayList();
List<Vector3f> spline = SplineHelper.makeSpline(0, 0, 0, 0, size, 0, 4); List<Vector3f> spline = SplineHelper.makeSpline(0, 0, 0, 0, size, 0, 4);
SplineHelper.offsetParts(spline, random, 0.7F, 0, 0.7F); SplineHelper.offsetParts(spline, random, 0.7F, 0, 0.7F);
Vector3f last = spline.get(spline.size() - 1); Vector3f last = spline.get(spline.size() - 1);
branch(splines, last.getX(), last.getY(), last.getZ(), size * 0.6F, MHelper.randRange(0, MHelper.PI2, random), random, MHelper.floor(Math.log(size) * 1.5F)); List<Vector3f> ends = Lists.newArrayList();
branch(splines, ends, last.getX(), last.getY(), last.getZ(), size * 0.6F, MHelper.randRange(0, MHelper.PI2, random), random, MHelper.floor(Math.log(size) * 1.5F));
SDF function = SplineHelper.buildSDF(spline, 1.4F, 0.8F, (bpos) -> { SDF function = SplineHelper.buildSDF(spline, 1.4F, 0.8F, (bpos) -> {
return BlockRegistry.PYTHADENDRON.bark.getDefaultState(); return BlockRegistry.PYTHADENDRON.bark.getDefaultState();
@ -41,21 +46,28 @@ public class PythadendronTreeFeature extends DefaultFeature {
for (List<Vector3f> sp: splines) { for (List<Vector3f> sp: splines) {
float width = 0.8F - (sp.get(0).getY() - size) / 40; float width = 0.8F - (sp.get(0).getY() - size) / 40;
if (size > 0F) { SDF funcSp = SplineHelper.buildSDF(sp, width, width, (bpos) -> {
SDF funcSp = SplineHelper.buildSDF(sp, width, width, (bpos) -> { return BlockRegistry.PYTHADENDRON.bark.getDefaultState();
return BlockRegistry.PYTHADENDRON.bark.getDefaultState(); });
}); function = new SDFUnion().setSourceA(function).setSourceB(funcSp);
function = new SDFUnion().setSourceA(function).setSourceB(funcSp);
}
} }
function = new SDFScale().setScale(MHelper.randRange(1F, 2F, random)).setSource(function);
OpenSimplexNoise noise = new OpenSimplexNoise(random.nextInt());
for (Vector3f v: ends) {
SDF sphere = new SDFSphere().setRadius(MHelper.randRange(2.5F, 3.5F, random)).setBlock(BlockRegistry.PYTHADENDRON_LEAVES);
sphere = new SDFTranslate().setTranslate(v.getX(), v.getY(), v.getZ()).setSource(sphere);
sphere = new SDFDisplacement().setFunction((vec) -> { return (float) noise.eval(vec.getX() * 0.2, vec.getY() * 0.2, vec.getZ() * 0.2); }).setSource(sphere);
function = new SDFUnion().setSourceA(function).setSourceB(sphere);
}
function = new SDFScale().setScale(MHelper.randRange(1.6F, 2.0F, random)).setSource(function);
function.setReplaceFunction(REPLACE); function.setReplaceFunction(REPLACE);
function.fillRecursive(world, pos); function.fillRecursive(world, pos);
return true; return true;
} }
private void branch(List<List<Vector3f>> splines, float x, float y, float z, float size, float angle, Random random, int depth) { private void branch(List<List<Vector3f>> splines, List<Vector3f> ends, float x, float y, float z, float size, float angle, Random random, int depth) {
if (depth == 0) return; if (depth == 0) return;
float dx = (float) Math.cos(angle) * size * 0.3F; float dx = (float) Math.cos(angle) * size * 0.3F;
@ -78,8 +90,13 @@ public class PythadendronTreeFeature extends DefaultFeature {
splines.add(spline); splines.add(spline);
Vector3f pos2 = spline.get(spline.size() - 1); Vector3f pos2 = spline.get(spline.size() - 1);
branch(splines, pos1.getX(), pos1.getY(), pos1.getZ(), size * 0.8F, angle + (float) Math.PI * 0.5F, random, depth - 1); if (depth == 1) {
branch(splines, pos2.getX(), pos2.getY(), pos2.getZ(), size * 0.8F, angle + (float) Math.PI * 0.5F, random, depth - 1); ends.add(pos1);
ends.add(pos2);
}
branch(splines, ends, pos1.getX(), pos1.getY(), pos1.getZ(), size * 0.8F, angle + (float) Math.PI * 0.5F, random, depth - 1);
branch(splines, ends, pos2.getX(), pos2.getY(), pos2.getZ(), size * 0.8F, angle + (float) Math.PI * 0.5F, random, depth - 1);
} }
static { static {

Binary file not shown.

After

Width:  |  Height:  |  Size: 1.6 KiB