-
Notifications
You must be signed in to change notification settings - Fork 59
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #162 from BenjaTK/docs
Add HeightmapGenerator tutorial
- Loading branch information
Showing
13 changed files
with
77 additions
and
3 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,68 @@ | ||
# Side-view terrain with HeightmapGenerator2D/3D | ||
|
||
The HeightmapGenerator2D is a bit more complicated than the WalkerGenerator. You'll need to use some different modifiers to recreate the terrain of games like Terraria. Here's how: | ||
|
||
## The nodes | ||
|
||
The setup is similar to the one at [Getting Started](../tutorials/getting_started.md) | ||
|
||
data:image/s3,"s3://crabby-images/53e13/53e134cf3e43c9e084676859e2908b8aa3330e24" alt="A HeightmapGenerator2D node, a TileMapLayer and a TilemapGaeaRenderer" | ||
|
||
Assign each node's required nodes. | ||
|
||
## The settings | ||
|
||
Add a settings resource. Start by setting `tile` to a `TilemapTileInfo` (or whatever you'd like to use). Then, set `noise` to a `FastNoiseLite` resource. I recommend setting `noise_type` to **Perlin**. | ||
|
||
After that, you can modify the terrain with the following properties: | ||
|
||
- `world_length`: pretty self-explanatory, changes the width of your world. | ||
- `height_offset`: it's the "medium" height of your terrain. | ||
- `height_intensity`: at each column, the terrain's height is set to `height_offset` plus a random value between -`height_intensity` and `height_intensity`. So for example, in the next image's configuration, the minimum height a terrain can reach is 135 and the max is 185. | ||
- `min_height`: by default, the terrain will start at y=0. You can change that with this property. | ||
|
||
data:image/s3,"s3://crabby-images/9fd95/9fd95f1b1ceba3594f1cae3fab4ba80c86c8b9f2" alt="Settings resource" | ||
|
||
Click generate, and it should look something like this: | ||
|
||
data:image/s3,"s3://crabby-images/320d8/320d82b2d2b5c85b20cec006b8bf47004341d945" alt="Initial generation with just dirt" | ||
|
||
This is just the base though. Let's add more tiles: | ||
|
||
## Modifiers | ||
|
||
Add a new modifier to the `modifiers` list. It's going to be a `HeightmapPainter`: | ||
|
||
data:image/s3,"s3://crabby-images/8582a/8582acccbdf71b411f3b8b1053f3d05bcdc68073" alt="HeightmapPainter without configuration" | ||
|
||
What this one does is paint over the base using the same way of generating terrain. Let's set it's `height_offset` to something slightly below the generator's `height_offset`, and it's `height_intensity` to the same. Now, set `tile` to, for example, a stone tile. Click generate again. | ||
|
||
data:image/s3,"s3://crabby-images/91d85/91d855a88d85b2886ae2bce1e546479619b62341" alt="Similar terrain as before but with a stone layer" | ||
|
||
Look at how the stone generates following the terrain's shape! You can use this method to add different terrain layers. But the terrain's looking kind of boring underground. Let's add some caves: | ||
|
||
To add caves, use the `Carver` modifier to, well, carve the terrain! Set it's threshold values until the preview resembles caves (I recommend using the **Simplex** `noise_type` for this one) | ||
|
||
data:image/s3,"s3://crabby-images/becc5/becc5f99955f97fd77f8a08474a1e44eb7eb7827" alt="Carver node with threshold min/max set to about -0.4 and -0.1" | ||
|
||
data:image/s3,"s3://crabby-images/88c7c/88c7ce149a6badc8c4b46d8abf45b9e7dd5e3b77" alt="Caves" | ||
|
||
**_VOILÀ!_**. The world is full of caves now. Maybe you don't want the `Carver` to remove dirt tiles though, so set it's filtering properties to something like this: | ||
|
||
data:image/s3,"s3://crabby-images/0e566/0e5669e3cfb85177c3acf952599c377c13f48bf8" alt="Filtering" | ||
|
||
"ground" in the `IDs` list should be the id of the TileInfo you don't want it to remove: | ||
|
||
data:image/s3,"s3://crabby-images/1bd0f/1bd0fbc97ca4ead21dbe8f374923e5fd7fff8db7" alt="A TileInfo of id "ground", which is the base TileInfo we created before." | ||
|
||
`layers` can be left empty. This means it'll check on every layer for the filtering options. | ||
|
||
Since `type` is set to **Blacklist**, it will NOT apply this modifier in any tiles of ID "ground" (or whatever you set). See? | ||
|
||
data:image/s3,"s3://crabby-images/634de/634de1cd40515d3088ea287356e1d472467b64ee" alt="No dirt deleted by caves in this case" | ||
|
||
You can use filters for all kind of things like this. For example, we can add a `NoisePainter` modifier and set it to only apply to stone tiles, and then use it to place ores around. | ||
|
||
## And it's done! | ||
|
||
You have very basic, but easy to expand, terrain generation. 3D works basically the same (though you can use a `GridMap` instead), so give it a try! `HeightmapGenerator`s also work with chunk generation, so check out the [chunk generation tutorial](chunk_generation.md). |