Added support for write to ostream into .osg plugin
This commit is contained in:
parent
935f2a62e5
commit
0e119ec26c
@ -24,6 +24,8 @@ class OSGReaderWriter : public ReaderWriter
|
||||
|
||||
virtual ReadResult readObject(const std::string& fileName, const Options* opt) { return readNode(fileName, opt); }
|
||||
|
||||
virtual ReadResult readObject(std::istream& fin, const Options* opt) { return readNode(fin, opt); }
|
||||
|
||||
virtual ReadResult readNode(const std::string& file, const Options* opt)
|
||||
{
|
||||
std::string ext = osgDB::getLowerCaseFileExtension(file);
|
||||
@ -111,6 +113,24 @@ class OSGReaderWriter : public ReaderWriter
|
||||
return WriteResult("Unable to open file for output");
|
||||
}
|
||||
|
||||
virtual WriteResult writeObject(const Object& obj,std::ostream& fout, const osgDB::ReaderWriter::Options* options)
|
||||
{
|
||||
Output foutput;
|
||||
|
||||
std::ios &fios = foutput;
|
||||
fios.rdbuf(fout.rdbuf());
|
||||
|
||||
if (fout)
|
||||
{
|
||||
setPrecision(foutput,options);
|
||||
|
||||
foutput.writeObject(obj);
|
||||
return WriteResult::FILE_SAVED;
|
||||
}
|
||||
return WriteResult("Unable to write to output stream");
|
||||
}
|
||||
|
||||
|
||||
virtual WriteResult writeNode(const Node& node,const std::string& fileName, const osgDB::ReaderWriter::Options* options)
|
||||
{
|
||||
std::string ext = getFileExtension(fileName);
|
||||
@ -129,6 +149,23 @@ class OSGReaderWriter : public ReaderWriter
|
||||
return WriteResult("Unable to open file for output");
|
||||
}
|
||||
|
||||
virtual WriteResult writeNode(const Node& node,std::ostream& fout, const osgDB::ReaderWriter::Options* options)
|
||||
{
|
||||
Output foutput;
|
||||
|
||||
std::ios &fios = foutput;
|
||||
fios.rdbuf(fout.rdbuf());
|
||||
|
||||
if (fout)
|
||||
{
|
||||
setPrecision(foutput,options);
|
||||
|
||||
foutput.writeObject(node);
|
||||
return WriteResult::FILE_SAVED;
|
||||
}
|
||||
return WriteResult("Unable to write to output stream");
|
||||
}
|
||||
|
||||
};
|
||||
|
||||
// now register with Registry to instantiate the above
|
||||
|
Loading…
Reference in New Issue
Block a user