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