added skins and jointNames
parent
cfa0ea3189
commit
79852de5ae
|
@ -128,6 +128,7 @@ namespace glTF
|
||||||
struct BufferView; // here due to cross-reference
|
struct BufferView; // here due to cross-reference
|
||||||
struct Texture;
|
struct Texture;
|
||||||
struct Light;
|
struct Light;
|
||||||
|
struct Skin;
|
||||||
|
|
||||||
|
|
||||||
// Vec/matrix types, as raw float arrays
|
// Vec/matrix types, as raw float arrays
|
||||||
|
@ -806,6 +807,10 @@ namespace glTF
|
||||||
Ref<Camera> camera;
|
Ref<Camera> camera;
|
||||||
Ref<Light> light;
|
Ref<Light> light;
|
||||||
|
|
||||||
|
std::vector< Ref<Node> > skeletons; //!< The ID of skeleton nodes.
|
||||||
|
Ref<Skin> skin; //!< The ID of the skin referenced by this node.
|
||||||
|
std::string jointName; //!< Name used when this node is a joint in a skin.
|
||||||
|
|
||||||
Node() {}
|
Node() {}
|
||||||
void Read(Value& obj, Asset& r);
|
void Read(Value& obj, Asset& r);
|
||||||
};
|
};
|
||||||
|
@ -845,6 +850,11 @@ namespace glTF
|
||||||
|
|
||||||
struct Skin : public Object
|
struct Skin : public Object
|
||||||
{
|
{
|
||||||
|
Nullable<mat4> bindShapeMatrix; //!< Floating-point 4x4 transformation matrix stored in column-major order.
|
||||||
|
Ref<Accessor> inverseBindMatrices; //!< The ID of the accessor containing the floating-point 4x4 inverse-bind matrices.
|
||||||
|
std::vector<std::string/*Ref<Node>*/> jointNames; //!< Joint names of the joints (nodes with a jointName property) in this skin.
|
||||||
|
std::string name; //!< The user-defined name of this object.
|
||||||
|
|
||||||
Skin() {}
|
Skin() {}
|
||||||
void Read(Value& obj, Asset& r);
|
void Read(Value& obj, Asset& r);
|
||||||
};
|
};
|
||||||
|
@ -1099,7 +1109,7 @@ namespace glTF
|
||||||
LazyDict<Sampler> samplers;
|
LazyDict<Sampler> samplers;
|
||||||
LazyDict<Scene> scenes;
|
LazyDict<Scene> scenes;
|
||||||
//LazyDict<Shader> shaders;
|
//LazyDict<Shader> shaders;
|
||||||
//LazyDict<Skin> skins;
|
LazyDict<Skin> skins;
|
||||||
//LazyDict<Technique> techniques;
|
//LazyDict<Technique> techniques;
|
||||||
LazyDict<Texture> textures;
|
LazyDict<Texture> textures;
|
||||||
|
|
||||||
|
@ -1124,7 +1134,7 @@ namespace glTF
|
||||||
, samplers (*this, "samplers")
|
, samplers (*this, "samplers")
|
||||||
, scenes (*this, "scenes")
|
, scenes (*this, "scenes")
|
||||||
//, shaders (*this, "shaders")
|
//, shaders (*this, "shaders")
|
||||||
//, skins (*this, "skins")
|
, skins (*this, "skins")
|
||||||
//, techniques (*this, "techniques")
|
//, techniques (*this, "techniques")
|
||||||
, textures (*this, "textures")
|
, textures (*this, "textures")
|
||||||
, lights (*this, "lights", "KHR_materials_common")
|
, lights (*this, "lights", "KHR_materials_common")
|
||||||
|
|
|
@ -377,6 +377,10 @@ namespace glTF {
|
||||||
AddRefsVector(obj, "children", n.children, w.mAl);
|
AddRefsVector(obj, "children", n.children, w.mAl);
|
||||||
|
|
||||||
AddRefsVector(obj, "meshes", n.meshes, w.mAl);
|
AddRefsVector(obj, "meshes", n.meshes, w.mAl);
|
||||||
|
|
||||||
|
if (!n.jointName.empty()) {
|
||||||
|
obj.AddMember("jointName", n.jointName, w.mAl);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Write(Value& obj, Program& b, AssetWriter& w)
|
inline void Write(Value& obj, Program& b, AssetWriter& w)
|
||||||
|
@ -412,7 +416,15 @@ namespace glTF {
|
||||||
|
|
||||||
inline void Write(Value& obj, Skin& b, AssetWriter& w)
|
inline void Write(Value& obj, Skin& b, AssetWriter& w)
|
||||||
{
|
{
|
||||||
|
/****************** jointNames *******************/
|
||||||
|
Value vJointNames;
|
||||||
|
vJointNames.SetArray();
|
||||||
|
vJointNames.Reserve(unsigned(b.jointNames.size()), w.mAl);
|
||||||
|
|
||||||
|
for (size_t i = 0; i < unsigned(b.jointNames.size()); ++i) {
|
||||||
|
vJointNames.PushBack(StringRef(b.jointNames[i]), w.mAl);
|
||||||
|
}
|
||||||
|
obj.AddMember("jointNames", vJointNames, w.mAl);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline void Write(Value& obj, Technique& b, AssetWriter& w)
|
inline void Write(Value& obj, Technique& b, AssetWriter& w)
|
||||||
|
|
|
@ -126,8 +126,6 @@ glTFExporter::glTFExporter(const char* filename, IOSystem* pIOSystem, const aiSc
|
||||||
|
|
||||||
ExportMetadata();
|
ExportMetadata();
|
||||||
|
|
||||||
//for (unsigned int i = 0; i < pScene->mNumAnimations; ++i) {}
|
|
||||||
|
|
||||||
//for (unsigned int i = 0; i < pScene->mNumCameras; ++i) {}
|
//for (unsigned int i = 0; i < pScene->mNumCameras; ++i) {}
|
||||||
|
|
||||||
//for (unsigned int i = 0; i < pScene->mNumLights; ++i) {}
|
//for (unsigned int i = 0; i < pScene->mNumLights; ++i) {}
|
||||||
|
@ -148,6 +146,8 @@ glTFExporter::glTFExporter(const char* filename, IOSystem* pIOSystem, const aiSc
|
||||||
|
|
||||||
ExportAnimations();
|
ExportAnimations();
|
||||||
|
|
||||||
|
ExportSkins();
|
||||||
|
|
||||||
glTF::AssetWriter writer(*mAsset);
|
glTF::AssetWriter writer(*mAsset);
|
||||||
|
|
||||||
if (isBinary) {
|
if (isBinary) {
|
||||||
|
@ -701,8 +701,7 @@ inline void ExtractAnimationData(Asset& mAsset, std::string& animId, Ref<Animati
|
||||||
std::vector<TimeType> timeData;
|
std::vector<TimeType> timeData;
|
||||||
timeData.resize(nodeChannel->mNumPositionKeys);
|
timeData.resize(nodeChannel->mNumPositionKeys);
|
||||||
for (size_t i = 0; i < nodeChannel->mNumPositionKeys; ++i) {
|
for (size_t i = 0; i < nodeChannel->mNumPositionKeys; ++i) {
|
||||||
// timeData[i] = uint16_t(nodeChannel->mPositionKeys[i].mTime);
|
timeData[i] = nodeChannel->mPositionKeys[i].mTime; // Check if we have to cast type here. e.g. uint16_t()
|
||||||
timeData[i] = nodeChannel->mPositionKeys[i].mTime;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Ref<Accessor> timeAccessor = ExportAnimationData(mAsset, animId, buffer, nodeChannel->mNumPositionKeys, &timeData[0], AttribType::SCALAR, AttribType::SCALAR, ComponentType_FLOAT);
|
Ref<Accessor> timeAccessor = ExportAnimationData(mAsset, animId, buffer, nodeChannel->mNumPositionKeys, &timeData[0], AttribType::SCALAR, AttribType::SCALAR, ComponentType_FLOAT);
|
||||||
|
@ -773,7 +772,6 @@ void glTFExporter::ExportAnimations()
|
||||||
// // Setup to output buffer data
|
// // Setup to output buffer data
|
||||||
// //--------------------------
|
// //--------------------------
|
||||||
|
|
||||||
// aiString aiName;
|
|
||||||
std::cout<<"mNumAnimations " << mScene->mNumAnimations << "\n";
|
std::cout<<"mNumAnimations " << mScene->mNumAnimations << "\n";
|
||||||
for (unsigned int i = 0; i < mScene->mNumAnimations; ++i) {
|
for (unsigned int i = 0; i < mScene->mNumAnimations; ++i) {
|
||||||
const aiAnimation* anim = mScene->mAnimations[i];
|
const aiAnimation* anim = mScene->mAnimations[i];
|
||||||
|
@ -793,25 +791,15 @@ void glTFExporter::ExportAnimations()
|
||||||
name = mAsset->FindUniqueID(name, "animation");
|
name = mAsset->FindUniqueID(name, "animation");
|
||||||
Ref<Animation> animRef = mAsset->animations.Create(name);
|
Ref<Animation> animRef = mAsset->animations.Create(name);
|
||||||
|
|
||||||
// Loop over the data and check to see if it exactly matches an existing buffer.
|
|
||||||
// If yes, then reference the existing corresponding accessor.
|
|
||||||
// Otherwise, add to the buffer and create a new accessor.
|
|
||||||
|
|
||||||
/******************* Parameters ********************/
|
/******************* Parameters ********************/
|
||||||
// If compression is used then you need parameters of uncompressed region: begin and size. At this step "begin" is stored.
|
// If compression is used then you need parameters of uncompressed region: begin and size. At this step "begin" is stored.
|
||||||
// if(comp_allow) idx_srcdata_begin = bufferRef->byteLength;
|
// if(comp_allow) idx_srcdata_begin = bufferRef->byteLength;
|
||||||
|
|
||||||
|
// Loop over the data and check to see if it exactly matches an existing buffer.
|
||||||
|
// If yes, then reference the existing corresponding accessor.
|
||||||
|
// Otherwise, add to the buffer and create a new accessor.
|
||||||
ExtractAnimationData(*mAsset, name, animRef, bufferRef, nodeChannel);
|
ExtractAnimationData(*mAsset, name, animRef, bufferRef, nodeChannel);
|
||||||
|
|
||||||
// FAKE DATA FOR NOW!!!!!
|
|
||||||
// These are accessors to bufferviews to buffer data.
|
|
||||||
// Ref<Accessor> acc = mAsset->accessors.Get(unsigned (0));
|
|
||||||
// animRef->Parameters.TIME = acc;
|
|
||||||
// animRef->Parameters.rotation = acc;
|
|
||||||
// animRef->Parameters.scale = acc;
|
|
||||||
// animRef->Parameters.translation = acc;
|
|
||||||
|
|
||||||
|
|
||||||
for (unsigned int j = 0; j < 3; ++j) {
|
for (unsigned int j = 0; j < 3; ++j) {
|
||||||
std::string channelType;
|
std::string channelType;
|
||||||
switch (j) {
|
switch (j) {
|
||||||
|
@ -848,6 +836,41 @@ void glTFExporter::ExportAnimations()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
void glTFExporter::ExportSkins()
|
||||||
|
{
|
||||||
|
for (unsigned int idx_mesh = 0; idx_mesh < mScene->mNumMeshes; ++idx_mesh) {
|
||||||
|
const aiMesh* aim = mScene->mMeshes[idx_mesh];
|
||||||
|
|
||||||
|
if(!aim->HasBones()) { continue; } // skip to next mesh if no bones.
|
||||||
|
|
||||||
|
std::string skinName = aim->mName.C_Str();
|
||||||
|
skinName = mAsset->FindUniqueID(skinName, "skin");
|
||||||
|
Ref<Skin> skinRef = mAsset->skins.Create(skinName);
|
||||||
|
skinRef->name = skinName;
|
||||||
|
|
||||||
|
for (unsigned int idx_bone = 0; idx_bone < aim->mNumBones; ++idx_bone) {
|
||||||
|
const aiBone* aib = aim->mBones[idx_bone];
|
||||||
|
|
||||||
|
Ref<Node> nodeRef = mAsset->nodes.Get(aib->mName.C_Str());
|
||||||
|
nodeRef->jointName = "joint_" + std::to_string(idx_bone);
|
||||||
|
|
||||||
|
skinRef->jointNames.push_back("joint_" + std::to_string(idx_bone));
|
||||||
|
|
||||||
|
std::cout << "Node->id " << nodeRef->id << "\n";
|
||||||
|
|
||||||
|
// skinRef->bindShapeMatrix;
|
||||||
|
// skinRef->inverseBindMatrices;
|
||||||
|
|
||||||
|
// aib->mNumWeights;
|
||||||
|
// aib->mOffsetMatrix;
|
||||||
|
// aib->mWeights;
|
||||||
|
|
||||||
|
} // End: for-loop mNumMeshes
|
||||||
|
|
||||||
|
} // End: for-loop mNumMeshes
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif // ASSIMP_BUILD_NO_GLTF_EXPORTER
|
#endif // ASSIMP_BUILD_NO_GLTF_EXPORTER
|
||||||
|
|
|
@ -102,6 +102,7 @@ namespace Assimp
|
||||||
unsigned int ExportNode(const aiNode* node);
|
unsigned int ExportNode(const aiNode* node);
|
||||||
void ExportScene();
|
void ExportScene();
|
||||||
void ExportAnimations();
|
void ExportAnimations();
|
||||||
|
void ExportSkins();
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue