From 1701ed3eec407d8dadd13ed0f0a6d51de737d048 Mon Sep 17 00:00:00 2001 From: tastybento Date: Tue, 12 Mar 2024 22:45:58 -0700 Subject: [PATCH 1/8] Register generators early. --- src/main/java/world/bentobox/boxed/Boxed.java | 52 ++++++++++++++----- 1 file changed, 39 insertions(+), 13 deletions(-) diff --git a/src/main/java/world/bentobox/boxed/Boxed.java b/src/main/java/world/bentobox/boxed/Boxed.java index d5ca749..2eb76f9 100644 --- a/src/main/java/world/bentobox/boxed/Boxed.java +++ b/src/main/java/world/bentobox/boxed/Boxed.java @@ -17,6 +17,7 @@ import org.eclipse.jdt.annotation.NonNull; import org.eclipse.jdt.annotation.Nullable; +import world.bentobox.bentobox.BentoBox; import world.bentobox.bentobox.api.addons.GameModeAddon; import world.bentobox.bentobox.api.commands.admin.DefaultAdminCommand; import world.bentobox.bentobox.api.commands.island.DefaultPlayerCommand; @@ -63,11 +64,18 @@ public class Boxed extends GameModeAddon { // Settings private Settings settings; private AbstractBoxedChunkGenerator chunkGenerator; + private AbstractBoxedChunkGenerator seedBaseGen; + private BoxedSeedChunkGenerator seedWorldGenerator; + private AbstractBoxedChunkGenerator netherChunkGenerator; + private AbstractBoxedChunkGenerator seedBaseGenNether; + private BoxedSeedChunkGenerator seedWorldNetherGenerator; + + private final Config configObject = new Config<>(this, Settings.class); private AdvancementsManager advManager; - private AbstractBoxedChunkGenerator netherChunkGenerator; private World seedWorld; private final Map generatorMap = new HashMap<>(); + private final Map generatorMaps = new HashMap<>(); //private World seedWorldEnd; private BiomeProvider boxedBiomeProvider; @@ -89,6 +97,7 @@ public void setup() new AdminPlaceStructureCommand(this); } }; + BentoBox.getInstance().logDebug("On LOAD done!"); } private boolean loadSettings() { @@ -102,12 +111,32 @@ private boolean loadSettings() { } // Initialize the Generator because createWorlds will be run after onLoad this.chunkGenerator = new BoxedChunkGenerator(this); + generatorMaps.put(settings.getWorldName(), chunkGenerator); + + seedBaseGen = new BoxedSeedChunkGenerator(this, Environment.NORMAL); + generatorMaps.put(settings.getWorldName() + "/" + SEED + BASE, seedBaseGen); + + seedWorldGenerator = new BoxedSeedChunkGenerator(this, Environment.NORMAL, + new SeedBiomeGenerator(this, seedBaseGen)); + generatorMaps.put(settings.getWorldName() + "/" + SEED, seedWorldGenerator); + + // Nether generators this.netherChunkGenerator = new BoxedChunkGenerator(this); + generatorMaps.put(settings.getWorldName() + "/" + NETHER, netherChunkGenerator); + + seedBaseGenNether = new BoxedSeedChunkGenerator(this, Environment.NETHER); + generatorMaps.put(settings.getWorldName() + "/" + NETHER + SEED + BASE, seedBaseGenNether); + + seedWorldNetherGenerator = new BoxedSeedChunkGenerator(this, Environment.NETHER, + new NetherSeedBiomeGenerator(this, seedBaseGen)); + generatorMaps.put(settings.getWorldName() + "/" + NETHER + SEED, seedWorldNetherGenerator); + return true; } @Override public void onEnable() { + BentoBox.getInstance().logDebug("On Enable started!"); // Check for recommended addons if (this.getPlugin().getAddonsManager().getAddonByName("Border").isEmpty()) { this.logWarning("Boxed normally requires the Border addon."); @@ -162,6 +191,7 @@ public Settings getSettings() { @Override public void createWorlds() { + BentoBox.getInstance().logDebug("Create Worlds started!"); String worldName = settings.getWorldName().toLowerCase(); // Create overworld createOverWorld(worldName); @@ -180,23 +210,20 @@ public void createWorlds() { private void createNether(String worldName) { // Create vanilla seed nether world log("Creating Boxed Seed Nether world ..."); - // This creates a vanilla base world with biomes - AbstractBoxedChunkGenerator seedBaseGen = new BoxedSeedChunkGenerator(this, Environment.NETHER); World baseWorldNether = WorldCreator .name(worldName + "/" + SEED + NETHER + BASE) - .generator(seedBaseGen) + .generator(seedBaseGenNether) .environment(Environment.NETHER) .seed(getSettings().getSeed()) .createWorld(); baseWorldNether.setDifficulty(Difficulty.PEACEFUL); baseWorldNether.setSpawnLocation(settings.getSeedX(), 64, settings.getSeedZ()); - generatorMap.put(baseWorldNether, seedBaseGen); + generatorMap.put(baseWorldNether, seedBaseGenNether); getPlugin().getIWM().addWorld(baseWorldNether, this); - copyChunks(baseWorldNether, seedBaseGen); + copyChunks(baseWorldNether, seedBaseGenNether); // Create seed world // This copies a base world with custom biomes log("Creating Boxed Biomed Nether world ..."); - BoxedSeedChunkGenerator seedWorldNetherGenerator = new BoxedSeedChunkGenerator(this, Environment.NETHER, new NetherSeedBiomeGenerator(this, seedBaseGen)); World seedWorldNether = WorldCreator .name(worldName + "/" + SEED + NETHER) .generator(seedWorldNetherGenerator) @@ -220,7 +247,6 @@ private void createOverWorld(String worldName) { // Create vanilla seed world log("Creating Boxed Seed world ..."); // This creates a vanilla base world with biomes - AbstractBoxedChunkGenerator seedBaseGen = new BoxedSeedChunkGenerator(this, Environment.NORMAL); World baseWorld = WorldCreator .name(worldName + "/" + SEED + BASE) .generator(seedBaseGen) @@ -235,7 +261,6 @@ private void createOverWorld(String worldName) { // Create seed world // This copies a base world with custom biomes log("Creating Boxed Biomed world ..."); - BoxedSeedChunkGenerator seedWorldGenerator = new BoxedSeedChunkGenerator(this, Environment.NORMAL, new SeedBiomeGenerator(this, seedBaseGen)); seedWorld = WorldCreator .name(worldName + "/" + SEED) .generator(seedWorldGenerator) @@ -250,8 +275,6 @@ private void createOverWorld(String worldName) { getPlugin().getIWM().addWorld(seedWorld, this); copyChunks(seedWorld, chunkGenerator); - - if (getServer().getWorld(worldName) == null) { log("Creating Boxed world ..."); } @@ -386,11 +409,14 @@ public WorldSettings getWorldSettings() { @Override public @Nullable ChunkGenerator getDefaultWorldGenerator(String worldName, String id) { - for (Entry en : generatorMap.entrySet()) { - if (en.getKey().getName().equalsIgnoreCase(worldName)) { + BentoBox.getInstance().logDebug("Calling default chunk gen in Boxed - request is for " + worldName); + for (Entry en : generatorMaps.entrySet()) { + if (en.getKey().equalsIgnoreCase(worldName)) { + BentoBox.getInstance().logDebug("Found!"); return en.getValue(); } } + BentoBox.getInstance().logDebug("Not found"); return null; } From d78e4120761781bba443b4f9136303b1bcb57484 Mon Sep 17 00:00:00 2001 From: tastybento Date: Tue, 12 Mar 2024 23:23:55 -0700 Subject: [PATCH 2/8] Make generators available asap. --- src/main/java/world/bentobox/boxed/Boxed.java | 60 +++++++++---------- .../chunks/BoxedChunkGenerator.java | 3 +- 2 files changed, 28 insertions(+), 35 deletions(-) diff --git a/src/main/java/world/bentobox/boxed/Boxed.java b/src/main/java/world/bentobox/boxed/Boxed.java index 2eb76f9..71be0ca 100644 --- a/src/main/java/world/bentobox/boxed/Boxed.java +++ b/src/main/java/world/bentobox/boxed/Boxed.java @@ -17,7 +17,6 @@ import org.eclipse.jdt.annotation.NonNull; import org.eclipse.jdt.annotation.Nullable; -import world.bentobox.bentobox.BentoBox; import world.bentobox.bentobox.api.addons.GameModeAddon; import world.bentobox.bentobox.api.commands.admin.DefaultAdminCommand; import world.bentobox.bentobox.api.commands.island.DefaultPlayerCommand; @@ -63,12 +62,12 @@ public class Boxed extends GameModeAddon { // Settings private Settings settings; - private AbstractBoxedChunkGenerator chunkGenerator; + private AbstractBoxedChunkGenerator worldGen; private AbstractBoxedChunkGenerator seedBaseGen; - private BoxedSeedChunkGenerator seedWorldGenerator; - private AbstractBoxedChunkGenerator netherChunkGenerator; - private AbstractBoxedChunkGenerator seedBaseGenNether; - private BoxedSeedChunkGenerator seedWorldNetherGenerator; + private BoxedSeedChunkGenerator seedGen; + private AbstractBoxedChunkGenerator netherGen; + private AbstractBoxedChunkGenerator netherSeedBaseGen; + private BoxedSeedChunkGenerator netherSeedGen; private final Config configObject = new Config<>(this, Settings.class); @@ -97,7 +96,6 @@ public void setup() new AdminPlaceStructureCommand(this); } }; - BentoBox.getInstance().logDebug("On LOAD done!"); } private boolean loadSettings() { @@ -110,33 +108,32 @@ private boolean loadSettings() { return false; } // Initialize the Generator because createWorlds will be run after onLoad - this.chunkGenerator = new BoxedChunkGenerator(this); - generatorMaps.put(settings.getWorldName(), chunkGenerator); + this.worldGen = new BoxedChunkGenerator(this); + generatorMaps.put(settings.getWorldName(), worldGen); seedBaseGen = new BoxedSeedChunkGenerator(this, Environment.NORMAL); generatorMaps.put(settings.getWorldName() + "/" + SEED + BASE, seedBaseGen); - seedWorldGenerator = new BoxedSeedChunkGenerator(this, Environment.NORMAL, + seedGen = new BoxedSeedChunkGenerator(this, Environment.NORMAL, new SeedBiomeGenerator(this, seedBaseGen)); - generatorMaps.put(settings.getWorldName() + "/" + SEED, seedWorldGenerator); + generatorMaps.put(settings.getWorldName() + "/" + SEED, seedGen); // Nether generators - this.netherChunkGenerator = new BoxedChunkGenerator(this); - generatorMaps.put(settings.getWorldName() + "/" + NETHER, netherChunkGenerator); + this.netherGen = new BoxedChunkGenerator(this); + generatorMaps.put(settings.getWorldName() + NETHER, netherGen); - seedBaseGenNether = new BoxedSeedChunkGenerator(this, Environment.NETHER); - generatorMaps.put(settings.getWorldName() + "/" + NETHER + SEED + BASE, seedBaseGenNether); + netherSeedBaseGen = new BoxedSeedChunkGenerator(this, Environment.NETHER); + generatorMaps.put(settings.getWorldName() + "/" + SEED + NETHER + BASE, netherSeedBaseGen); // + SEED + NETHER + BASE) - seedWorldNetherGenerator = new BoxedSeedChunkGenerator(this, Environment.NETHER, + netherSeedGen = new BoxedSeedChunkGenerator(this, Environment.NETHER, new NetherSeedBiomeGenerator(this, seedBaseGen)); - generatorMaps.put(settings.getWorldName() + "/" + NETHER + SEED, seedWorldNetherGenerator); + generatorMaps.put(settings.getWorldName() + "/" + SEED + NETHER, netherSeedGen); return true; } @Override public void onEnable() { - BentoBox.getInstance().logDebug("On Enable started!"); // Check for recommended addons if (this.getPlugin().getAddonsManager().getAddonByName("Border").isEmpty()) { this.logWarning("Boxed normally requires the Border addon."); @@ -191,7 +188,6 @@ public Settings getSettings() { @Override public void createWorlds() { - BentoBox.getInstance().logDebug("Create Worlds started!"); String worldName = settings.getWorldName().toLowerCase(); // Create overworld createOverWorld(worldName); @@ -212,30 +208,30 @@ private void createNether(String worldName) { log("Creating Boxed Seed Nether world ..."); World baseWorldNether = WorldCreator .name(worldName + "/" + SEED + NETHER + BASE) - .generator(seedBaseGenNether) + .generator(netherSeedBaseGen) .environment(Environment.NETHER) .seed(getSettings().getSeed()) .createWorld(); baseWorldNether.setDifficulty(Difficulty.PEACEFUL); baseWorldNether.setSpawnLocation(settings.getSeedX(), 64, settings.getSeedZ()); - generatorMap.put(baseWorldNether, seedBaseGenNether); + generatorMap.put(baseWorldNether, netherSeedBaseGen); getPlugin().getIWM().addWorld(baseWorldNether, this); - copyChunks(baseWorldNether, seedBaseGenNether); + copyChunks(baseWorldNether, netherSeedBaseGen); // Create seed world // This copies a base world with custom biomes log("Creating Boxed Biomed Nether world ..."); World seedWorldNether = WorldCreator .name(worldName + "/" + SEED + NETHER) - .generator(seedWorldNetherGenerator) + .generator(netherSeedGen) .environment(Environment.NETHER) .seed(getSettings().getSeed()) .createWorld(); seedWorldNether.setDifficulty(Difficulty.EASY); seedWorldNether.setSpawnLocation(settings.getNetherSeedX(), 64, settings.getNetherSeedZ()); - generatorMap.put(seedWorldNether, seedWorldNetherGenerator); + generatorMap.put(seedWorldNether, netherSeedGen); getPlugin().getIWM().addWorld(seedWorldNether, this); - copyChunks(seedWorldNether, netherChunkGenerator); + copyChunks(seedWorldNether, netherGen); if (getServer().getWorld(worldName + NETHER) == null) { log("Creating Boxed's Nether..."); @@ -263,7 +259,7 @@ private void createOverWorld(String worldName) { log("Creating Boxed Biomed world ..."); seedWorld = WorldCreator .name(worldName + "/" + SEED) - .generator(seedWorldGenerator) + .generator(seedGen) .environment(Environment.NORMAL) .seed(getSettings().getSeed()) .createWorld(); @@ -271,9 +267,9 @@ private void createOverWorld(String worldName) { seedWorld.setSpawnLocation(settings.getSeedX(), 64, settings.getSeedZ()); - generatorMap.put(seedWorld, seedWorldGenerator); + generatorMap.put(seedWorld, seedGen); getPlugin().getIWM().addWorld(seedWorld, this); - copyChunks(seedWorld, chunkGenerator); + copyChunks(seedWorld, worldGen); if (getServer().getWorld(worldName) == null) { log("Creating Boxed world ..."); @@ -331,7 +327,8 @@ private void copyChunks(World world, AbstractBoxedChunkGenerator gen) { int p = (int) (count / percent * 100); if (p % 10 == 0 && p != last) { last = p; - this.log("Pregenrating seed chunks for " + world.getName() + "'s " + world.getEnvironment() + " " + p + "% done"); + this.log("Pregenerating seed chunks for " + world.getName() + "'s " + world.getEnvironment() + " " + + p + "% done"); } } @@ -344,7 +341,7 @@ private void copyChunks(World world, AbstractBoxedChunkGenerator gen) { * @return the chunkGenerator for the environment */ public AbstractBoxedChunkGenerator getChunkGenerator(Environment env) { - return env.equals(Environment.NORMAL) ? chunkGenerator : netherChunkGenerator; + return env.equals(Environment.NORMAL) ? worldGen : netherGen; } /** @@ -409,14 +406,11 @@ public WorldSettings getWorldSettings() { @Override public @Nullable ChunkGenerator getDefaultWorldGenerator(String worldName, String id) { - BentoBox.getInstance().logDebug("Calling default chunk gen in Boxed - request is for " + worldName); for (Entry en : generatorMaps.entrySet()) { if (en.getKey().equalsIgnoreCase(worldName)) { - BentoBox.getInstance().logDebug("Found!"); return en.getValue(); } } - BentoBox.getInstance().logDebug("Not found"); return null; } diff --git a/src/main/java/world/bentobox/boxed/generators/chunks/BoxedChunkGenerator.java b/src/main/java/world/bentobox/boxed/generators/chunks/BoxedChunkGenerator.java index 7383583..e47099b 100644 --- a/src/main/java/world/bentobox/boxed/generators/chunks/BoxedChunkGenerator.java +++ b/src/main/java/world/bentobox/boxed/generators/chunks/BoxedChunkGenerator.java @@ -33,7 +33,6 @@ import org.bukkit.material.Colorable; import org.bukkit.util.Vector; -import world.bentobox.bentobox.BentoBox; import world.bentobox.bentobox.blueprints.dataobjects.BlueprintBlock; import world.bentobox.bentobox.blueprints.dataobjects.BlueprintCreatureSpawner; import world.bentobox.bentobox.blueprints.dataobjects.BlueprintEntity; @@ -206,7 +205,7 @@ public void generateNoise(WorldInfo worldInfo, Random r, int chunkX, int chunkZ, if (chunk == null) { // This should never be needed because islands should abut each other //cd.setRegion(0, minY, 0, 16, 0, 16, Material.WATER); - BentoBox.getInstance().logError("No chunks found for " + xx + " " + zz); + //BentoBox.getInstance().logError("No chunks found for " + xx + " " + zz); return; } // Copy the chunk From e30b12b3123c855bb2079e38885ae5c52178810f Mon Sep 17 00:00:00 2001 From: tastybento Date: Sat, 23 Mar 2024 22:02:36 -0700 Subject: [PATCH 3/8] Make just one seed world. Implement vanilla biomes. --- src/main/java/world/bentobox/boxed/Boxed.java | 43 +- .../biomes/AbstractSeedBiomeProvider.java | 1055 ++++++++++++++++- .../biomes/NetherSeedBiomeGenerator.java | 6 +- .../generators/biomes/SeedBiomeGenerator.java | 7 +- .../chunks/AbstractBoxedChunkGenerator.java | 1 + 5 files changed, 1009 insertions(+), 103 deletions(-) diff --git a/src/main/java/world/bentobox/boxed/Boxed.java b/src/main/java/world/bentobox/boxed/Boxed.java index 71be0ca..8255fb5 100644 --- a/src/main/java/world/bentobox/boxed/Boxed.java +++ b/src/main/java/world/bentobox/boxed/Boxed.java @@ -58,15 +58,12 @@ public class Boxed extends GameModeAddon { private static final String SEED = "seed"; private static final String NETHER = "_nether"; private static final String THE_END = "_the_end"; - private static final String BASE = "_base"; // Settings private Settings settings; private AbstractBoxedChunkGenerator worldGen; - private AbstractBoxedChunkGenerator seedBaseGen; private BoxedSeedChunkGenerator seedGen; private AbstractBoxedChunkGenerator netherGen; - private AbstractBoxedChunkGenerator netherSeedBaseGen; private BoxedSeedChunkGenerator netherSeedGen; @@ -75,7 +72,6 @@ public class Boxed extends GameModeAddon { private World seedWorld; private final Map generatorMap = new HashMap<>(); private final Map generatorMaps = new HashMap<>(); - //private World seedWorldEnd; private BiomeProvider boxedBiomeProvider; @Override @@ -111,22 +107,16 @@ private boolean loadSettings() { this.worldGen = new BoxedChunkGenerator(this); generatorMaps.put(settings.getWorldName(), worldGen); - seedBaseGen = new BoxedSeedChunkGenerator(this, Environment.NORMAL); - generatorMaps.put(settings.getWorldName() + "/" + SEED + BASE, seedBaseGen); - seedGen = new BoxedSeedChunkGenerator(this, Environment.NORMAL, - new SeedBiomeGenerator(this, seedBaseGen)); + new SeedBiomeGenerator(this)); generatorMaps.put(settings.getWorldName() + "/" + SEED, seedGen); // Nether generators this.netherGen = new BoxedChunkGenerator(this); generatorMaps.put(settings.getWorldName() + NETHER, netherGen); - netherSeedBaseGen = new BoxedSeedChunkGenerator(this, Environment.NETHER); - generatorMaps.put(settings.getWorldName() + "/" + SEED + NETHER + BASE, netherSeedBaseGen); // + SEED + NETHER + BASE) - netherSeedGen = new BoxedSeedChunkGenerator(this, Environment.NETHER, - new NetherSeedBiomeGenerator(this, seedBaseGen)); + new NetherSeedBiomeGenerator(this)); generatorMaps.put(settings.getWorldName() + "/" + SEED + NETHER, netherSeedGen); return true; @@ -206,20 +196,6 @@ public void createWorlds() { private void createNether(String worldName) { // Create vanilla seed nether world log("Creating Boxed Seed Nether world ..."); - World baseWorldNether = WorldCreator - .name(worldName + "/" + SEED + NETHER + BASE) - .generator(netherSeedBaseGen) - .environment(Environment.NETHER) - .seed(getSettings().getSeed()) - .createWorld(); - baseWorldNether.setDifficulty(Difficulty.PEACEFUL); - baseWorldNether.setSpawnLocation(settings.getSeedX(), 64, settings.getSeedZ()); - generatorMap.put(baseWorldNether, netherSeedBaseGen); - getPlugin().getIWM().addWorld(baseWorldNether, this); - copyChunks(baseWorldNether, netherSeedBaseGen); - // Create seed world - // This copies a base world with custom biomes - log("Creating Boxed Biomed Nether world ..."); World seedWorldNether = WorldCreator .name(worldName + "/" + SEED + NETHER) .generator(netherSeedGen) @@ -242,21 +218,6 @@ private void createNether(String worldName) { private void createOverWorld(String worldName) { // Create vanilla seed world log("Creating Boxed Seed world ..."); - // This creates a vanilla base world with biomes - World baseWorld = WorldCreator - .name(worldName + "/" + SEED + BASE) - .generator(seedBaseGen) - .environment(Environment.NORMAL) - .seed(getSettings().getSeed()) - .createWorld(); - baseWorld.setDifficulty(Difficulty.PEACEFUL); - baseWorld.setSpawnLocation(settings.getSeedX(), 64, settings.getSeedZ()); - generatorMap.put(baseWorld, seedBaseGen); - getPlugin().getIWM().addWorld(baseWorld, this); - copyChunks(baseWorld, seedBaseGen); - // Create seed world - // This copies a base world with custom biomes - log("Creating Boxed Biomed world ..."); seedWorld = WorldCreator .name(worldName + "/" + SEED) .generator(seedGen) diff --git a/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java b/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java index 8efd5cb..4b3895b 100644 --- a/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java +++ b/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java @@ -8,7 +8,6 @@ import java.util.Locale; import java.util.Map; import java.util.Map.Entry; -import java.util.Objects; import java.util.SortedMap; import java.util.TreeMap; @@ -16,6 +15,7 @@ import org.bukkit.block.Biome; import org.bukkit.block.BlockFace; import org.bukkit.configuration.file.YamlConfiguration; +import org.bukkit.generator.BiomeParameterPoint; import org.bukkit.generator.BiomeProvider; import org.bukkit.generator.WorldInfo; import org.bukkit.util.Vector; @@ -24,8 +24,6 @@ import com.google.common.base.Enums; import world.bentobox.boxed.Boxed; -import world.bentobox.boxed.generators.chunks.AbstractBoxedChunkGenerator; -import world.bentobox.boxed.generators.chunks.AbstractBoxedChunkGenerator.ChunkStore; /** * Generates the biomes for the seed world. A seed world is the template for the chunks that @@ -36,7 +34,6 @@ public abstract class AbstractSeedBiomeProvider extends BiomeProvider { private static final Map ENV_MAP; - private static final int DEPTH = 50; static { Map e = new EnumMap<>(Environment.class); @@ -46,22 +43,240 @@ public abstract class AbstractSeedBiomeProvider extends BiomeProvider { ENV_MAP = Collections.unmodifiableMap(e); } - private final Boxed addon; - private final Biome defaultBiome; - //private Map, Biome> biomeCache = new HashMap<>(); + private enum Ridges { + VALLEYS(-1.0, -0.85), LOW(-0.85, -0.6), MID(-0.6, 0.2), HIGH(0.2, 0.7), PEAKS(0.7, 1.0); - protected final int dist; + private double low; + private double high; + + Ridges(double low, double high) { + this.low = low; + this.high = high; + } + + public static Ridges getRidge(double x) { + for (Ridges r : Ridges.values()) { + if (x >= r.low && x < r.high) { + return r; + } + } + return MID; + } + + } + + private enum BadlandBiome { + h0(0, Biome.BADLANDS, Biome.ERODED_BADLANDS), h1(1, Biome.BADLANDS, Biome.ERODED_BADLANDS), + h2(2, Biome.BADLANDS, Biome.BADLANDS), h3(3, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS), + h4(4, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS); + + private int h; + private Biome biome; + private Biome biome2; + + BadlandBiome(int h, Biome biome, Biome biome2) { + this.h = h; + this.biome = biome; + this.biome2 = biome2; + } + + public static Biome getBiome(int h, double we) { + for (BadlandBiome mb : BadlandBiome.values()) { + if (mb.h == h) { + if (we < 0) { + return mb.biome; + } else { + return mb.biome2; + } + } + } + throw new IllegalArgumentException("badlands biome h = " + h); + } + } + + private enum MiddleBiome { + x00(0, 0, Biome.SNOWY_PLAINS, Biome.ICE_SPIKES), x01(0, 1, Biome.PLAINS, Biome.PLAINS), + x02(0, 2, Biome.FLOWER_FOREST, Biome.SUNFLOWER_PLAINS), x03(0, 3, Biome.SAVANNA, Biome.SAVANNA), + x04(0, 4, Biome.DESERT, Biome.DESERT), + + x10(1, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_PLAINS), x11(1, 1, Biome.PLAINS, Biome.PLAINS), + x12(1, 2, Biome.PLAINS, Biome.PLAINS), x13(1, 3, Biome.SAVANNA, Biome.SAVANNA), + x14(1, 4, Biome.DESERT, Biome.DESERT), + + x20(2, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_TAIGA), x21(2, 1, Biome.FOREST, Biome.FOREST), + x22(2, 2, Biome.FOREST, Biome.FOREST), x23(2, 3, Biome.FOREST, Biome.PLAINS), + x24(2, 4, Biome.DESERT, Biome.DESERT), + + x30(3, 0, Biome.SNOWY_TAIGA, Biome.SNOWY_TAIGA), x31(3, 1, Biome.TAIGA, Biome.TAIGA), + x32(3, 2, Biome.BIRCH_FOREST, Biome.OLD_GROWTH_BIRCH_FOREST), x33(3, 3, Biome.JUNGLE, Biome.SPARSE_JUNGLE), + x34(3, 4, Biome.DESERT, Biome.DESERT), + + x40(4, 0, Biome.TAIGA, Biome.TAIGA), x41(4, 1, Biome.OLD_GROWTH_SPRUCE_TAIGA, Biome.OLD_GROWTH_PINE_TAIGA), + x42(4, 2, Biome.DARK_FOREST, Biome.DARK_FOREST), x43(4, 3, Biome.JUNGLE, Biome.BAMBOO_JUNGLE), + x44(4, 4, Biome.DESERT, Biome.DESERT), + ; + + private int t; + private int h; + private Biome b; + private Biome weirdBiome; + + MiddleBiome(int h, int t, Biome b, Biome weirdBiome) { + this.h = h; + this.t = t; + this.weirdBiome = weirdBiome; + this.b = b; + } + + public static Biome getBiome(int h, int t, double we) { + for (MiddleBiome mb : MiddleBiome.values()) { + if (mb.h == h && mb.t == t) { + if (we < 0) { + return mb.b; + } else { + return mb.weirdBiome; + } + } + } + throw new IllegalArgumentException("middle biome h = " + h + " t = " + t); + } + } + + private enum PlateauBiome { + x00(0, 0, Biome.SNOWY_PLAINS, Biome.ICE_SPIKES), x01(0, 1, Biome.MEADOW, Biome.CHERRY_GROVE), + x02(0, 2, Biome.MEADOW, Biome.CHERRY_GROVE), x03(0, 3, Biome.SAVANNA_PLATEAU, Biome.SAVANNA_PLATEAU), + x04(0, 4, Biome.BADLANDS, Biome.ERODED_BADLANDS), + + x10(1, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_PLAINS), x11(1, 1, Biome.MEADOW, Biome.MEADOW), + x12(1, 2, Biome.MEADOW, Biome.CHERRY_GROVE), x13(1, 3, Biome.SAVANNA_PLATEAU, Biome.SAVANNA_PLATEAU), + x14(1, 4, Biome.BADLANDS, Biome.ERODED_BADLANDS), + + x20(2, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_TAIGA), x21(2, 1, Biome.FOREST, Biome.MEADOW), + x22(2, 2, Biome.MEADOW, Biome.BIRCH_FOREST), x23(2, 3, Biome.FOREST, Biome.FOREST), + x24(2, 4, Biome.BADLANDS, Biome.BADLANDS), + + x30(3, 0, Biome.SNOWY_TAIGA, Biome.SNOWY_TAIGA), x31(3, 1, Biome.TAIGA, Biome.MEADOW), + x32(3, 2, Biome.MEADOW, Biome.BIRCH_FOREST), x33(3, 3, Biome.FOREST, Biome.FOREST), + x34(3, 4, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS), + + x40(4, 0, Biome.SNOWY_TAIGA, Biome.SNOWY_TAIGA), + x41(4, 1, Biome.OLD_GROWTH_SPRUCE_TAIGA, Biome.OLD_GROWTH_PINE_TAIGA), + x42(4, 2, Biome.DARK_FOREST, Biome.DARK_FOREST), x43(4, 3, Biome.JUNGLE, Biome.JUNGLE), + x44(4, 4, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS),; + + private int temp; + private int humidity; + private Biome b; + private Biome weirdBiome; + + PlateauBiome(int humidity, int temp, Biome b, Biome weirdBiome) { + this.humidity = humidity; + this.temp = temp; + this.weirdBiome = weirdBiome; + this.b = b; + } + + public static Biome getBiome(int humidity, int temp, double weirdness) { + for (PlateauBiome mb : PlateauBiome.values()) { + if (mb.humidity == humidity && mb.temp == temp) { + if (weirdness < 0) { + return mb.b; + } else { + return mb.weirdBiome; + } + } + } + throw new IllegalArgumentException("plateau biome h = " + humidity + " t = " + temp); + } + } + + private enum ShatteredBiome { + x00(0, 0, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), + x01(0, 1, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), + x02(0, 2, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), x03(0, 3, Biome.SAVANNA, Biome.SAVANNA), + x04(0, 4, Biome.DESERT, Biome.DESERT), + + x10(1, 0, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), + x11(1, 1, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), + x12(1, 2, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), + x13(1, 3, Biome.SAVANNA_PLATEAU, Biome.SAVANNA_PLATEAU), x14(1, 4, Biome.DESERT, Biome.DESERT), + + x20(2, 0, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), + x21(2, 1, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), + x22(2, 2, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), x23(2, 3, Biome.FOREST, Biome.FOREST), + x24(2, 4, Biome.DESERT, Biome.DESERT), + + x30(3, 0, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), + x31(3, 1, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), + x32(3, 2, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), x33(3, 3, Biome.JUNGLE, Biome.SPARSE_JUNGLE), + x34(3, 4, Biome.DESERT, Biome.DESERT), + + x40(4, 0, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), + x41(4, 1, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), + x42(4, 2, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), x43(4, 3, Biome.JUNGLE, Biome.BAMBOO_JUNGLE), + x44(4, 4, Biome.DESERT, Biome.DESERT),; + + private int t; + private int h; + private Biome b; + private Biome weirdBiome; + + ShatteredBiome(int h, int t, Biome b, Biome weirdBiome) { + this.h = h; + this.t = t; + this.weirdBiome = weirdBiome; + this.b = b; + } + + public static Biome getBiome(int h, int t, double we) { + for (ShatteredBiome mb : ShatteredBiome.values()) { + if (mb.h == h && mb.t == t) { + if (we < 0) { + return mb.b; + } else { + return mb.weirdBiome; + } + } + } + throw new IllegalArgumentException("shattered biome h = " + h + " t = " + t); + } + } + + private enum ContLoc { + MUSHROOM_FIELDS(-1.2, -1.05), + DEEP_OCEAN(-1.05, -0.455), + OCEAN(-0.455, -0.19), + COAST(-0.19, -0.11), + NEAR_INLAND(-0.11, 0.03), + MID_INLAND(0.03, 0.3), + FAR_INLAND(0.3, 10.0); + + private double min; + private double max; + ContLoc(double min, double max) { + this.min = min; + this.max = max; + } + + public static ContLoc getCont(double value) { + for (ContLoc c : ContLoc.values()) { + if (value >= c.min && value < c.max) { + return c; + } + } + throw new IllegalArgumentException("contloc out of spec value = " + value); + } + } + + private final Boxed addon; + protected final int dist; private final int spawnX; private final int spawnZ; protected final Map> quadrants; - private final AbstractBoxedChunkGenerator seedGen; - - protected AbstractSeedBiomeProvider(Boxed boxed, Environment env, Biome defaultBiome, AbstractBoxedChunkGenerator seedGen) { + protected AbstractSeedBiomeProvider(Boxed boxed, Environment env) { this.addon = boxed; - this.defaultBiome = defaultBiome; - this.seedGen = seedGen; // These fields are used to determine the biomes around the spawn point this.dist = addon.getSettings().getIslandDistance(); if (env.equals(Environment.NORMAL)) { @@ -95,12 +310,14 @@ private Biome getQuadrantBiome(BlockFace dir, double d) { return en == null ? null : en.getValue(); } - /** - * x, y, and z are block coordinates - */ + @Override + public Biome getBiome(WorldInfo worldInfo, int x, int y, int z, BiomeParameterPoint biomeParameterPoint) { + return this.getMappedBiome(worldInfo, x, y, z, biomeParameterPoint); + } + @Override public Biome getBiome(WorldInfo worldInfo, int x, int y, int z) { - return this.getMappedBiome(worldInfo, x, y, z); + throw new IllegalStateException("This method should never be called."); } /** @@ -112,24 +329,762 @@ public Biome getBiome(WorldInfo worldInfo, int x, int y, int z) { * @return Biome */ @NonNull - private Biome getVanillaBiome(WorldInfo worldInfo, int x, int y, int z) { - // Get the chunk coordinates - int chunkX = AbstractBoxedChunkGenerator.repeatCalc(x >> 4); - int chunkZ = AbstractBoxedChunkGenerator.repeatCalc(z >> 4); - // Get the stored snapshot - ChunkStore snapshot = this.seedGen.getChunk(chunkX, chunkZ); - if (snapshot == null) { - // This snapshot is not stored... - return defaultBiome; + private Biome getVanillaBiome(WorldInfo worldInfo, int x, int y, int z, BiomeParameterPoint bpb, Biome def) { + if (worldInfo.getEnvironment() == Environment.NORMAL) { + return getNormalBiome(bpb, def); + } + return getNetherBiome(bpb); + + } + + private @NonNull Biome getNetherBiome(BiomeParameterPoint bpb) { + if (bpb.getTemperature() == -0.5D && bpb.getHumidity() == 0.0D) { + return Biome.BASALT_DELTAS; + } else if (bpb.getTemperature() == 0.4D && bpb.getHumidity() == 0.0D) { + return Biome.CRIMSON_FOREST; + } else if (bpb.getTemperature() == 0.0D && bpb.getHumidity() == -0.5D) { + return Biome.SOUL_SAND_VALLEY; + } else if (bpb.getTemperature() == -0.5D && bpb.getHumidity() == 0.5D) { + return Biome.WARPED_FOREST; } - // Get the in-chunk coordinates - int xx = Math.floorMod(x, 16); - int zz = Math.floorMod(z, 16); - //int yy = Math.max(Math.min(y * 4, worldInfo.getMaxHeight()), worldInfo.getMinHeight()); // To handle bug in Spigot - Biome b = snapshot.chunkBiomes().getOrDefault(new Vector(xx, y, zz), defaultBiome); + return Biome.NETHER_WASTES; + } + + private @NonNull Biome getNormalBiome(BiomeParameterPoint bpb, Biome def) { + /* + * Caves + */ + double d = bpb.getDepth(); + if (d > 0.2 && d < 0.9) { + if (bpb.getHumidity() >= 0.4 && bpb.getHumidity() < 1.0) { + def = Biome.LUSH_CAVES; + } + if (bpb.getContinentalness() >= 0.8D && bpb.getContinentalness() <= 1.0D) { + def = Biome.DRIPSTONE_CAVES; + } + } + if (d >= 0.9) { // Vanilla has this as 1.1 + def = Biome.DEEP_DARK; + } + if (def != null) { + return def; + } + + /* + * Continentalness (also known as continents) is used to decide between ocean/beach/land biomes. + */ + int temp = getTemp(bpb.getTemperature()); + int humidity = getHumidity(bpb.getHumidity()); + int erosion = getErosion(bpb.getErosion()); + double we = bpb.getWeirdness(); + + return switch (ContLoc.getCont(bpb.getContinentalness())) { + case COAST -> coastBiome(humidity, temp, erosion, we); + case DEEP_OCEAN -> deepOceanBiome(temp); + case FAR_INLAND -> farInlandBiome(humidity, temp, erosion, we); + case MID_INLAND -> midInlandBiome(humidity, temp, erosion, we); + case MUSHROOM_FIELDS -> Biome.MUSHROOM_FIELDS; + case NEAR_INLAND -> nearInlandBiome(humidity, temp, erosion, we); + case OCEAN -> oceanBiome(temp); + default -> farInlandBiome(humidity, temp, erosion, we); + }; + } + + /** + * Erosion values are divided into 7 levels. The corresponding ranges from level 0 to level 6 are: + * -1.0~-0.78, -0.78~-0.375, -0.375~-0.2225, -0.2225~0.05, 0.05~0.45, 0.45~0.55, 0.55~1.0. + * + * @param erosion The erosion value + * @return The erosion level (0-6) + */ + private int getErosion(double erosion) { + if (erosion < -0.78) { + return 0; + } else if (erosion < -0.375) { + return 1; + } else if (erosion < -0.2225) { + return 2; + } else if (erosion < 0.05) { + return 3; + } else if (erosion < 0.45) { + return 4; + } else if (erosion < 0.55) { + return 5; + } else { + return 6; + } + } - return Objects.requireNonNull(b); + /** + * Humidity values are also divided into 5 levels. The corresponding ranges from level 0 to level 4 are: + * -1.0~-0.35, -0.35~-0.1, -0.1~0.1, 0.1~0.3, 0.3~1.0. + * + * @param humidity The humidity value + * @return The humidity level (0-4) + */ + private int getHumidity(double humidity) { + if (humidity < -0.35) { + return 0; + } else if (humidity < -0.1) { + return 1; + } else if (humidity < 0.1) { + return 2; + } else if (humidity < 0.3) { + return 3; + } else { + return 4; + } + } + + /** + * Temperature is a noise parameter used only in biome generation and does not affect terrain generation. + * Temperature values are divided into 5 levels. The corresponding ranges from level 0 to level 4 are: + * -1.0~-0.45, -0.45~-0.15, -0.15~0.2, 0.2~0.55, 0.55~1.0. + * + * @param temp The temperature value + * @return The temperature level (0-4) + */ + private int getTemp(double temp) { + if (temp < -0.45) { + return 0; + } else if (temp < -0.15) { + return 1; + } else if (temp < 0.2) { + return 2; + } else if (temp < 0.55) { + return 3; + } else { + return 4; + } + } + + + private @NonNull Biome oceanBiome(int temp) { + return switch (temp) { + case 0 -> Biome.FROZEN_OCEAN; + case 1 -> Biome.COLD_OCEAN; + case 2 -> Biome.OCEAN; + case 3 -> Biome.LUKEWARM_OCEAN; + case 4 -> Biome.WARM_OCEAN; + default -> Biome.OCEAN; + }; + } + + private @NonNull Biome deepOceanBiome(int temp) { + return switch (temp) { + case 0 -> Biome.DEEP_FROZEN_OCEAN; + case 1 -> Biome.DEEP_COLD_OCEAN; + case 2 -> Biome.DEEP_OCEAN; + case 3 -> Biome.DEEP_LUKEWARM_OCEAN; + case 4 -> Biome.WARM_OCEAN; + default -> Biome.DEEP_OCEAN; + }; + } + + private @NonNull Biome farInlandBiome(int h, int t, int e, double we) { + Ridges r = Ridges.getRidge(convertToY(we)); + switch (r) { + case HIGH: + if (e == 0) { + if (t < 3 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } + if (t < 3 && (h == 2 || h == 3 || h == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(h, t, we); + } else if (e == 1) { + if (t == 0 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } + if (t == 0 && (h == 2 || h == 3 || h == 4)) { + return Biome.GROVE; + } + if (t > 0 && t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e == 2 || e == 3 || e == 4) { + return PlateauBiome.getBiome(h, t, we); + } else if (e == 4 || e == 6) { + return MiddleBiome.getBiome(h, t, we); + } + return ShatteredBiome.getBiome(h, t, we); + case LOW: + if (e >= 0 && e < 2) { + if (t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e >= 2 && e < 5) { + // Middle Biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 5) { + if (we < 0 && (t == 0 || t == 1 || h == 4)) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } + if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + if (t == 0) { + return MiddleBiome.getBiome(h, t, we); + } else if (t == 1 || t == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + case MID: + if (e == 0) { + if (t < 3 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } + if (t < 3 && (h == 2 || h == 3 || h == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(h, t, we); + } else if (e == 1) { + if (t == 0 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } + if (t == 0 && (h == 2 || h == 3 || h == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(h, t, we); + } else if (e == 2) { + return PlateauBiome.getBiome(h, t, we); + } else if (e == 3) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 5) { + if (we < 0 && (t == 0 || t == 1) || h == 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } + if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + if (t == 0) { + // Middle Biomes + return MiddleBiome.getBiome(h, t, we); + } + if (t == 1 || t == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + case PEAKS: + if (e == 0) { + if (t >= 0 && t <= 2) { + if (we < 0) { + return Biome.JAGGED_PEAKS; + } else { + return Biome.FROZEN_PEAKS; + } + } else if (t == 3) { + return Biome.STONY_PEAKS; + } + return BadlandBiome.getBiome(h, we); + + } else if (e == 1) { + if (t == 0 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } else if (t == 0 && h > 1) { + return Biome.GROVE; + } else if (t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e >= 2 && e <= 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 5) { + if (we < 0 && (t == 0 || t == 1 || h == 4)) { + // Shattered biomes + return ShatteredBiome.getBiome(h, t, we); + } + if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + // middle biomes + return MiddleBiome.getBiome(h, t, we); + default: + //case VALLEYS: + if (e >= 0 && e < 6) { + if (t > 0D) { + return Biome.RIVER; + } else { + return Biome.FROZEN_RIVER; + } + } + // e == 6 + if (t == 0) { + return Biome.FROZEN_RIVER; + } + if (t == 1 || t == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + } + } + + private @NonNull Biome nearInlandBiome(int h, int t, int e, double we) { + Ridges r = Ridges.getRidge(convertToY(we)); // Normalize + switch (r) { + case HIGH: + if (e == 0) { + if (t < 3 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } + if (t < 3 && (h == 2 || h == 3 || h == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(h, t, we); + } else if (e == 1) { + if (t == 0 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } + if (t == 0 && (h == 2 || h == 3 || h == 4)) { + return Biome.GROVE; + } + if (t > 0 && t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e >= 2 && e <= 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 5) { + if (we < 0 && (t == 0 || t == 1) || h == 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } + if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + return MiddleBiome.getBiome(h, t, we); + case LOW: + if (e >= 0 && e < 2) { + if (t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e >= 2 && e < 5) { + // Middle Biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 5) { + if (we < 0 && (t == 0 || t == 1 || h == 4)) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } + if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + if (t == 0) { + return MiddleBiome.getBiome(h, t, we); + } else if (t == 1 || t == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + case MID: + if (e == 0) { + if (t < 3 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } + if (t < 3 && (h == 2 || h == 3 || h == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(h, t, we); + } else if (e == 1) { + if (t == 0 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } + if (t == 0 && (h == 2 || h == 3 || h == 4)) { + return Biome.GROVE; + } + if (t > 0 && t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e >= 2 && e <= 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 5) { + if (we < 0 && (t == 0 || t == 1) || h == 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } + if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + if (t == 0) { + // Middle Biomes + return MiddleBiome.getBiome(h, t, we); + } + if (t == 1 || t == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + case PEAKS: + if (e == 0) { + if (t >= 0 && t <= 2) { + if (we < 0) { + return Biome.JAGGED_PEAKS; + } else { + return Biome.FROZEN_PEAKS; + } + } else if (t == 3) { + return Biome.STONY_PEAKS; + } + return BadlandBiome.getBiome(h, we); + + } else if (e == 1) { + if (t == 0 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } else if (t == 0 && h > 1) { + return Biome.GROVE; + } else if (t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e >= 2 && e <= 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 5) { + if (we < 0 && (t == 0 || t == 1 || h == 4)) { + // Shattered biomes + return ShatteredBiome.getBiome(h, t, we); + } + if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + // middle biomes + return MiddleBiome.getBiome(h, t, we); + default: + //case VALLEYS: + if (e >= 0 && e < 6) { + if (t > 0D) { + return Biome.RIVER; + } else { + return Biome.FROZEN_RIVER; + } + } + // e == 6 + if (t == 0) { + return Biome.FROZEN_RIVER; + } + if (t == 1 || t == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + } + } + + private @NonNull Biome midInlandBiome(int h, int t, int e, double we) { + Ridges r = Ridges.getRidge(convertToY(we)); // Normalize + switch (r) { + case HIGH: + if (e == 0) { + if (t < 3 && we < 0D) { + return Biome.JAGGED_PEAKS; + } + if (t < 3 && we > 0.0D) { + return Biome.FROZEN_PEAKS; + } + if (t == 3) { + return Biome.STONY_PEAKS; + } + return BadlandBiome.getBiome(h, we); + } else if (e == 1) { + if (t < 3 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } + if (t < 3 && (h == 2 || h == 3 || h == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(h, t, we); + } else if (e == 2) { + return PlateauBiome.getBiome(h, t, we); + } else if (e == 3) { + if (t < 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e == 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 5) { + return ShatteredBiome.getBiome(h, t, we); + } + return MiddleBiome.getBiome(h, t, we); + case LOW: + if (e == 0 || e == 1) { + if (t == 0 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } else if (t == 0 && h > 1) { + return Biome.GROVE; + } else if (t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } + if (e == 2 || e == 3) { + if (t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } + // e == 6 + if (t == 0) { + // Middle Biomes + return MiddleBiome.getBiome(h, t, we); + } + if (t == 1 || t == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + case MID: + if (e == 0) { + if (t < 3 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } + if (t < 3 && (h == 2 || h == 3 || h == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(h, t, we); + } else if (e == 1) { + if (t == 0 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } + if (t == 0 && (h == 2 || h == 3 || h == 4)) { + return Biome.GROVE; + } + if (t > 0 && t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e == 2 || e == 3) { + if (t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e == 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 5) { + return ShatteredBiome.getBiome(h, t, we); + } + if (t == 0) { + // Middle Biomes + return MiddleBiome.getBiome(h, t, we); + } + if (t == 1 || t == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + case PEAKS: + if (e == 0 || e == 1) { + if (t >= 0 && t <= 2) { + if (we < 0) { + return Biome.JAGGED_PEAKS; + } else { + return Biome.FROZEN_PEAKS; + } + } else if (t == 3) { + return Biome.STONY_PEAKS; + } + return BadlandBiome.getBiome(h, we); + + } else if (e == 2) { + return PlateauBiome.getBiome(h, t, we); + } else if (e == 3) { + if (t < 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e == 4 || e == 6) { + return MiddleBiome.getBiome(h, t, we); + } + return ShatteredBiome.getBiome(h, t, we); + default: + //case VALLEYS: + if (e == 0 || e == 1) { + if (t < 4) { + return MiddleBiome.getBiome(h, t, we); + } else { + return BadlandBiome.getBiome(h, we); + } + } + if (e >= 2 && e <= 5) { + if (t == 0) { + return Biome.FROZEN_RIVER; + } else { + return Biome.RIVER; + } + } + if (t == 0) { + return Biome.FROZEN_RIVER; + } + if (t == 1 || t == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + } + } + + private @NonNull Biome coastBiome(int h, int t, int e, double we) { + Ridges r = Ridges.getRidge(convertToY(we)); // Normalize + switch (r) { + case HIGH: + if (e >= 0 && e < 5) { + // Middle Biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 5) { + if (we < 0 && (t == 0 || t == 1 || h == 4)) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } + if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + // Middle Biomes + return MiddleBiome.getBiome(h, t, we); + case LOW: + if (e >= 0 && e < 3) { + return Biome.STONY_SHORE; + } else if (e >= 3 && e < 5) { + // Beach Biomes + return getBeachBiome(t); + } else if (e == 5) { + if (we < 0) { + // Beach Biomes + return getBeachBiome(t); + } + if (we < 0 && (t == 0 || t == 1 || h == 4)) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } + if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + // Else Beach biomes + return getBeachBiome(t); + case MID: + if (e > 0 && e < 3) { + return Biome.STONY_SHORE; + } else if (e == 3) { + // Middle Biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 4) { + if (we < 0) { + // Beach Biomes + return getBeachBiome(t); + } else { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } + } else if (e == 5) { + if (we < 0) { + // Beach Biomes + return getBeachBiome(t); + } + if (we < 0 && (t == 0 || t == 1 || h == 4)) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } + if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + + } else if (e == 6) { + if (we < 0D) { + // Beach Biomes + return getBeachBiome(t); + } else { + // Middle Biomes + return MiddleBiome.getBiome(h, t, we); + } + } + // Else Beach biomes + return getBeachBiome(t); + case PEAKS: + if (e == 0) { + if (t >= 0 && t <= 2) { + if (we < 0) { + return Biome.JAGGED_PEAKS; + } else { + return Biome.FROZEN_PEAKS; + } + } else if (t == 3) { + return Biome.STONY_PEAKS; + } + return BadlandBiome.getBiome(h, we); + + } else if (e == 1) { + if (t == 0 && (h == 0 || h == 1)) { + return Biome.SNOWY_SLOPES; + } else if (t == 0 && h > 1) { + return Biome.GROVE; + } else if (t < 4) { + return MiddleBiome.getBiome(h, t, we); + } + return BadlandBiome.getBiome(h, we); + } else if (e >= 2 && e <= 4) { + // Middle biomes + return MiddleBiome.getBiome(h, t, we); + } else if (e == 5) { + if (we < 0 && (t == 0 || t == 1 || h == 4)) { + // Shattered biomes + return ShatteredBiome.getBiome(h, t, we); + } + if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + // middle biomes + return MiddleBiome.getBiome(h, t, we); + default: + //case VALLEYS: + if (t > 0D) { + + return Biome.RIVER; + } + return Biome.FROZEN_RIVER; + } + } + + + Biome getBeachBiome(int t) { + return switch (t) { + case 0 -> Biome.SNOWY_BEACH; + case 4 -> Biome.DESERT; + default -> Biome.BEACH; + }; + } + + public static double convertToY(double x) { + x = Math.max(-1, Math.min(1, x)); // Clamp value + if (x >= -1 && x < -0.5) { + return 2 * x + 1; + } else if (x >= -0.5 && x < 0) { + return -2 * x; + } else if (x >= 0 && x < 0.5) { + return 2 * x; + } else if (x >= 0.5 && x <= 1) { + return -2 * x + 1; + } else { + throw new IllegalArgumentException("Invalid x value. x must be in the range [-1, 1]. Value = " + x); + } } /** @@ -138,32 +1093,21 @@ private Biome getVanillaBiome(WorldInfo worldInfo, int x, int y, int z) { * @param x - block coord * @param y - block coord * @param z - block coord + * @param biomeParameterPoint * @return Biome */ - private Biome getMappedBiome(WorldInfo worldInfo, int x, int y, int z) { - - // Custom biomes are not 3D yet - if (y < DEPTH) { - Biome result = getVanillaBiome(worldInfo, x, y, z); - return Objects.requireNonNull(result); - } - + private Biome getMappedBiome(WorldInfo worldInfo, int x, int y, int z, BiomeParameterPoint biomeParameterPoint) { /* * Biomes go around the island centers * */ - // Try to get the cached value - //Biome result = biomeCache.get((new Pair(x,z))); - //if (result != null) { - //return result; - //} Vector s = new Vector(x, 0, z); - Vector l = new Vector(spawnX,0,spawnZ); + Vector l = new Vector(spawnX, 0, spawnZ); double dis = l.distance(s); if (dis > dist * 2) { // Only customize biomes around the spawn location - return getVanillaBiome(worldInfo, x, y, z); + return getVanillaBiome(worldInfo, x, y, z, biomeParameterPoint, null); } // Provide custom biomes Biome result; @@ -180,11 +1124,15 @@ private Biome getMappedBiome(WorldInfo worldInfo, int x, int y, int z) { } if (result == null || result.equals(Biome.CUSTOM)) { - result = getVanillaBiome(worldInfo, x, y, z); + result = getVanillaBiome(worldInfo, x, y, z, biomeParameterPoint, null); + + } + // Caves + if (biomeParameterPoint.getDepth() > 0.2) { + result = getVanillaBiome(worldInfo, x, y, z, biomeParameterPoint, null); } - // Cache good result - //biomeCache.put(new Pair(x,z), result); + return result; } @@ -192,7 +1140,7 @@ private Biome getMappedBiome(WorldInfo worldInfo, int x, int y, int z) { @Override public List getBiomes(WorldInfo worldInfo) { // Return all of them for now! - return Arrays.stream(Biome.values()).filter(b -> !b.equals(Biome.CUSTOM)).filter(b -> !b.equals(Enums.getIfPresent(Biome.class, "CHERRY_GROVE").orNull())).toList(); + return Arrays.stream(Biome.values()).filter(b -> !b.equals(Biome.CUSTOM)).toList(); } /** @@ -219,8 +1167,9 @@ private SortedMap loadQuad(YamlConfiguration config, String secto // A biome of null means that no alternative biome should be applied result.put(d, biome); } - } catch(Exception e) { - addon.logError(sector + ": " + split[0] + " does not seem to be a double. For integers add a .0 to the end"); + } catch (Exception e) { + addon.logError(sector + ": " + split[0] + + " does not seem to be a double. For integers add a .0 to the end"); } } else { addon.logError(ring + " must be in the format ratio:biome where ratio is a double."); diff --git a/src/main/java/world/bentobox/boxed/generators/biomes/NetherSeedBiomeGenerator.java b/src/main/java/world/bentobox/boxed/generators/biomes/NetherSeedBiomeGenerator.java index 1577636..5589fff 100644 --- a/src/main/java/world/bentobox/boxed/generators/biomes/NetherSeedBiomeGenerator.java +++ b/src/main/java/world/bentobox/boxed/generators/biomes/NetherSeedBiomeGenerator.java @@ -1,10 +1,8 @@ package world.bentobox.boxed.generators.biomes; import org.bukkit.World.Environment; -import org.bukkit.block.Biome; import world.bentobox.boxed.Boxed; -import world.bentobox.boxed.generators.chunks.AbstractBoxedChunkGenerator; /** * Generator for the Nether seed world @@ -13,8 +11,8 @@ */ public class NetherSeedBiomeGenerator extends AbstractSeedBiomeProvider { - public NetherSeedBiomeGenerator(Boxed boxed, AbstractBoxedChunkGenerator seedGen) { - super(boxed, Environment.NETHER, Biome.BASALT_DELTAS, seedGen); + public NetherSeedBiomeGenerator(Boxed boxed) { + super(boxed, Environment.NETHER); } } \ No newline at end of file diff --git a/src/main/java/world/bentobox/boxed/generators/biomes/SeedBiomeGenerator.java b/src/main/java/world/bentobox/boxed/generators/biomes/SeedBiomeGenerator.java index a6d36ab..a094e25 100644 --- a/src/main/java/world/bentobox/boxed/generators/biomes/SeedBiomeGenerator.java +++ b/src/main/java/world/bentobox/boxed/generators/biomes/SeedBiomeGenerator.java @@ -1,10 +1,8 @@ package world.bentobox.boxed.generators.biomes; import org.bukkit.World.Environment; -import org.bukkit.block.Biome; import world.bentobox.boxed.Boxed; -import world.bentobox.boxed.generators.chunks.AbstractBoxedChunkGenerator; /** * Generator for the seed world @@ -13,8 +11,7 @@ */ public class SeedBiomeGenerator extends AbstractSeedBiomeProvider { - public SeedBiomeGenerator(Boxed boxed, AbstractBoxedChunkGenerator seedGen) { - super(boxed, Environment.NORMAL, Biome.PLAINS, seedGen); + public SeedBiomeGenerator(Boxed boxed) { + super(boxed, Environment.NORMAL); } - } \ No newline at end of file diff --git a/src/main/java/world/bentobox/boxed/generators/chunks/AbstractBoxedChunkGenerator.java b/src/main/java/world/bentobox/boxed/generators/chunks/AbstractBoxedChunkGenerator.java index f668666..421ee44 100644 --- a/src/main/java/world/bentobox/boxed/generators/chunks/AbstractBoxedChunkGenerator.java +++ b/src/main/java/world/bentobox/boxed/generators/chunks/AbstractBoxedChunkGenerator.java @@ -38,6 +38,7 @@ public record ChestData(Vector relativeLoc, BlueprintBlock chest) {} public AbstractBoxedChunkGenerator(Boxed addon) { this.addon = addon; size = (int)(addon.getSettings().getIslandDistance() / 16D); // Size is chunks + } /** From ef3bdfeba26f36bb23c5b7cda219f0e38819b056 Mon Sep 17 00:00:00 2001 From: tastybento Date: Sat, 23 Mar 2024 22:06:54 -0700 Subject: [PATCH 4/8] Version 2.5.0 --- pom.xml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/pom.xml b/pom.xml index 269f5b0..ea38ff5 100644 --- a/pom.xml +++ b/pom.xml @@ -65,7 +65,7 @@ -LOCAL - 2.4.0 + 2.5.0 BentoBoxWorld_Boxed bentobox-world From 4ad149f9c9da584fb281dd092159296754aa478d Mon Sep 17 00:00:00 2001 From: tastybento Date: Sat, 23 Mar 2024 22:24:44 -0700 Subject: [PATCH 5/8] Refined nether biomes. --- .../generators/biomes/AbstractSeedBiomeProvider.java | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) diff --git a/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java b/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java index 4b3895b..6ce9172 100644 --- a/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java +++ b/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java @@ -338,13 +338,15 @@ private Biome getVanillaBiome(WorldInfo worldInfo, int x, int y, int z, BiomePar } private @NonNull Biome getNetherBiome(BiomeParameterPoint bpb) { - if (bpb.getTemperature() == -0.5D && bpb.getHumidity() == 0.0D) { + double temp = Math.round(bpb.getTemperature() * 10.0) / 10.0; + double humidity = Math.round(bpb.getHumidity() * 10.0) / 10.0; + if (temp == -0.5D && humidity == 0.0D) { return Biome.BASALT_DELTAS; - } else if (bpb.getTemperature() == 0.4D && bpb.getHumidity() == 0.0D) { + } else if (temp == 0.4D && humidity == 0.0D) { return Biome.CRIMSON_FOREST; - } else if (bpb.getTemperature() == 0.0D && bpb.getHumidity() == -0.5D) { + } else if (temp == 0.0D && humidity == -0.5D) { return Biome.SOUL_SAND_VALLEY; - } else if (bpb.getTemperature() == -0.5D && bpb.getHumidity() == 0.5D) { + } else if (temp == -0.5D && humidity == 0.5D) { return Biome.WARPED_FOREST; } From 1803e2bd56aeb2a84b319bc1e50dcdc585ba7e9b Mon Sep 17 00:00:00 2001 From: tastybento Date: Thu, 28 Mar 2024 16:57:52 -0700 Subject: [PATCH 6/8] Refactor to reduce complexity. Rename enum values --- .../biomes/AbstractSeedBiomeProvider.java | 1281 +++++++++-------- 1 file changed, 675 insertions(+), 606 deletions(-) diff --git a/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java b/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java index 6ce9172..1c5fbcd 100644 --- a/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java +++ b/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java @@ -43,6 +43,9 @@ public abstract class AbstractSeedBiomeProvider extends BiomeProvider { ENV_MAP = Collections.unmodifiableMap(e); } + /** + * Heights / ridges by erosion + */ private enum Ridges { VALLEYS(-1.0, -0.85), LOW(-0.85, -0.6), MID(-0.6, 0.2), HIGH(0.2, 0.7), PEAKS(0.7, 1.0); @@ -54,9 +57,9 @@ private enum Ridges { this.high = high; } - public static Ridges getRidge(double x) { + public static Ridges getRidge(double erosion) { for (Ridges r : Ridges.values()) { - if (x >= r.low && x < r.high) { + if (erosion >= r.low && erosion < r.high) { return r; } } @@ -65,104 +68,113 @@ public static Ridges getRidge(double x) { } + /** + * Badland Biones by Humidity Zone + */ private enum BadlandBiome { - h0(0, Biome.BADLANDS, Biome.ERODED_BADLANDS), h1(1, Biome.BADLANDS, Biome.ERODED_BADLANDS), - h2(2, Biome.BADLANDS, Biome.BADLANDS), h3(3, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS), - h4(4, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS); + HZONE0(0, Biome.BADLANDS, Biome.ERODED_BADLANDS), HZONE1(1, Biome.BADLANDS, Biome.ERODED_BADLANDS), + HZONE2(2, Biome.BADLANDS, Biome.BADLANDS), HZONE3(3, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS), + HZONE4(4, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS); - private int h; + private int humidityZone; private Biome biome; private Biome biome2; BadlandBiome(int h, Biome biome, Biome biome2) { - this.h = h; + this.humidityZone = h; this.biome = biome; this.biome2 = biome2; } - public static Biome getBiome(int h, double we) { + public static Biome getBiome(int humidity, double weirdness) { for (BadlandBiome mb : BadlandBiome.values()) { - if (mb.h == h) { - if (we < 0) { + if (mb.humidityZone == humidity) { + if (weirdness < 0) { return mb.biome; } else { return mb.biome2; } } } - throw new IllegalArgumentException("badlands biome h = " + h); + throw new IllegalArgumentException("badlands biome h = " + humidity); } } + /** + * Middle Biomes by temperature and humidity zones + */ private enum MiddleBiome { - x00(0, 0, Biome.SNOWY_PLAINS, Biome.ICE_SPIKES), x01(0, 1, Biome.PLAINS, Biome.PLAINS), - x02(0, 2, Biome.FLOWER_FOREST, Biome.SUNFLOWER_PLAINS), x03(0, 3, Biome.SAVANNA, Biome.SAVANNA), - x04(0, 4, Biome.DESERT, Biome.DESERT), + X00(0, 0, Biome.SNOWY_PLAINS, Biome.ICE_SPIKES), X01(0, 1, Biome.PLAINS, Biome.PLAINS), + X02(0, 2, Biome.FLOWER_FOREST, Biome.SUNFLOWER_PLAINS), x03(0, 3, Biome.SAVANNA, Biome.SAVANNA), + X04(0, 4, Biome.DESERT, Biome.DESERT), - x10(1, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_PLAINS), x11(1, 1, Biome.PLAINS, Biome.PLAINS), - x12(1, 2, Biome.PLAINS, Biome.PLAINS), x13(1, 3, Biome.SAVANNA, Biome.SAVANNA), - x14(1, 4, Biome.DESERT, Biome.DESERT), + X10(1, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_PLAINS), X11(1, 1, Biome.PLAINS, Biome.PLAINS), + X12(1, 2, Biome.PLAINS, Biome.PLAINS), X13(1, 3, Biome.SAVANNA, Biome.SAVANNA), + X14(1, 4, Biome.DESERT, Biome.DESERT), - x20(2, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_TAIGA), x21(2, 1, Biome.FOREST, Biome.FOREST), - x22(2, 2, Biome.FOREST, Biome.FOREST), x23(2, 3, Biome.FOREST, Biome.PLAINS), - x24(2, 4, Biome.DESERT, Biome.DESERT), + X20(2, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_TAIGA), X21(2, 1, Biome.FOREST, Biome.FOREST), + X22(2, 2, Biome.FOREST, Biome.FOREST), X23(2, 3, Biome.FOREST, Biome.PLAINS), + X24(2, 4, Biome.DESERT, Biome.DESERT), - x30(3, 0, Biome.SNOWY_TAIGA, Biome.SNOWY_TAIGA), x31(3, 1, Biome.TAIGA, Biome.TAIGA), - x32(3, 2, Biome.BIRCH_FOREST, Biome.OLD_GROWTH_BIRCH_FOREST), x33(3, 3, Biome.JUNGLE, Biome.SPARSE_JUNGLE), - x34(3, 4, Biome.DESERT, Biome.DESERT), + X30(3, 0, Biome.SNOWY_TAIGA, Biome.SNOWY_TAIGA), X31(3, 1, Biome.TAIGA, Biome.TAIGA), + X32(3, 2, Biome.BIRCH_FOREST, Biome.OLD_GROWTH_BIRCH_FOREST), X33(3, 3, Biome.JUNGLE, Biome.SPARSE_JUNGLE), + X34(3, 4, Biome.DESERT, Biome.DESERT), - x40(4, 0, Biome.TAIGA, Biome.TAIGA), x41(4, 1, Biome.OLD_GROWTH_SPRUCE_TAIGA, Biome.OLD_GROWTH_PINE_TAIGA), - x42(4, 2, Biome.DARK_FOREST, Biome.DARK_FOREST), x43(4, 3, Biome.JUNGLE, Biome.BAMBOO_JUNGLE), - x44(4, 4, Biome.DESERT, Biome.DESERT), + X40(4, 0, Biome.TAIGA, Biome.TAIGA), X41(4, 1, Biome.OLD_GROWTH_SPRUCE_TAIGA, Biome.OLD_GROWTH_PINE_TAIGA), + X42(4, 2, Biome.DARK_FOREST, Biome.DARK_FOREST), X43(4, 3, Biome.JUNGLE, Biome.BAMBOO_JUNGLE), + X44(4, 4, Biome.DESERT, Biome.DESERT), ; - private int t; - private int h; - private Biome b; - private Biome weirdBiome; + private int temperature; + private int humidity; + private Biome biome; + private Biome weirdBiome; // What the biome be if the weirdness is high enough MiddleBiome(int h, int t, Biome b, Biome weirdBiome) { - this.h = h; - this.t = t; + this.humidity = h; + this.temperature = t; this.weirdBiome = weirdBiome; - this.b = b; + this.biome = b; } - public static Biome getBiome(int h, int t, double we) { + public static Biome getBiome(int humidity, int temperature, double weirdness) { for (MiddleBiome mb : MiddleBiome.values()) { - if (mb.h == h && mb.t == t) { - if (we < 0) { - return mb.b; + if (mb.humidity == humidity && mb.temperature == temperature) { + if (weirdness < 0) { + return mb.biome; } else { return mb.weirdBiome; } } } - throw new IllegalArgumentException("middle biome h = " + h + " t = " + t); + throw new IllegalArgumentException("middle biome h = " + humidity + " t = " + temperature); } } + /** + * Plateau biomes by temperature and humidity zones + */ private enum PlateauBiome { - x00(0, 0, Biome.SNOWY_PLAINS, Biome.ICE_SPIKES), x01(0, 1, Biome.MEADOW, Biome.CHERRY_GROVE), - x02(0, 2, Biome.MEADOW, Biome.CHERRY_GROVE), x03(0, 3, Biome.SAVANNA_PLATEAU, Biome.SAVANNA_PLATEAU), - x04(0, 4, Biome.BADLANDS, Biome.ERODED_BADLANDS), + X00(0, 0, Biome.SNOWY_PLAINS, Biome.ICE_SPIKES), x01(0, 1, Biome.MEADOW, Biome.CHERRY_GROVE), + X02(0, 2, Biome.MEADOW, Biome.CHERRY_GROVE), x03(0, 3, Biome.SAVANNA_PLATEAU, Biome.SAVANNA_PLATEAU), + X04(0, 4, Biome.BADLANDS, Biome.ERODED_BADLANDS), - x10(1, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_PLAINS), x11(1, 1, Biome.MEADOW, Biome.MEADOW), - x12(1, 2, Biome.MEADOW, Biome.CHERRY_GROVE), x13(1, 3, Biome.SAVANNA_PLATEAU, Biome.SAVANNA_PLATEAU), - x14(1, 4, Biome.BADLANDS, Biome.ERODED_BADLANDS), + X10(1, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_PLAINS), x11(1, 1, Biome.MEADOW, Biome.MEADOW), + X12(1, 2, Biome.MEADOW, Biome.CHERRY_GROVE), x13(1, 3, Biome.SAVANNA_PLATEAU, Biome.SAVANNA_PLATEAU), + X14(1, 4, Biome.BADLANDS, Biome.ERODED_BADLANDS), - x20(2, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_TAIGA), x21(2, 1, Biome.FOREST, Biome.MEADOW), - x22(2, 2, Biome.MEADOW, Biome.BIRCH_FOREST), x23(2, 3, Biome.FOREST, Biome.FOREST), - x24(2, 4, Biome.BADLANDS, Biome.BADLANDS), + X20(2, 0, Biome.SNOWY_PLAINS, Biome.SNOWY_TAIGA), x21(2, 1, Biome.FOREST, Biome.MEADOW), + X22(2, 2, Biome.MEADOW, Biome.BIRCH_FOREST), x23(2, 3, Biome.FOREST, Biome.FOREST), + X24(2, 4, Biome.BADLANDS, Biome.BADLANDS), - x30(3, 0, Biome.SNOWY_TAIGA, Biome.SNOWY_TAIGA), x31(3, 1, Biome.TAIGA, Biome.MEADOW), - x32(3, 2, Biome.MEADOW, Biome.BIRCH_FOREST), x33(3, 3, Biome.FOREST, Biome.FOREST), - x34(3, 4, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS), + X30(3, 0, Biome.SNOWY_TAIGA, Biome.SNOWY_TAIGA), x31(3, 1, Biome.TAIGA, Biome.MEADOW), + X32(3, 2, Biome.MEADOW, Biome.BIRCH_FOREST), x33(3, 3, Biome.FOREST, Biome.FOREST), + X34(3, 4, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS), - x40(4, 0, Biome.SNOWY_TAIGA, Biome.SNOWY_TAIGA), - x41(4, 1, Biome.OLD_GROWTH_SPRUCE_TAIGA, Biome.OLD_GROWTH_PINE_TAIGA), - x42(4, 2, Biome.DARK_FOREST, Biome.DARK_FOREST), x43(4, 3, Biome.JUNGLE, Biome.JUNGLE), - x44(4, 4, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS),; + X40(4, 0, Biome.SNOWY_TAIGA, Biome.SNOWY_TAIGA), + X41(4, 1, Biome.OLD_GROWTH_SPRUCE_TAIGA, Biome.OLD_GROWTH_PINE_TAIGA), + X42(4, 2, Biome.DARK_FOREST, Biome.DARK_FOREST), x43(4, 3, Biome.JUNGLE, Biome.JUNGLE), + X44(4, 4, Biome.WOODED_BADLANDS, Biome.WOODED_BADLANDS),; private int temp; private int humidity; @@ -190,49 +202,52 @@ public static Biome getBiome(int humidity, int temp, double weirdness) { } } + /** + * Shattered biomes by temperature and humidity + */ private enum ShatteredBiome { - x00(0, 0, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), - x01(0, 1, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), - x02(0, 2, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), x03(0, 3, Biome.SAVANNA, Biome.SAVANNA), - x04(0, 4, Biome.DESERT, Biome.DESERT), - - x10(1, 0, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), - x11(1, 1, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), - x12(1, 2, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), - x13(1, 3, Biome.SAVANNA_PLATEAU, Biome.SAVANNA_PLATEAU), x14(1, 4, Biome.DESERT, Biome.DESERT), - - x20(2, 0, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), - x21(2, 1, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), - x22(2, 2, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), x23(2, 3, Biome.FOREST, Biome.FOREST), - x24(2, 4, Biome.DESERT, Biome.DESERT), - - x30(3, 0, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), - x31(3, 1, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), - x32(3, 2, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), x33(3, 3, Biome.JUNGLE, Biome.SPARSE_JUNGLE), - x34(3, 4, Biome.DESERT, Biome.DESERT), - - x40(4, 0, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), - x41(4, 1, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), - x42(4, 2, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), x43(4, 3, Biome.JUNGLE, Biome.BAMBOO_JUNGLE), - x44(4, 4, Biome.DESERT, Biome.DESERT),; - - private int t; - private int h; - private Biome b; + X00(0, 0, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), + X01(0, 1, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), + X02(0, 2, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), X03(0, 3, Biome.SAVANNA, Biome.SAVANNA), + X04(0, 4, Biome.DESERT, Biome.DESERT), + + X10(1, 0, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), + X11(1, 1, Biome.WINDSWEPT_GRAVELLY_HILLS, Biome.WINDSWEPT_GRAVELLY_HILLS), + X12(1, 2, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), + X13(1, 3, Biome.SAVANNA_PLATEAU, Biome.SAVANNA_PLATEAU), X14(1, 4, Biome.DESERT, Biome.DESERT), + + X20(2, 0, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), + X21(2, 1, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), + X22(2, 2, Biome.WINDSWEPT_HILLS, Biome.WINDSWEPT_HILLS), X23(2, 3, Biome.FOREST, Biome.FOREST), + X24(2, 4, Biome.DESERT, Biome.DESERT), + + X30(3, 0, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), + X31(3, 1, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), + X32(3, 2, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), X33(3, 3, Biome.JUNGLE, Biome.SPARSE_JUNGLE), + X34(3, 4, Biome.DESERT, Biome.DESERT), + + X40(4, 0, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), + X41(4, 1, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), + X42(4, 2, Biome.WINDSWEPT_FOREST, Biome.WINDSWEPT_FOREST), X43(4, 3, Biome.JUNGLE, Biome.BAMBOO_JUNGLE), + X44(4, 4, Biome.DESERT, Biome.DESERT),; + + private int temperature; + private int humidity; + private Biome biome; private Biome weirdBiome; ShatteredBiome(int h, int t, Biome b, Biome weirdBiome) { - this.h = h; - this.t = t; + this.humidity = h; + this.temperature = t; this.weirdBiome = weirdBiome; - this.b = b; + this.biome = b; } public static Biome getBiome(int h, int t, double we) { for (ShatteredBiome mb : ShatteredBiome.values()) { - if (mb.h == h && mb.t == t) { + if (mb.humidity == h && mb.temperature == t) { if (we < 0) { - return mb.b; + return mb.biome; } else { return mb.weirdBiome; } @@ -242,6 +257,9 @@ public static Biome getBiome(int h, int t, double we) { } } + /** + * Continental location by continentalness + */ private enum ContLoc { MUSHROOM_FIELDS(-1.2, -1.05), DEEP_OCEAN(-1.05, -0.455), @@ -259,13 +277,13 @@ private enum ContLoc { this.max = max; } - public static ContLoc getCont(double value) { + public static ContLoc getCont(double continentalness) { for (ContLoc c : ContLoc.values()) { - if (value >= c.min && value < c.max) { + if (continentalness >= c.min && continentalness < c.max) { return c; } } - throw new IllegalArgumentException("contloc out of spec value = " + value); + throw new IllegalArgumentException("contloc out of spec value = " + continentalness); } } @@ -338,6 +356,7 @@ private Biome getVanillaBiome(WorldInfo worldInfo, int x, int y, int z, BiomePar } private @NonNull Biome getNetherBiome(BiomeParameterPoint bpb) { + // Bring these values to 1 decimal place double temp = Math.round(bpb.getTemperature() * 10.0) / 10.0; double humidity = Math.round(bpb.getHumidity() * 10.0) / 10.0; if (temp == -0.5D && humidity == 0.0D) { @@ -484,587 +503,637 @@ private int getTemp(double temp) { }; } - private @NonNull Biome farInlandBiome(int h, int t, int e, double we) { - Ridges r = Ridges.getRidge(convertToY(we)); - switch (r) { - case HIGH: - if (e == 0) { - if (t < 3 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } - if (t < 3 && (h == 2 || h == 3 || h == 4)) { - return Biome.GROVE; - } - return PlateauBiome.getBiome(h, t, we); - } else if (e == 1) { - if (t == 0 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } - if (t == 0 && (h == 2 || h == 3 || h == 4)) { - return Biome.GROVE; - } - if (t > 0 && t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e == 2 || e == 3 || e == 4) { - return PlateauBiome.getBiome(h, t, we); - } else if (e == 4 || e == 6) { - return MiddleBiome.getBiome(h, t, we); - } - return ShatteredBiome.getBiome(h, t, we); - case LOW: - if (e >= 0 && e < 2) { - if (t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e >= 2 && e < 5) { - // Middle Biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 5) { - if (we < 0 && (t == 0 || t == 1 || h == 4)) { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } - if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { - return Biome.WINDSWEPT_SAVANNA; + private @NonNull Biome farInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + return switch (Ridges.getRidge(convertToY(weirdness))) { + case HIGH -> getFarInlandHighBiome(humidity, temperature, erosion, weirdness); + case LOW -> getFarInlandLowBiome(humidity, temperature, erosion, weirdness); + case MID -> getFarInlandMidBiome(humidity, temperature, erosion, weirdness); + case PEAKS -> getFarInlandPeaksBiome(humidity, temperature, erosion, weirdness); + default -> getFarInlandValleysBiome(humidity, temperature, erosion, weirdness); + }; + } + + private @NonNull Biome getFarInlandValleysBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion >= 0 && erosion < 6) { + if (temperature > 0D) { + return Biome.RIVER; + } else { + return Biome.FROZEN_RIVER; + } + } + // e == 6 + if (temperature == 0) { + return Biome.FROZEN_RIVER; + } + if (temperature == 1 || temperature == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + } + + private @NonNull Biome getFarInlandPeaksBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0) { + if (temperature >= 0 && temperature <= 2) { + if (weirdness < 0) { + return Biome.JAGGED_PEAKS; + } else { + return Biome.FROZEN_PEAKS; } + } else if (temperature == 3) { + return Biome.STONY_PEAKS; } - if (t == 0) { - return MiddleBiome.getBiome(h, t, we); - } else if (t == 1 || t == 2) { - return Biome.SWAMP; + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion == 1) { + if (temperature == 0 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } else if (temperature == 0 && humidity > 1) { + return Biome.GROVE; + } else if (temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - return Biome.MANGROVE_SWAMP; - case MID: - if (e == 0) { - if (t < 3 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } - if (t < 3 && (h == 2 || h == 3 || h == 4)) { - return Biome.GROVE; - } - return PlateauBiome.getBiome(h, t, we); - } else if (e == 1) { - if (t == 0 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } - if (t == 0 && (h == 2 || h == 3 || h == 4)) { - return Biome.GROVE; - } - return PlateauBiome.getBiome(h, t, we); - } else if (e == 2) { - return PlateauBiome.getBiome(h, t, we); - } else if (e == 3) { + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion >= 2 && erosion <= 4) { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 5) { + if (weirdness < 0 && (temperature == 0 || temperature == 1 || humidity == 4)) { + // Shattered biomes + return ShatteredBiome.getBiome(humidity, temperature, weirdness); + } + if (weirdness > 0 && (temperature > 2 && temperature <= 4 && humidity >= 0 && humidity <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + // middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + + private @NonNull Biome getFarInlandMidBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0) { + if (temperature < 3 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } + if (temperature < 3 && (humidity == 2 || humidity == 3 || humidity == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 1) { + if (temperature == 0 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } + if (temperature == 0 && (humidity == 2 || humidity == 3 || humidity == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 2) { + return PlateauBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 3) { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 5) { + if (weirdness < 0 && (temperature == 0 || temperature == 1) || humidity == 4) { // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 5) { - if (we < 0 && (t == 0 || t == 1) || h == 4) { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } - if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { - return Biome.WINDSWEPT_SAVANNA; - } + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - if (t == 0) { - // Middle Biomes - return MiddleBiome.getBiome(h, t, we); + if (weirdness > 0 && (temperature > 2 && temperature <= 4 && humidity >= 0 && humidity <= 4)) { + return Biome.WINDSWEPT_SAVANNA; } - if (t == 1 || t == 2) { - return Biome.SWAMP; + } + if (temperature == 0) { + // Middle Biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + if (temperature == 1 || temperature == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + } + + private @NonNull Biome getFarInlandLowBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion >= 0 && erosion < 2) { + if (temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - return Biome.MANGROVE_SWAMP; - case PEAKS: - if (e == 0) { - if (t >= 0 && t <= 2) { - if (we < 0) { - return Biome.JAGGED_PEAKS; - } else { - return Biome.FROZEN_PEAKS; - } - } else if (t == 3) { - return Biome.STONY_PEAKS; - } - return BadlandBiome.getBiome(h, we); - - } else if (e == 1) { - if (t == 0 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } else if (t == 0 && h > 1) { - return Biome.GROVE; - } else if (t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e >= 2 && e <= 4) { + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion >= 2 && erosion < 5) { + // Middle Biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 5) { + if (weirdness < 0 && (temperature == 0 || temperature == 1 || humidity == 4)) { // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 5) { - if (we < 0 && (t == 0 || t == 1 || h == 4)) { - // Shattered biomes - return ShatteredBiome.getBiome(h, t, we); - } - if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { - return Biome.WINDSWEPT_SAVANNA; - } + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + if (weirdness > 0 && (temperature > 2 && temperature <= 4 && humidity >= 0 && humidity <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + if (temperature == 0) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (temperature == 1 || temperature == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + } + + private @NonNull Biome getFarInlandHighBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0) { + if (temperature < 3 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } + if (temperature < 3 && (humidity == 2 || humidity == 3 || humidity == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 1) { + if (temperature == 0 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } + if (temperature == 0 && (humidity == 2 || humidity == 3 || humidity == 4)) { + return Biome.GROVE; + } + if (temperature > 0 && temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion == 2 || erosion == 3 || erosion == 4) { + return PlateauBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 4 || erosion == 6) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + return ShatteredBiome.getBiome(humidity, temperature, weirdness); + } + + private @NonNull Biome nearInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + return switch (Ridges.getRidge(convertToY(weirdness))) { + case HIGH -> getHighNearInlandBiome(humidity, temperature, erosion, weirdness); + case LOW -> getLowNearInlandBiome(humidity, temperature, erosion, weirdness); + case MID -> getMidNearInlandBiome(humidity, temperature, erosion, weirdness); + case PEAKS -> getPeaksNearInlandBiome(humidity, temperature, erosion, weirdness); + default -> getValleysNearInlandBiome(humidity, temperature, erosion, weirdness); + }; + } + + private @NonNull Biome getValleysNearInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + //case VALLEYS: + if (erosion >= 0 && erosion < 6) { + if (temperature > 0D) { + return Biome.RIVER; + } else { + return Biome.FROZEN_RIVER; } - // middle biomes - return MiddleBiome.getBiome(h, t, we); - default: - //case VALLEYS: - if (e >= 0 && e < 6) { - if (t > 0D) { - return Biome.RIVER; + } + // e == 6 + if (temperature == 0) { + return Biome.FROZEN_RIVER; + } + if (temperature == 1 || temperature == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + } + + private @NonNull Biome getPeaksNearInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0) { + if (temperature >= 0 && temperature <= 2) { + if (weirdness < 0) { + return Biome.JAGGED_PEAKS; } else { - return Biome.FROZEN_RIVER; + return Biome.FROZEN_PEAKS; } + } else if (temperature == 3) { + return Biome.STONY_PEAKS; } - // e == 6 - if (t == 0) { - return Biome.FROZEN_RIVER; + return BadlandBiome.getBiome(humidity, weirdness); + + } else if (erosion == 1) { + if (temperature == 0 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } else if (temperature == 0 && humidity > 1) { + return Biome.GROVE; + } else if (temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion >= 2 && erosion <= 4) { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 5) { + if (weirdness < 0 && (temperature == 0 || temperature == 1 || humidity == 4)) { + // Shattered biomes + return ShatteredBiome.getBiome(humidity, temperature, weirdness); } - if (t == 1 || t == 2) { - return Biome.SWAMP; + if (weirdness > 0 && (temperature > 2 && temperature <= 4 && humidity >= 0 && humidity <= 4)) { + return Biome.WINDSWEPT_SAVANNA; } - return Biome.MANGROVE_SWAMP; } + // middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - private @NonNull Biome nearInlandBiome(int h, int t, int e, double we) { - Ridges r = Ridges.getRidge(convertToY(we)); // Normalize - switch (r) { - case HIGH: - if (e == 0) { - if (t < 3 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } - if (t < 3 && (h == 2 || h == 3 || h == 4)) { - return Biome.GROVE; - } - return PlateauBiome.getBiome(h, t, we); - } else if (e == 1) { - if (t == 0 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } - if (t == 0 && (h == 2 || h == 3 || h == 4)) { - return Biome.GROVE; - } - if (t > 0 && t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e >= 2 && e <= 4) { + private @NonNull Biome getMidNearInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0) { + if (temperature < 3 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } + if (temperature < 3 && (humidity == 2 || humidity == 3 || humidity == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 1) { + if (temperature == 0 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } + if (temperature == 0 && (humidity == 2 || humidity == 3 || humidity == 4)) { + return Biome.GROVE; + } + if (temperature > 0 && temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion >= 2 && erosion <= 4) { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 5) { + if (weirdness < 0 && (temperature == 0 || temperature == 1) || humidity == 4) { // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 5) { - if (we < 0 && (t == 0 || t == 1) || h == 4) { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } - if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { - return Biome.WINDSWEPT_SAVANNA; - } + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - return MiddleBiome.getBiome(h, t, we); - case LOW: - if (e >= 0 && e < 2) { - if (t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e >= 2 && e < 5) { - // Middle Biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 5) { - if (we < 0 && (t == 0 || t == 1 || h == 4)) { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } - if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { - return Biome.WINDSWEPT_SAVANNA; - } + if (weirdness > 0 && (temperature > 2 && temperature <= 4 && humidity >= 0 && humidity <= 4)) { + return Biome.WINDSWEPT_SAVANNA; } - if (t == 0) { - return MiddleBiome.getBiome(h, t, we); - } else if (t == 1 || t == 2) { - return Biome.SWAMP; + } + if (temperature == 0) { + // Middle Biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + if (temperature == 1 || temperature == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + } + + private @NonNull Biome getLowNearInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion >= 0 && erosion < 2) { + if (temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - return Biome.MANGROVE_SWAMP; - case MID: - if (e == 0) { - if (t < 3 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } - if (t < 3 && (h == 2 || h == 3 || h == 4)) { - return Biome.GROVE; - } - return PlateauBiome.getBiome(h, t, we); - } else if (e == 1) { - if (t == 0 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } - if (t == 0 && (h == 2 || h == 3 || h == 4)) { - return Biome.GROVE; - } - if (t > 0 && t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e >= 2 && e <= 4) { + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion >= 2 && erosion < 5) { + // Middle Biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 5) { + if (weirdness < 0 && (temperature == 0 || temperature == 1 || humidity == 4)) { // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 5) { - if (we < 0 && (t == 0 || t == 1) || h == 4) { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } - if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { - return Biome.WINDSWEPT_SAVANNA; - } + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - if (t == 0) { - // Middle Biomes - return MiddleBiome.getBiome(h, t, we); + if (weirdness > 0 && (temperature > 2 && temperature <= 4 && humidity >= 0 && humidity <= 4)) { + return Biome.WINDSWEPT_SAVANNA; } - if (t == 1 || t == 2) { - return Biome.SWAMP; + } + if (temperature == 0) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (temperature == 1 || temperature == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + } + + private @NonNull Biome getHighNearInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0) { + if (temperature < 3 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; } - return Biome.MANGROVE_SWAMP; - case PEAKS: - if (e == 0) { - if (t >= 0 && t <= 2) { - if (we < 0) { - return Biome.JAGGED_PEAKS; - } else { - return Biome.FROZEN_PEAKS; - } - } else if (t == 3) { - return Biome.STONY_PEAKS; - } - return BadlandBiome.getBiome(h, we); - - } else if (e == 1) { - if (t == 0 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } else if (t == 0 && h > 1) { - return Biome.GROVE; - } else if (t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e >= 2 && e <= 4) { + if (temperature < 3 && (humidity == 2 || humidity == 3 || humidity == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 1) { + if (temperature == 0 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } + if (temperature == 0 && (humidity == 2 || humidity == 3 || humidity == 4)) { + return Biome.GROVE; + } + if (temperature > 0 && temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion >= 2 && erosion <= 4) { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 5) { + if (weirdness < 0 && (temperature == 0 || temperature == 1) || humidity == 4) { // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 5) { - if (we < 0 && (t == 0 || t == 1 || h == 4)) { - // Shattered biomes - return ShatteredBiome.getBiome(h, t, we); - } - if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { - return Biome.WINDSWEPT_SAVANNA; - } + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - // middle biomes - return MiddleBiome.getBiome(h, t, we); - default: - //case VALLEYS: - if (e >= 0 && e < 6) { - if (t > 0D) { - return Biome.RIVER; - } else { - return Biome.FROZEN_RIVER; - } + if (weirdness > 0 && (temperature > 2 && temperature <= 4 && humidity >= 0 && humidity <= 4)) { + return Biome.WINDSWEPT_SAVANNA; } - // e == 6 - if (t == 0) { - return Biome.FROZEN_RIVER; + } + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + + private @NonNull Biome midInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + return switch (Ridges.getRidge(convertToY(weirdness))) { + case HIGH -> getHighMidInlandBiome(humidity, temperature, erosion, weirdness); + case LOW -> getLowMidInlandBiome(humidity, temperature, erosion, weirdness); + case MID -> getMidMidInlandBiome(humidity, temperature, erosion, weirdness); + case PEAKS -> getPeaksMidInlandBiome(humidity, temperature, erosion, weirdness); + default -> getValleysMidInlandBiome(humidity, temperature, erosion, weirdness); + }; + } + + private @NonNull Biome getValleysMidInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0 || erosion == 1) { + if (temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else { + return BadlandBiome.getBiome(humidity, weirdness); } - if (t == 1 || t == 2) { - return Biome.SWAMP; + } + if (erosion >= 2 && erosion <= 5) { + if (temperature == 0) { + return Biome.FROZEN_RIVER; + } else { + return Biome.RIVER; } - return Biome.MANGROVE_SWAMP; } + if (temperature == 0) { + return Biome.FROZEN_RIVER; + } + if (temperature == 1 || temperature == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; } - private @NonNull Biome midInlandBiome(int h, int t, int e, double we) { - Ridges r = Ridges.getRidge(convertToY(we)); // Normalize - switch (r) { - case HIGH: - if (e == 0) { - if (t < 3 && we < 0D) { + private @NonNull Biome getPeaksMidInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0 || erosion == 1) { + if (temperature >= 0 && temperature <= 2) { + if (weirdness < 0) { return Biome.JAGGED_PEAKS; - } - if (t < 3 && we > 0.0D) { + } else { return Biome.FROZEN_PEAKS; } - if (t == 3) { - return Biome.STONY_PEAKS; - } - return BadlandBiome.getBiome(h, we); - } else if (e == 1) { - if (t < 3 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } - if (t < 3 && (h == 2 || h == 3 || h == 4)) { - return Biome.GROVE; - } - return PlateauBiome.getBiome(h, t, we); - } else if (e == 2) { - return PlateauBiome.getBiome(h, t, we); - } else if (e == 3) { - if (t < 4) { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e == 4) { + } else if (temperature == 3) { + return Biome.STONY_PEAKS; + } + return BadlandBiome.getBiome(humidity, weirdness); + + } else if (erosion == 2) { + return PlateauBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 3) { + if (temperature < 4) { // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 5) { - return ShatteredBiome.getBiome(h, t, we); - } - return MiddleBiome.getBiome(h, t, we); - case LOW: - if (e == 0 || e == 1) { - if (t == 0 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } else if (t == 0 && h > 1) { - return Biome.GROVE; - } else if (t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - if (e == 2 || e == 3) { - if (t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion == 4 || erosion == 6) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + return ShatteredBiome.getBiome(humidity, temperature, weirdness); + } + + private @NonNull Biome getMidMidInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0) { + if (temperature < 3 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; } - // e == 6 - if (t == 0) { - // Middle Biomes - return MiddleBiome.getBiome(h, t, we); + if (temperature < 3 && (humidity == 2 || humidity == 3 || humidity == 4)) { + return Biome.GROVE; } - if (t == 1 || t == 2) { - return Biome.SWAMP; + return PlateauBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 1) { + if (temperature == 0 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; } - return Biome.MANGROVE_SWAMP; - case MID: - if (e == 0) { - if (t < 3 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } - if (t < 3 && (h == 2 || h == 3 || h == 4)) { - return Biome.GROVE; - } - return PlateauBiome.getBiome(h, t, we); - } else if (e == 1) { - if (t == 0 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } - if (t == 0 && (h == 2 || h == 3 || h == 4)) { - return Biome.GROVE; - } - if (t > 0 && t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e == 2 || e == 3) { - if (t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e == 4) { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 5) { - return ShatteredBiome.getBiome(h, t, we); + if (temperature == 0 && (humidity == 2 || humidity == 3 || humidity == 4)) { + return Biome.GROVE; } - if (t == 0) { - // Middle Biomes - return MiddleBiome.getBiome(h, t, we); + if (temperature > 0 && temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - if (t == 1 || t == 2) { - return Biome.SWAMP; + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion == 2 || erosion == 3) { + if (temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - return Biome.MANGROVE_SWAMP; - case PEAKS: - if (e == 0 || e == 1) { - if (t >= 0 && t <= 2) { - if (we < 0) { - return Biome.JAGGED_PEAKS; - } else { - return Biome.FROZEN_PEAKS; - } - } else if (t == 3) { - return Biome.STONY_PEAKS; - } - return BadlandBiome.getBiome(h, we); - - } else if (e == 2) { - return PlateauBiome.getBiome(h, t, we); - } else if (e == 3) { - if (t < 4) { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e == 4 || e == 6) { - return MiddleBiome.getBiome(h, t, we); - } - return ShatteredBiome.getBiome(h, t, we); - default: - //case VALLEYS: - if (e == 0 || e == 1) { - if (t < 4) { - return MiddleBiome.getBiome(h, t, we); - } else { - return BadlandBiome.getBiome(h, we); - } + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion == 4) { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 5) { + return ShatteredBiome.getBiome(humidity, temperature, weirdness); + } + if (temperature == 0) { + // Middle Biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + if (temperature == 1 || temperature == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + } + + private @NonNull Biome getLowMidInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0 || erosion == 1) { + if (temperature == 0 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } else if (temperature == 0 && humidity > 1) { + return Biome.GROVE; + } else if (temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - if (e >= 2 && e <= 5) { - if (t == 0) { - return Biome.FROZEN_RIVER; - } else { - return Biome.RIVER; - } + return BadlandBiome.getBiome(humidity, weirdness); + } + if (erosion == 2 || erosion == 3) { + if (temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - if (t == 0) { - return Biome.FROZEN_RIVER; + return BadlandBiome.getBiome(humidity, weirdness); + } + // e == 6 + if (temperature == 0) { + // Middle Biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + if (temperature == 1 || temperature == 2) { + return Biome.SWAMP; + } + return Biome.MANGROVE_SWAMP; + } + + private @NonNull Biome getHighMidInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0) { + if (temperature < 3 && weirdness < 0D) { + return Biome.JAGGED_PEAKS; } - if (t == 1 || t == 2) { - return Biome.SWAMP; + if (temperature < 3 && weirdness > 0.0D) { + return Biome.FROZEN_PEAKS; } - return Biome.MANGROVE_SWAMP; + if (temperature == 3) { + return Biome.STONY_PEAKS; + } + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion == 1) { + if (temperature < 3 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } + if (temperature < 3 && (humidity == 2 || humidity == 3 || humidity == 4)) { + return Biome.GROVE; + } + return PlateauBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 2) { + return PlateauBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 3) { + if (temperature < 4) { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion == 4) { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 5) { + return ShatteredBiome.getBiome(humidity, temperature, weirdness); } + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - private @NonNull Biome coastBiome(int h, int t, int e, double we) { - Ridges r = Ridges.getRidge(convertToY(we)); // Normalize - switch (r) { - case HIGH: - if (e >= 0 && e < 5) { - // Middle Biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 5) { - if (we < 0 && (t == 0 || t == 1 || h == 4)) { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } - if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { - return Biome.WINDSWEPT_SAVANNA; + private @NonNull Biome coastBiome(int humidity, int temperature, int erosion, double weirdness) { + return switch (Ridges.getRidge(convertToY(weirdness))) { + case HIGH -> getHighCoastBionme(humidity, temperature, erosion, weirdness); + case LOW -> getLowCoastBionme(humidity, temperature, erosion, weirdness); + case MID -> getMidCoastBionme(humidity, temperature, erosion, weirdness); + case PEAKS -> getPeaksCoastBionme(humidity, temperature, erosion, weirdness); + default -> getValleysCoastBionme(humidity, temperature, erosion, weirdness); + }; + } + + private @NonNull Biome getValleysCoastBionme(int humidity, int temperature, int erosion, double weirdness) { + if (temperature > 0D) { + return Biome.RIVER; + } + return Biome.FROZEN_RIVER; + } + + private @NonNull Biome getPeaksCoastBionme(int humidity, int temperature, int erosion, double weirdness) { + if (erosion == 0) { + if (temperature >= 0 && temperature <= 2) { + if (weirdness < 0) { + return Biome.JAGGED_PEAKS; + } else { + return Biome.FROZEN_PEAKS; } + } else if (temperature == 3) { + return Biome.STONY_PEAKS; + } + return BadlandBiome.getBiome(humidity, weirdness); + + } else if (erosion == 1) { + if (temperature == 0 && (humidity == 0 || humidity == 1)) { + return Biome.SNOWY_SLOPES; + } else if (temperature == 0 && humidity > 1) { + return Biome.GROVE; + } else if (temperature < 4) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + return BadlandBiome.getBiome(humidity, weirdness); + } else if (erosion >= 2 && erosion <= 4) { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 5) { + if (weirdness < 0 && (temperature == 0 || temperature == 1 || humidity == 4)) { + // Shattered biomes + return ShatteredBiome.getBiome(humidity, temperature, weirdness); } + if (weirdness > 0 && (temperature > 2 && temperature <= 4 && humidity >= 0 && humidity <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + // middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + + private @NonNull Biome getMidCoastBionme(int humidity, int temperature, int erosion, double weirdness) { + if (erosion > 0 && erosion < 3) { + return Biome.STONY_SHORE; + } else if (erosion == 3) { // Middle Biomes - return MiddleBiome.getBiome(h, t, we); - case LOW: - if (e >= 0 && e < 3) { - return Biome.STONY_SHORE; - } else if (e >= 3 && e < 5) { + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 4) { + if (weirdness < 0) { // Beach Biomes - return getBeachBiome(t); - } else if (e == 5) { - if (we < 0) { - // Beach Biomes - return getBeachBiome(t); - } - if (we < 0 && (t == 0 || t == 1 || h == 4)) { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } - if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { - return Biome.WINDSWEPT_SAVANNA; - } + return getBeachBiome(temperature); + } else { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - // Else Beach biomes - return getBeachBiome(t); - case MID: - if (e > 0 && e < 3) { - return Biome.STONY_SHORE; - } else if (e == 3) { + } else if (erosion == 5) { + if (weirdness < 0) { + // Beach Biomes + return getBeachBiome(temperature); + } + if (weirdness < 0 && (temperature == 0 || temperature == 1 || humidity == 4)) { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + if (weirdness > 0 && (temperature > 2 && temperature <= 4 && humidity >= 0 && humidity <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + + } else if (erosion == 6) { + if (weirdness < 0D) { + // Beach Biomes + return getBeachBiome(temperature); + } else { // Middle Biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 4) { - if (we < 0) { - // Beach Biomes - return getBeachBiome(t); - } else { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } - } else if (e == 5) { - if (we < 0) { - // Beach Biomes - return getBeachBiome(t); - } - if (we < 0 && (t == 0 || t == 1 || h == 4)) { - // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } - if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { - return Biome.WINDSWEPT_SAVANNA; - } + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + } + // Else Beach biomes + return getBeachBiome(temperature); + } - } else if (e == 6) { - if (we < 0D) { - // Beach Biomes - return getBeachBiome(t); - } else { - // Middle Biomes - return MiddleBiome.getBiome(h, t, we); - } + private @NonNull Biome getLowCoastBionme(int humidity, int temperature, int erosion, double weirdness) { + if (erosion >= 0 && erosion < 3) { + return Biome.STONY_SHORE; + } else if (erosion >= 3 && erosion < 5) { + // Beach Biomes + return getBeachBiome(temperature); + } else if (erosion == 5) { + if (weirdness < 0) { + // Beach Biomes + return getBeachBiome(temperature); } - // Else Beach biomes - return getBeachBiome(t); - case PEAKS: - if (e == 0) { - if (t >= 0 && t <= 2) { - if (we < 0) { - return Biome.JAGGED_PEAKS; - } else { - return Biome.FROZEN_PEAKS; - } - } else if (t == 3) { - return Biome.STONY_PEAKS; - } - return BadlandBiome.getBiome(h, we); - - } else if (e == 1) { - if (t == 0 && (h == 0 || h == 1)) { - return Biome.SNOWY_SLOPES; - } else if (t == 0 && h > 1) { - return Biome.GROVE; - } else if (t < 4) { - return MiddleBiome.getBiome(h, t, we); - } - return BadlandBiome.getBiome(h, we); - } else if (e >= 2 && e <= 4) { + if (weirdness < 0 && (temperature == 0 || temperature == 1 || humidity == 4)) { // Middle biomes - return MiddleBiome.getBiome(h, t, we); - } else if (e == 5) { - if (we < 0 && (t == 0 || t == 1 || h == 4)) { - // Shattered biomes - return ShatteredBiome.getBiome(h, t, we); - } - if (we > 0 && (t > 2 && t <= 4 && h >= 0 && h <= 4)) { - return Biome.WINDSWEPT_SAVANNA; - } + return MiddleBiome.getBiome(humidity, temperature, weirdness); } - // middle biomes - return MiddleBiome.getBiome(h, t, we); - default: - //case VALLEYS: - if (t > 0D) { - - return Biome.RIVER; + if (weirdness > 0 && (temperature > 2 && temperature <= 4 && humidity >= 0 && humidity <= 4)) { + return Biome.WINDSWEPT_SAVANNA; } - return Biome.FROZEN_RIVER; } + // Else Beach biomes + return getBeachBiome(temperature); } + private @NonNull Biome getHighCoastBionme(int humidity, int temperature, int erosion, double weirdness) { + if (erosion >= 0 && erosion < 5) { + // Middle Biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } else if (erosion == 5) { + if (weirdness < 0 && (temperature == 0 || temperature == 1 || humidity == 4)) { + // Middle biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } + if (weirdness > 0 && (temperature > 2 && temperature <= 4 && humidity >= 0 && humidity <= 4)) { + return Biome.WINDSWEPT_SAVANNA; + } + } + // Middle Biomes + return MiddleBiome.getBiome(humidity, temperature, weirdness); + } Biome getBeachBiome(int t) { return switch (t) { From 0ffccb40d1d151ce9bd5e67a48df6f090b677e63 Mon Sep 17 00:00:00 2001 From: tastybento Date: Thu, 28 Mar 2024 21:20:09 -0700 Subject: [PATCH 7/8] Remove some duplication --- .../biomes/AbstractSeedBiomeProvider.java | 23 ++++--------------- 1 file changed, 4 insertions(+), 19 deletions(-) diff --git a/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java b/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java index 1c5fbcd..ac10713 100644 --- a/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java +++ b/src/main/java/world/bentobox/boxed/generators/biomes/AbstractSeedBiomeProvider.java @@ -531,6 +531,10 @@ private int getTemp(double temp) { return Biome.MANGROVE_SWAMP; } + private @NonNull Biome getValleysNearInlandBiome(int humidity, int temperature, int erosion, double weirdness) { + return getFarInlandValleysBiome(humidity, temperature, erosion, weirdness); + } + private @NonNull Biome getFarInlandPeaksBiome(int humidity, int temperature, int erosion, double weirdness) { if (erosion == 0) { if (temperature >= 0 && temperature <= 2) { @@ -673,25 +677,6 @@ private int getTemp(double temp) { }; } - private @NonNull Biome getValleysNearInlandBiome(int humidity, int temperature, int erosion, double weirdness) { - //case VALLEYS: - if (erosion >= 0 && erosion < 6) { - if (temperature > 0D) { - return Biome.RIVER; - } else { - return Biome.FROZEN_RIVER; - } - } - // e == 6 - if (temperature == 0) { - return Biome.FROZEN_RIVER; - } - if (temperature == 1 || temperature == 2) { - return Biome.SWAMP; - } - return Biome.MANGROVE_SWAMP; - } - private @NonNull Biome getPeaksNearInlandBiome(int humidity, int temperature, int erosion, double weirdness) { if (erosion == 0) { if (temperature >= 0 && temperature <= 2) { From 8daafc0caf5eb6c5091cc494b7a23c86b47272ca Mon Sep 17 00:00:00 2001 From: tastybento Date: Thu, 28 Mar 2024 21:56:17 -0700 Subject: [PATCH 8/8] Remove reference to 5 being the lowest. It isn't. --- src/main/java/world/bentobox/boxed/Settings.java | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/src/main/java/world/bentobox/boxed/Settings.java b/src/main/java/world/bentobox/boxed/Settings.java index 81142d8..d665c00 100644 --- a/src/main/java/world/bentobox/boxed/Settings.java +++ b/src/main/java/world/bentobox/boxed/Settings.java @@ -131,7 +131,7 @@ public class Settings implements WorldSettings { @ConfigEntry(path = "world.max-areas") private int maxIslands = -1; - @ConfigComment("Area height - Lowest is 5.") + @ConfigComment("Area height") @ConfigComment("It is the y coordinate of the bedrock block in the blueprint.") @ConfigEntry(path = "world.area-height") private int islandHeight = 8;