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/CombinedMeshFactory.cs | 43 ++++++++++++++++++++++ 1 file changed, 43 insertions(+) create mode 100644 Thronefall_1_57/Decompile/NGS.MeshFusionPro/CombinedMeshFactory.cs (limited to 'Thronefall_1_57/Decompile/NGS.MeshFusionPro/CombinedMeshFactory.cs') diff --git a/Thronefall_1_57/Decompile/NGS.MeshFusionPro/CombinedMeshFactory.cs b/Thronefall_1_57/Decompile/NGS.MeshFusionPro/CombinedMeshFactory.cs new file mode 100644 index 0000000..850efd8 --- /dev/null +++ b/Thronefall_1_57/Decompile/NGS.MeshFusionPro/CombinedMeshFactory.cs @@ -0,0 +1,43 @@ +using UnityEngine; + +namespace NGS.MeshFusionPro; + +public class CombinedMeshFactory : ICombinedMeshFactory +{ + private IMeshToolsFactory _tools; + + private IMovableCombinedMeshFactory _movableMeshFactory; + + public CombinedMeshFactory(MeshType meshType, CombineMethod combineMethod, MoveMethod moveMethod = MoveMethod.Simple) + { + if (meshType == MeshType.Standard) + { + _tools = new SimpleToolsSTDFactory(); + if (moveMethod == MoveMethod.Simple) + { + _movableMeshFactory = new SimpleMovableMeshSTDFactory(_tools); + } + else + { + _movableMeshFactory = new JobsMovableMeshSTDFactory(_tools); + } + return; + } + _tools = new SimpleToolsLWFactory(); + if (moveMethod == MoveMethod.Simple) + { + Debug.Log("Simple mover not implemented yet for lightweight meshes. Jobs mover will be used instead"); + } + _movableMeshFactory = new JobsMovableMeshLWFactory(_tools); + } + + public CombinedMesh CreateCombinedMesh() + { + return new CombinedMesh(_tools.CreateMeshCombiner(), _tools.CreateMeshCutter()); + } + + public CombinedMesh CreateMovableCombinedMesh(out ICombinedMeshMover mover) + { + return _movableMeshFactory.CreateMovableMesh(out mover); + } +} -- cgit v1.1-26-g67d0