Enable OSG cache (default) and option to disable.
(also requires flightgear update)
This commit is contained in:
parent
3c0c51a946
commit
83243f471a
@ -35,6 +35,8 @@
|
||||
using namespace osg;
|
||||
using namespace simgear;
|
||||
|
||||
bool SGPagedLOD::_cache = true;
|
||||
|
||||
SGPagedLOD::SGPagedLOD()
|
||||
: PagedLOD()
|
||||
{
|
||||
@ -53,6 +55,20 @@ SGPagedLOD::SGPagedLOD(const SGPagedLOD& plod,const CopyOp& copyop)
|
||||
{
|
||||
}
|
||||
|
||||
void
|
||||
SGPagedLOD::setReaderWriterOptions(osgDB::ReaderWriter::Options *options)
|
||||
{
|
||||
if (_cache)
|
||||
options->setObjectCacheHint(osgDB::ReaderWriter::Options::CACHE_ALL);
|
||||
else
|
||||
options->setObjectCacheHint(osgDB::ReaderWriter::Options::CACHE_NONE);
|
||||
#if SG_PAGEDLOD_HAS_OPTIONS
|
||||
setDatabaseOptions(options);
|
||||
#else
|
||||
_readerWriterOptions = options;
|
||||
#endif
|
||||
}
|
||||
|
||||
bool SGPagedLOD::addChild(osg::Node *child)
|
||||
{
|
||||
if (!PagedLOD::addChild(child))
|
||||
|
@ -52,14 +52,7 @@ public:
|
||||
// reimplemented to notify the loading through ModelData
|
||||
bool addChild(osg::Node *child);
|
||||
|
||||
void setReaderWriterOptions(osgDB::ReaderWriter::Options *options) {
|
||||
options->setObjectCacheHint(osgDB::ReaderWriter::Options::CACHE_NONE);
|
||||
#if SG_PAGEDLOD_HAS_OPTIONS
|
||||
setDatabaseOptions(options);
|
||||
#else
|
||||
_readerWriterOptions = options;
|
||||
#endif
|
||||
}
|
||||
void setReaderWriterOptions(osgDB::ReaderWriter::Options *options);
|
||||
|
||||
osgDB::ReaderWriter::Options* getReaderWriterOptions() {
|
||||
#if SG_PAGEDLOD_HAS_OPTIONS
|
||||
@ -69,11 +62,14 @@ public:
|
||||
#endif
|
||||
}
|
||||
|
||||
static void setRenderingCache(bool cache) {_cache = cache;}
|
||||
protected:
|
||||
virtual ~SGPagedLOD();
|
||||
#if !SG_PAGEDLOD_HAS_OPTIONS
|
||||
osg::ref_ptr<osgDB::ReaderWriter::Options> _readerWriterOptions;
|
||||
#endif
|
||||
private:
|
||||
static bool _cache;
|
||||
};
|
||||
}
|
||||
#endif
|
||||
|
@ -52,14 +52,11 @@ SGModelLib::panel_func SGModelLib::static_panelFunc = NULL;
|
||||
////////////////////////////////////////////////////////////////////////
|
||||
// Implementation of SGModelLib.
|
||||
////////////////////////////////////////////////////////////////////////
|
||||
void SGModelLib::init(const string &root_dir)
|
||||
void SGModelLib::init(const string &root_dir, SGPropertyNode* root)
|
||||
{
|
||||
osgDB::Registry::instance()->getDataFilePathList().push_front(root_dir);
|
||||
}
|
||||
|
||||
void SGModelLib::setPropRoot(SGPropertyNode* root)
|
||||
{
|
||||
static_propRoot = root;
|
||||
SGPagedLOD::setRenderingCache(root->getBoolValue("/sim/rendering/cache",true));
|
||||
}
|
||||
|
||||
void SGModelLib::setPanelFunc(panel_func pf)
|
||||
|
@ -44,9 +44,7 @@ class SGModelLib
|
||||
public:
|
||||
typedef osg::Node *(*panel_func)(SGPropertyNode *);
|
||||
|
||||
static void init(const std::string &root_dir);
|
||||
|
||||
static void setPropRoot(SGPropertyNode* root);
|
||||
static void init(const std::string &root_dir, SGPropertyNode* root);
|
||||
|
||||
static void setPanelFunc(panel_func pf);
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user