2012-07-26 16:05:24 +00:00
|
|
|
/*
|
|
|
|
Open Asset Import Library (assimp)
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
|
2016-01-01 20:07:24 +00:00
|
|
|
Copyright (c) 2006-2016, assimp team
|
2012-07-26 16:05:24 +00:00
|
|
|
All rights reserved.
|
|
|
|
|
2015-05-19 03:52:10 +00:00
|
|
|
Redistribution and use of this software in source and binary forms,
|
|
|
|
with or without modification, are permitted provided that the
|
2012-07-26 16:05:24 +00:00
|
|
|
following conditions are met:
|
|
|
|
|
|
|
|
* Redistributions of source code must retain the above
|
|
|
|
copyright notice, this list of conditions and the
|
|
|
|
following disclaimer.
|
|
|
|
|
|
|
|
* Redistributions in binary form must reproduce the above
|
|
|
|
copyright notice, this list of conditions and the
|
|
|
|
following disclaimer in the documentation and/or other
|
|
|
|
materials provided with the distribution.
|
|
|
|
|
|
|
|
* Neither the name of the assimp team, nor the names of its
|
|
|
|
contributors may be used to endorse or promote products
|
|
|
|
derived from this software without specific prior
|
|
|
|
written permission of the assimp team.
|
|
|
|
|
2015-05-19 03:52:10 +00:00
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
|
|
|
"AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
2012-07-26 16:05:24 +00:00
|
|
|
LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
2015-05-19 03:52:10 +00:00
|
|
|
A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
2012-07-26 16:05:24 +00:00
|
|
|
OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
2015-05-19 03:52:10 +00:00
|
|
|
SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
2012-07-26 16:05:24 +00:00
|
|
|
LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
2015-05-19 03:52:10 +00:00
|
|
|
DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
|
|
|
THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
|
|
|
(INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
2012-07-26 16:05:24 +00:00
|
|
|
OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
|
|
----------------------------------------------------------------------
|
|
|
|
*/
|
|
|
|
|
|
|
|
/** @file FBXNoteAttribute.cpp
|
|
|
|
* @brief Assimp::FBX::NodeAttribute (and subclasses) implementation
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef ASSIMP_BUILD_NO_FBX_IMPORTER
|
|
|
|
|
|
|
|
#include "FBXParser.h"
|
|
|
|
#include "FBXDocument.h"
|
|
|
|
#include "FBXImporter.h"
|
|
|
|
#include "FBXImportSettings.h"
|
|
|
|
#include "FBXDocumentUtil.h"
|
|
|
|
#include "FBXProperties.h"
|
2015-04-15 23:00:17 +00:00
|
|
|
#include <boost/foreach.hpp>
|
2012-07-26 16:05:24 +00:00
|
|
|
|
|
|
|
namespace Assimp {
|
|
|
|
namespace FBX {
|
|
|
|
|
2015-05-19 03:57:13 +00:00
|
|
|
using namespace Util;
|
2012-07-26 16:05:24 +00:00
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
Deformer::Deformer(uint64_t id, const Element& element, const Document& doc, const std::string& name)
|
2015-05-19 03:57:13 +00:00
|
|
|
: Object(id,element,name)
|
2012-07-26 16:05:24 +00:00
|
|
|
{
|
2015-05-19 03:57:13 +00:00
|
|
|
const Scope& sc = GetRequiredScope(element);
|
2012-07-26 16:05:24 +00:00
|
|
|
|
2015-05-19 03:57:13 +00:00
|
|
|
const std::string& classname = ParseTokenAsString(GetRequiredToken(element,2));
|
|
|
|
props = GetPropertyTable(doc,"Deformer.Fbx" + classname,element,sc,true);
|
2012-07-26 16:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
Deformer::~Deformer()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
Cluster::Cluster(uint64_t id, const Element& element, const Document& doc, const std::string& name)
|
|
|
|
: Deformer(id,element,doc,name)
|
2012-07-26 17:13:19 +00:00
|
|
|
, node()
|
2012-07-26 16:05:24 +00:00
|
|
|
{
|
2015-05-19 03:57:13 +00:00
|
|
|
const Scope& sc = GetRequiredScope(element);
|
|
|
|
|
|
|
|
const Element* const Indexes = sc["Indexes"];
|
|
|
|
const Element* const Weights = sc["Weights"];
|
|
|
|
|
|
|
|
const Element& Transform = GetRequiredElement(sc,"Transform",&element);
|
|
|
|
const Element& TransformLink = GetRequiredElement(sc,"TransformLink",&element);
|
|
|
|
|
|
|
|
transform = ReadMatrix(Transform);
|
|
|
|
transformLink = ReadMatrix(TransformLink);
|
|
|
|
|
|
|
|
// it is actually possible that there be Deformer's with no weights
|
|
|
|
if (!!Indexes != !!Weights) {
|
|
|
|
DOMError("either Indexes or Weights are missing from Cluster",&element);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(Indexes) {
|
|
|
|
ParseVectorDataArray(indices,*Indexes);
|
|
|
|
ParseVectorDataArray(weights,*Weights);
|
|
|
|
}
|
|
|
|
|
|
|
|
if(indices.size() != weights.size()) {
|
|
|
|
DOMError("sizes of index and weight array don't match up",&element);
|
|
|
|
}
|
|
|
|
|
|
|
|
// read assigned node
|
|
|
|
const std::vector<const Connection*>& conns = doc.GetConnectionsByDestinationSequenced(ID(),"Model");
|
|
|
|
BOOST_FOREACH(const Connection* con, conns) {
|
|
|
|
const Model* const mod = ProcessSimpleConnection<Model>(*con, false, "Model -> Cluster", element);
|
|
|
|
if(mod) {
|
|
|
|
node = mod;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!node) {
|
|
|
|
DOMError("failed to read target Node for Cluster",&element);
|
|
|
|
}
|
2012-07-26 16:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
Cluster::~Cluster()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
Skin::Skin(uint64_t id, const Element& element, const Document& doc, const std::string& name)
|
|
|
|
: Deformer(id,element,doc,name)
|
|
|
|
{
|
2015-05-19 03:57:13 +00:00
|
|
|
const Scope& sc = GetRequiredScope(element);
|
2012-07-26 16:05:24 +00:00
|
|
|
|
2015-05-19 03:57:13 +00:00
|
|
|
const Element* const Link_DeformAcuracy = sc["Link_DeformAcuracy"];
|
|
|
|
if(Link_DeformAcuracy) {
|
|
|
|
accuracy = ParseTokenAsFloat(GetRequiredToken(*Link_DeformAcuracy,0));
|
|
|
|
}
|
2012-07-26 16:05:24 +00:00
|
|
|
|
2015-05-19 03:57:13 +00:00
|
|
|
// resolve assigned clusters
|
|
|
|
const std::vector<const Connection*>& conns = doc.GetConnectionsByDestinationSequenced(ID(),"Deformer");
|
2012-07-26 16:05:24 +00:00
|
|
|
|
2015-05-19 03:57:13 +00:00
|
|
|
clusters.reserve(conns.size());
|
|
|
|
BOOST_FOREACH(const Connection* con, conns) {
|
2012-07-26 16:05:24 +00:00
|
|
|
|
2015-05-19 03:57:13 +00:00
|
|
|
const Cluster* const cluster = ProcessSimpleConnection<Cluster>(*con, false, "Cluster -> Skin", element);
|
|
|
|
if(cluster) {
|
|
|
|
clusters.push_back(cluster);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
}
|
2012-07-26 16:05:24 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// ------------------------------------------------------------------------------------------------
|
|
|
|
Skin::~Skin()
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|