Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nicopap/bevy_mod_paramap
Experimental extensions to bevy's parallax mapping shader
https://github.com/nicopap/bevy_mod_paramap
bevy rust shader
Last synced: 3 months ago
JSON representation
Experimental extensions to bevy's parallax mapping shader
- Host: GitHub
- URL: https://github.com/nicopap/bevy_mod_paramap
- Owner: nicopap
- License: apache-2.0
- Created: 2022-09-09T07:22:03.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-03-06T18:27:06.000Z (almost 2 years ago)
- Last Synced: 2024-10-06T21:05:42.154Z (4 months ago)
- Topics: bevy, rust, shader
- Language: Rust
- Homepage: https://nicopap.github.io/bevy_mod_paramap/
- Size: 5.1 MB
- Stars: 19
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
## Bevy parallax mapping
[parallax mapping] is a graphical effect adding the impression of depth to
simple 2d textures by moving the texture's pixel around according to the
viewport's perspective.This is **NOT** a "parallax" à la Super Mario World. This is intended for 3D
rendering. This technic has been used with success in the Demon's Souls
Bluepoint remake.This crate adds a custom material that extends the default bevy PBR material
with [parallax mapping]. The [`ParallaxMaterial`] asset is a straight copy
of bevy's PBR material with the addition of the `height_map: Handle`
filed (it's not `Option` since you might as well use the default shader if
there is no height maps).`height_map` is a greyscale image representing the height of the object at the
specific pixel.[`ParallaxMaterial`] allows selecting the algorithm used for parallaxing. By
setting the [`algorithm`] field to the [`ParallaxAlgo`] of your choosing, you
may opt into using Relief Mapping. By default, [`ParallaxMaterial`] uses the
Parallax Occlusion Mapping (POM) method. (see the shader source code for
explanation on what the algorithms do)### Examples
This repo contains two examples.
```bash
cargo run --example
```- [`earth3d`]: a spinning view of the earth. Takes advantage of height map,
but also of all the bevy PBR fields. This a good demonstration of bevy's
capabilities.
\
You can orbit the earth by holding down the right mouse button, and zoom
in/out with the mouse wheel.https://user-images.githubusercontent.com/26321040/189361740-1a0876d2-9b39-49f3-a8cb-8837601b5b39.mp4
- [`cube`]: A spinning cube with a parallaxed material in a basic 3d scene,
mouse left click to switch point of view.https://user-images.githubusercontent.com/26321040/189361802-3db6aa98-fa7f-4440-b5a7-20d73a36ac23.mp4
### Bugs and limitations- This doesn't implement silhouetting, so the meshes's silhouette will not
change with the height map
- As a result, height maps that are top-heavy should be favored (tree bark, bricks)
- This doesn't implement self-shadowing, resulting in potentially surprising sharp cutoffs
- self-shadowing is described in the [sunblackcat] article, but bevy's lighting system requires
handling several light types and multiple light sources at once, which is more complex than
I can handle right now.
- The height map is inverted from the more common usage
### LiteratureThe code is basically copied from the [sunblackcat] implementation linked
on Wikipedia.Optimization leads include:
1.
2.
3.
4.
5.Note that (1) says that (2) is slower than POM, while (3) is beyond out-of-scope
for a small opensource crate (unless you want to pay me).### TODO
- [ ] Useability
- [X] bevy-inspector-egui definition (~~behind compile flag~~, now derives `Reflect`)
- [ ] Generic over shader (should be possible to use with a
traditional phong shader)
- [ ] Conversion methods `from_standard(StandardMaterial, height_map)`
- [ ] Automatic `height_map` computation based on a `normal_map` if possible
-
-
-
-
- Search keywords are a bit silly, I found that "invert displacement map from normal map" gave
satisfactory results on ddg.
- [ ] Implement insights from (5)
- The height map does't need to have the same precision as the normal map
- Works better when the height map doesn't have sharp differences
(so blur the input image)
- [ ] Can reduce even further the number of layers (called "steps" in video)
by accounting for distance to position.### Change log
* `0.2.0`: Update bevy dependency to `0.9`
* `0.3.0`: Update bevy dependency to `0.10`### Version Matrix
| bevy | latest supporting version |
|------|--------|
| 0.10 | 0.3.0 |
| 0.9 | 0.2.0 |
| 0.8 | 0.1.0 |## License
Earth images in `assets/earth` are public domain and taken from Wikimedia. I edited them myself, you
are free to re-use the edited version however you want without restrictions.- [height map]: `elevation_water.png` and `elevation_surface.png` adjust the values to highlight
different topological features of earth, the `normal_map.jpg` is also derived from it.
- [albedo] (aka base color) is a scalled-down version of the 2002 Nasa blue marble earth satellite
view using a equirectangular projection. `metallic_roughness.png` and `base_color.jpg` are derived
from that image.
- [emissive texture] is from the 2012 Nasa blue marble project. It's a night time satellite view of
earth.
- An alternative higher-quality height map is available at:
Copyright of code and assets go to their respective authors.
Original code is copyright © 2022 Nicola Papale
This software is licensed under Apache 2.0.
[parallax mapping]: https://en.wikipedia.org/wiki/Parallax_mapping
[parallax occlusion mapping]: https://en.wikipedia.org/wiki/Parallax_occlusion_mapping
[sunblackcat]: https://web.archive.org/web/20150419215321/http://sunandblackcat.com/tipFullView.php?l=eng&topicid=28
[height map]: https://commons.wikimedia.org/wiki/File:Earth_dry_elevation.png
[albedo]: https://commons.wikimedia.org/wiki/File:Blue_Marble_2002_bg21600.png
[emissive texture]: https://commons.wikimedia.org/wiki/File:Composite_map_of_the_world_2012.jpg
[`ParallaxMaterial`]: https://docs.rs/bevy_mod_paramap/0.2.0/bevy_mod_paramap/struct.ParallaxMaterial.html
[`algorithm`]: https://docs.rs/bevy_mod_paramap/0.2.0/bevy_mod_paramap/struct.ParallaxMaterial.html#algorithm
[`ParallaxAlgo`]: https://docs.rs/bevy_mod_paramap/0.2.0/bevy_mod_paramap/enum.ParallaxAlgo.html
[`cube`]: https://github.com/nicopap/bevy_mod_paramap/blob/main/examples/cube.rs
[`earth3d`]: https://github.com/nicopap/bevy_mod_paramap/blob/main/examples/earth3d.rs