Prototype your terrain faster with the power of curves and CSG nodes.
This is a plugin for Godot Engine to prototype terrains on a simple and non destructive way. It's made with CSG (Constructive Solid Geometry), so you are supposed to combine with geometric shapes and even other terrains to achieve the desired form. Read more about CSG.
Unlike other systems the terrain is molded purely with paths, not brushes or other 3D tools. This forced simplicity allows to focus on what is important before finalizing in 3D software.
CSG Terrain is based on 3D meshes that can be baked to make compatible with Godot's Baked Global Illumination (LightmapGI) and can be exported to 3D softwares such as Blender.
When placing a CSG Terrain node, it will also place a Path3D in the middle and the terrain will follow it.
This is the basic idea: You place paths, and the terrain follows.
You can place several Path3D nodes as needed.
- Download the file
CSG_Terrain_0.5-Beta.zip
from the Download Page - Extract the
addons
folder on the root of your project (res://
). Other files/folders are optional. - Go to Godot's "Project" menu -> "Project Settings" -> "Plugins" tab -> enable "CSG TErrain".
- Place the CSGTerrain node in your scene \o/
The terrain follows the line between the points of the path. Because of that each path needs at least 2 points to work.
When creating a new Path3D as child of the CSG Terrain node, the path node will contain various extra parameters:
Width: The number of terrain vertices affected on each side of the curve. The value 2 will affect 2 vertices on each side, the number 0 will not affect the terrain.
Smoothness: Amount of curvature around the path. Value 1 will smoothly lower the curve. Zero will create a flat slope with the height of the curve.
Paint Width: How many pixels around the path that will be painted bellow the curve. You can choose the texture in the Terrain Material.
Paint Smoothness: How much the path texture will blend with the terrain. Zero will cause blockness and high values will make the texture thinner.
Similar to canvas items, paths that are childs of the CSG Terrain node will be applied one on top of each other following the order in the scene tree.
The first child will be drown on bottom and the last will be drown on top.
You can change the order at will.
If you duplicate an Path3D with Control+D and move to a new CSG Terrain node, both curves will be synchronized.
Note: To avoid conflics, make sure that both terrains have the same Size and Divs, which are explained on the next section.
The CSG Terrain node comes with several parameters:
Size: The size of each side of the terrain. Terrains will always be squared. Smaller terrains will have higher vertex density and vice versa.
Divs: The number of faces on each side of the terrain. Higher values will cause slowdown and are not recommended. Place several smaller terrains instead.
Path Mask Resolution: The resolution of the mask applied to the path texture. Only change if the path texture is not merging accordingly.
Bake Terrain Mesh: Create a MeshInstance3D without the bottom cube. It will be placed below the CSG Terrain node. This step is necessary in order to be compatible with Godot's Baked Global Illumination (LightmapGI).
Export Terrain File: Save the mesh without the bottom cube to a glTF file so it can be edited in 3D software.
The terrain material is located on the CSG node, in CSGMesh section.
It's composed of 3 materials: Ground, Walls and Path.
For each one you can change the material properties and the textures for Albedo, Normal Map and Roughness Map (Rough Map) similar to Godot's StandardMaterial3D counterparts.
The Shader Parameter Wall Underlay set how the wall will be merged with the ground. Zero means no wall will be applied. High values will make the transition sharper.
The terrain material aims to be simple and serves as base for users make their own terrain material. In the final product it's recommended to polish this shader and make optimizations such as channel packing.
CSG Terrain is not designed to work with a high number of divs. Instead, consider placing several several smaller terrains.
Too many or too large paths can decrease performance in the editor. Simple optimization ideas are welcomed as explained on the next section.
CSG Terrain is designed to be as simple as possible. Because of that no new features are planned in order to avoid feature creep.
The code aims to be readable and beginner friendly. Users are encoraged to change and expand the code in their end, but this repository must be kept neat and tidy.
Contributions to make the code simpler, more readable and bugfixes are welcomed. Optimizations must be easy to understand even for beginner/intermediate users, example: Advanced features like compute shaders would greatly benefits the plugin speed, but will be kept out of the code in order to keep it accessible.