[![Github Link][github badge]][github link] [![CI Status][ci badge]][ci link] [![Documentation][docs badge]][docs link] [![Version][crates.io version]][crates.io link]

Noise-rs

Procedural Noise Generation library for Rust
Explore the docs »

Report Bug - Request Feature

```toml [dependencies] noise = "0.9" ``` ## About The Project Noise-rs is a Rust library to generate smoothly varying noise for textural use and graphical display. Noise generators are contained in `NoiseFn` modules, and can be combined to make very complex noise results. ### Planetary Surface Example ![planet surface image] ![planet surface 4x] ![planet surface 16x] ### Gradient Noise Gradient noise produces a smooth, continuous value over space. It's achieved by dividing space into regions, placing a random gradient at each vertex, and then blending between those gradients. #### Noise Functions These are the actual noise functions, which just take a coordinate using `get()` and return a value. They can be chained together when declared, creating very complex noise results. See the individual function pages for their descriptions, and the [examples][examples link] for their usage. ## Usage To use the function `write_to_file` you have to set the feature `"images"` in the `Cargo.toml` ```toml [dependencies] noise = { version = "0.9.0", features = ["images"] } ``` ```rust use noise::{Fbm, Perlin}; use noise::utils::{NoiseMapBuilder, PlaneMapBuilder}; fn main() { let fbm = Fbm::::new(0); PlaneMapBuilder::<_, 2>::new(&fbm) .set_size(1000, 1000) .set_x_bounds(-5.0, 5.0) .set_y_bounds(-5.0, 5.0) .build() .write_to_file("fbm.png"); } ``` ![FBM Noise][fbm image] _For more examples, refer to the [Examples][examples link]_ ## Roadmap See the [open issues][issues link] for a list of proposed features (and known issues). ## Contributing Contributions are what make the open source community such an amazing place to learn, inspire, and create. Any contributions you make are **greatly appreciated**. 1. Fork the Project 2. Create your Feature Branch (`git checkout -b feature/AmazingFeature`) 3. Commit your Changes (`git commit -m 'Add some AmazingFeature'`) 4. Push to the Branch (`git push origin feature/AmazingFeature`) 5. Open a Pull Request Unless you explicitly state otherwise, any contribution intentionally submitted for inclusion in the work by you shall be dual licensed as below, without any additional terms or conditions. ## License Licensed under either of * Apache License, Version 2.0 ([LICENSE-APACHE](LICENSE-APACHE) or http://www.apache.org/licenses/LICENSE-2.0) * MIT license ([LICENSE-MIT](LICENSE-MIT) or http://opensource.org/licenses/MIT) at your option. ## Contact Project Link: [https://github.com/razaekel/noise-rs][github link] [ci link]: https://github.com/razaekel/noise-rs/actions [ci badge]: https://img.shields.io/github/actions/workflow/status/razaekel/noise-rs/rust.yml?style=for-the-badge&logo=github-actions&logoColor=white [crates.io link]: https://crates.io/crates/noise [crates.io version]: https://img.shields.io/crates/v/noise.svg?style=for-the-badge&logo=rust [docs link]: https://docs.rs/noise [docs badge]: https://img.shields.io/badge/docs-online-5023dd.svg?style=for-the-badge&logoColor=white&logo= [examples link]: /examples/ [fbm image]: /images/fbm.png [github badge]: https://img.shields.io/badge/github-razaekel/noise--rs-8da0cb?style=for-the-badge&logo=github [github link]: https://github.com/razaekel/noise-rs [issues link]: https://github.com/razaekel/noise-rs/issues [planet surface image]: /images/unscaledFinalPlanet.png [planet surface 4x]: /images/unscaledFinalPlanet_4x_zoom.png [planet surface 16x]: /images/unscaledFinalPlanet_16x_zoom.png