2015-08-13 07:29:00 +00:00
|
|
|
#ifndef _DNAMP3_CSKR_HPP_
|
|
|
|
#define _DNAMP3_CSKR_HPP_
|
|
|
|
|
2015-08-17 22:05:00 +00:00
|
|
|
#include "hecl/blender/BlenderConnection.hpp"
|
2015-08-13 07:29:00 +00:00
|
|
|
#include "../DNACommon/DNACommon.hpp"
|
|
|
|
#include "CINF.hpp"
|
|
|
|
|
|
|
|
namespace Retro
|
|
|
|
{
|
|
|
|
namespace DNAMP3
|
|
|
|
{
|
|
|
|
|
|
|
|
struct CSKR : BigDNA
|
|
|
|
{
|
|
|
|
DECL_DNA
|
|
|
|
Value<atUint32> skinningRuleCount;
|
|
|
|
struct SkinningRule : BigDNA
|
|
|
|
{
|
|
|
|
DECL_DNA
|
|
|
|
Value<atUint32> weightCount;
|
|
|
|
struct Weight : BigDNA
|
|
|
|
{
|
|
|
|
DECL_DNA
|
|
|
|
Value<atUint32> boneId;
|
|
|
|
Value<float> weight;
|
|
|
|
};
|
|
|
|
Vector<Weight, DNA_COUNT(weightCount)> weights;
|
|
|
|
Value<atUint32> vertCount;
|
|
|
|
};
|
|
|
|
Vector<SkinningRule, DNA_COUNT(skinningRuleCount)> 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_
|