aboutsummaryrefslogtreecommitdiff
path: root/NvBlast/samples/SampleBase/scene/SampleAssetListParser.cpp
diff options
context:
space:
mode:
authorBryan Galdrikian <[email protected]>2017-02-24 09:32:20 -0800
committerBryan Galdrikian <[email protected]>2017-02-24 09:32:20 -0800
commite1bf674c16e3c8472b29574159c789cd3f0c64e0 (patch)
tree9f0cfce09c71a2c27ff19589fcad6cd83504477c /NvBlast/samples/SampleBase/scene/SampleAssetListParser.cpp
parentfirst commit (diff)
downloadblast-e1bf674c16e3c8472b29574159c789cd3f0c64e0.tar.xz
blast-e1bf674c16e3c8472b29574159c789cd3f0c64e0.zip
Updating to [email protected] and [email protected] with a new directory structure.
NvBlast folder is gone, files have been moved to top level directory. README is changed to reflect this.
Diffstat (limited to 'NvBlast/samples/SampleBase/scene/SampleAssetListParser.cpp')
-rw-r--r--NvBlast/samples/SampleBase/scene/SampleAssetListParser.cpp272
1 files changed, 0 insertions, 272 deletions
diff --git a/NvBlast/samples/SampleBase/scene/SampleAssetListParser.cpp b/NvBlast/samples/SampleBase/scene/SampleAssetListParser.cpp
deleted file mode 100644
index 00cf4df..0000000
--- a/NvBlast/samples/SampleBase/scene/SampleAssetListParser.cpp
+++ /dev/null
@@ -1,272 +0,0 @@
-/*
-* Copyright (c) 2008-2015, NVIDIA CORPORATION. All rights reserved.
-*
-* NVIDIA CORPORATION and its licensors retain all intellectual property
-* and proprietary rights in and to this software, related documentation
-* and any modifications thereto. Any use, reproduction, disclosure or
-* distribution of this software and related documentation without an express
-* license agreement from NVIDIA CORPORATION is strictly prohibited.
-*/
-
-#include "SampleAssetListParser.h"
-#include <PsFastXml.h>
-#include "Sample.h"
-#include "PxVec4.h"
-#include "PxInputDataFromPxFileBuf.h"
-
-
-using namespace physx;
-
-
-const float DEGREE_TO_RAD = acos(-1.0) / 180.0;
-
-class AssetListParser : public physx::shdfnd::FastXml::Callback
-{
-public:
- AssetListParser(AssetList& assetList): m_assetList(assetList){}
-protected:
-
- // encountered a comment in the XML
- virtual bool processComment(const char* /*comment*/)
- {
- return true;
- }
-
- virtual bool processClose(const char* elementName, unsigned int /*depth*/, bool& /*isError*/)
- {
- if (::strcmp(elementName, "Box") == 0)
- {
- m_assetList.boxes.push_back(m_boxTemp);
- m_boxTemp = AssetList::BoxAsset();
- }
- else if (::strcmp(elementName, "Composite") == 0)
- {
- m_assetList.composites.push_back(m_compositeTemp);
- m_compositeTemp = AssetList::CompositeAsset();
- }
- return true;
- }
-
- // return true to continue processing the XML document, false to skip.
- virtual bool processElement(const char* elementName, // name of the element
- const char* elementData, // element data, null if none
- const physx::shdfnd::FastXml::AttributePairs& attr,
- int /*lineno*/) // line number in the source XML file
- {
- if (::strcmp(elementName, "Model") == 0)
- {
- m_assetList.models.resize(m_assetList.models.size() + 1);
- auto& model = m_assetList.models.back();
- for (int i = 0; i < attr.getNbAttr(); ++i)
- {
- if (::strcmp(attr.getKey(i), "id") == 0)
- {
- model.id = std::string(attr.getValue(i));
- }
- else if (::strcmp(attr.getKey(i), "file") == 0)
- {
- model.file = std::string(attr.getValue(i));
- }
- else if (::strcmp(attr.getKey(i), "name") == 0)
- {
- model.name = std::string(attr.getValue(i));
- }
- else if (::strcmp(attr.getKey(i), "isSkinned") == 0)
- {
- std::string str = attr.getValue(i);
- if (::strcmp(&str[0], "true") == 0)
- {
- model.isSkinned = true;
- }
- }
- }
-
- model.transform = parseTransform(attr);
-
- if (model.name.empty())
- {
- model.name = model.file;
- }
- if (model.id.empty())
- {
- model.id = model.name;
- }
- }
- else if (::strcmp(elementName, "Box") == 0)
- {
- for (int i = 0; i < attr.getNbAttr(); ++i)
- {
- if (::strcmp(attr.getKey(i), "id") == 0)
- {
- m_boxTemp.id = std::string(attr.getValue(i));
- }
- else if (::strcmp(attr.getKey(i), "name") == 0)
- {
- m_boxTemp.name = std::string(attr.getValue(i));
- }
- else if (::strcmp(attr.getKey(i), "staticHeight") == 0)
- {
- std::string str = attr.getValue(i);
- sscanf(&str[0], "%f", &m_boxTemp.staticHeight);
- }
- else if (::strcmp(attr.getKey(i), "jointAllBonds") == 0)
- {
- std::string str = attr.getValue(i);
- if (::strcmp(&str[0], "true") == 0)
- {
- m_boxTemp.jointAllBonds = true;
- }
- }
- else if (::strcmp(attr.getKey(i), "extents") == 0)
- {
- std::string str = attr.getValue(i);
- sscanf(&str[0], "%f %f %f", &m_boxTemp.extents.x, &m_boxTemp.extents.y, &m_boxTemp.extents.z);
- }
- }
-
- if (m_boxTemp.id.empty())
- {
- m_boxTemp.id = m_boxTemp.name;
- }
- }
- else if (::strcmp(elementName, "Level") == 0)
- {
- m_boxTemp.levels.push_back(AssetList::BoxAsset::Level());
- auto& level = m_boxTemp.levels.back();
- for (int i = 0; i < attr.getNbAttr(); ++i)
- {
- if (::strcmp(attr.getKey(i), "slices") == 0)
- {
- std::string str = attr.getValue(i);
- sscanf(&str[0], "%d %d %d", &level.x, &level.y, &level.z);
- }
- if (::strcmp(attr.getKey(i), "isSupport") == 0)
- {
- std::string str = attr.getValue(i);
- if (::strcmp(&str[0], "true") == 0)
- {
- level.isSupport = true;
- }
- }
- }
- }
- else if (::strcmp(elementName, "Composite") == 0)
- {
- for (int i = 0; i < attr.getNbAttr(); ++i)
- {
- if (::strcmp(attr.getKey(i), "id") == 0)
- {
- m_compositeTemp.id = std::string(attr.getValue(i));
- }
- else if (::strcmp(attr.getKey(i), "name") == 0)
- {
- m_compositeTemp.name = std::string(attr.getValue(i));
- }
- }
- m_compositeTemp.transform = parseTransform(attr);
-
- if (m_compositeTemp.id.empty())
- {
- m_compositeTemp.id = m_compositeTemp.name;
- }
- }
- else if (::strcmp(elementName, "AssetRef") == 0)
- {
- m_compositeTemp.assetRefs.push_back(AssetList::CompositeAsset::AssetRef());
- AssetList::CompositeAsset::AssetRef& assetRef = m_compositeTemp.assetRefs.back();
- for (int i = 0; i < attr.getNbAttr(); ++i)
- {
- if (::strcmp(attr.getKey(i), "id") == 0)
- {
- assetRef.id = attr.getValue(i);
- }
- }
- assetRef.transform = parseTransform(attr);
- }
- else if (::strcmp(elementName, "Joint") == 0)
- {
- m_compositeTemp.joints.push_back(AssetList::CompositeAsset::Joint());
- AssetList::CompositeAsset::Joint& joint = m_compositeTemp.joints.back();
- for (int i = 0; i < attr.getNbAttr(); ++i)
- {
- if (::strcmp(attr.getKey(i), "asset0") == 0)
- {
- joint.assetIndices[0] = std::stoi(attr.getValue(i));
- }
- else if (::strcmp(attr.getKey(i), "asset1") == 0)
- {
- joint.assetIndices[1] = std::stoi(attr.getValue(i));
- }
- if (::strcmp(attr.getKey(i), "chunk0") == 0)
- {
- joint.chunkIndices[0] = std::stoi(attr.getValue(i));
- }
- else if (::strcmp(attr.getKey(i), "chunk1") == 0)
- {
- joint.chunkIndices[1] = std::stoi(attr.getValue(i));
- }
- else if (::strcmp(attr.getKey(i), "position0") == 0)
- {
- joint.attachPositions[0] = parsePosition(attr.getValue(i));
- }
- else if (::strcmp(attr.getKey(i), "position1") == 0)
- {
- joint.attachPositions[1] = parsePosition(attr.getValue(i));
- }
- }
- }
- return true;
- }
-
-private:
- PxTransform parseTransform(const physx::shdfnd::FastXml::AttributePairs& attr)
- {
- PxTransform transform(PxIdentity);
- for (int i = 0; i < attr.getNbAttr(); ++i)
- {
- if (::strcmp(attr.getKey(i), "position") == 0)
- {
- transform.p = parsePosition(attr.getValue(i));
- }
- else if (::strcmp(attr.getKey(i), "rotation") == 0)
- {
- transform.q = parseRotation(attr.getValue(i));
- }
- }
- return transform;
- }
-
- PxVec3 parsePosition(const char* value)
- {
- PxVec3 ps;
- sscanf(value, "%f %f %f", &ps.x, &ps.y, &ps.z);
- return ps;
- }
-
- PxQuat parseRotation(const char* value)
- {
- PxVec4 ps;
- sscanf(value, "%f %f %f %f", &ps.x, &ps.y, &ps.z, &ps.w);
- ps.w = ps.w * DEGREE_TO_RAD;
- return PxQuat(ps.w, PxVec3(ps.x, ps.y, ps.z).getNormalized());;
- }
-
- AssetList::BoxAsset m_boxTemp;
- AssetList::CompositeAsset m_compositeTemp;
- AssetList& m_assetList;
-};
-
-
-void parseAssetList(AssetList& assetList, std::string filepath)
-{
- physx::PsFileBuffer fileBuffer(filepath.c_str(), physx::general_PxIOStream2::PxFileBuf::OPEN_READ_ONLY);
- if (!fileBuffer.isOpen())
- {
- return;
- }
- PxInputDataFromPxFileBuf inputData(fileBuffer);
- AssetListParser parser(assetList);
- physx::shdfnd::FastXml* xml = physx::shdfnd::createFastXml(&parser);
- xml->processXml(inputData, false);
- xml->release();
-} \ No newline at end of file