You are viewing a potentially older version of this package.
View all versions.
TerraMesh
An API for terrain to mesh conversion and mesh manipulation
Date uploaded | 21 hours ago |
Version | 1.1.3 |
Download link | v0xx-TerraMesh-1.1.3.zip |
Downloads | 1056 |
Dependency string | v0xx-TerraMesh-1.1.3 |
This mod requires the following mods to function
BepInEx-BepInExPack
BepInEx pack for Mono Unity games. Preconfigured and ready to use.
Preferred version: 5.4.2100README
TerraMesh
This is a simple plugin that allows conversion of Unity Terrains to Mesh objects. Based on a fork of Triangle.NET and includes all of its functionality. This is supposed to be used by developers, it doesn't do anything by itself!
How to use:
- Create an instance of meshing configuration TerraMeshConfig
- Use .Meshify method on the desired Unity Terrain object to turn it into mesh
- Obtain the material instance from the mesh renderer of newly created mesh terrain and run .SetupMaterialFromTerrain method to copy texture references from TerrainLayers
More information here: https://discord.com/channels/1168655651455639582/1303914349533990983
Information
It has two ways of meshing:
- Uniform: if you don't provide a box collider it will apply a regular grid with a specified step size (1 = exactly the same as original, 2 = resolution halved, 3 = resolution/3, etc).
- Variable: Provide a box collider intersecting with your terrain and apply non-uniform meshing: within the box it will use min step size, outside the box the step will gradually increase towards the edges (only in multiples of two). HIGHLY recommend to use the 2nd option!
- Falloff factor regulates how fast the step size changes.
- Use refine mesh option if you see very thin triangles appearing, this can happen if your terrain is rectangular or a very high falloff used with big maximum step, realistically this should be disabled in most cases.
- Copy trees toogle will save trees from your terrain as separate objects
- Carve holes toggle will carve holes in the mesh if they exist in your terrain.
Grass is NOT supported, probably won't be.
Performance considerations!
- Set your mesh terrain/trees objects to static and set the material of your trees/grass to use "GPU Instanced" option - this will allow batching, instead of rendering each object in separate draw calls.
- To keep rendering performance the same, your terrain should have less than 100k vertices, for vanilla sized moons the number is close to 20-30k.
- It automatically applies a mesh collider so be careful with high polygon counts! You can run the tool with lower quality and use the simpler mesh for the collider!
- Ideally, have a high res terrain for your playable area and low res outer terrain (w/o collider) to create a feeling of a vast environment.
CHANGELOG
1.1.3
- Fixed incorrect submesh splitting
- Added async Meshify and Postprocess methods
1.1.2
- Fixed the shader glitching when no normal map was assigned on a terrain layer
1.1.1
- Small refactor, moved data structures to a separate namespace to cleanup
1.1.0
- Added mesh post processing option.
1.0.0
- Release.