mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-11 09:36:37 +00:00
a854a6e04a
Currently, we use an `UnrefQueue` which supposedly aims to transfer destruction costs to another thread. The implications of this unusual pattern can not be well understood because some allocators might free resources more efficiently if they are freed by the same thread that allocated them. In addition, `UnrefQueue` complicates the validation of thread safety in our engine. Lastly, our current usage of `UnrefQueue` triggers `ref()`, `unref()` atomic operations as objects are passed into the queue. These operations could be more expensive than the actual destruction. With this PR we thus remove `UnrefQueue`. We can expect these changes to have a minor impact at most because we free most resources elsewhere in `ResourceSystem::updateCache`.
74 lines
2.0 KiB
C++
74 lines
2.0 KiB
C++
#ifndef OPENMW_COMPONENTS_TERRAIN_COMPOSITEMAPRENDERER_H
|
|
#define OPENMW_COMPONENTS_TERRAIN_COMPOSITEMAPRENDERER_H
|
|
|
|
#include <osg/Drawable>
|
|
|
|
#include <set>
|
|
#include <mutex>
|
|
|
|
namespace osg
|
|
{
|
|
class FrameBufferObject;
|
|
class RenderInfo;
|
|
class Texture2D;
|
|
}
|
|
|
|
namespace Terrain
|
|
{
|
|
|
|
class CompositeMap : public osg::Referenced
|
|
{
|
|
public:
|
|
CompositeMap();
|
|
~CompositeMap();
|
|
std::vector<osg::ref_ptr<osg::Drawable> > mDrawables;
|
|
osg::ref_ptr<osg::Texture2D> mTexture;
|
|
unsigned int mCompiled;
|
|
};
|
|
|
|
/**
|
|
* @brief The CompositeMapRenderer is responsible for updating composite map textures in a blocking or non-blocking way.
|
|
*/
|
|
class CompositeMapRenderer : public osg::Drawable
|
|
{
|
|
public:
|
|
CompositeMapRenderer();
|
|
~CompositeMapRenderer();
|
|
|
|
void drawImplementation(osg::RenderInfo& renderInfo) const override;
|
|
|
|
void compile(CompositeMap& compositeMap, osg::RenderInfo& renderInfo, double* timeLeft) const;
|
|
|
|
/// Set the available time in seconds for compiling (non-immediate) composite maps each frame
|
|
void setMinimumTimeAvailableForCompile(double time);
|
|
|
|
/// If current frame rate is higher than this, the extra time will be set aside to do more compiling
|
|
void setTargetFrameRate(float framerate);
|
|
|
|
/// Add a composite map to be rendered
|
|
void addCompositeMap(CompositeMap* map, bool immediate=false);
|
|
|
|
/// Mark this composite map to be required for the current frame
|
|
void setImmediate(CompositeMap* map);
|
|
|
|
unsigned int getCompileSetSize() const;
|
|
|
|
private:
|
|
float mTargetFrameRate;
|
|
double mMinimumTimeAvailable;
|
|
mutable osg::Timer mTimer;
|
|
|
|
typedef std::set<osg::ref_ptr<CompositeMap> > CompileSet;
|
|
|
|
mutable CompileSet mCompileSet;
|
|
mutable CompileSet mImmediateCompileSet;
|
|
|
|
mutable std::mutex mMutex;
|
|
|
|
osg::ref_ptr<osg::FrameBufferObject> mFBO;
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|