起因:从打包的大文件中提取出部分节点数据在内存中合并到一个节点中,不想把提取出的数据先写到磁盘上然后再读到内存节点
目的:从内存中读node
实现:由于osgDB::ReaderWriter提供了readNode(std::istream&, ...),只要由内存数据构造出std::istream即可
实例:
class StreamBuffer : public std::basic_streambuf<char, std::char_traits<char>>
{
public:
StreamBuffer(char * buffer, int size){setg(buffer, buffer, buffer+size);}
};
uchar *pOutputData = hugeFile.map(_startPos, _fileSize );
osgDB::ReaderWriter* rw = osgDB::Registry::instance()->getReaderWriterForExtension("ive");
if ( rw )
{
StreamBuffer sb((char*)pOutputData, _fileSize );
std::istream is(&sb);
osgDB::ReaderWriter::ReadResult rr = rw->readNode(is);
osg::ref_ptr<osg::Node> node = rr.takeNode();
if(group && node)
group->addChild(node);
}
hugeFile.close();
参考:http://blog.youkuaiyun.com/linyanwen99/article/details/8592857
本文介绍了一种高效的方法,在不将提取出的节点数据写入磁盘的情况下,直接从内存中读取并合并节点数据,利用osgDB::ReaderWriter库实现了这一过程。
749

被折叠的 条评论
为什么被折叠?



