Reimplemented safe corridor in space dimension (y> 200)

Added smaller bottom safe corridor (y < 5)
This commit is contained in:
LemADEC 2016-01-31 22:54:48 +01:00
parent 4de69216a1
commit 2bba86190c
5 changed files with 56 additions and 23 deletions

View file

@ -11,6 +11,7 @@ import java.util.Arrays;
import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilder;
import javax.xml.parsers.DocumentBuilderFactory; import javax.xml.parsers.DocumentBuilderFactory;
import javax.xml.parsers.ParserConfigurationException; import javax.xml.parsers.ParserConfigurationException;
import org.xml.sax.ErrorHandler; import org.xml.sax.ErrorHandler;
import org.xml.sax.SAXException; import org.xml.sax.SAXException;
import org.xml.sax.SAXParseException; import org.xml.sax.SAXParseException;
@ -21,6 +22,7 @@ import cpw.mods.fml.common.registry.GameRegistry;
import cr0s.warpdrive.WarpDrive; import cr0s.warpdrive.WarpDrive;
import cr0s.warpdrive.config.filler.FillerManager; import cr0s.warpdrive.config.filler.FillerManager;
import cr0s.warpdrive.config.structures.StructureManager; import cr0s.warpdrive.config.structures.StructureManager;
import cr0s.warpdrive.config.structures.StructureReference;
import cr0s.warpdrive.data.Planet; import cr0s.warpdrive.data.Planet;
import net.minecraft.block.Block; import net.minecraft.block.Block;
import net.minecraft.item.Item; import net.minecraft.item.Item;
@ -121,6 +123,13 @@ public class WarpDriveConfig {
// Planets // Planets
public static Planet[] PLANETS = null; public static Planet[] PLANETS = null;
// Space generator
public static int SPACE_GENERATOR_Y_MIN_CENTER = 55;
public static int SPACE_GENERATOR_Y_MAX_CENTER = 128;
public static int SPACE_GENERATOR_Y_MIN_BORDER = 5;
public static int SPACE_GENERATOR_Y_MAX_BORDER = 200;
public static RandomCollection<StructureReference> SPACE_GENERATOR_STRUCTURES_CHANCES = null;
// Ship // Ship
public static int SHIP_MAX_ENERGY_STORED = 100000000; public static int SHIP_MAX_ENERGY_STORED = 100000000;
public static int SHIP_NORMALJUMP_ENERGY_PER_BLOCK = 10; public static int SHIP_NORMALJUMP_ENERGY_PER_BLOCK = 10;

View file

@ -30,15 +30,17 @@ public class MetaOrbInstance extends OrbInstance {
} }
LocalProfiler.start("[AsteroidInstance] Generating MetaOrb " + structure.name + " of " + metashell.count + " cores with radius of " + totalThickness); LocalProfiler.start("[AsteroidInstance] Generating MetaOrb " + structure.name + " of " + metashell.count + " cores with radius of " + totalThickness);
int y2 = Math.min(WarpDriveConfig.SPACE_GENERATOR_Y_MAX_BORDER - totalThickness - (int)metashell.radius,
Math.max(y, WarpDriveConfig.SPACE_GENERATOR_Y_MIN_BORDER + totalThickness + (int)metashell.radius));
if (((MetaOrb)structure).metashell == null) { if (((MetaOrb)structure).metashell == null) {
return super.generate(world, random, x, y, z); return super.generate(world, random, x, y2, z);
} }
// generate an abstract form for the core // generate an abstract form for the core
for (VectorI location: metashell.locations) { for (VectorI location: metashell.locations) {
// place core block // place core block
if (metashell.block != null) { if (metashell.block != null) {
world.setBlock(x + location.x, y + location.y, z + location.z, metashell.block, metashell.metadata, 2); world.setBlock(x + location.x, y2 + location.y, z + location.z, metashell.block, metashell.metadata, 2);
} }
// calculate distance to borders of generation area // calculate distance to borders of generation area
@ -52,7 +54,7 @@ public class MetaOrbInstance extends OrbInstance {
maxLocalRadius = Math.max(minThickness, maxLocalRadius); maxLocalRadius = Math.max(minThickness, maxLocalRadius);
// Generate shell // Generate shell
addShell(world, new VectorI(x, y, z).add(location), maxLocalRadius); addShell(world, new VectorI(x, y2, z).add(location), maxLocalRadius);
} }
LocalProfiler.stop(); LocalProfiler.stop();

View file

@ -4,6 +4,7 @@ import java.util.Random;
import net.minecraft.nbt.NBTTagCompound; import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.world.World; import net.minecraft.world.World;
import cr0s.warpdrive.config.WarpDriveConfig;
import cr0s.warpdrive.config.structures.Orb.OrbShell; import cr0s.warpdrive.config.structures.Orb.OrbShell;
import cr0s.warpdrive.world.EntitySphereGen; import cr0s.warpdrive.world.EntitySphereGen;
import cr0s.warpdrive.world.EntityStarCore; import cr0s.warpdrive.world.EntityStarCore;
@ -71,13 +72,15 @@ public class OrbInstance extends AbstractInstance {
@Override @Override
public boolean generate(World world, Random random, int x, int y, int z) { public boolean generate(World world, Random random, int x, int y, int z) {
boolean hasShip = schematicName != null && !schematicName.isEmpty(); boolean hasShip = schematicName != null && !schematicName.isEmpty();
int y2 = Math.min(WarpDriveConfig.SPACE_GENERATOR_Y_MAX_BORDER - totalThickness,
Math.max(y, WarpDriveConfig.SPACE_GENERATOR_Y_MIN_BORDER + totalThickness));
if (hasShip) { if (hasShip) {
new WorldGenSmallShip(false).generate(world, random, x, y, z); new WorldGenSmallShip(false).generate(world, random, x, y2, z);
} }
EntitySphereGen entitySphereGen = new EntitySphereGen(world, x, y, z, this, !hasShip); EntitySphereGen entitySphereGen = new EntitySphereGen(world, x, y2, z, this, !hasShip);
world.spawnEntityInWorld(entitySphereGen); world.spawnEntityInWorld(entitySphereGen);
if (((Orb)structure).hasStarCore) { if (((Orb)structure).hasStarCore) {
return world.spawnEntityInWorld(new EntityStarCore(world, x, y, z, totalThickness)); return world.spawnEntityInWorld(new EntityStarCore(world, x, y2, z, totalThickness));
} }
return true; return true;
} }

View file

@ -0,0 +1,33 @@
package cr0s.warpdrive.config.structures;
import java.util.Random;
import net.minecraft.world.World;
import org.w3c.dom.Element;
import cr0s.warpdrive.config.InvalidXmlException;
public class StructureReference extends AbstractStructure {
public StructureReference(final String group, final String name) {
super(group, name);
}
@Override
public boolean loadFromXmlElement(Element element) throws InvalidXmlException {
super.loadFromXmlElement(element);
return true;
}
@Override
public boolean generate(World world, Random random, int x, int y, int z) {
return instantiate(random).generate(world, random, x, y, z);
}
@Override
public AbstractInstance instantiate(Random random) {
return StructureManager.getStructure(random, group, name).instantiate(random);
}
}

View file

@ -18,21 +18,6 @@ import cr0s.warpdrive.config.structures.StructureManager;
* @author Cr0s * @author Cr0s
*/ */
public class SpaceWorldGenerator implements IWorldGenerator { public class SpaceWorldGenerator implements IWorldGenerator {
// Radius of simple moon
public final int MOON_RADIUS = 32;
public final int MOON_CORE_RADIUS = 10;
// Star radius
public final int RED_DWARF_RADIUS = 42;
public final int YELLOW_GIANT_RADIUS = 64;
public final int YELLOW_SUPERGIANT_RADIUS = 80;
// Upper than 200 nothing should generate naturally (safe place)
public static int Y_LIMIT_HARD_MAX = 200;
// Upper than 128 almost nothing will be generated
public static int Y_LIMIT_SOFT_MAX = 128;
// Lower limit
public static int Y_LIMIT_SOFT_MIN = 55;
/** /**
* Generator for chunk * Generator for chunk
@ -55,7 +40,7 @@ public class SpaceWorldGenerator implements IWorldGenerator {
if (WarpDriveConfig.G_SPACE_WORLDBORDER_BLOCKS > 0 && (Math.abs(x) > WarpDriveConfig.G_SPACE_WORLDBORDER_BLOCKS || Math.abs(z) > WarpDriveConfig.G_SPACE_WORLDBORDER_BLOCKS)) { if (WarpDriveConfig.G_SPACE_WORLDBORDER_BLOCKS > 0 && (Math.abs(x) > WarpDriveConfig.G_SPACE_WORLDBORDER_BLOCKS || Math.abs(z) > WarpDriveConfig.G_SPACE_WORLDBORDER_BLOCKS)) {
return; return;
} }
int y = Y_LIMIT_SOFT_MIN + random.nextInt(Y_LIMIT_SOFT_MAX - Y_LIMIT_SOFT_MIN); int y = WarpDriveConfig.SPACE_GENERATOR_Y_MIN_CENTER + random.nextInt(WarpDriveConfig.SPACE_GENERATOR_Y_MAX_CENTER - WarpDriveConfig.SPACE_GENERATOR_Y_MIN_CENTER);
// Moon setup // Moon setup
if (random.nextInt(700) == 1) { if (random.nextInt(700) == 1) {
AbstractStructure moon = StructureManager.getStructure(world.rand, StructureManager.GROUP_MOONS, null); AbstractStructure moon = StructureManager.getStructure(world.rand, StructureManager.GROUP_MOONS, null);
@ -145,7 +130,8 @@ public class SpaceWorldGenerator implements IWorldGenerator {
int numOfSmallAsteroids = Math.round((1.0F - bigRatio) * surfaceSmall / surfacePerAsteroid); int numOfSmallAsteroids = Math.round((1.0F - bigRatio) * surfaceSmall / surfacePerAsteroid);
int numOfClouds = Math.round(numOfBigAsteroids * 1.0F / (10.0F + world.rand.nextInt(10))); int numOfClouds = Math.round(numOfBigAsteroids * 1.0F / (10.0F + world.rand.nextInt(10)));
int maxHeight = 70 + world.rand.nextInt(50); int maxHeight = 70 + world.rand.nextInt(50);
int y2 = Math.min(Y_LIMIT_HARD_MAX - maxHeight, Math.max(y1, maxHeight)); int y2 = Math.min(WarpDriveConfig.SPACE_GENERATOR_Y_MAX_BORDER - maxHeight,
Math.max(y1, WarpDriveConfig.SPACE_GENERATOR_Y_MIN_BORDER + maxHeight));
WarpDrive.logger.info("Generating asteroid field at " + x + "," + y2 + "," + z + " qty " + numOfBigAsteroids + ", " + numOfSmallAsteroids + ", " WarpDrive.logger.info("Generating asteroid field at " + x + "," + y2 + "," + z + " qty " + numOfBigAsteroids + ", " + numOfSmallAsteroids + ", "
+ numOfClouds + " over " + maxDistance + ", " + maxHeight + " surfacePerAsteroid " + String.format("%.1f", surfacePerAsteroid)); + numOfClouds + " over " + maxDistance + ", " + maxHeight + " surfacePerAsteroid " + String.format("%.1f", surfacePerAsteroid));