proper worldgen!

This commit is contained in:
nelle 2024-12-21 16:32:40 -07:00
parent e49a692261
commit ce09fc287a
14 changed files with 304 additions and 61 deletions

View file

@ -1,9 +1,6 @@
{ {
"type": "minecraft:flower", "type": "minecraft:flower",
"config": { "config": {
"tries": 2,
"xz_spread": 2,
"y_spread": 1,
"feature": { "feature": {
"feature": { "feature": {
"type": "minecraft:simple_block", "type": "minecraft:simple_block",
@ -12,10 +9,16 @@
"type": "minecraft:weighted_state_provider", "type": "minecraft:weighted_state_provider",
"entries": [ "entries": [
{ {
"weight": 2,
"data": { "data": {
"Name": "roses_mod:cyan_rose_flower" "Name": "roses_mod:cyan_rose"
} },
"weight": 2
},
{
"data": {
"Name": "roses_mod:cyan_rose"
},
"weight": 1
} }
] ]
} }
@ -30,6 +33,9 @@
} }
} }
] ]
} },
"tries": 64,
"xz_spread": 7,
"y_spread": 3
} }
} }

View file

@ -1,9 +1,6 @@
{ {
"type": "minecraft:flower", "type": "minecraft:flower",
"config": { "config": {
"tries": 6,
"xz_spread": 5,
"y_spread": 5,
"feature": { "feature": {
"feature": { "feature": {
"type": "minecraft:simple_block", "type": "minecraft:simple_block",
@ -12,10 +9,16 @@
"type": "minecraft:weighted_state_provider", "type": "minecraft:weighted_state_provider",
"entries": [ "entries": [
{ {
"weight": 5,
"data": { "data": {
"Name": "roses_mod:rose_flower" "Name": "roses_mod:rose_flower"
} },
"weight": 2
},
{
"data": {
"Name": "roses_mod:rose_flower"
},
"weight": 1
} }
] ]
} }
@ -30,6 +33,9 @@
} }
} }
] ]
} },
"tries": 64,
"xz_spread": 7,
"y_spread": 3
} }
} }

View file

