Skip to content

Godot terrain system made with CSG nodes for fast prototyping

License

Notifications You must be signed in to change notification settings

SpockBauru/CSG_Terrain

Repository files navigation

WARNING: This plugin is in beta phase. Only works with Godot 4.4 beta or later.

CSG Terrain

Prototype your terrain faster with the power of curves and CSG nodes.

What is it?

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.

How does it work?

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.

How to install

  1. Download the file CSG_Terrain_0.5-Beta.zip from the Download Page
  2. Extract the addons folder on the root of your project (res://). Other files/folders are optional.
  3. Go to Godot's "Project" menu -> "Project Settings" -> "Plugins" tab -> enable "CSG TErrain".
  4. Place the CSGTerrain node in your scene \o/

The Path workflow

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.

Order matters

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.

Synchronizing neighboring terrains

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

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

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.

Limitations

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.

Future features and how to contribute

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.

About

Godot terrain system made with CSG nodes for fast prototyping

Resources

License

Stars

Watchers

Forks