First, I added a plane that was deformed by sin(x)sin(z) to give it some bumps. Then I added fbm to give it some ridges. I learned this from iq's raymarching terrain blogpost.
From there, I used fbm to alter the terrain more. Also adding noise to the color.
Then I added two more layers of color and animated them.
toolbox functions used:
- gain
- bias
- ease_out_quadratic
Practice using raymarching, SDFs, and toolbox functions to sculpt a beautiful 3d landscape.
- Starting with the base code, create a ray marcher that can accurately render 3d shapes. We recommend testing with a sphere at the center of your canvas
- Add normal computation to properly shade your geometry. Start with lambert shading
- Add basic raymarching optimizations: use sphere-tracing, limit the number of maximum steps to avoid infinite loop
Using what you've learned about toolbox functions and sdfs:
- Create a noise-based terrain with height-based coloration that suggests at least 3 distinct terrain features (for example, the lowest portions of your terrain can be water and the highest, white-colored icecaps.). Feel free to get creative and do a non-realistic or stylized scene.
- You must use at least 3 different toolbox functions, such as bias/gain or a wave function. At this point we expect you to be comfy using such functions to modify shape.
- Create a backdrop / sky where there is no terrain. For example, an interesting gradient with some kind of noise.
- Using the 3-point lighting system (fill light, key light, and fake global illumination light), light your scene to bring it to life.
Add some element of animation to your scene that ISN'T just changing terrain height. (Been there done that with the fireball!)
Suggestions:
- Animate the position of your lighting / sun to simulate a change in time of day. We recommend the sky change color in step with your lighting change.
- Animate the thresholds for different terrain features, to suggest rising tides, or melting ice-caps, or a seasonal change in foliage color.
- If you elect to add clouds, animate the cloud positions to suggest wind.
- Additional scene elements eg. a building or animal or trees. [easy-hard, depends]
- Sculpting with sdfs can be fiddly, so trying to model something very precise may be frustrating. We suggest keeping it simple
- If your models get heavy you may also need to add acceleration structures *bonus points!
- Add 3d translucent clouds to your sky. [hard, it will be fiddly and slow your program down A LOT]
- Add camera animation to create a fly-over effect [???]
- Depending on how you set up your scene, this may be a pretty involved change because the terrain will have to look good EVERYWHERE not just at a fixed angle. #proceduralLessons).
- Update README.md to contain a solid description of your project
- Publish your project to gh-pages.
npm run deploy
. It should now be visible at http://username.github.io/repo-name - Create a pull request to this repository, and in the comment, include a link to your published project.
- Submit the link to your pull request on Canvas.