mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-26 18:35:20 +00:00
Move IncrementalCompileOperation to SceneManager
This commit is contained in:
parent
5de24552a8
commit
723beb1cac
@ -181,7 +181,8 @@ namespace MWGui
|
|||||||
|
|
||||||
void LoadingScreen::setProgress (size_t value)
|
void LoadingScreen::setProgress (size_t value)
|
||||||
{
|
{
|
||||||
if (value - mProgress < mProgressBar->getScrollRange()/100.f)
|
// skip expensive update if there isn't enough visible progress
|
||||||
|
if (value - mProgress < mProgressBar->getScrollRange()/200.f)
|
||||||
return;
|
return;
|
||||||
mProgress = value;
|
mProgress = value;
|
||||||
mProgressBar->setScrollPosition(0);
|
mProgressBar->setScrollPosition(0);
|
||||||
|
@ -7,8 +7,6 @@
|
|||||||
#include <osg/PositionAttitudeTransform>
|
#include <osg/PositionAttitudeTransform>
|
||||||
#include <osg/UserDataContainer>
|
#include <osg/UserDataContainer>
|
||||||
|
|
||||||
#include <osgUtil/IncrementalCompileOperation>
|
|
||||||
|
|
||||||
#include <osgParticle/ParticleSystem>
|
#include <osgParticle/ParticleSystem>
|
||||||
#include <osgParticle/ParticleProcessor>
|
#include <osgParticle/ParticleProcessor>
|
||||||
|
|
||||||
@ -81,11 +79,6 @@ Objects::~Objects()
|
|||||||
mCellSceneNodes.clear();
|
mCellSceneNodes.clear();
|
||||||
}
|
}
|
||||||
|
|
||||||
void Objects::setIncrementalCompileOperation(osgUtil::IncrementalCompileOperation *ico)
|
|
||||||
{
|
|
||||||
mIncrementalCompileOperation = ico;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Objects::insertBegin(const MWWorld::Ptr& ptr)
|
void Objects::insertBegin(const MWWorld::Ptr& ptr)
|
||||||
{
|
{
|
||||||
osg::ref_ptr<osg::Group> cellnode;
|
osg::ref_ptr<osg::Group> cellnode;
|
||||||
@ -118,9 +111,6 @@ void Objects::insertModel(const MWWorld::Ptr &ptr, const std::string &mesh, bool
|
|||||||
|
|
||||||
std::auto_ptr<ObjectAnimation> anim (new ObjectAnimation(ptr, mesh, mResourceSystem, allowLight));
|
std::auto_ptr<ObjectAnimation> anim (new ObjectAnimation(ptr, mesh, mResourceSystem, allowLight));
|
||||||
|
|
||||||
if (mIncrementalCompileOperation && anim->getObjectRoot())
|
|
||||||
mIncrementalCompileOperation->add(anim->getObjectRoot());
|
|
||||||
|
|
||||||
if (!allowLight)
|
if (!allowLight)
|
||||||
{
|
{
|
||||||
RemoveParticlesVisitor visitor;
|
RemoveParticlesVisitor visitor;
|
||||||
@ -144,9 +134,6 @@ void Objects::insertCreature(const MWWorld::Ptr &ptr, const std::string &mesh, b
|
|||||||
else
|
else
|
||||||
anim.reset(new CreatureAnimation(ptr, mesh, mResourceSystem));
|
anim.reset(new CreatureAnimation(ptr, mesh, mResourceSystem));
|
||||||
|
|
||||||
if (mIncrementalCompileOperation && anim->getObjectRoot())
|
|
||||||
mIncrementalCompileOperation->add(anim->getObjectRoot());
|
|
||||||
|
|
||||||
mObjects.insert(std::make_pair(ptr, anim.release()));
|
mObjects.insert(std::make_pair(ptr, anim.release()));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -157,9 +144,6 @@ void Objects::insertNPC(const MWWorld::Ptr &ptr)
|
|||||||
|
|
||||||
std::auto_ptr<NpcAnimation> anim (new NpcAnimation(ptr, osg::ref_ptr<osg::Group>(ptr.getRefData().getBaseNode()), mResourceSystem, 0));
|
std::auto_ptr<NpcAnimation> anim (new NpcAnimation(ptr, osg::ref_ptr<osg::Group>(ptr.getRefData().getBaseNode()), mResourceSystem, 0));
|
||||||
|
|
||||||
if (mIncrementalCompileOperation && anim->getObjectRoot())
|
|
||||||
mIncrementalCompileOperation->add(anim->getObjectRoot());
|
|
||||||
|
|
||||||
mObjects.insert(std::make_pair(ptr, anim.release()));
|
mObjects.insert(std::make_pair(ptr, anim.release()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -69,14 +69,10 @@ class Objects{
|
|||||||
|
|
||||||
Resource::ResourceSystem* mResourceSystem;
|
Resource::ResourceSystem* mResourceSystem;
|
||||||
|
|
||||||
osg::ref_ptr<osgUtil::IncrementalCompileOperation> mIncrementalCompileOperation;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
Objects(Resource::ResourceSystem* resourceSystem, osg::ref_ptr<osg::Group> rootNode);
|
Objects(Resource::ResourceSystem* resourceSystem, osg::ref_ptr<osg::Group> rootNode);
|
||||||
~Objects();
|
~Objects();
|
||||||
|
|
||||||
void setIncrementalCompileOperation(osgUtil::IncrementalCompileOperation* ico);
|
|
||||||
|
|
||||||
/// @param animated Attempt to load separate keyframes from a .kf file matching the model file?
|
/// @param animated Attempt to load separate keyframes from a .kf file matching the model file?
|
||||||
/// @param allowLight If false, no lights will be created, and particles systems will be removed.
|
/// @param allowLight If false, no lights will be created, and particles systems will be removed.
|
||||||
void insertModel(const MWWorld::Ptr& ptr, const std::string &model, bool animated=false, bool allowLight=true);
|
void insertModel(const MWWorld::Ptr& ptr, const std::string &model, bool animated=false, bool allowLight=true);
|
||||||
|
@ -17,6 +17,7 @@
|
|||||||
|
|
||||||
#include <components/resource/resourcesystem.hpp>
|
#include <components/resource/resourcesystem.hpp>
|
||||||
#include <components/resource/texturemanager.hpp>
|
#include <components/resource/texturemanager.hpp>
|
||||||
|
#include <components/resource/scenemanager.hpp>
|
||||||
|
|
||||||
#include <components/settings/settings.hpp>
|
#include <components/settings/settings.hpp>
|
||||||
|
|
||||||
@ -101,7 +102,7 @@ namespace MWRender
|
|||||||
|
|
||||||
mViewer->setIncrementalCompileOperation(new osgUtil::IncrementalCompileOperation);
|
mViewer->setIncrementalCompileOperation(new osgUtil::IncrementalCompileOperation);
|
||||||
|
|
||||||
mObjects->setIncrementalCompileOperation(mViewer->getIncrementalCompileOperation());
|
mResourceSystem->getSceneManager()->setIncrementalCompileOperation(mViewer->getIncrementalCompileOperation());
|
||||||
|
|
||||||
mEffectManager.reset(new EffectManager(mRootNode, mResourceSystem));
|
mEffectManager.reset(new EffectManager(mRootNode, mResourceSystem));
|
||||||
|
|
||||||
|
@ -6,6 +6,8 @@
|
|||||||
|
|
||||||
#include <osgParticle/ParticleSystem>
|
#include <osgParticle/ParticleSystem>
|
||||||
|
|
||||||
|
#include <osgUtil/IncrementalCompileOperation>
|
||||||
|
|
||||||
#include <components/nifosg/nifloader.hpp>
|
#include <components/nifosg/nifloader.hpp>
|
||||||
#include <components/nif/niffile.hpp>
|
#include <components/nif/niffile.hpp>
|
||||||
|
|
||||||
@ -88,7 +90,10 @@ namespace Resource
|
|||||||
// TODO: add support for non-NIF formats
|
// TODO: add support for non-NIF formats
|
||||||
|
|
||||||
NifOsg::Loader loader;
|
NifOsg::Loader loader;
|
||||||
osg::ref_ptr<const osg::Node> loaded = loader.load(Nif::NIFFilePtr(new Nif::NIFFile(file, normalized)), mTextureManager);
|
osg::ref_ptr<osg::Node> loaded = loader.load(Nif::NIFFilePtr(new Nif::NIFFile(file, normalized)), mTextureManager);
|
||||||
|
|
||||||
|
if (mIncrementalCompileOperation)
|
||||||
|
mIncrementalCompileOperation->add(loaded);
|
||||||
|
|
||||||
mIndex[normalized] = loaded;
|
mIndex[normalized] = loaded;
|
||||||
return loaded;
|
return loaded;
|
||||||
@ -147,6 +152,11 @@ namespace Resource
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void SceneManager::setIncrementalCompileOperation(osgUtil::IncrementalCompileOperation *ico)
|
||||||
|
{
|
||||||
|
mIncrementalCompileOperation = ico;
|
||||||
|
}
|
||||||
|
|
||||||
const VFS::Manager* SceneManager::getVFS() const
|
const VFS::Manager* SceneManager::getVFS() const
|
||||||
{
|
{
|
||||||
return mVFS;
|
return mVFS;
|
||||||
|
@ -24,6 +24,11 @@ namespace NifOsg
|
|||||||
class KeyframeHolder;
|
class KeyframeHolder;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
namespace osgUtil
|
||||||
|
{
|
||||||
|
class IncrementalCompileOperation;
|
||||||
|
}
|
||||||
|
|
||||||
namespace Resource
|
namespace Resource
|
||||||
{
|
{
|
||||||
|
|
||||||
@ -56,6 +61,9 @@ namespace Resource
|
|||||||
/// in cases where multiple contexts are used over the lifetime of the application.
|
/// in cases where multiple contexts are used over the lifetime of the application.
|
||||||
void releaseGLObjects(osg::State* state);
|
void releaseGLObjects(osg::State* state);
|
||||||
|
|
||||||
|
/// Set up an IncrementalCompileOperation for background compiling of loaded scenes.
|
||||||
|
void setIncrementalCompileOperation(osgUtil::IncrementalCompileOperation* ico);
|
||||||
|
|
||||||
const VFS::Manager* getVFS() const;
|
const VFS::Manager* getVFS() const;
|
||||||
|
|
||||||
Resource::TextureManager* getTextureManager();
|
Resource::TextureManager* getTextureManager();
|
||||||
@ -64,6 +72,8 @@ namespace Resource
|
|||||||
const VFS::Manager* mVFS;
|
const VFS::Manager* mVFS;
|
||||||
Resource::TextureManager* mTextureManager;
|
Resource::TextureManager* mTextureManager;
|
||||||
|
|
||||||
|
osg::ref_ptr<osgUtil::IncrementalCompileOperation> mIncrementalCompileOperation;
|
||||||
|
|
||||||
// observer_ptr?
|
// observer_ptr?
|
||||||
typedef std::map<std::string, osg::ref_ptr<const osg::Node> > Index;
|
typedef std::map<std::string, osg::ref_ptr<const osg::Node> > Index;
|
||||||
Index mIndex;
|
Index mIndex;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user