diff options
| author | chai <215380520@qq.com> | 2024-05-19 16:05:58 +0800 |
|---|---|---|
| committer | chai <215380520@qq.com> | 2024-05-19 16:05:58 +0800 |
| commit | 8e13e7e2874adc8982e16d1d2ed2e28d7480b45f (patch) | |
| tree | 63ef85c460288891f5a593d69afeca16cba050b3 /Thronefall_1_57/Decompile/NGS.MeshFusionPro/MeshCombinerSimpleSTD.cs | |
| parent | c5f145786f4c6d2fe4bea831dfc16e52228920a5 (diff) | |
+1.57
Diffstat (limited to 'Thronefall_1_57/Decompile/NGS.MeshFusionPro/MeshCombinerSimpleSTD.cs')
| -rw-r--r-- | Thronefall_1_57/Decompile/NGS.MeshFusionPro/MeshCombinerSimpleSTD.cs | 42 |
1 files changed, 42 insertions, 0 deletions
diff --git a/Thronefall_1_57/Decompile/NGS.MeshFusionPro/MeshCombinerSimpleSTD.cs b/Thronefall_1_57/Decompile/NGS.MeshFusionPro/MeshCombinerSimpleSTD.cs new file mode 100644 index 0000000..3e9fb86 --- /dev/null +++ b/Thronefall_1_57/Decompile/NGS.MeshFusionPro/MeshCombinerSimpleSTD.cs @@ -0,0 +1,42 @@ +using System.Collections.Generic; +using UnityEngine; + +namespace NGS.MeshFusionPro; + +public class MeshCombinerSimpleSTD : MeshCombinerBase +{ + private MeshSeparatorSimple _meshSeparator; + + public MeshCombinerSimpleSTD() + { + _meshSeparator = new MeshSeparatorSimple(); + } + + protected override void CombineInternal(Mesh mesh, IList<MeshCombineInfo> infos) + { + CombineInstance[] array = new CombineInstance[infos.Count + 1]; + Mesh mesh2 = Object.Instantiate(mesh); + array[0] = CreateCombineInstance(new MeshCombineInfo(mesh2)); + for (int i = 0; i < infos.Count; i++) + { + array[i + 1] = CreateCombineInstance(infos[i]); + } + mesh.CombineMeshes(array, mergeSubMeshes: true, useMatrices: true, hasLightmapData: true); + } + + private CombineInstance CreateCombineInstance(MeshCombineInfo info) + { + Mesh mesh = info.mesh; + if (mesh.subMeshCount > 1) + { + mesh = _meshSeparator.GetSubmesh(mesh, info.submeshIndex); + } + CombineInstance result = default(CombineInstance); + result.mesh = mesh; + result.subMeshIndex = 0; + result.transform = info.transformMatrix; + result.lightmapScaleOffset = info.lightmapScaleOffset; + result.realtimeLightmapScaleOffset = info.realtimeLightmapScaleOffset; + return result; + } +} |
