From c2ca835ff56bfb52b86540289dc56c009c07124c Mon Sep 17 00:00:00 2001 From: Passive <20432486+PassiveModding@users.noreply.github.com> Date: Fri, 30 Aug 2024 20:25:09 +1000 Subject: [PATCH] Fix character textures overwriting eachother when exporting multiple characters with shared textures --- Meddle/Meddle.Plugin/Services/ExportService.cs | 14 ++++++++++---- 1 file changed, 10 insertions(+), 4 deletions(-) diff --git a/Meddle/Meddle.Plugin/Services/ExportService.cs b/Meddle/Meddle.Plugin/Services/ExportService.cs index 1dba86b..4c826b8 100644 --- a/Meddle/Meddle.Plugin/Services/ExportService.cs +++ b/Meddle/Meddle.Plugin/Services/ExportService.cs @@ -439,7 +439,8 @@ public async Task Export(ParsedInstance[] instances, Vector3 origin, ModelExport var meshes = HandleModel(characterInstance.CharacterInfo.CustomizeData, characterInstance.CharacterInfo.CustomizeParameter, characterInstance.CharacterInfo.GenderRace, - mdlFileGroup, ref bones, rootBone, token); + mdlFileGroup, ref bones, rootBone, token, + $"{characterInstance.Name}_{characterInstance.Id}"); foreach (var mesh in meshes) { meshOutput.Add((mesh.model, mesh.mesh)); @@ -529,7 +530,7 @@ public static void AddMesh( } } - private MaterialBuilder HandleMaterial(CustomizeData customizeData, CustomizeParameter customizeParams, MtrlFileGroup mtrlGroup) + private MaterialBuilder HandleMaterial(CustomizeData customizeData, CustomizeParameter customizeParams, MtrlFileGroup mtrlGroup, string? suffix = null) { var material = new Material(mtrlGroup.MdlPath, mtrlGroup.MtrlFile, mtrlGroup.TexFiles.ToDictionary(x => x.MtrlPath, x => x.Resource), mtrlGroup.ShpkFile); using var activityMtrl = ActivitySource.StartActivity(); @@ -539,6 +540,10 @@ private MaterialBuilder HandleMaterial(CustomizeData customizeData, CustomizePar activityMtrl?.SetTag("shaderPackageName", material.ShaderPackageName); var name = $"{Path.GetFileNameWithoutExtension(material.HandlePath)}_{Path.GetFileNameWithoutExtension(material.ShaderPackageName)}"; + if (suffix != null) + { + name += $"_{suffix}"; + } var builder = material.ShaderPackageName switch { "bg.shpk" => MaterialUtility.BuildBg(material, name), @@ -575,7 +580,8 @@ private MaterialBuilder BuildAndLogFallbackMaterial(Material material, string na MdlFileGroup mdlGroup, ref List bones, BoneNodeBuilder? root, - CancellationToken token) + CancellationToken token, + string? suffix = null) { using var activity = ActivitySource.StartActivity(); activity?.SetTag("characterPath", mdlGroup.CharacterPath); @@ -610,7 +616,7 @@ private MaterialBuilder BuildAndLogFallbackMaterial(Material material, string na if (mtrlFile is MtrlFileGroup mtrlGroup) { if (token.IsCancellationRequested) return meshOutput; - var builder = HandleMaterial(customizeData, customizeParams, mtrlGroup); + var builder = HandleMaterial(customizeData, customizeParams, mtrlGroup, suffix); materials.Add(builder); } else if (mtrlFile is MtrlFileStubGroup stub)