#ifndef _DNAMP3_CSKR_HPP_ #define _DNAMP3_CSKR_HPP_ #include "BlenderConnection.hpp" #include "../DNACommon/DNACommon.hpp" #include "CINF.hpp" namespace Retro { namespace DNAMP3 { struct CSKR : BigDNA { DECL_DNA Value skinningRuleCount; struct SkinningRule : BigDNA { DECL_DNA Value weightCount; struct Weight : BigDNA { DECL_DNA Value boneId; Value weight; }; Vector weights; Value vertCount; }; Vector skinningRules; void weightVertex(HECL::BlenderConnection::PyOutStream& os, const CINF& cinf, atUint32 idx) const { atUint32 accum = 0; for (const SkinningRule& rule : skinningRules) { if (idx < accum + rule.vertCount) for (const SkinningRule::Weight& weight : rule.weights) os.format("vert[dvert_lay][%u] = %f\n", cinf.getBoneIdxFromId(weight.boneId), weight.weight); accum += rule.vertCount; } } }; } } #endif // _DNAMP3_CSKR_HPP_