#bevy #game-engine #png #mesh #load #heightmap #height

bevy_heightmap

Create meshes from heightmap PNGs in the Bevy game engine

6 releases

0.3.0 Dec 1, 2024
0.2.3 Aug 5, 2024
0.2.1 Jul 15, 2024
0.1.0 Jul 15, 2024

#556 in Game dev

Download history 8/week @ 2024-09-25 3/week @ 2024-10-02 2/week @ 2024-10-30 2/week @ 2024-11-06 156/week @ 2024-11-27 180/week @ 2024-12-04 96/week @ 2024-12-11 31/week @ 2024-12-18 32/week @ 2024-12-25 38/week @ 2025-01-01 35/week @ 2025-01-08

143 downloads per month

MIT/Apache

3MB
202 lines

bevy_heightmap

License Crates.io Docs

Load height map PNGs as meshes in bevy.

Height map Generated
example_image example_image

Usage

Create a height map from a value function:

use bevy::prelude::*;
use bevy_heightmap::*;
let heightmap = HeightMap {
  size: UVec2::new(10, 10),
  h: |p: Vec2| ((20. * p.x).sin() + (20. * p.y).sin()) / 2.
};
let mesh: Mesh = heightmap.into();
assert_eq!(mesh.count_vertices(), 4 * 10 * 10);

Load a height map as a mesh from an image (requires .hmp.png extension):

use bevy::prelude::*;
use bevy_heightmap::*;
fn setup(asset_server: Res<AssetServer>) {
    let mesh: Handle<Mesh> = asset_server.load("textures/terrain.hmp.png");
}

Examples

cargo run --example image

Bevy support table

bevy bevy_heightmap
0.15 0.3.0
0.14 0.2.0
0.13 0.1.0

Dependencies

~23–34MB
~563K SLoC