mirror of https://github.com/AxioDL/metaforce.git
57 lines
1.6 KiB
C++
57 lines
1.6 KiB
C++
#ifndef _DNAMP1_CINF_HPP_
|
|
#define _DNAMP1_CINF_HPP_
|
|
|
|
#include "../DNACommon/DNACommon.hpp"
|
|
#include "../DNACommon/RigInverter.hpp"
|
|
|
|
namespace DataSpec::DNAMP1
|
|
{
|
|
|
|
struct CINF : BigDNA
|
|
{
|
|
DECL_DNA
|
|
Value<atUint32> boneCount;
|
|
struct Bone : BigDNA
|
|
{
|
|
DECL_DNA
|
|
Value<atUint32> id;
|
|
Value<atUint32> parentId;
|
|
Value<atVec3f> origin;
|
|
Value<atUint32> linkedCount;
|
|
Vector<atUint32, DNA_COUNT(linkedCount)> linked;
|
|
};
|
|
Vector<Bone, DNA_COUNT(boneCount)> bones;
|
|
|
|
Value<atUint32> boneIdCount;
|
|
Vector<atUint32, DNA_COUNT(boneIdCount)> boneIds;
|
|
|
|
Value<atUint32> nameCount;
|
|
struct Name : BigDNA
|
|
{
|
|
DECL_DNA
|
|
String<-1> name;
|
|
Value<atUint32> boneId;
|
|
};
|
|
Vector<Name, DNA_COUNT(nameCount)> names;
|
|
|
|
atUint32 getInternalBoneIdxFromId(atUint32 id) const;
|
|
atUint32 getBoneIdxFromId(atUint32 id) const;
|
|
const std::string* getBoneNameFromId(atUint32 id) const;
|
|
void sendVertexGroupsToBlender(hecl::blender::PyOutStream& os) const;
|
|
void sendCINFToBlender(hecl::blender::PyOutStream& os, const UniqueID32& cinfId) const;
|
|
static std::string GetCINFArmatureName(const UniqueID32& cinfId);
|
|
|
|
CINF() = default;
|
|
using Armature = hecl::blender::Armature;
|
|
using BlenderBone = hecl::blender::Bone;
|
|
|
|
int RecursiveAddArmatureBone(const Armature& armature, const BlenderBone* bone, int parent, int& curId,
|
|
std::unordered_map<std::string, atInt32>& idMap, std::map<std::string, int>& nameMap);
|
|
|
|
CINF(const Armature& armature, std::unordered_map<std::string, atInt32>& idMap);
|
|
};
|
|
|
|
}
|
|
|
|
#endif // _DNAMP1_CINF_HPP_
|