Crate noise_functions
source ·Expand description
Fast and lightweight noise algorithm implementations.
Check out the live demo!
use noise_functions::{ Perlin, CellDistance, OpenSimplex2s, Sample2, NoiseFn };
let point = [1.0, 2.0];
// perlin noise
let value = Perlin.sample2(point);
// seeded perlin noise
let value = Perlin.seed(42).sample2(point);
// fractal perlin noise
let value = Perlin.fbm(3, 0.5, 3.0).sample2(point);
// seeded fractal perlin noise
let value = Perlin.fbm(3, 0.5, 3.0).seed(42).sample2(point);
// perlin noise with adjusted frequency
let value = Perlin.frequency(3.0).sample2(point);
// cell distance (voronoi) noise
let value = CellDistance.sample2(point);
// cell distance (voronoi) noise with jitter multiplier
let value = CellDistance.jitter(0.5).sample2(point);
// domain warped OpenSimplex2s noise
let warped_noise = |pos: [f32; 2]| {
let warp_x = OpenSimplex2s.seed(1).sample2(pos);
let warp_y = OpenSimplex2s.seed(2).sample2(pos);
let warped = [pos[0] + warp_x, pos[1] + warp_y];
OpenSimplex2s.sample2(warped)
};
let value = warped_noise(point);
The implementation of these noise functions are from FastNoiseLite (github/crate).
§Feature flags
std
(enabled by default) — Uses floating point functions from the standard library.libm
— Useslibm
for floating point functions. Required forno_std
.nightly-simd
— Adds support for sampling with simd types.nightly-const-fn-float
— Makesfbm(_weighted)
andridged(_weighted)
const fn
s.
Modules§
Structs§
- Wraps a function to make it implement
Sample
.
Traits§
- Helper trait that provides
sample2
as a shorthand forSample<2, [f32; 2]>::sample
. - Sample2a
nightly-simd
Helper trait that providessample2a
as a shorthand forSample<2, f32x2>::sample
. - Helper trait that provides
sample3
as a shorthand forSample<3, [f32; 3]>::sample
. - Sample3a
nightly-simd
Helper trait that providessample3a
as a shorthand forSample<3, f32x4>::sample
.