use std::ops::{Add, Mul, Sub}; use vek::*; use veloren_world::{util::Sampler, World}; const W: usize = 640; const H: usize = 480; fn main() { let world = World::generate(0); let sampler = world.sample_columns(); let mut win = minifb::Window::new("World Viewer", W, H, minifb::WindowOptions::default()).unwrap(); let mut focus = Vec2::zero(); let mut gain = 1.0; let mut scale = 4; while win.is_open() { let mut buf = vec![0; W * H]; for i in 0..W { for j in 0..H { let pos = focus + Vec2::new(i as i32, j as i32) * scale; let (alt, location) = sampler .get(pos) .map(|sample| ( sample.alt.sub(64.0).add(gain).mul(0.7).max(0.0).min(255.0) as u8, sample.location, )) .unwrap_or((0, None)); let loc_color = location.map(|l| ( l.name().bytes().nth(0).unwrap() * 17, l.name().bytes().nth(1).unwrap() * 17, )).unwrap_or((0, 0)); buf[j * W + i] = u32::from_le_bytes([loc_color.0, loc_color.1, alt, alt]); } } let spd = 32; if win.is_key_down(minifb::Key::W) { focus.y -= spd * scale; } if win.is_key_down(minifb::Key::A) { focus.x -= spd * scale; } if win.is_key_down(minifb::Key::S) { focus.y += spd * scale; } if win.is_key_down(minifb::Key::D) { focus.x += spd * scale; } if win.is_key_down(minifb::Key::Q) { gain += 10.0; } if win.is_key_down(minifb::Key::E) { gain -= 10.0; } if win.is_key_down(minifb::Key::R) { scale += 1; } if win.is_key_down(minifb::Key::F) { scale -= 1; } win.update_with_buffer(&buf).unwrap(); } }