@ -3,7 +3,7 @@
"placement": [ "placement": [
{ {
"type": "minecraft:rarity_filter", "type": "minecraft:rarity_filter",
"chance": 7 "chance": 85
}, },
{ {
"type": "minecraft:in_square" "type": "minecraft:in_square"

View file

@ -3,7 +3,7 @@
"placement": [ "placement": [
{ {
"type": "minecraft:rarity_filter", "type": "minecraft:rarity_filter",
"chance": 1 "chance": 45
}, },
{ {
"type": "minecraft:in_square" "type": "minecraft:in_square"

View file

@ -0,0 +1,19 @@
{
"feature": "roses_mod:cyan_rose_flower",
"placement": [
{
"type": "minecraft:rarity_filter",
"chance": 70
},
{
"type": "minecraft:in_square"
},
{
"type": "minecraft:heightmap",
"heightmap": "MOTION_BLOCKING"
},
{
"type": "minecraft:biome"
}
]
}

View file

@ -0,0 +1,19 @@
{
"feature": "roses_mod:cyan_rose_flower",
"placement": [
{
"type": "minecraft:rarity_filter",
"chance": 90
},
{
"type": "minecraft:in_square"
},
{
"type": "minecraft:heightmap",
"heightmap": "MOTION_BLOCKING"
},
{
"type": "minecraft:biome"
}
]
}

View file

@ -3,7 +3,7 @@
"placement": [ "placement": [
{ {
"type": "minecraft:rarity_filter", "type": "minecraft:rarity_filter",
"chance": 1 "chance": 4
}, },
{ {
"type": "minecraft:in_square" "type": "minecraft:in_square"

View file

@ -1,9 +1,9 @@
{ {
"feature": "roses_mod:cyan_rose_bush", "feature": "roses_mod:rose_flower",
"placement": [ "placement": [
{ {
"type": "minecraft:rarity_filter", "type": "minecraft:rarity_filter",
"chance": 1 "chance": 32
}, },
{ {
"type": "minecraft:in_square" "type": "minecraft:in_square"

View file

@ -0,0 +1,19 @@
{
"feature": "roses_mod:rose_flower",
"placement": [
{
"type": "minecraft:rarity_filter",
"chance": 80
},
{
"type": "minecraft:in_square"
},
{
"type": "minecraft:heightmap",
"heightmap": "MOTION_BLOCKING"
},
{
"type": "minecraft:biome"
}
]
}

View file

@ -2,12 +2,15 @@ package observer.nelle.roses.world;
// Configured Feature (flowers, how does this look like) -> Placed Feature (How is this feature placed) -> WorldGen/BiomeMod (Where is our feature placed) // Configured Feature (flowers, how does this look like) -> Placed Feature (How is this feature placed) -> WorldGen/BiomeMod (Where is our feature placed)
import net.minecraft.block.BlockState;
import net.minecraft.registry.Registerable; import net.minecraft.registry.Registerable;
import net.minecraft.registry.RegistryKey; import net.minecraft.registry.RegistryKey;
import net.minecraft.registry.RegistryKeys; import net.minecraft.registry.RegistryKeys;
import net.minecraft.util.Identifier; import net.minecraft.util.Identifier;
import net.minecraft.util.collection.DataPool;
import net.minecraft.world.gen.feature.*; import net.minecraft.world.gen.feature.*;
import net.minecraft.world.gen.stateprovider.BlockStateProvider; import net.minecraft.world.gen.stateprovider.BlockStateProvider;
import net.minecraft.world.gen.stateprovider.WeightedBlockStateProvider;
import observer.nelle.roses.RosesBlocks; import observer.nelle.roses.RosesBlocks;
import observer.nelle.roses.RosesModKt; import observer.nelle.roses.RosesModKt;
@ -15,12 +18,28 @@ import java.util.Objects;
public class RosesConfiguredFeatures { public class RosesConfiguredFeatures {
public static final RegistryKey<ConfiguredFeature<?, ?>> cyanRoseBushKey = registerKey("cyan_rose_bush"); public static final RegistryKey<ConfiguredFeature<?, ?>> cyanRoseBushKey = registerKey("cyan_rose_bush");
public static final RegistryKey<ConfiguredFeature<?, ?>> cyanRoseKey = registerKey("cyan_rose_flower");
public static final RegistryKey<ConfiguredFeature<?, ?>> roseKey = registerKey("rose_flower");
public static void bootstrap(Registerable<ConfiguredFeature<?, ?>> context) { public static void bootstrap(Registerable<ConfiguredFeature<?, ?>> context) {
// pretty much exactly as FOREST_FLOWERS // pretty much exactly as FOREST_FLOWERS
register(context, cyanRoseBushKey, Feature.RANDOM_PATCH, register(context, cyanRoseBushKey, Feature.RANDOM_PATCH,
ConfiguredFeatures.createRandomPatchFeatureConfig(Feature.SIMPLE_BLOCK, ConfiguredFeatures.createRandomPatchFeatureConfig(Feature.SIMPLE_BLOCK,
new SimpleBlockFeatureConfig(BlockStateProvider.of(Objects.requireNonNull(RosesBlocks.INSTANCE.getCyanRoseBush()))))); new SimpleBlockFeatureConfig(BlockStateProvider.of(Objects.requireNonNull(RosesBlocks.INSTANCE.getCyanRoseBush())))));
register(context, cyanRoseKey, Feature.FLOWER,
createRandomFlowerPatchFeatureConfig(
new WeightedBlockStateProvider(DataPool.<BlockState>builder()
.add(Objects.requireNonNull(RosesBlocks.INSTANCE.getCyanRoseFlower()).getDefaultState(), 2)
.add(Objects.requireNonNull(RosesBlocks.INSTANCE.getCyanRoseFlower()).getDefaultState(), 1)), 64
));
register(context, roseKey, Feature.FLOWER,
createRandomFlowerPatchFeatureConfig(
new WeightedBlockStateProvider(DataPool.<BlockState>builder()
.add(Objects.requireNonNull(RosesBlocks.INSTANCE.getRoseFlower()).getDefaultState(), 2)
.add(Objects.requireNonNull(RosesBlocks.INSTANCE.getRoseFlower()).getDefaultState(), 1)), 64
));
} }
public static RegistryKey<ConfiguredFeature<?, ?>> registerKey(String name) { public static RegistryKey<ConfiguredFeature<?, ?>> registerKey(String name) {
@ -31,4 +50,8 @@ public class RosesConfiguredFeatures {
RegistryKey<ConfiguredFeature<?, ?>> key, F feature, FC configuration) { RegistryKey<ConfiguredFeature<?, ?>> key, F feature, FC configuration) {
context.register(key, new ConfiguredFeature<>(feature, configuration)); context.register(key, new ConfiguredFeature<>(feature, configuration));
} }
private static RandomPatchFeatureConfig createRandomFlowerPatchFeatureConfig(BlockStateProvider block, int tries) {
return ConfiguredFeatures.createRandomPatchFeatureConfig(tries, PlacedFeatures.createEntry(Feature.SIMPLE_BLOCK, new SimpleBlockFeatureConfig(block)));
}
} }

View file

@ -5,20 +5,76 @@ import net.minecraft.registry.RegistryKey;
import net.minecraft.registry.RegistryKeys; import net.minecraft.registry.RegistryKeys;
import net.minecraft.registry.entry.RegistryEntry; import net.minecraft.registry.entry.RegistryEntry;
import net.minecraft.util.Identifier; import net.minecraft.util.Identifier;
import net.minecraft.world.gen.feature.ConfiguredFeature; import net.minecraft.util.math.intprovider.ClampedIntProvider;
import net.minecraft.world.gen.feature.Feature; import net.minecraft.util.math.intprovider.UniformIntProvider;
import net.minecraft.world.gen.feature.FeatureConfig; import net.minecraft.world.gen.feature.*;
import net.minecraft.world.gen.feature.PlacedFeature;
import net.minecraft.world.gen.placementmodifier.PlacementModifier; import net.minecraft.world.gen.placementmodifier.PlacementModifier;
import net.minecraft.world.gen.placementmodifier.*;
import observer.nelle.roses.RosesModKt; import observer.nelle.roses.RosesModKt;
import java.util.List; import java.util.List;
public class RosesPlacedFeatures { public class RosesPlacedFeatures {
public static final RegistryKey<PlacedFeature> cyanRoseBushPlacedKey = registerKey("cyan_rose_bush_placed");
public static final RegistryKey<PlacedFeature> cyanRosePlacedKey = registerKey("cyan_rose_placed");
public static final RegistryKey<PlacedFeature> rosePlacedKey = registerKey("rose_placed");
public static final RegistryKey<PlacedFeature> cyanRoseRarerPlacedKey = registerKey("cyan_rose_rare_placed");
public static final RegistryKey<PlacedFeature> roseRarerPlacedKey = registerKey("rose_rare_placed");
public static final RegistryKey<PlacedFeature> cyanRoseCommonPlacedKey = registerKey("cyan_rose_common_placed");
public static final RegistryKey<PlacedFeature> roseCommonPlacedKey = registerKey("rose_common_placed");
public static void bootstrap(Registerable<PlacedFeature> context) { public static void bootstrap(Registerable<PlacedFeature> context) {
var configuredFeatures = context.getRegistryLookup(RegistryKeys.CONFIGURED_FEATURE); var configuredFeatures = context.getRegistryLookup(RegistryKeys.CONFIGURED_FEATURE);
register(context, cyanRoseBushPlacedKey, configuredFeatures.getOrThrow(RosesConfiguredFeatures.cyanRoseBushKey),
RarityFilterPlacementModifier.of(85),
SquarePlacementModifier.of(),
PlacedFeatures.MOTION_BLOCKING_HEIGHTMAP,
CountPlacementModifier.of(ClampedIntProvider.create(UniformIntProvider.create(-1, 3), 0, 3)),
BiomePlacementModifier.of());
// regular
register(context, cyanRosePlacedKey, configuredFeatures.getOrThrow(RosesConfiguredFeatures.cyanRoseKey),
RarityFilterPlacementModifier.of(70),
SquarePlacementModifier.of(),
PlacedFeatures.MOTION_BLOCKING_HEIGHTMAP,
BiomePlacementModifier.of());
register(context, rosePlacedKey, configuredFeatures.getOrThrow(RosesConfiguredFeatures.roseKey),
RarityFilterPlacementModifier.of(32),
SquarePlacementModifier.of(),
PlacedFeatures.MOTION_BLOCKING_HEIGHTMAP,
BiomePlacementModifier.of());
// rarer
register(context, cyanRoseRarerPlacedKey, configuredFeatures.getOrThrow(RosesConfiguredFeatures.cyanRoseKey),
RarityFilterPlacementModifier.of(90),
SquarePlacementModifier.of(),
PlacedFeatures.MOTION_BLOCKING_HEIGHTMAP,
BiomePlacementModifier.of());
register(context, roseRarerPlacedKey, configuredFeatures.getOrThrow(RosesConfiguredFeatures.roseKey),
RarityFilterPlacementModifier.of(80),
SquarePlacementModifier.of(),
PlacedFeatures.MOTION_BLOCKING_HEIGHTMAP,
BiomePlacementModifier.of());
// more common
register(context, cyanRoseCommonPlacedKey, configuredFeatures.getOrThrow(RosesConfiguredFeatures.cyanRoseKey),
RarityFilterPlacementModifier.of(45),
SquarePlacementModifier.of(),
PlacedFeatures.MOTION_BLOCKING_HEIGHTMAP,
BiomePlacementModifier.of());
register(context, roseCommonPlacedKey, configuredFeatures.getOrThrow(RosesConfiguredFeatures.roseKey),
RarityFilterPlacementModifier.of(4),
SquarePlacementModifier.of(),
PlacedFeatures.MOTION_BLOCKING_HEIGHTMAP,
BiomePlacementModifier.of());
} }
public static RegistryKey<PlacedFeature> registerKey(String name) { public static RegistryKey<PlacedFeature> registerKey(String name) {

View file

@ -0,0 +1,128 @@
package observer.nelle.roses.world.gen;
import net.fabricmc.fabric.api.biome.v1.BiomeModifications;
import net.fabricmc.fabric.api.biome.v1.BiomeSelectors;
import net.minecraft.world.biome.BiomeKeys;
import net.minecraft.world.gen.GenerationStep;
import observer.nelle.roses.world.RosesPlacedFeatures;
public class RosesVegetationGeneration {
public static void generateVegetation() {
BiomeModifications.addFeature(
BiomeSelectors.includeByKey(
BiomeKeys.FOREST,
BiomeKeys.FLOWER_FOREST,
BiomeKeys.BIRCH_FOREST,
BiomeKeys.OLD_GROWTH_BIRCH_FOREST,
BiomeKeys.DARK_FOREST),
GenerationStep.Feature.VEGETAL_DECORATION, RosesPlacedFeatures.cyanRoseBushPlacedKey);
// regular
BiomeModifications.addFeature(
BiomeSelectors.includeByKey(
BiomeKeys.PLAINS,
BiomeKeys.SUNFLOWER_PLAINS,
BiomeKeys.MEADOW, // https://minecraft.wiki/w/Flower#Flower_gradients
BiomeKeys.FLOWER_FOREST, // https://minecraft.wiki/w/Flower#Flower_gradients
BiomeKeys.SNOWY_PLAINS,
BiomeKeys.FOREST,
BiomeKeys.BIRCH_FOREST,
BiomeKeys.OLD_GROWTH_BIRCH_FOREST,
BiomeKeys.TAIGA,
BiomeKeys.OLD_GROWTH_PINE_TAIGA,
BiomeKeys.OLD_GROWTH_SPRUCE_TAIGA,
BiomeKeys.SNOWY_TAIGA,
BiomeKeys.DARK_FOREST,
BiomeKeys.WINDSWEPT_HILLS,
BiomeKeys.WINDSWEPT_FOREST,
BiomeKeys.WINDSWEPT_GRAVELLY_HILLS,
BiomeKeys.RIVER,
BiomeKeys.FROZEN_RIVER),
GenerationStep.Feature.VEGETAL_DECORATION, RosesPlacedFeatures.cyanRosePlacedKey);
BiomeModifications.addFeature(BiomeSelectors.includeByKey(
BiomeKeys.PLAINS,
BiomeKeys.SUNFLOWER_PLAINS,
BiomeKeys.MEADOW, // https://minecraft.wiki/w/Flower#Flower_gradients
BiomeKeys.FLOWER_FOREST, // https://minecraft.wiki/w/Flower#Flower_gradients
BiomeKeys.SNOWY_PLAINS,
BiomeKeys.FOREST,
BiomeKeys.BIRCH_FOREST,
BiomeKeys.OLD_GROWTH_BIRCH_FOREST,
BiomeKeys.TAIGA,
BiomeKeys.OLD_GROWTH_PINE_TAIGA,
BiomeKeys.OLD_GROWTH_SPRUCE_TAIGA,
BiomeKeys.SNOWY_TAIGA,
BiomeKeys.DARK_FOREST,
BiomeKeys.WINDSWEPT_HILLS,
BiomeKeys.WINDSWEPT_FOREST,
BiomeKeys.WINDSWEPT_GRAVELLY_HILLS,
BiomeKeys.RIVER,
BiomeKeys.FROZEN_RIVER),
GenerationStep.Feature.VEGETAL_DECORATION, RosesPlacedFeatures.rosePlacedKey);
// rarer
BiomeModifications.addFeature(
BiomeSelectors.includeByKey(
BiomeKeys.BEACH,
BiomeKeys.SNOWY_BEACH,
BiomeKeys.STONY_SHORE,
BiomeKeys.OCEAN,
BiomeKeys.DEEP_COLD_OCEAN,
BiomeKeys.COLD_OCEAN,
BiomeKeys.DEEP_FROZEN_OCEAN,
BiomeKeys.DEEP_LUKEWARM_OCEAN,
BiomeKeys.DEEP_OCEAN,
BiomeKeys.FROZEN_OCEAN,
BiomeKeys.LUKEWARM_OCEAN,
BiomeKeys.WARM_OCEAN,
BiomeKeys.DESERT,
BiomeKeys.ICE_SPIKES,
BiomeKeys.DRIPSTONE_CAVES,
BiomeKeys.DEEP_DARK
),
GenerationStep.Feature.VEGETAL_DECORATION, RosesPlacedFeatures.cyanRoseRarerPlacedKey);
BiomeModifications.addFeature(BiomeSelectors.includeByKey(
BiomeKeys.BEACH,
BiomeKeys.SNOWY_BEACH,
BiomeKeys.STONY_SHORE,
BiomeKeys.OCEAN,
BiomeKeys.DEEP_COLD_OCEAN,
BiomeKeys.COLD_OCEAN,
BiomeKeys.DEEP_FROZEN_OCEAN,
BiomeKeys.DEEP_LUKEWARM_OCEAN,
BiomeKeys.DEEP_OCEAN,
BiomeKeys.FROZEN_OCEAN,
BiomeKeys.LUKEWARM_OCEAN,
BiomeKeys.WARM_OCEAN,
BiomeKeys.DESERT,
BiomeKeys.ICE_SPIKES,
BiomeKeys.DRIPSTONE_CAVES,
BiomeKeys.DEEP_DARK
),
GenerationStep.Feature.VEGETAL_DECORATION, RosesPlacedFeatures.roseRarerPlacedKey);
// more common
BiomeModifications.addFeature(
BiomeSelectors.includeByKey(
BiomeKeys.JUNGLE,
BiomeKeys.BAMBOO_JUNGLE,
BiomeKeys.SPARSE_JUNGLE,
BiomeKeys.SAVANNA,
BiomeKeys.SAVANNA_PLATEAU,
BiomeKeys.WINDSWEPT_SAVANNA
),
GenerationStep.Feature.VEGETAL_DECORATION, RosesPlacedFeatures.cyanRoseCommonPlacedKey);
BiomeModifications.addFeature(BiomeSelectors.includeByKey(
BiomeKeys.JUNGLE,
BiomeKeys.BAMBOO_JUNGLE,
BiomeKeys.SPARSE_JUNGLE,
BiomeKeys.SAVANNA,
BiomeKeys.SAVANNA_PLATEAU,
BiomeKeys.WINDSWEPT_SAVANNA
),
GenerationStep.Feature.VEGETAL_DECORATION, RosesPlacedFeatures.roseCommonPlacedKey);
}
}

View file

@ -2,6 +2,6 @@ package observer.nelle.roses.world.gen;
public class RosesWorldGeneration { public class RosesWorldGeneration {
public static void generateRosesWorldGen() { public static void generateRosesWorldGen() {
RosesVegetationGeneration.generateVegetation();
} }
} }

View file

@ -1,33 +0,0 @@
{
"type": "minecraft:random_patch",
"config": {
"tries": 1,
"xz_spread": 7,
"y_spread": 3,
"feature": {
"feature": {
"type": "minecraft:simple_block",
"config": {
"to_place": {
"type": "minecraft:simple_state_provider",
"state": {
"Name": "roses_mod:cyan_rose_bush",
"Properties": {
"half": "lower"
}
}
}
}
},
"placement": [
{
"type": "minecraft:block_predicate_filter",
"predicate": {
"type": "minecraft:matching_blocks",
"blocks": "minecraft:air"
}
}
]
}
}
}