From d88b996df15fc830fa3dbe4b16b3a12a7ddb5a24 Mon Sep 17 00:00:00 2001 From: Robert Osfield Date: Thu, 14 Dec 2006 21:15:40 +0000 Subject: [PATCH] From Brede Johansen, "New option "cloneExternalReferences" for OpenFlight plugin" --- src/osgPlugins/OpenFlight/ReaderWriterFLT.cpp | 20 ++++++++++++++----- 1 file changed, 15 insertions(+), 5 deletions(-) diff --git a/src/osgPlugins/OpenFlight/ReaderWriterFLT.cpp b/src/osgPlugins/OpenFlight/ReaderWriterFLT.cpp index f18153e66..641a05383 100644 --- a/src/osgPlugins/OpenFlight/ReaderWriterFLT.cpp +++ b/src/osgPlugins/OpenFlight/ReaderWriterFLT.cpp @@ -27,16 +27,20 @@ using namespace osgDB; class ReadExternalsVisitor : public osg::NodeVisitor { + bool _cloneExternalReferences; osg::ref_ptr _options; public: ReadExternalsVisitor(ReaderWriter::Options* options) : osg::NodeVisitor(osg::NodeVisitor::TRAVERSE_ALL_CHILDREN), - _options(options) + _options(options), + _cloneExternalReferences(false) { + if (options) + _cloneExternalReferences = (options->getOptionString().find("cloneExternalReferences")!=std::string::npos); } - + virtual ~ReadExternalsVisitor() {} virtual void apply(ProxyNode& node) @@ -50,14 +54,20 @@ public: std::string filename = node.getFileName(pos); // read external - osg::Node* external = osgDB::readNodeFile(filename,_options.get()); - if (external) - node.addChild(external); + osg::ref_ptr external = osgDB::readNodeFile(filename,_options.get()); + if (external.valid()) + { + if (_cloneExternalReferences) + external = dynamic_cast(external->clone(osg::CopyOp(osg::CopyOp::DEEP_COPY_NODES))); + + node.addChild(external.get()); + } } } }; + class FLTReaderWriter : public ReaderWriter { public: