19 KiB
Changelog
This is a high-level list of features, changes and fixes that have been made over time.
At the moment, this module doesn't have a distinct release schedule, so this changelog follows Godot's version numbers and binary releases. Almost each version mentionned here should have an associated Git branch (for THIS repo, not Godot's) containing features at the time of the version. Backports aren't done so far.
Semver is not yet in place, so each version can have breaking changes, although it shouldn't happen often across minor versions.
1.x - Ongoing development - master
Godot 4 is required from this version.
-
General
- Added
gi_mode
to terrain nodes to choose how they behave with Godot's global illumination - Added
FastNoise2
for faster SIMD noise - Added experimental support functions to help setting up basic multiplayer with
VoxelTerrain
(might change in the future) VoxelGeneratorGraph
: added support for outputting to the TYPE channel, allowing use withVoxelMesherBlocky
VoxelGeneratorGraph
: editor: unconnected inputs show their default value directly on the nodeVoxelGeneratorGraph
: editor: allow to change the axes on preview nodes 3D slices
- Added
-
Smooth voxels
VoxelLodTerrain
: added experimentalfull_load_mode
, in which all edited data is loaded at once, allowing any area to be edited anytime. Useful for some fixed-size volumes.VoxelToolLodTerrain
: added experimentaldo_sphere_async
, an alternative version ofdo_sphere
which defers the task on threads to reduce stutter if the affected area is big.VoxelInstancer
: Allow to dump VoxelInstancer as scene for debug inspectionVoxelInstancer
: Editor: instance chunks are shown when the node is selectedVoxelInstanceLibraryMultiMeshItem
: Support setting up mesh LODs from a scene with nameLODx
suffixes
-
Fixes
VoxelBuffer
: frequently creating buffers with always different sizes no longer wastes memoryVoxel
: properties of the inspector were not refreshed when changinggeometry_type
VoxelGeneratorGraph
: editor: fix inspector starting to throw errors after deleting a node, as it is still inspecting itVoxelGeneratorGraph
: fixed Image2D node not accepting image formats L8 and LA8VoxelTerrain
: fixedCondition "mesh_block == nullptr" is true
which could happen in some conditionsVoxelTool
:raycast
locking up if you send a Vector3 containing NaNVoxelInstancer
: fix instances not refreshing when an item is modified and the mesh block size is 32VoxelInstancer
: fix crash when removing an item from the library while an instancer node is using itVoxelToolTerrain
:run_blocky_random_tick
no longer snaps area borders to chunk borders in unintuitive waysVoxelStreamScript
: fix voxel data not getting retrieved whenBLOCK_FOUND
is returned
-
Breaking changes
- Some functions now take
Vector3i
instead ofVector3
. If you used to sendVector3
withoutfloor()
orround()
, it can have side-effects in negative coordinates. VoxelLodTerrain
:set_process_mode
andget_process_mode
were renamedset_process_callback
andget_process_callback
(due to a name conflict)VoxelMesherTransvoxel
: Shader API: The data inCOLOR
andUV
was moved respectively toCUSTOM0
andCUSTOM1
(old attributes no longer work for this use case)Voxel
was renamedVoxelBlockyModel
VoxelLibrary
was renamedVoxelBlockyLibrary
VoxelVoxImporter
was renamedVoxelVoxSceneImporter
VoxelInstanceLibraryItem
was renamedVoxelInstanceLibraryMultiMeshItem
VoxelInstanceLibraryItemBase
was renamedVoxelInstanceLibraryItem
VoxelStream
: renamedemerge_block
=>load_voxel_block
VoxelStream
: renamedimmerge_block
=>save_voxel_block
VoxelStreamScript
: renamed_emerge_block
=>_load_voxel_block
VoxelStreamScript
: renamed_immerge_block
=>_save_voxel_block
VoxelGeneratorGraph
: theSelect
node'sthresdold
port is now a parameter instead.
- Some functions now take
-
Known issues
- Some nodes and resources no longer start with predefined properties due to a warning introduced in Godot4 when properties are resources.
- SDFGI does not work all the time and can only be forced to update by moving away and coming back, pre-generating the terrain, or toggling it off and on. This is a limitation of Godot not supporting well meshes created dynamically.
- Moving fast near a terrain with mesh size 16 can cause more noticeable slowdowns compared to Godot3. This is because Godot's Vulkan allocator is much slower to free mesh buffers. A mitigation is in place to smooth the slowdown but it is not avoidable.
0.5.x - Legacy Godot 3 branch - godot3.x
This branch is the last supporting Godot 3
-
Smooth voxels
VoxelLodTerrain
: added experimentalfull_load_mode
, in which all edited data is loaded at once, allowing any area to be edited anytime. Useful for some fixed-size volumes.VoxelToolLodTerrain
: added experimentaldo_sphere_async
, an alternative version ofdo_sphere
which defers the task on threads to reduce stutter if the affected area is big.VoxelInstanceLibraryItem
: Support setting up mesh LODs from a scene with nameLODx
suffixes
-
Fixes
VoxelBuffer
: frequently creating buffers with always different sizes no longer wastes memoryVoxel
: properties were not refreshed when changinggeometry_type
VoxelGeneratorGraph
: fixed Image2D node not accepting image formats L8 and LA8VoxelTerrain
: fixedCondition "mesh_block == nullptr" is true
which could happen in some conditionsVoxelTool
:raycast
locking up if you send a Vector3 containing NaNVoxelInstancer
: fix instances not refreshing when an item is modified and the mesh block size is 32VoxelInstancer
: fix crash when removing an item from the library while an instancer node is using itVoxelStreamScript
: fix voxel data not getting retrieved whenBLOCK_FOUND
is returned- Terrain was not visible if a room/portals system was used. For now it is not culled by rooms.
0.5 - 06/11/2021 - godot3.4
-
General
VoxelTerrain
: addedget_data_block_size()
VoxelToolTerrain
: addedfor_each_voxel_metadata_in_area()
to quickly find all metadata in a boxFastNoiseLiteGradient
: exposed missing warp functions- Added property to terrain nodes to configure collision margin
- Thread count is automatically determined from the number of concurrent threads the CPU supports
- Added project settings to configure thread count
- Added third-party licenses to the About Window in the editor
-
Blocky voxels
- Added *.vox importers to import MagicaVoxel files as scenes or meshes
-
Smooth voxels
VoxelMesherTransvoxel
: Initial support for texturing data in voxels, using 4-bit indices and weightsVoxelMesherTransvoxel
: optimized hot path, making it about 20% fasterVoxelMesherTransvoxel
: added option to simplify meshes using MeshOptimizerVoxelToolLodTerrain
: addedcopy
functionVoxelToolLodTerrain
: addedget_voxel_f_interpolated
function, useful to obtain interpolated SDFVoxelToolLodTerrain
: added a function to separate floating chunks as rigid-bodies in a specified regionVoxelInstanceGenerator
: added extra option to emit from faces more precisely, especially when meshes got simplified (slower than the other options)VoxelInstancer
: added menu to setup a multimesh item from a scene (similarly to GridMap), which also allows to set up collidersVoxelInstancer
: added initial support for instancing regular scenes (slower than multimeshes)VoxelInstancer
: added option to turn off random rotationVoxelInstanceLibrary
: moved menu to add/remove/update items to the inspector, instead of the 3D editor toolbar
-
Breaking changes
VoxelBuffer
: channelsDATA3
andDATA4
were renamedINDICES
andWEIGHTS
VoxelInstanceGenerator
:EMIT_FROM_FACES
got renamedEMIT_FROM_FACES_FAST
.EMIT_FROM_FACES
still exists but is a different algorithm.VoxelServer
:get_stats()
format has changed, check documentationVoxelLodTerrain
:get_statistics()
format has changed:time_process_update_responses
andremaining_main_thread_blocks
are no longer availableVoxelLodTerrain
: Maximum LOD count was decreased to 24, which is still largely enough. Higher maximums were likely to cause integer overflows.VoxelTerrain
:get_statistics()
format has changed:time_process_update_responses
andremaining_main_thread_blocks
are no longer availableVoxelViewer
:requires_collisions
is nowtrue
by default
-
Fixes
VoxelGeneratorGraph
: changes to node properties are now saved properlyVoxelGeneratorGraph
: fix some per-thread memory not freed on exitVoxelGeneratorGraph
:debug_analyze_range
was crashing when given a negative-size areaVoxelBuffer
:copy_voxel_metadata_in_area
was checking the source box incorrectlyVoxelBuffer
: multiple calls tocreate()
with different sizes could lead to heap corruption if a channel was not uniformVoxelBuffer
:copy_channel_from_area
could lead to heap corruption if the source and destination had the same size and were copied entirelyVoxelMesherTransvoxel
: no longer crashes when the input buffer is not cubicVoxelLodTerrain
: fixed errors and crashes when editing voxels near loading bordersVoxelLodTerrain
: fixed crash occurring after a few edits when LOD count is set to 1VoxelLodTerrain
: fixed crash whenrun stream in editor
is turned off while the terrain is loading in editorVoxelTool
channel no longer defaults to 7 when usingget_voxel_tool
from a terrain with a stream assigned. Instead it picks first used channel of the mesher (fallback order is mesher, then generator, then stream).VoxelInstancer
: fixed error when node visibility changesVoxelInstancer
: fixed no instances generated when density is 1 in vertex emission modeVoxelInstanceLibraryItem
: fixed collision shapes setup in editor not being savedVoxelInstanceLibrarySceneItem
: fixed associated scene not being savedVoxelTerrain
: fixed materials shown under the wrong inspector categoryVoxelStreamRegionFiles
: fixed errors caused by meta file being sometimes written with wrong depth valuesVoxelStreamBlockFiles
: fixed warning about channels always shown in the scene treeVoxelStreamSQLite
: fixed blocks above LOD0 being saved at wrong locations, causing them to be reloaded often floating in the air- Fix some crashes occurring when all PoolVector allocs are in use (Godot 3.x limitation). It will print errors instead, but crashes can still occur inside Godot's code as it's not often checking for this
- Fix some crashes occurring when negative sizes are sent to AABB function parameters
0.4 - 09/05/2021 - godot3.3
-
General
- Introduction of
VoxelServer
, which shares threaded tasks among all voxel nodes - Voxel data is no longer copied when sent to processing threads, reducing high memory spikes in some scenarios
- Added a utility class to load
.vox
files created with MagicaVoxel (scripts only) - Voxel nodes can be moved, scaled and rotated
- Voxel nodes can be limited to specific bounds, rather than being infinitely paging volumes (multiples of block size).
- Meshers are now resources so you can choose and configure them per terrain
- Added FastNoiseLite for a wider variety of noises
- Generators are no longer limited to a single background thread
- Added
VoxelStreamSQLite
, allowing to save volumes as a single SQLite database - Implemented
copy
andpaste
forVoxelToolTerrain
- Added ability to double block size used for meshes and instancing, improving rendering speed at the cost of slower modification
- Added collision layer and mask properties
- Introduction of
-
Editor
- Streaming/LOD can be set to follow the editor camera instead of being centered on world origin. Use with caution, fast big movements and zooms can cause lag
- The amount of pending background tasks is now indicated when the node is selected
- Added About window
-
Smooth voxels
- Shaders now have access to the transform of each block, useful for triplanar mapping on moving volumes
- Transvoxel runs faster (almost x2 speedup)
- The SDF channel is now 16-bit by default instead of 8-bit, which reduces terracing in big terrains
- Optimized
VoxelGeneratorGraph
by making it detect empty blocks more accurately and process by buffers VoxelGeneratorGraph
now exposes performance tuning parameters- Added
SdfSphereHeightmap
andNormalize
nodes to voxel graph, which can help making planets - Added
SdfSmoothUnion
andSdfSmoothSubtract
nodes to voxel graph - Added
VoxelInstancer
to instantiate items on top ofVoxelLodTerrain
, aimed at spawning natural elements such as rocks and foliage - Implemented
VoxelToolLodterrain.raycast()
- Added experimental API for LOD fading, with some limitations.
-
Blocky voxels
- Introduced a second blocky mesher dedicated to colored cubes, with greedy meshing and palette support
- Replaced
transparent
property withtransparency_index
for more control on the culling of transparent faces - The TYPE channel is now 16-bit by default instead of 8-bit, allowing to store up to 65,536 types (part of this channel might actually be used to store rotation in the future)
- Added normalmaps support
VoxelRaycastResult
now also contains hit distance, so it is possible to determine the exact hit positionVoxelBoxMover
supports scaled/translated terrains andVoxelMesherCubes
(limited to non-zero color voxels)VoxelColorPalette
colors can be edited in the inspectorVoxelToolTerrain.raycast
accounts for scale and rotation, and supports VoxelMesherCubes (non-zero values)
-
Breaking changes
VoxelViewer
now replaces theviewer_path
property onVoxelTerrain
, and allows multiple loading points- Defined
COLOR
channel inVoxelBuffer
, previously known asDATA2
VoxelGenerator
is no longer the base for script-based generators, useVoxelGeneratorScript
insteadVoxelGenerator
no longer inheritsVoxelStream
VoxelStream
is no longer the base for script-based streams, useVoxelStreamScript
instead- Generators and streams have been split. Streams are more dedicated to files and use a single background thread. Generators are dedicated to generation and can be used by more than one background thread. Terrains have one property for each.
- The meshing system no longer "guesses" how voxels will look like. Instead it uses the mesher assigned to the terrain.
- SDF and TYPE channels have different default depth, so if you relied on 8-bit depth, you may have to explicitely set that format in your generator, to avoid mismatch with existing savegames
- The block serialization format has changed, and migration is not implemented, so old saves using it cannot be used. See documentation for more information.
- Terrains no longer auto-save when they are destroyed while having a
stream
assigned. You have to callsave_modified_blocks()
explicitely before doing that. VoxelLodTerrain.lod_split_scale
has been replaced withlod_distance
for clarity. It is the distance from the viewer where the first LOD level may extend.
-
Fixes
- C# should be able to properly implement generator/stream functions
-
Known issues
VoxelLodTerrain
does not entirely supportVoxelViewer
, but a refactoring pass is planned for it.
0.3 - 08/09/2020 - godot3.2.3
-
General
- Added per-voxel and per-block metadata, which are saved by file streams along with voxel data
StringName
is now used when possible to call script functions, to reduce overhead- Exposed block serializer to allow encoding voxels for network or files from script
- Added terrain methods to trigger saves explicitely
- The module only prints debug logs if the engine is in verbose mode
VoxelTerrain
now emit signals when blocks are loaded and unloaded
-
Editor
- Terrain nodes now render in the editor, unless scripts are involved (can be changed with an option)
-
Blocky voxels
- Added collision masks to blocky voxels, which takes effect with
VoxelBoxMover
and voxel raycasts - Added random tick API for blocky terrains
- Blocky mesh collision shapes now take all surfaces into account
- Added collision masks to blocky voxels, which takes effect with
-
Smooth voxels
- Added a graph-based generator, dedicated to SDF data for now
-
Fixes
- Fixed crash when
VoxelTerrain
is used without a stream - Fixed
Voxel.duplicate()
not implemented properly - Fixed collision shapes only being generated for the first mesh surface
- Fixed
VoxelTool
truncating 64-bit values
- Fixed crash when
0.2 - 27/03/2020 - (no branch) - Tokisan Games binary version
-
General
- Optimized
VoxelBuffer
memory allocation with a pool (best when sizes are often the same) - Optimized block visibility by removing meshes from the world rather than setting the
visible
property - Added customizable bit depth to
VoxelBuffer
(8, 16, 32 and 64 bits) - Added node configuration warnings in case terrain nodes are wrongly setup
- Implemented VoxelTool for VoxelBuffers
- Added
VoxelStreamNoise2D
- Added blur option in
VoxelGeneratorImage
- Generators now all inherit
VoxelGenerator
- Optimized
-
Blocky voxels
- Blocky voxels can be defined with a custom mesh, sides get culled automatically even when not a cube
- Blocky voxels can have custom collision AABBs for use with
VoxelBoxMover
- The 3D noise generator now works in blocky mode with
VoxelTerrain
- Blocky voxels support 8 bit and 16 bit depths
-
Smooth voxels
- Implemented Transvoxel mesher, supporting transition meshes for seamless LOD. It now replaces DMC by default.
- Heightmap generators now have an
iso_scale
tuning property which helps reducing terracing
-
Fixes
- Fixed dark normals occasionally appearing on smooth terrains
- Fixed Transvoxel mesher being offset compared to other meshers
- Fixed stuttering caused by
ShaderMaterial
creation, now they are pooled - Fixed cases where
VoxelLodTerrain
was getting stuck when teleporting far away - Fixed a few bugs with
VoxelStreamBlockFiles
andVoxelStreamRegionFiles
-
Breaking changes
- Removed channel enum from
Voxel
, it was redundant withVoxelBuffer
- Renamed
VoxelBuffer.CHANNEL_ISOLEVEL
=>CHANNEL_SDF
- Removed
VoxelIsoSurfaceTool
, superseded byVoxelTool
- Removed
VoxelMesherMC
, superseded byVoxelMesherTransvoxel
- Replaced
VoxelGeneratorTest
byVoxelGeneratorWaves
andVoxelGeneratorFlat
- Removed channel enum from
0.1 - 03/10/2019 - godot3.1
Initial reference version.
- Support for blocky, dual marching cubes and simple marching cubes meshers
- Terrain with constant LOD paging, or variable LOD (smooth voxels only)
- Voxels editable in game (limited to LOD0)
- Various simple streams to generate, save and load voxel terrain data
- Meshers and storage primitives available to use by scripts
...
- 01/05/2016 - Creation of the module, using Godot 3.0 beta