mirror of
https://gitlab.com/veloren/veloren.git
synced 2024-08-30 18:12:32 +00:00
8ae2692b6e
Currently we only do this when no players are in range of the chunk. We also send the first client who posted the chunk a message indicating that it's canceled, the hope being that this will be a performance win in single player mode since you don't have to wait three seconds to realize that the server won't generate the chunk for you. We now check an atomic flag for every column sample in a chunk. We could probably do this less frequently, but since it's a relaxed load it has essentially no performance impact on Intel architectures.
41 lines
1.0 KiB
Rust
41 lines
1.0 KiB
Rust
use noise::{Seedable, SuperSimplex};
|
|
|
|
use vek::*;
|
|
|
|
const W: usize = 640;
|
|
const H: usize = 640;
|
|
|
|
fn main() {
|
|
let mut win = minifb::Window::new("Turb", W, H, minifb::WindowOptions::default()).unwrap();
|
|
|
|
let _nz_x = SuperSimplex::new().set_seed(0);
|
|
let _nz_y = SuperSimplex::new().set_seed(1);
|
|
|
|
let mut time = 0.0f64;
|
|
while win.is_open() {
|
|
let mut buf = vec![0; W * H];
|
|
|
|
for i in 0..W {
|
|
for j in 0..H {
|
|
let pos = Vec2::new(i as f64 / W as f64, j as f64 / H as f64) * 0.5 - 0.25;
|
|
|
|
let pos = pos * 10.0;
|
|
|
|
let pos = (0..10).fold(pos, |pos, _| pos.map(|e| e.powf(3.0) - 1.0));
|
|
|
|
let val = if pos.map(|e| e.abs() < 0.5).reduce_and() {
|
|
1.0f32
|
|
} else {
|
|
0.0
|
|
};
|
|
|
|
buf[j * W + i] = u32::from_le_bytes([(val.max(0.0).min(1.0) * 255.0) as u8; 4]);
|
|
}
|
|
}
|
|
|
|
win.update_with_buffer(&buf).unwrap();
|
|
|
|
time += 1.0 / 60.0;
|
|
}
|
|
}
|