1 unstable release
0.1.0 | Sep 29, 2021 |
---|
#6 in #heightmap
8KB
72 lines
height-mesh
A small crate to generate a 3D mesh from a 2D heightmap.
use height_mesh::ndshape::{ConstShape, ConstShape2u32};
use height_mesh::{height_mesh, HeightMeshBuffer};
// A 64^2 chunk with 1-voxel boundary padding.
type ChunkShape = ConstShape2u32<66, 66>;
// This chunk will cover just a single quadrant of a parabola.
let mut sdf = [1.0; ChunkShape::SIZE as usize];
for i in 0u32..ChunkShape::SIZE {
let [x, y] = ChunkShape::delinearize(i);
sdf[i as usize] = ((x * x + y * y) as f32).sqrt();
}
let mut buffer = HeightMeshBuffer::default();
height_mesh(&sdf, &ChunkShape {}, [0; 2], [65; 2], &mut buffer);
// Some triangles were generated.
assert!(!buffer.indices.is_empty());
License: MIT OR Apache-2.0
lib.rs
:
A small crate to generate a 3D mesh from a 2D heightmap.
use height_mesh::ndshape::{ConstShape, ConstShape2u32};
use height_mesh::{height_mesh, HeightMeshBuffer};
// A 64^2 chunk with 1-voxel boundary padding.
type ChunkShape = ConstShape2u32<66, 66>;
// This chunk will cover just a single quadrant of a parabola.
let mut sdf = [1.0; ChunkShape::SIZE as usize];
for i in 0u32..ChunkShape::SIZE {
let [x, y] = ChunkShape::delinearize(i);
sdf[i as usize] = ((x * x + y * y) as f32).sqrt();
}
let mut buffer = HeightMeshBuffer::default();
height_mesh(&sdf, &ChunkShape {}, [0; 2], [65; 2], &mut buffer);
// Some triangles were generated.
assert!(!buffer.indices.is_empty());
Dependencies
~74KB