- fbx: collapse animation nodes whenever possible to avoid overly busted output scenes.
parent
8336aa423f
commit
6bbbbfde4c
|
@ -542,9 +542,6 @@ private:
|
||||||
/** checks if a node has more than just scaling, rotation and translation components */
|
/** checks if a node has more than just scaling, rotation and translation components */
|
||||||
bool NeedsComplexTransformationChain(const Model& model)
|
bool NeedsComplexTransformationChain(const Model& model)
|
||||||
{
|
{
|
||||||
// XXX TEMPORARY
|
|
||||||
return true;
|
|
||||||
|
|
||||||
const PropertyTable& props = model.Props();
|
const PropertyTable& props = model.Props();
|
||||||
bool ok;
|
bool ok;
|
||||||
|
|
||||||
|
@ -652,9 +649,6 @@ private:
|
||||||
GetRotationMatrix(rot, Rotation, chain[TransformationComp_Rotation]);
|
GetRotationMatrix(rot, Rotation, chain[TransformationComp_Rotation]);
|
||||||
}
|
}
|
||||||
|
|
||||||
// XXX TEMPORARY
|
|
||||||
is_complex = true;
|
|
||||||
|
|
||||||
// is_complex needs to be consistent with NeedsComplexTransformationChain()
|
// is_complex needs to be consistent with NeedsComplexTransformationChain()
|
||||||
// or the interplay between this code and the animation converter would
|
// or the interplay between this code and the animation converter would
|
||||||
// not be guaranteed.
|
// not be guaranteed.
|
||||||
|
@ -679,8 +673,7 @@ private:
|
||||||
const TransformationComp comp = static_cast<TransformationComp>(i);
|
const TransformationComp comp = static_cast<TransformationComp>(i);
|
||||||
|
|
||||||
if (chain[i].IsIdentity() && (anim_chain_bitmask & bit) == 0) {
|
if (chain[i].IsIdentity() && (anim_chain_bitmask & bit) == 0) {
|
||||||
// XXX TEMPORARY
|
continue;
|
||||||
//continue;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
aiNode* nd = new aiNode();
|
aiNode* nd = new aiNode();
|
||||||
|
@ -1785,7 +1778,8 @@ private:
|
||||||
node_property_map.end(),
|
node_property_map.end(),
|
||||||
layer_map,
|
layer_map,
|
||||||
max_time,
|
max_time,
|
||||||
min_time
|
min_time,
|
||||||
|
true // input is TRS order, assimp is SRT
|
||||||
);
|
);
|
||||||
|
|
||||||
ai_assert(nd);
|
ai_assert(nd);
|
||||||
|
@ -2056,7 +2050,8 @@ private:
|
||||||
NodeMap::const_iterator iter_end,
|
NodeMap::const_iterator iter_end,
|
||||||
const LayerMap& layer_map,
|
const LayerMap& layer_map,
|
||||||
double& max_time,
|
double& max_time,
|
||||||
double& min_time)
|
double& min_time,
|
||||||
|
bool reverse_order = false)
|
||||||
|
|
||||||
{
|
{
|
||||||
ScopeGuard<aiNodeAnim> na(new aiNodeAnim());
|
ScopeGuard<aiNodeAnim> na(new aiNodeAnim());
|
||||||
|
@ -2064,57 +2059,98 @@ private:
|
||||||
|
|
||||||
const PropertyTable& props = target.Props();
|
const PropertyTable& props = target.Props();
|
||||||
|
|
||||||
// if a particular transformation is not given, grab it from
|
if(reverse_order) {
|
||||||
// the corresponding node to meet the semantics of aiNodeAnim,
|
|
||||||
// which requires all of rotation, scaling and translation
|
|
||||||
// to be set.
|
|
||||||
if(chain[TransformationComp_Scaling] != iter_end) {
|
|
||||||
ConvertScaleKeys(na, (*chain[TransformationComp_Scaling]).second,
|
|
||||||
layer_map,
|
|
||||||
max_time,
|
|
||||||
min_time);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
na->mScalingKeys = new aiVectorKey[1];
|
|
||||||
na->mNumScalingKeys = 1;
|
|
||||||
|
|
||||||
na->mScalingKeys[0].mTime = 0.;
|
// need to convert from TRS order to SRT?
|
||||||
na->mScalingKeys[0].mValue = PropertyGet(props,"Lcl Scaling",
|
const KeyFrameListList& scaling = GetKeyframeList((*chain[TransformationComp_Scaling]).second);
|
||||||
aiVector3D(1.f,1.f,1.f));
|
const KeyFrameListList& translation = GetKeyframeList((*chain[TransformationComp_Translation]).second);
|
||||||
}
|
const KeyFrameListList& rotation = GetKeyframeList((*chain[TransformationComp_Rotation]).second);
|
||||||
|
|
||||||
if(chain[TransformationComp_Rotation] != iter_end) {
|
KeyFrameListList joined;
|
||||||
ConvertRotationKeys(na, (*chain[TransformationComp_Rotation]).second,
|
joined.insert(joined.end(), scaling.begin(), scaling.end());
|
||||||
layer_map,
|
joined.insert(joined.end(), translation.begin(), translation.end());
|
||||||
|
joined.insert(joined.end(), rotation.begin(), rotation.end());
|
||||||
|
|
||||||
|
const KeyTimeList& times = GetKeyTimeList(joined);
|
||||||
|
|
||||||
|
aiQuatKey* out_quat = new aiQuatKey[times.size()];
|
||||||
|
aiVectorKey* out_scale = new aiVectorKey[times.size()];
|
||||||
|
aiVectorKey* out_translation = new aiVectorKey[times.size()];
|
||||||
|
|
||||||
|
ConvertTransformOrder_TRStoSRT(out_quat, out_scale, out_translation,
|
||||||
|
scaling,
|
||||||
|
translation,
|
||||||
|
rotation,
|
||||||
|
times,
|
||||||
max_time,
|
max_time,
|
||||||
min_time,
|
min_time,
|
||||||
target.RotationOrder());
|
target.RotationOrder());
|
||||||
|
|
||||||
|
// XXX remove duplicates / redundant keys which this operation did
|
||||||
|
// likely produce if not all three channels were equally dense.
|
||||||
|
|
||||||
|
na->mNumScalingKeys = static_cast<unsigned int>(times.size());
|
||||||
|
na->mNumRotationKeys = na->mNumScalingKeys;
|
||||||
|
na->mNumPositionKeys = na->mNumScalingKeys;
|
||||||
|
|
||||||
|
na->mScalingKeys = out_scale;
|
||||||
|
na->mRotationKeys = out_quat;
|
||||||
|
na->mPositionKeys = out_translation;
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
na->mRotationKeys = new aiQuatKey[1];
|
|
||||||
na->mNumRotationKeys = 1;
|
|
||||||
|
|
||||||
na->mRotationKeys[0].mTime = 0.;
|
// if a particular transformation is not given, grab it from
|
||||||
na->mRotationKeys[0].mValue = EulerToQuaternion(
|
// the corresponding node to meet the semantics of aiNodeAnim,
|
||||||
PropertyGet(props,"Lcl Rotation",aiVector3D(0.f,0.f,0.f)),
|
// which requires all of rotation, scaling and translation
|
||||||
target.RotationOrder());
|
// to be set.
|
||||||
|
if(chain[TransformationComp_Scaling] != iter_end) {
|
||||||
|
ConvertScaleKeys(na, (*chain[TransformationComp_Scaling]).second,
|
||||||
|
layer_map,
|
||||||
|
max_time,
|
||||||
|
min_time);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
na->mScalingKeys = new aiVectorKey[1];
|
||||||
|
na->mNumScalingKeys = 1;
|
||||||
|
|
||||||
|
na->mScalingKeys[0].mTime = 0.;
|
||||||
|
na->mScalingKeys[0].mValue = PropertyGet(props,"Lcl Scaling",
|
||||||
|
aiVector3D(1.f,1.f,1.f));
|
||||||
|
}
|
||||||
|
|
||||||
|
if(chain[TransformationComp_Rotation] != iter_end) {
|
||||||
|
ConvertRotationKeys(na, (*chain[TransformationComp_Rotation]).second,
|
||||||
|
layer_map,
|
||||||
|
max_time,
|
||||||
|
min_time,
|
||||||
|
target.RotationOrder());
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
na->mRotationKeys = new aiQuatKey[1];
|
||||||
|
na->mNumRotationKeys = 1;
|
||||||
|
|
||||||
|
na->mRotationKeys[0].mTime = 0.;
|
||||||
|
na->mRotationKeys[0].mValue = EulerToQuaternion(
|
||||||
|
PropertyGet(props,"Lcl Rotation",aiVector3D(0.f,0.f,0.f)),
|
||||||
|
target.RotationOrder());
|
||||||
|
}
|
||||||
|
|
||||||
|
if(chain[TransformationComp_Translation] != iter_end) {
|
||||||
|
ConvertTranslationKeys(na, (*chain[TransformationComp_Translation]).second,
|
||||||
|
layer_map,
|
||||||
|
max_time,
|
||||||
|
min_time);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
na->mPositionKeys = new aiVectorKey[1];
|
||||||
|
na->mNumPositionKeys = 1;
|
||||||
|
|
||||||
|
na->mPositionKeys[0].mTime = 0.;
|
||||||
|
na->mPositionKeys[0].mValue = PropertyGet(props,"Lcl Translation",
|
||||||
|
aiVector3D(0.f,0.f,0.f));
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if(chain[TransformationComp_Translation] != iter_end) {
|
|
||||||
ConvertTranslationKeys(na, (*chain[TransformationComp_Translation]).second,
|
|
||||||
layer_map,
|
|
||||||
max_time,
|
|
||||||
min_time);
|
|
||||||
}
|
|
||||||
else {
|
|
||||||
na->mPositionKeys = new aiVectorKey[1];
|
|
||||||
na->mNumPositionKeys = 1;
|
|
||||||
|
|
||||||
na->mPositionKeys[0].mTime = 0.;
|
|
||||||
na->mPositionKeys[0].mValue = PropertyGet(props,"Lcl Translation",
|
|
||||||
aiVector3D(0.f,0.f,0.f));
|
|
||||||
}
|
|
||||||
|
|
||||||
return na.dismiss();
|
return na.dismiss();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2282,7 +2318,8 @@ private:
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
void InterpolateKeys(aiQuatKey* valOut,const KeyTimeList& keys, const KeyFrameListList& inputs, const bool geom,
|
void InterpolateKeys(aiQuatKey* valOut,const KeyTimeList& keys, const KeyFrameListList& inputs,
|
||||||
|
const bool geom,
|
||||||
double& maxTime,
|
double& maxTime,
|
||||||
double& minTime,
|
double& minTime,
|
||||||
Model::RotOrder order)
|
Model::RotOrder order)
|
||||||
|
@ -2301,6 +2338,37 @@ private:
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// ------------------------------------------------------------------------------------------------
|
||||||
|
void ConvertTransformOrder_TRStoSRT(aiQuatKey* out_quat, aiVectorKey* out_scale,
|
||||||
|
aiVectorKey* out_translation,
|
||||||
|
const KeyFrameListList& scaling,
|
||||||
|
const KeyFrameListList& translation,
|
||||||
|
const KeyFrameListList& rotation,
|
||||||
|
const KeyTimeList& times,
|
||||||
|
double& maxTime,
|
||||||
|
double& minTime,
|
||||||
|
Model::RotOrder order)
|
||||||
|
{
|
||||||
|
InterpolateKeys(out_quat, times, rotation, false, maxTime, minTime, order);
|
||||||
|
InterpolateKeys(out_scale, times, scaling, true, maxTime, minTime);
|
||||||
|
InterpolateKeys(out_translation, times, translation, false, maxTime, minTime);
|
||||||
|
|
||||||
|
const size_t count = times.size();
|
||||||
|
for (size_t i = 0; i < count; ++i) {
|
||||||
|
aiQuaternion& r = out_quat[i].mValue;
|
||||||
|
aiVector3D& s = out_scale[i].mValue;
|
||||||
|
aiVector3D& t = out_translation[i].mValue;
|
||||||
|
|
||||||
|
aiMatrix4x4 mat, temp;
|
||||||
|
aiMatrix4x4::Translation(t, mat);
|
||||||
|
mat *= aiMatrix4x4( r.GetMatrix() );
|
||||||
|
mat *= aiMatrix4x4::Scaling(s, temp);
|
||||||
|
|
||||||
|
mat.Decompose(s, r, t);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
// ------------------------------------------------------------------------------------------------
|
// ------------------------------------------------------------------------------------------------
|
||||||
// euler xyz -> quat
|
// euler xyz -> quat
|
||||||
aiQuaternion EulerToQuaternion(const aiVector3D& rot, Model::RotOrder order)
|
aiQuaternion EulerToQuaternion(const aiVector3D& rot, Model::RotOrder order)
|
||||||
|
|
Loading…
Reference in New Issue