mirror of
				https://github.com/Laupetin/OpenAssetTools.git
				synced 2025-10-26 08:15:54 +00:00 
			
		
		
		
	chore: move materialIndex to XModelObject
This commit is contained in:
		| @@ -312,14 +312,16 @@ namespace | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     void AddXModelObjects(AbstractXModelWriter& writer, const XModel* model, const unsigned lod) | ||||
|     void AddXModelObjects(AbstractXModelWriter& writer, const XModel* model, const unsigned lod, const DistinctMapper<Material*>& materialMapper) | ||||
|     { | ||||
|         const auto surfCount = model->lodInfo[lod].numsurfs; | ||||
|         const auto baseSurfaceIndex = model->lodInfo[lod].surfIndex; | ||||
|  | ||||
|         for (auto surfIndex = 0u; surfIndex < surfCount; surfIndex++) | ||||
|         { | ||||
|             XModelObject object; | ||||
|             object.name = "surf" + std::to_string(surfIndex); | ||||
|             object.materialIndex = static_cast<int>(materialMapper.GetDistinctPositionByInputPosition(surfIndex + baseSurfaceIndex)); | ||||
|  | ||||
|             writer.AddObject(std::move(object)); | ||||
|         } | ||||
| @@ -506,11 +508,10 @@ namespace | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     void AddXModelFaces(AbstractXModelWriter& writer, const DistinctMapper<Material*>& materialMapper, const XModel* model, const unsigned lod) | ||||
|     void AddXModelFaces(AbstractXModelWriter& writer, const XModel* model, const unsigned lod) | ||||
|     { | ||||
|         const auto* surfs = &model->surfs[model->lodInfo[lod].surfIndex]; | ||||
|         const auto surfCount = model->lodInfo[lod].numsurfs; | ||||
|         const auto baseSurfIndex = model->lodInfo[lod].surfIndex; | ||||
|  | ||||
|         for (auto surfIndex = 0u; surfIndex < surfCount; surfIndex++) | ||||
|         { | ||||
| @@ -524,7 +525,6 @@ namespace | ||||
|                 face.vertexIndex[1] = tri[1] + surface.baseVertIndex; | ||||
|                 face.vertexIndex[2] = tri[2] + surface.baseVertIndex; | ||||
|                 face.objectIndex = static_cast<int>(surfIndex); | ||||
|                 face.materialIndex = static_cast<int>(materialMapper.GetDistinctPositionByInputPosition(surfIndex + baseSurfIndex)); | ||||
|                 writer.AddFace(face); | ||||
|             } | ||||
|         } | ||||
| @@ -538,10 +538,10 @@ namespace | ||||
|  | ||||
|         AddXModelBones(context, writer, model); | ||||
|         AddXModelMaterials(writer, materialMapper, model); | ||||
|         AddXModelObjects(writer, model, lod); | ||||
|         AddXModelObjects(writer, model, lod, materialMapper); | ||||
|         AddXModelVertices(writer, model, lod); | ||||
|         AddXModelVertexBoneWeights(writer, model, lod, boneWeightCollection); | ||||
|         AddXModelFaces(writer, materialMapper, model, lod); | ||||
|         AddXModelFaces(writer, model, lod); | ||||
|     } | ||||
|  | ||||
|     void DumpXModelExportLod(const AssetDumpingContext& context, const XAssetInfo<XModel>* asset, const unsigned lod) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user