Fixed #82 hardcoded biome id

Fixed biome registration
Fixed default biome id from 24 to 95
Code cleanup
This commit is contained in:
LemADEC 2015-08-28 11:33:57 +02:00
parent 97ac427d12
commit dfbd452b1a
7 changed files with 158 additions and 237 deletions

View file

@ -18,6 +18,7 @@ import net.minecraft.util.ChatComponentText;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraft.world.WorldServer; import net.minecraft.world.WorldServer;
import net.minecraft.world.biome.BiomeGenBase; import net.minecraft.world.biome.BiomeGenBase;
import net.minecraftforge.common.BiomeDictionary;
import net.minecraftforge.common.DimensionManager; import net.minecraftforge.common.DimensionManager;
import net.minecraftforge.common.ForgeChunkManager; import net.minecraftforge.common.ForgeChunkManager;
import net.minecraftforge.common.ForgeChunkManager.LoadingCallback; import net.minecraftforge.common.ForgeChunkManager.LoadingCallback;
@ -109,9 +110,9 @@ import cr0s.warpdrive.network.PacketHandler;
import cr0s.warpdrive.render.ClientCameraHandler; import cr0s.warpdrive.render.ClientCameraHandler;
import cr0s.warpdrive.render.RenderOverlayCamera; import cr0s.warpdrive.render.RenderOverlayCamera;
import cr0s.warpdrive.world.BiomeSpace; import cr0s.warpdrive.world.BiomeSpace;
import cr0s.warpdrive.world.HyperSpaceProvider; import cr0s.warpdrive.world.HyperSpaceWorldProvider;
import cr0s.warpdrive.world.HyperSpaceWorldGenerator; import cr0s.warpdrive.world.HyperSpaceWorldGenerator;
import cr0s.warpdrive.world.SpaceProvider; import cr0s.warpdrive.world.SpaceWorldProvider;
import cr0s.warpdrive.world.SpaceWorldGenerator; import cr0s.warpdrive.world.SpaceWorldGenerator;
@Mod(modid = WarpDrive.MODID, name = "WarpDrive", version = WarpDrive.VERSION, dependencies = "after:IC2API;" + " after:CoFHCore;" + " after:ComputerCraft;" @Mod(modid = WarpDrive.MODID, name = "WarpDrive", version = WarpDrive.VERSION, dependencies = "after:IC2API;" + " after:CoFHCore;" + " after:ComputerCraft;"
@ -864,13 +865,14 @@ public class WarpDrive implements LoadingCallback {
} }
private static void registerSpaceDimension() { private static void registerSpaceDimension() {
spaceBiome = (new BiomeSpace(24)).setColor(0).setDisableRain().setBiomeName("Space"); spaceBiome = (new BiomeSpace(WarpDriveConfig.G_SPACE_BIOME_ID)).setColor(0).setDisableRain().setBiomeName("Space");
DimensionManager.registerProviderType(WarpDriveConfig.G_SPACE_PROVIDER_ID, SpaceProvider.class, true); BiomeDictionary.registerBiomeType(spaceBiome, BiomeDictionary.Type.DEAD, BiomeDictionary.Type.WASTELAND);
DimensionManager.registerProviderType(WarpDriveConfig.G_SPACE_PROVIDER_ID, SpaceWorldProvider.class, true);
DimensionManager.registerDimension(WarpDriveConfig.G_SPACE_DIMENSION_ID, WarpDriveConfig.G_SPACE_PROVIDER_ID); DimensionManager.registerDimension(WarpDriveConfig.G_SPACE_DIMENSION_ID, WarpDriveConfig.G_SPACE_PROVIDER_ID);
} }
private static void registerHyperSpaceDimension() { private static void registerHyperSpaceDimension() {
DimensionManager.registerProviderType(WarpDriveConfig.G_HYPERSPACE_PROVIDER_ID, HyperSpaceProvider.class, true); DimensionManager.registerProviderType(WarpDriveConfig.G_HYPERSPACE_PROVIDER_ID, HyperSpaceWorldProvider.class, true);
DimensionManager.registerDimension(WarpDriveConfig.G_HYPERSPACE_DIMENSION_ID, WarpDriveConfig.G_HYPERSPACE_PROVIDER_ID); DimensionManager.registerDimension(WarpDriveConfig.G_HYPERSPACE_DIMENSION_ID, WarpDriveConfig.G_HYPERSPACE_PROVIDER_ID);
} }

View file

@ -80,6 +80,7 @@ public class WarpDriveConfig {
// Mod configuration (see loadWarpDriveConfig() for comments/definitions) // Mod configuration (see loadWarpDriveConfig() for comments/definitions)
// General // General
public static int G_SPACE_BIOME_ID = 95;
public static int G_SPACE_PROVIDER_ID = 14; public static int G_SPACE_PROVIDER_ID = 14;
public static int G_SPACE_DIMENSION_ID = -2; public static int G_SPACE_DIMENSION_ID = -2;
public static int G_HYPERSPACE_PROVIDER_ID = 15; public static int G_HYPERSPACE_PROVIDER_ID = 15;
@ -303,6 +304,8 @@ public class WarpDriveConfig {
config.load(); config.load();
// General // General
G_SPACE_BIOME_ID = clamp(Integer.MIN_VALUE, Integer.MAX_VALUE,
config.get("general", "space_biome_id", G_SPACE_BIOME_ID, "Space biome ID").getInt());
G_SPACE_PROVIDER_ID = clamp(Integer.MIN_VALUE, Integer.MAX_VALUE, G_SPACE_PROVIDER_ID = clamp(Integer.MIN_VALUE, Integer.MAX_VALUE,
config.get("general", "space_provider_id", G_SPACE_PROVIDER_ID, "Space dimension provider ID").getInt()); config.get("general", "space_provider_id", G_SPACE_PROVIDER_ID, "Space dimension provider ID").getInt());
G_SPACE_DIMENSION_ID = clamp(Integer.MIN_VALUE, Integer.MAX_VALUE, G_SPACE_DIMENSION_ID = clamp(Integer.MIN_VALUE, Integer.MAX_VALUE,

View file

@ -5,7 +5,7 @@ import java.util.Random;
import net.minecraft.block.Block; import net.minecraft.block.Block;
import net.minecraft.entity.EnumCreatureType; import net.minecraft.entity.EnumCreatureType;
import net.minecraft.util.IProgressUpdate; import net.minecraft.world.ChunkPosition;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraft.world.biome.BiomeGenBase; import net.minecraft.world.biome.BiomeGenBase;
import net.minecraft.world.chunk.Chunk; import net.minecraft.world.chunk.Chunk;
@ -13,77 +13,49 @@ import net.minecraft.world.chunk.IChunkProvider;
import net.minecraft.world.gen.ChunkProviderGenerate; import net.minecraft.world.gen.ChunkProviderGenerate;
import cr0s.warpdrive.WarpDrive; import cr0s.warpdrive.WarpDrive;
public class HyperSpaceGenerator extends ChunkProviderGenerate implements IChunkProvider { public class HyperSpaceGenerator extends ChunkProviderGenerate {
private World worldObj;
private Random rand; private Random rand;
private BiomeGenBase[] biomesForGeneration = new BiomeGenBase[1]; private BiomeGenBase[] biomesForGeneration = new BiomeGenBase[1];
/** public HyperSpaceGenerator(World worldObj, long par2) {
* Reference to the World object. super(worldObj, par2, false);
*/ rand = new Random(par2);
private World worldObj; this.worldObj = worldObj;
public HyperSpaceGenerator(World par1World, long par2) {
super(par1World, par2, false);
rand = new Random();
this.worldObj = par1World;
} }
@Override @Override
public Chunk provideChunk(int par1, int par2) { public Chunk provideChunk(int par1, int par2) {
this.rand.setSeed(par1 * 341873128712L + par2 * 132897987541L); this.rand.setSeed(par1 * 341873128712L + par2 * 132897987541L);
Block[] var3 = new Block[32768]; Block[] var3 = new Block[32768];
this.biomesForGeneration[0] = WarpDrive.spaceBiome; // this.biomesForGeneration[0] = WarpDrive.spaceBiome;
// this.caveGenerator.generate(this, this.worldObj, par1, par2, var3); // this.caveGenerator.generate(this, this.worldObj, par1, par2, var3);
this.biomesForGeneration[0] = WarpDrive.spaceBiome; this.biomesForGeneration[0] = WarpDrive.spaceBiome;
Chunk var4 = new Chunk(this.worldObj, var3, par1, par2); Chunk var4 = new Chunk(worldObj, var3, par1, par2);
var4.generateSkylightMap(); var4.generateSkylightMap();
return var4; return var4;
} }
@Override
public Chunk loadChunk(int var1, int var2) {
// TODO Auto-generated method stub
return this.provideChunk(var1, var2);
}
@Override @Override
public void populate(IChunkProvider var1, int var2, int var3) { public void populate(IChunkProvider var1, int var2, int var3) {
// super.populate(var1, var2, var3); // super.populate(var1, var2, var3);
// Generate chunk population // Generate chunk population
// GameRegistry.generateWorld(var2, var3, worldObj, var1, var1); // GameRegistry.generateWorld(var2, var3, worldObj, var1, var1);
} }
@Override
public boolean saveChunks(boolean var1, IProgressUpdate var2) {
return super.saveChunks(var1, var2);
}
@Override
public boolean canSave() {
// TODO Auto-generated method stub
return super.canSave();
}
@Override
public String makeString() {
// TODO Auto-generated method stub
return super.makeString();
}
@Override @Override
public List getPossibleCreatures(EnumCreatureType var1, int var2, int var3, int var4) { public List getPossibleCreatures(EnumCreatureType var1, int var2, int var3, int var4) {
// TODO Auto-generated method stub
return null; return null;
} }
@Override @Override
public int getLoadedChunkCount() { public ChunkPosition func_147416_a(World var1, String var2, int var3, int var4, int var5) {
// TODO Auto-generated method stub // no structure generation
return super.getLoadedChunkCount(); return null;
} }
@Override @Override
public void recreateStructures(int var1, int var2) { public void recreateStructures(int var1, int var2) {
// TODO Auto-generated method stub // no structure generation
} }
} }

View file

@ -16,38 +16,34 @@ import cr0s.warpdrive.WarpDrive;
import cr0s.warpdrive.config.WarpDriveConfig; import cr0s.warpdrive.config.WarpDriveConfig;
import cr0s.warpdrive.render.RenderBlank; import cr0s.warpdrive.render.RenderBlank;
public class HyperSpaceProvider extends WorldProvider { public class HyperSpaceWorldProvider extends WorldProvider {
public int exitXCoord;
public int exitYCoord; public HyperSpaceWorldProvider() {
public int exitZCoord;
public int exitDimID;
public HyperSpaceProvider() {
this.worldChunkMgr = new WorldChunkManagerHell(WarpDrive.spaceBiome, 0.0F); this.worldChunkMgr = new WorldChunkManagerHell(WarpDrive.spaceBiome, 0.0F);
this.hasNoSky = false; this.hasNoSky = false;
} }
@Override @Override
public String getDimensionName() { public String getDimensionName() {
return "Hyperspace"; return "Hyperspace";
} }
@Override @Override
public boolean canRespawnHere() { public boolean canRespawnHere() {
return true; return true;
} }
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
@Override @Override
public float getStarBrightness(float par1) { public float getStarBrightness(float par1) {
return 0F; return 0F;
} }
@Override @Override
public boolean isSurfaceWorld() { public boolean isSurfaceWorld() {
return true; return true;
} }
@Override @Override
public int getAverageGroundLevel() { public int getAverageGroundLevel() {
return 1; return 1;
@ -57,100 +53,99 @@ public class HyperSpaceProvider extends WorldProvider {
public double getHorizon() { public double getHorizon() {
return 1; return 1;
} }
@Override @Override
public void updateWeather() { public void updateWeather() {
super.resetRainAndThunder(); super.resetRainAndThunder();
} }
@Override @Override
public BiomeGenBase getBiomeGenForCoords(int x, int z) { public BiomeGenBase getBiomeGenForCoords(int x, int z) {
return WarpDrive.spaceBiome; return WarpDrive.spaceBiome;
} }
@Override @Override
public void setAllowedSpawnTypes(boolean allowHostile, boolean allowPeaceful) { public void setAllowedSpawnTypes(boolean allowHostile, boolean allowPeaceful) {
super.setAllowedSpawnTypes(true, true); super.setAllowedSpawnTypes(true, true);
} }
@Override @Override
public float calculateCelestialAngle(long par1, float par3) { public float calculateCelestialAngle(long par1, float par3) {
return 0.5F; return 0.5F;
} }
@Override @Override
protected void generateLightBrightnessTable() { protected void generateLightBrightnessTable() {
float var1 = 0.0F; float f = 0.0F;
for (int var2 = 0; var2 <= 15; ++var2) { for (int i = 0; i <= 15; ++i) {
float var3 = 1.0F - var2 / 15.0F; float f1 = 1.0F - i / 15.0F;
this.lightBrightnessTable[var2] = (1.0F - var3) / (var3 * 3.0F + 1.0F) * (1.0F - var1) + var1; this.lightBrightnessTable[i] = (1.0F - f1) / (f1 * 3.0F + 1.0F) * (1.0F - f) + f;
} }
} }
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
@Override @Override
public String getSaveFolder() { public String getSaveFolder() {
return (dimensionId == 0 ? null : "WarpDriveHyperSpace" + dimensionId); return (dimensionId == 0 ? null : "WarpDriveHyperSpace" + dimensionId);
} }
@Override @Override
public boolean canCoordinateBeSpawn(int par1, int par2) { public boolean canCoordinateBeSpawn(int par1, int par2) {
int var3 = this.worldObj.getTopSolidOrLiquidBlock(par1, par2); int var3 = this.worldObj.getTopSolidOrLiquidBlock(par1, par2);
return var3 != 0; return var3 != 0;
} }
@Override @Override
public Vec3 getSkyColor(Entity cameraEntity, float partialTicks) { public Vec3 getSkyColor(Entity cameraEntity, float partialTicks) {
setCloudRenderer(new RenderBlank()); setCloudRenderer(new RenderBlank());
setSkyRenderer(new RenderBlank()); setSkyRenderer(new RenderBlank());
return Vec3.createVectorHelper(1.0D, 0.0D, 0.0D); return Vec3.createVectorHelper(1.0D, 0.0D, 0.0D);
} }
@Override @Override
public Vec3 getFogColor(float par1, float par2) { public Vec3 getFogColor(float par1, float par2) {
return Vec3.createVectorHelper(0.1D, 0.0D, 0.0D); return Vec3.createVectorHelper(0.1D, 0.0D, 0.0D);
} }
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
@Override @Override
public boolean isSkyColored() { public boolean isSkyColored() {
return true; return true;
} }
@Override @Override
public ChunkCoordinates getEntrancePortalLocation() { public ChunkCoordinates getEntrancePortalLocation() {
return null; return null;
} }
@Override @Override
public int getRespawnDimension(EntityPlayerMP player) { public int getRespawnDimension(EntityPlayerMP player) {
return WarpDriveConfig.G_HYPERSPACE_DIMENSION_ID; return WarpDriveConfig.G_HYPERSPACE_DIMENSION_ID;
} }
@Override @Override
public IChunkProvider createChunkGenerator() { public IChunkProvider createChunkGenerator() {
return new HyperSpaceGenerator(worldObj, 46); return new HyperSpaceGenerator(worldObj, 46);
} }
@Override @Override
public boolean canBlockFreeze(int x, int y, int z, boolean byWater) { public boolean canBlockFreeze(int x, int y, int z, boolean byWater) {
return false; return false;
} }
@Override @Override
public ChunkCoordinates getRandomizedSpawnPoint() { public ChunkCoordinates getRandomizedSpawnPoint() {
ChunkCoordinates var5 = new ChunkCoordinates(this.worldObj.getSpawnPoint()); ChunkCoordinates var5 = new ChunkCoordinates(worldObj.getSpawnPoint());
// boolean isAdventure = worldObj.getWorldInfo().getGameType() == // boolean isAdventure = worldObj.getWorldInfo().getGameType() == EnumGameType.ADVENTURE;
// EnumGameType.ADVENTURE;
int spawnFuzz = 100; int spawnFuzz = 100;
int spawnFuzzHalf = spawnFuzz / 2; int spawnFuzzHalf = spawnFuzz / 2;
{ {
var5.posX += this.worldObj.rand.nextInt(spawnFuzz) - spawnFuzzHalf; var5.posX += worldObj.rand.nextInt(spawnFuzz) - spawnFuzzHalf;
var5.posZ += this.worldObj.rand.nextInt(spawnFuzz) - spawnFuzzHalf; var5.posZ += worldObj.rand.nextInt(spawnFuzz) - spawnFuzzHalf;
var5.posY = 200; var5.posY = 200;
} }
if (worldObj.isAirBlock(var5.posX, var5.posY, var5.posZ)) { if (worldObj.isAirBlock(var5.posX, var5.posY, var5.posZ)) {
worldObj.setBlock(var5.posX, var5.posY, var5.posZ, Blocks.stone, 0, 2); worldObj.setBlock(var5.posX, var5.posY, var5.posZ, Blocks.stone, 0, 2);
worldObj.setBlock(var5.posX + 1, var5.posY + 1, var5.posZ, Blocks.glass, 0, 2); worldObj.setBlock(var5.posX + 1, var5.posY + 1, var5.posZ, Blocks.glass, 0, 2);
@ -165,25 +160,25 @@ public class HyperSpaceProvider extends WorldProvider {
worldObj.setBlock(var5.posX, var5.posY, var5.posZ, WarpDrive.blockAir, 15, 2); worldObj.setBlock(var5.posX, var5.posY, var5.posZ, WarpDrive.blockAir, 15, 2);
worldObj.setBlock(var5.posX, var5.posY + 1, var5.posZ, WarpDrive.blockAir, 15, 2); worldObj.setBlock(var5.posX, var5.posY + 1, var5.posZ, WarpDrive.blockAir, 15, 2);
} }
return var5; return var5;
} }
@Override @Override
public boolean getWorldHasVoidParticles() { public boolean getWorldHasVoidParticles() {
return false; return false;
} }
@Override @Override
public boolean isDaytime() { public boolean isDaytime() {
return true; return true;
} }
@Override @Override
public boolean canDoLightning(Chunk chunk) { public boolean canDoLightning(Chunk chunk) {
return false; return false;
} }
@Override @Override
public boolean canDoRainSnowIce(Chunk chunk) { public boolean canDoRainSnowIce(Chunk chunk) {
return false; return false;

View file

@ -1,7 +1,3 @@
/*
* To change this template, choose Tools | Templates
* and open the template in the editor.
*/
package cr0s.warpdrive.world; package cr0s.warpdrive.world;
import java.util.List; import java.util.List;
@ -9,7 +5,6 @@ import java.util.Random;
import net.minecraft.block.Block; import net.minecraft.block.Block;
import net.minecraft.entity.EnumCreatureType; import net.minecraft.entity.EnumCreatureType;
import net.minecraft.util.IProgressUpdate;
import net.minecraft.world.ChunkPosition; import net.minecraft.world.ChunkPosition;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraft.world.biome.BiomeGenBase; import net.minecraft.world.biome.BiomeGenBase;
@ -19,82 +14,48 @@ import net.minecraft.world.gen.ChunkProviderGenerate;
import cr0s.warpdrive.WarpDrive; import cr0s.warpdrive.WarpDrive;
public class SpaceGenerator extends ChunkProviderGenerate { public class SpaceGenerator extends ChunkProviderGenerate {
private World worldObj;
private Random rand; private Random rand;
private BiomeGenBase[] biomesForGeneration = new BiomeGenBase[1]; private BiomeGenBase[] biomesForGeneration = new BiomeGenBase[1];
/** public SpaceGenerator(World worldObj, long par2) {
* Reference to the World object. super(worldObj, par2, false);
*/ rand = new Random(par2);
private World worldObj; this.worldObj = worldObj;
public SpaceGenerator(World par1World, long par2) {
super(par1World, par2, false);
rand = new Random();
this.worldObj = par1World;
} }
@Override @Override
public Chunk provideChunk(int par1, int par2) { public Chunk provideChunk(int par1, int par2) {
this.rand.setSeed(par1 * 341873128712L + par2 * 132897987541L); this.rand.setSeed(par1 * 341873128712L + par2 * 132897987541L);
Block[] var3 = new Block[32768]; Block[] var3 = new Block[32768];
this.biomesForGeneration[0] = WarpDrive.spaceBiome; // this.biomesForGeneration[0] = WarpDrive.spaceBiome;
// this.caveGenerator.generate(this, this.worldObj, par1, par2, var3); // this.caveGenerator.generate(this, this.worldObj, par1, par2, var3);
this.biomesForGeneration[0] = WarpDrive.spaceBiome; this.biomesForGeneration[0] = WarpDrive.spaceBiome;
Chunk var4 = new Chunk(this.worldObj, var3, par1, par2); Chunk var4 = new Chunk(worldObj, var3, par1, par2);
var4.generateSkylightMap(); var4.generateSkylightMap();
return var4; return var4;
} }
@Override
public Chunk loadChunk(int var1, int var2) {
// TODO Auto-generated method stub
return this.provideChunk(var1, var2);
}
@Override @Override
public void populate(IChunkProvider var1, int var2, int var3) { public void populate(IChunkProvider var1, int var2, int var3) {
// super.populate(var1, var2, var3); // super.populate(var1, var2, var3);
// Generate chunk population // Generate chunk population
// GameRegistry.generateWorld(var2, var3, worldObj, var1, var1); // GameRegistry.generateWorld(var2, var3, worldObj, var1, var1);
} }
@Override
public boolean saveChunks(boolean var1, IProgressUpdate var2) {
return super.saveChunks(var1, var2);
}
@Override
public boolean canSave() {
// TODO Auto-generated method stub
return super.canSave();
}
@Override
public String makeString() {
// TODO Auto-generated method stub
return super.makeString();
}
@Override @Override
public List getPossibleCreatures(EnumCreatureType var1, int var2, int var3, int var4) { public List getPossibleCreatures(EnumCreatureType var1, int var2, int var3, int var4) {
// TODO Auto-generated method stub
return null; return null;
} }
@Override @Override
public ChunkPosition func_147416_a(World var1, String var2, int var3, int var4, int var5) { public ChunkPosition func_147416_a(World var1, String var2, int var3, int var4, int var5) {
// TODO Auto-generated method stub // no structure generation
return null; return null;
} }
@Override
public int getLoadedChunkCount() {
// TODO Auto-generated method stub
return super.getLoadedChunkCount();
}
@Override @Override
public void recreateStructures(int var1, int var2) { public void recreateStructures(int var1, int var2) {
// TODO Auto-generated method stub // no structure generation
} }
} }

View file

@ -71,10 +71,10 @@ public class SpaceSkyRenderer extends IRenderHandler {
@Override @Override
public void render(float partialTicks, WorldClient world, Minecraft mc) { public void render(float partialTicks, WorldClient world, Minecraft mc) {
SpaceProvider spaceProvider = null; SpaceWorldProvider spaceProvider = null;
if (world.provider instanceof SpaceProvider) { if (world.provider instanceof SpaceWorldProvider) {
spaceProvider = (SpaceProvider) world.provider; spaceProvider = (SpaceWorldProvider) world.provider;
} }
GL11.glDisable(GL11.GL_TEXTURE_2D); GL11.glDisable(GL11.GL_TEXTURE_2D);

View file

@ -14,188 +14,176 @@ import cpw.mods.fml.relauncher.SideOnly;
import cr0s.warpdrive.WarpDrive; import cr0s.warpdrive.WarpDrive;
import cr0s.warpdrive.render.RenderBlank; import cr0s.warpdrive.render.RenderBlank;
public class SpaceProvider extends WorldProvider { public class SpaceWorldProvider extends WorldProvider {
public int exitXCoord;
public int exitYCoord; public SpaceWorldProvider() {
public int exitZCoord;
public int exitDimID;
public SpaceProvider() {
this.worldChunkMgr = new WorldChunkManagerHell(WarpDrive.spaceBiome, 0.0F); this.worldChunkMgr = new WorldChunkManagerHell(WarpDrive.spaceBiome, 0.0F);
this.hasNoSky = false; this.hasNoSky = false;
} }
@Override @Override
public String getDimensionName() { public String getDimensionName() {
return "Space"; return "Space";
} }
@Override @Override
public boolean canRespawnHere() { public boolean canRespawnHere() {
return false; return false;
} }
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
@Override @Override
public float getStarBrightness(float par1) { public float getStarBrightness(float par1) {
return 1.0F; return 1.0F;
} }
@Override @Override
public boolean isSurfaceWorld() { public boolean isSurfaceWorld() {
return true; return true;
} }
@Override @Override
public int getAverageGroundLevel() { public int getAverageGroundLevel() {
return 1; return 1;
} }
@Override @Override
public double getHorizon() { public double getHorizon() {
return 1; return 1;
} }
@Override @Override
public void updateWeather() { public void updateWeather() {
this.worldObj.getWorldInfo().setRainTime(0); super.resetRainAndThunder();
this.worldObj.getWorldInfo().setRaining(false);
this.worldObj.getWorldInfo().setThunderTime(0);
this.worldObj.getWorldInfo().setThundering(false);
} }
@Override @Override
public BiomeGenBase getBiomeGenForCoords(int x, int z) { public BiomeGenBase getBiomeGenForCoords(int x, int z) {
return WarpDrive.spaceBiome; return WarpDrive.spaceBiome;
} }
@Override @Override
public void setAllowedSpawnTypes(boolean allowHostile, boolean allowPeaceful) { public void setAllowedSpawnTypes(boolean allowHostile, boolean allowPeaceful) {
super.setAllowedSpawnTypes(true, true); super.setAllowedSpawnTypes(true, true);
} }
@Override @Override
public float calculateCelestialAngle(long par1, float par3) { public float calculateCelestialAngle(long par1, float par3) {
return 0F; return 0F;
} }
@Override @Override
protected void generateLightBrightnessTable() { protected void generateLightBrightnessTable() {
/* float f = 0.0F; // 0.1F
* float var1 = 0.1F;
* for (int i = 0; i <= 15; ++i) {
* for (int var2 = 0; var2 <= 15; ++var2) { float var3 = 1.0F - float f1 = 1.0F - i / 15.0F;
* (float)var2 / 15.0F; this.lightBrightnessTable[var2] = (1.0F - var3) this.lightBrightnessTable[i] = (1.0F - f1) / (f1 * 3.0F + 1.0F) * (1.0F - f) + f;
* / (var3 * 3.0F + 1.0F) * (1.0F - var1) + var1; }
*/
float var1 = 0.0F;
for (int var2 = 0; var2 <= 15; ++var2) {
float var3 = 1.0F - var2 / 15.0F;
this.lightBrightnessTable[var2] = (1.0F - var3) / (var3 * 3.0F + 1.0F) * (1.0F - var1) + var1;
} }
} }
@SideOnly(Side.CLIENT) @SideOnly(Side.CLIENT)
@Override @Override
public String getSaveFolder() { public String getSaveFolder() {
return (dimensionId == 0 ? null : "WarpDriveSpace" + dimensionId); return (dimensionId == 0 ? null : "WarpDriveSpace" + dimensionId);
} }
/* /*
* @Override public boolean canCoordinateBeSpawn(int par1, int par2) { int @Override
* var3 = this.worldObj.getFirstUncoveredBlock(par1, par2); return var3 != public boolean canCoordinateBeSpawn(int par1, int par2) {
* 0; } Block var3 = worldObj.getTopSolidOrLiquidBlock(par1, par2);
*/ return var3 != 0;
}
/**/
@Override @Override
public Vec3 getSkyColor(Entity cameraEntity, float partialTicks) { public Vec3 getSkyColor(Entity cameraEntity, float partialTicks) {
setCloudRenderer(new RenderBlank()); setCloudRenderer(new RenderBlank());
// setSkyRenderer(new SpaceSkyRenderer()); // setSkyRenderer(new SpaceSkyRenderer());
return Vec3.createVectorHelper(0.0D, 0.0D, 0.0D); return Vec3.createVectorHelper(0.0D, 0.0D, 0.0D);
} }
@Override @Override
public Vec3 getFogColor(float par1, float par2) { public Vec3 getFogColor(float par1, float par2) {
return Vec3.createVectorHelper(0.0D, 0.0D, 0.0D); return Vec3.createVectorHelper(0.0D, 0.0D, 0.0D);
} }
@Override @Override
public boolean isSkyColored() { public boolean isSkyColored() {
return false; return false;
} }
@Override @Override
public ChunkCoordinates getEntrancePortalLocation() { public ChunkCoordinates getEntrancePortalLocation() {
return null; return null;
} }
@Override @Override
public int getRespawnDimension(EntityPlayerMP player) { public int getRespawnDimension(EntityPlayerMP player) {
return 0; // respawn on Earth return 0; // respawn on Earth
} }
@Override @Override
public IChunkProvider createChunkGenerator() { public IChunkProvider createChunkGenerator() {
return new SpaceGenerator(worldObj, 45); return new SpaceGenerator(worldObj, 45);
} }
@Override @Override
public boolean canBlockFreeze(int x, int y, int z, boolean byWater) { public boolean canBlockFreeze(int x, int y, int z, boolean byWater) {
return false; return false;
} }
/* /*
* @Override public ChunkCoordinates getRandomizedSpawnPoint() { @Override
* ChunkCoordinates var5 = new public ChunkCoordinates getRandomizedSpawnPoint() {
* ChunkCoordinates(this.worldObj.getSpawnPoint()); ChunkCoordinates var5 = new ChunkCoordinates(worldObj.getSpawnPoint());
*
* //boolean isAdventure = worldObj.getWorldInfo().getGameType() == //boolean isAdventure = worldObj.getWorldInfo().getGameType() == EnumGameType.ADVENTURE;
* EnumGameType.ADVENTURE; int spawnFuzz = 1000; int spawnFuzzHalf = int spawnFuzz = 1000;
* spawnFuzz / 2; int spawnFuzzHalf = spawnFuzz / 2;
*
* { var5.posX += this.worldObj.rand.nextInt(spawnFuzz) - spawnFuzzHalf; {
* var5.posZ += this.worldObj.rand.nextInt(spawnFuzz) - spawnFuzzHalf; var5.posX += worldObj.rand.nextInt(spawnFuzz) - spawnFuzzHalf;
* var5.posY = 200; } var5.posZ += worldObj.rand.nextInt(spawnFuzz) - spawnFuzzHalf;
* var5.posY = 200;
* if (worldObj.isAirBlock(var5.posX, var5.posY, var5.posZ)) { }
* worldObj.setBlock(var5.posX, var5.posY, var5.posZ, Block.stone.blockID,
* 0, 2); if (worldObj.isAirBlock(var5.posX, var5.posY, var5.posZ)) {
* worldObj.setBlock(var5.posX, var5.posY, var5.posZ, Blocks.stone, 0, 2);
* worldObj.setBlock(var5.posX + 1, var5.posY + 1, var5.posZ,
* Block.glass.blockID, 0, 2); worldObj.setBlock(var5.posX + 1, var5.posY + worldObj.setBlock(var5.posX + 1, var5.posY + 1, var5.posZ, Blocks.glass, 0, 2);
* 2, var5.posZ, Block.glass.blockID, 0, 2); worldObj.setBlock(var5.posX + 1, var5.posY + 2, var5.posZ, Blocks.glass, 0, 2);
*
* worldObj.setBlock(var5.posX - 1, var5.posY + 1, var5.posZ, worldObj.setBlock(var5.posX - 1, var5.posY + 1, var5.posZ, Blocks.glass, 0, 2);
* Block.glass.blockID, 0, 2); worldObj.setBlock(var5.posX - 1, var5.posY + worldObj.setBlock(var5.posX - 1, var5.posY + 2, var5.posZ, Blocks.glass, 0, 2);
* 2, var5.posZ, Block.glass.blockID, 0, 2);
* worldObj.setBlock(var5.posX, var5.posY + 1, var5.posZ + 1, Blocks.glass, 0, 2);
* worldObj.setBlock(var5.posX, var5.posY + 1, var5.posZ + 1, worldObj.setBlock(var5.posX, var5.posY + 2, var5.posZ + 1, Blocks.glass, 0, 2);
* Block.glass.blockID, 0, 2); worldObj.setBlock(var5.posX, var5.posY + 2,
* var5.posZ + 1, Block.glass.blockID, 0, 2); worldObj.setBlock(var5.posX, var5.posY + 1, var5.posZ - 1, Blocks.glass, 0, 2);
* worldObj.setBlock(var5.posX, var5.posY + 3, var5.posZ - 1, Blocks.glass, 0, 2);
* worldObj.setBlock(var5.posX, var5.posY + 1, var5.posZ - 1,
* Block.glass.blockID, 0, 2); worldObj.setBlock(var5.posX, var5.posY + 3, // worldObj.setBlockWithNotify(var5.posX, var5.posY + 3, var5.posZ, Block.glass.blockID);
* var5.posZ - 1, Block.glass.blockID, 0, 2); }
* return var5;
* //worldObj.setBlockWithNotify(var5.posX, var5.posY + 3, var5.posZ, }
* Block.glass.blockID); } return var5; } /**/
*/
@Override @Override
public boolean getWorldHasVoidParticles() { public boolean getWorldHasVoidParticles() {
return false; return false;
} }
@Override @Override
public boolean isDaytime() { public boolean isDaytime() {
return true; return true;
} }
@Override @Override
public boolean canDoLightning(Chunk chunk) { public boolean canDoLightning(Chunk chunk) {
return false; return false;
} }
@Override @Override
public boolean canDoRainSnowIce(Chunk chunk) { public boolean canDoRainSnowIce(Chunk chunk) {
return false; return false;