From 284abbe9e1f569e9d04ce595f84149d1853006b5 Mon Sep 17 00:00:00 2001 From: George Papadopoulos Date: Fri, 20 Dec 2013 11:36:35 +0200 Subject: [PATCH 1/2] fix for collada parser when importing empty arrays. Exiting function so early break the parsing procedure, misses node closing and causes improper initialization of element (cannot be referenced later on) --- code/ColladaParser.cpp | 1 - 1 file changed, 1 deletion(-) diff --git a/code/ColladaParser.cpp b/code/ColladaParser.cpp index 767347695..b577aab0b 100644 --- a/code/ColladaParser.cpp +++ b/code/ColladaParser.cpp @@ -1660,7 +1660,6 @@ void ColladaParser::ReadDataArray() std::string id = mReader->getAttributeValue( indexID); int indexCount = GetAttribute( "count"); unsigned int count = (unsigned int) mReader->getAttributeValueAsInt( indexCount); - if (count == 0) { return; } // some exporters write empty data arrays with count="0" const char* content = TestTextContent(); // read values and store inside an array in the data library From 2d709dd638a9fabefe52f896a5644e44866f4a61 Mon Sep 17 00:00:00 2001 From: George Papadopoulos Date: Sun, 29 Dec 2013 21:02:16 +0200 Subject: [PATCH 2/2] Fix for FBX pivot transformation. Parse and use the GeometricScaling,GeometricRotation and GeometricTranslation model properties in node transformation --- code/FBXConverter.cpp | 44 +++++++++++++++++++++++++++++++++++++------ 1 file changed, 38 insertions(+), 6 deletions(-) diff --git a/code/FBXConverter.cpp b/code/FBXConverter.cpp index 342c5f144..54a3bc594 100644 --- a/code/FBXConverter.cpp +++ b/code/FBXConverter.cpp @@ -88,6 +88,9 @@ public: TransformationComp_ScalingPivot, TransformationComp_Scaling, TransformationComp_ScalingPivotInverse, + TransformationComp_GeometricTranslation, + TransformationComp_GeometricRotation, + TransformationComp_GeometricScaling, TransformationComp_MAXIMUM }; @@ -419,6 +422,12 @@ private: return "Scaling"; case TransformationComp_ScalingPivotInverse: return "ScalingPivotInverse"; + case TransformationComp_GeometricScaling: + return "GeometricScaling"; + case TransformationComp_GeometricRotation: + return "GeometricRotation"; + case TransformationComp_GeometricTranslation: + return "GeometricTranslation"; case TransformationComp_MAXIMUM: // this is to silence compiler warnings break; } @@ -456,6 +465,12 @@ private: return "Lcl Scaling"; case TransformationComp_ScalingPivotInverse: return "ScalingPivotInverse"; + case TransformationComp_GeometricScaling: + return "GeometricScaling"; + case TransformationComp_GeometricRotation: + return "GeometricRotation"; + case TransformationComp_GeometricTranslation: + return "GeometricTranslation"; case TransformationComp_MAXIMUM: // this is to silence compiler warnings break; } @@ -577,9 +592,8 @@ private: for (size_t i = 0; i < TransformationComp_MAXIMUM; ++i) { const TransformationComp comp = static_cast(i); - if(comp == TransformationComp_Rotation || comp == TransformationComp_Scaling || - comp == TransformationComp_Translation) { - + if( comp == TransformationComp_Rotation || comp == TransformationComp_Scaling || comp == TransformationComp_Translation || + comp == TransformationComp_GeometricScaling || comp == TransformationComp_GeometricRotation || comp == TransformationComp_GeometricTranslation ) { continue; } @@ -676,6 +690,21 @@ private: if(ok && Rotation.SquareLength() > zero_epsilon) { GetRotationMatrix(rot, Rotation, chain[TransformationComp_Rotation]); } + + const aiVector3D& GeometricScaling = PropertyGet(props, "GeometricScaling", ok); + if (ok && fabs(GeometricScaling.SquareLength() - 1.0f) > zero_epsilon) { + aiMatrix4x4::Scaling(GeometricScaling, chain[TransformationComp_GeometricScaling]); + } + + const aiVector3D& GeometricRotation = PropertyGet(props, "GeometricRotation", ok); + if (ok && GeometricRotation.SquareLength() > zero_epsilon) { + GetRotationMatrix(rot, GeometricRotation, chain[TransformationComp_GeometricRotation]); + } + + const aiVector3D& GeometricTranslation = PropertyGet(props, "GeometricTranslation", ok); + if (ok && GeometricTranslation.SquareLength() > zero_epsilon){ + aiMatrix4x4::Translation(GeometricTranslation, chain[TransformationComp_GeometricTranslation]); + } // is_complex needs to be consistent with NeedsComplexTransformationChain() // or the interplay between this code and the animation converter would @@ -1900,9 +1929,9 @@ private: has_any = true; - if (comp != TransformationComp_Rotation && comp != TransformationComp_Scaling && - comp != TransformationComp_Translation) { - + if (comp != TransformationComp_Rotation && comp != TransformationComp_Scaling && comp != TransformationComp_Translation && + comp != TransformationComp_GeometricScaling && comp != TransformationComp_GeometricRotation && comp != TransformationComp_GeometricTranslation ) + { has_complex = true; } } @@ -1955,6 +1984,7 @@ private: case TransformationComp_Rotation: case TransformationComp_PreRotation: case TransformationComp_PostRotation: + case TransformationComp_GeometricRotation: na = GenerateRotationNodeAnim(chain_name, target, (*chain[i]).second, @@ -1969,6 +1999,7 @@ private: case TransformationComp_ScalingOffset: case TransformationComp_ScalingPivot: case TransformationComp_Translation: + case TransformationComp_GeometricTranslation: na = GenerateTranslationNodeAnim(chain_name, target, (*chain[i]).second, @@ -2017,6 +2048,7 @@ private: break; case TransformationComp_Scaling: + case TransformationComp_GeometricScaling: na = GenerateScalingNodeAnim(chain_name, target, (*chain[i]).second,