From 8e13e7e2874adc8982e16d1d2ed2e28d7480b45f Mon Sep 17 00:00:00 2001 From: chai <215380520@qq.com> Date: Sun, 19 May 2024 16:05:58 +0800 Subject: +1.57 --- .../NGS.MeshFusionPro/MeshCombinerSimpleSTD.cs | 42 ++++++++++++++++++++++ 1 file changed, 42 insertions(+) create mode 100644 Thronefall_1_57/Decompile/NGS.MeshFusionPro/MeshCombinerSimpleSTD.cs (limited to 'Thronefall_1_57/Decompile/NGS.MeshFusionPro/MeshCombinerSimpleSTD.cs') 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 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; + } +} -- cgit v1.1-26-g67d0