mirror of
				https://github.com/AxioDL/metaforce.git
				synced 2025-10-25 21:30:25 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			67 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| #pragma once
 | |
| 
 | |
| #include <vector>
 | |
| 
 | |
| #include "Runtime/CFactoryMgr.hpp"
 | |
| #include "Runtime/Character/CSegId.hpp"
 | |
| #include "Runtime/Graphics/CCubeModel.hpp"
 | |
| #include "Runtime/RetroTypes.hpp"
 | |
| 
 | |
| #include <zeus/CVector3f.hpp>
 | |
| 
 | |
| namespace metaforce {
 | |
| class CCharLayoutInfo;
 | |
| class CPoseAsTransforms;
 | |
| class CModel;
 | |
| 
 | |
| struct SSkinWeighting {
 | |
|   CSegId x0_id;
 | |
|   float x4_weight;
 | |
|   explicit SSkinWeighting(CInputStream& in) : x0_id(in), x4_weight(in.ReadFloat()) {}
 | |
| };
 | |
| 
 | |
| class CVirtualBone {
 | |
|   friend class CSkinnedModel;
 | |
| 
 | |
|   rstl::reserved_vector<SSkinWeighting, 3> x0_weights;
 | |
|   u32 x1c_vertexCount;
 | |
|   zeus::CTransform x20_xf;
 | |
|   zeus::CMatrix3f x50_rotation;
 | |
| 
 | |
| public:
 | |
|   explicit CVirtualBone(CInputStream& in);
 | |
| 
 | |
|   void BuildPoints(const zeus::CVector3f* in, TVectorRef out, u32 count) const;
 | |
|   void BuildNormals(const zeus::CVector3f* in, TVectorRef out, u32 count) const;
 | |
|   void BuildAccumulatedTransform(const CPoseAsTransforms& pose, const zeus::CVector3f* points);
 | |
| 
 | |
|   [[nodiscard]] const auto& GetWeights() const { return x0_weights; }
 | |
|   [[nodiscard]] u32 GetVertexCount() const { return x1c_vertexCount; }
 | |
| 
 | |
| private:
 | |
|   void BuildFinalPosMatrix(const CPoseAsTransforms& pose, const zeus::CVector3f* points);
 | |
| };
 | |
| 
 | |
| class CSkinRules {
 | |
|   friend class CSkinnedModel;
 | |
| 
 | |
|   std::vector<CVirtualBone> x0_bones;
 | |
|   u32 x10_vertexCount = 0;
 | |
|   u32 x14_normalCount = 0;
 | |
| 
 | |
| public:
 | |
|   explicit CSkinRules(CInputStream& in);
 | |
| 
 | |
|   void BuildPoints(TConstVectorRef positions, TVectorRef out);
 | |
|   void BuildNormals(TConstVectorRef normals, TVectorRef out);
 | |
|   void BuildAccumulatedTransforms(const CPoseAsTransforms& pose, const CCharLayoutInfo& info);
 | |
| 
 | |
|   [[nodiscard]] u32 GetVertexCount() const { return x10_vertexCount; }
 | |
|   [[nodiscard]] u32 GetNormalCount() const { return x14_normalCount; }
 | |
| };
 | |
| 
 | |
| CFactoryFnReturn FSkinRulesFactory(const SObjectTag& tag, CInputStream& in, const CVParamTransfer& params,
 | |
|                                    CObjectReference* selfRef);
 | |
| 
 | |
| } // namespace metaforce
 |