mirror of https://github.com/AxioDL/metaforce.git
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
|