Drew DeVault 6517738949 Improve terrain generation
- Enforced coding style
- Improved perlin constants
- Improved biome constants
- Spawn plants before trees so plants may grow underneath
- Fixed areas that were not deterministic
2015-04-26 18:08:56 -06:00

95 lines
2.9 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using TrueCraft.API.World;
using TrueCraft.API;
using TrueCraft.Core.TerrainGen.Noise;
namespace TrueCraft.Core.World
{
public class BiomeMap : IBiomeMap
{
public IList<BiomeCell> BiomeCells { get; private set; }
Perlin TempNoise = new Perlin();
Perlin RainNoise = new Perlin();
public BiomeMap(int seed)
{
BiomeCells = new List<BiomeCell>();
TempNoise.Persistance = 1.45;
TempNoise.Frequency = 0.015;
TempNoise.Amplitude = 5;
TempNoise.Octaves = 2;
TempNoise.Lacunarity = 1.3;
RainNoise.Frequency = 0.03;
RainNoise.Octaves = 2;
RainNoise.Amplitude = 5;
RainNoise.Lacunarity = 1.7;
TempNoise.Seed = seed;
RainNoise.Seed = seed;
}
public void AddCell(BiomeCell cell)
{
BiomeCells.Add(cell);
}
public byte GetBiome(Coordinates2D location)
{
byte BiomeID = (ClosestCell(location) != null) ? ClosestCell(location).BiomeID : (byte)Biome.Plains;
return BiomeID;
}
public byte GenerateBiome(int seed, IBiomeRepository biomes, Coordinates2D location)
{
double temp = Math.Abs(TempNoise.Value2D(location.X, location.Z));
double rainfall = Math.Abs(RainNoise.Value2D(location.X, location.Z));
byte ID = biomes.GetBiome(temp, rainfall).ID;
return ID;
}
/*
* The closest biome cell to the specified location(uses the Chebyshev distance function).
*/
public BiomeCell ClosestCell(Coordinates2D location)
{
BiomeCell cell = null;
var distance = double.MaxValue;
foreach (BiomeCell C in BiomeCells)
{
var _distance = Distance(location, C.CellPoint);
if (_distance < distance)
{
distance = _distance;
cell = C;
}
}
return cell;
}
/*
* The distance to the closest biome cell point to the specified location(uses the Chebyshev distance function).
*/
public double ClosestCellPoint(Coordinates2D location)
{
var distance = double.MaxValue;
foreach (BiomeCell C in BiomeCells)
{
var _distance = Distance(location, C.CellPoint);
if (_distance < distance)
{
distance = _distance;
}
}
return distance;
}
public double Distance(Coordinates2D a, Coordinates2D b)
{
Coordinates2D diff = a - b;
return Math.Max(Math.Abs(diff.X), Math.Abs(diff.Z));
}
}
}