mirror of
https://github.com/Noratrieb/game-wip-dontplay.git
synced 2026-01-16 20:35:02 +01:00
Add very crude proof-of-concept worldgen
This commit is contained in:
parent
314d2eafa0
commit
930f7aac47
7 changed files with 109 additions and 27 deletions
76
src/worldgen.rs
Normal file
76
src/worldgen.rs
Normal file
|
|
@ -0,0 +1,76 @@
|
|||
use rand::{thread_rng, Rng};
|
||||
use worldgen::{
|
||||
constraint,
|
||||
noise::perlin::PerlinNoise,
|
||||
noisemap::{NoiseMap, NoiseMapGenerator, Seed, Step},
|
||||
world::{
|
||||
tile::{Constraint, ConstraintType},
|
||||
Size, Tile, World,
|
||||
},
|
||||
};
|
||||
|
||||
use crate::world::{ChunkPos, Tile as Tl, CHUNK_EXTENT};
|
||||
|
||||
pub struct Worldgen {
|
||||
world: World<crate::world::Tile>,
|
||||
}
|
||||
|
||||
impl Default for Worldgen {
|
||||
fn default() -> Self {
|
||||
let noise = PerlinNoise::new();
|
||||
let mut rng = thread_rng();
|
||||
|
||||
let nm1 = NoiseMap::new(noise)
|
||||
.set(Seed::of(rng.gen::<i64>()))
|
||||
.set(Step::of(0.005, 0.005));
|
||||
|
||||
let nm2 = NoiseMap::new(noise)
|
||||
.set(Seed::of(rng.gen::<i64>()))
|
||||
.set(Step::of(0.05, 0.05));
|
||||
|
||||
let nm = Box::new(nm1 + nm2 * 3);
|
||||
|
||||
let world = World::new()
|
||||
.set(Size::of(CHUNK_EXTENT as i64, CHUNK_EXTENT as i64))
|
||||
// Dirt coal
|
||||
.add(
|
||||
Tile::new(Tl {
|
||||
bg: 9,
|
||||
mid: 2,
|
||||
fg: 6,
|
||||
})
|
||||
.when(constraint!(nm.clone(), < -0.8)),
|
||||
)
|
||||
// Dirt
|
||||
.add(
|
||||
Tile::new(Tl {
|
||||
bg: 9,
|
||||
mid: 2,
|
||||
fg: 0,
|
||||
})
|
||||
.when(constraint!(nm.clone(), < -0.1)),
|
||||
)
|
||||
// Stone
|
||||
.add(
|
||||
Tile::new(Tl {
|
||||
bg: 7,
|
||||
mid: 1,
|
||||
fg: 0,
|
||||
})
|
||||
.when(constraint!(nm.clone(), < 0.45)),
|
||||
)
|
||||
// Dirt wall
|
||||
.add(Tile::new(Tl {
|
||||
bg: 9,
|
||||
mid: 0,
|
||||
fg: 0,
|
||||
}));
|
||||
Self { world }
|
||||
}
|
||||
}
|
||||
|
||||
impl Worldgen {
|
||||
pub fn chunk_noise(&self, pos: ChunkPos) -> Vec<Vec<Tl>> {
|
||||
self.world.generate(pos.x as i64, pos.y as i64).unwrap()
|
||||
}
|
||||
}
|
||||
Loading…
Add table
Add a link
Reference in a new issue