Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/gerhalt/topograft
Inspirational 3-dimensional world generation and visualization with tunable parameters as a three dimensional map rendered with pure Javascript in the browser.
https://github.com/gerhalt/topograft
3d generation javascript procedural-generation terrain terrain-generation three-js threejs webgl worldbuilding
Last synced: about 1 month ago
JSON representation
Inspirational 3-dimensional world generation and visualization with tunable parameters as a three dimensional map rendered with pure Javascript in the browser.
- Host: GitHub
- URL: https://github.com/gerhalt/topograft
- Owner: gerhalt
- Created: 2022-04-25T22:40:07.000Z (almost 3 years ago)
- Default Branch: master
- Last Pushed: 2022-05-30T18:22:22.000Z (over 2 years ago)
- Last Synced: 2024-11-14T03:09:21.209Z (3 months ago)
- Topics: 3d, generation, javascript, procedural-generation, terrain, terrain-generation, three-js, threejs, webgl, worldbuilding
- Language: HTML
- Homepage:
- Size: 7.27 MB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Topograft - Procedural Terrain Generation
data:image/s3,"s3://crabby-images/4a9c7/4a9c7c387a19ee88e9b79bd2ac194e417c6ae9ca" alt="sample terrain"
[Play with the demo here!](https://gerhalt.github.io/topograft)
Inspirational 3-dimensional world generation and visualization with tunable parameters as a three dimensional map rendered with pure Javascript in the browser.
## Procedure
This is a work in progress, but the generation mostly works as follows:
1. We begin with a grid of randomized points.
2. Those points are fed into [Delaunator](https://github.com/mapbox/delaunator), a library for quickly generating [Delaunay triangulations](https://en.wikipedia.org/wiki/Delaunay_triangulation). For our purposes, this connects nearby points.
3. From the triangulation, we build a graph of nodes from each raw point, containing default height information and links to the neighboring nodes. It's all graph traversal from here on out.
4. Feature generation
1. Randomly generate initial parameters. Peak or trough (below sea level), spread, ridge length, etc.
2. Choose an initial starting point. Record its distance from the ridge line (as 0). Add it to our node queue.
3. While the ridge length is less than the desired length, add a neighboring node we haven't seen to our node queue. If we're more than two nodes in, check all neighbors and find the node with the maximum angle between the incoming and outgoing edges. Record these distances as 0.
4. Once we've collected our ridge, begin pulling nodes off the queue. Set the height based on our height falloff function. If the current distance is less than the maximum feature spread, add the neighboring nodes we haven't operated on yet to our queue. Mark their distances as the current distance plus one.