1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-19 22:53:53 +00:00
openmw/components/resource/scenemanager.hpp

281 lines
10 KiB
C++
Raw Normal View History

2015-03-26 17:02:51 +00:00
#ifndef OPENMW_COMPONENTS_RESOURCE_SCENEMANAGER_H
#define OPENMW_COMPONENTS_RESOURCE_SCENEMANAGER_H
2023-07-28 22:29:03 +00:00
#include <array>
#include <memory>
2020-06-25 19:46:07 +00:00
#include <mutex>
2022-09-22 18:26:05 +00:00
#include <string>
2015-03-26 17:02:51 +00:00
2022-09-22 18:26:05 +00:00
#include <osg/Texture>
#include <osg/ref_ptr>
2015-03-26 17:02:51 +00:00
#include "resourcemanager.hpp"
#include <components/sceneutil/lightmanager.hpp>
#include <filesystem>
2022-10-09 10:39:43 +00:00
namespace VFS
{
class Manager;
}
namespace osg
{
class Group;
class Node;
class Program;
class State;
class Stats;
}
namespace Resource
{
2016-02-05 22:03:53 +00:00
class ImageManager;
class NifFileManager;
class BgsmFileManager;
class SharedStateManager;
}
namespace osgUtil
{
class IncrementalCompileOperation;
}
namespace Shader
{
class ShaderManager;
class ShaderVisitor;
}
2015-03-26 17:02:51 +00:00
namespace Resource
{
class TemplateRef : public osg::Object
{
public:
2022-09-22 18:26:05 +00:00
TemplateRef(const Object* object)
: mObject(object)
{
}
TemplateRef() {}
2022-09-22 18:26:05 +00:00
TemplateRef(const TemplateRef& copy, const osg::CopyOp&)
: mObject(copy.mObject)
{
}
META_Object(Resource, TemplateRef)
private:
osg::ref_ptr<const Object> mObject;
};
class TemplateMultiRef : public osg::Object
{
public:
TemplateMultiRef() {}
2022-09-22 18:26:05 +00:00
TemplateMultiRef(const TemplateMultiRef& copy, const osg::CopyOp&)
: mObjects(copy.mObjects)
{
}
void addRef(const osg::Node* node);
META_Object(Resource, TemplateMultiRef)
private:
std::vector<osg::ref_ptr<const Object>> mObjects;
};
2015-03-26 17:02:51 +00:00
/// @brief Handles loading and caching of scenes, e.g. .nif files or .osg files
2022-09-22 18:26:05 +00:00
/// @note Some methods of the scene manager can be used from any thread, see the methods documentation for more
/// details.
class SceneManager : public ResourceManager
2015-03-26 17:02:51 +00:00
{
public:
explicit SceneManager(const VFS::Manager* vfs, Resource::ImageManager* imageManager,
Resource::NifFileManager* nifFileManager, Resource::BgsmFileManager* bgsmFileManager, double expiryDelay);
2015-05-08 15:52:35 +00:00
~SceneManager();
2015-03-26 17:02:51 +00:00
Shader::ShaderManager& getShaderManager();
2022-09-22 18:26:05 +00:00
/// Re-create shaders for this node, need to call this if alpha testing, texture stages or vertex color mode
/// have changed.
void recreateShaders(osg::ref_ptr<osg::Node> node, const std::string& shaderPrefix = "objects",
bool forceShadersForNode = false, const osg::Program* programTemplate = nullptr);
/// Applying shaders to a node may replace some fixed-function state.
/// This restores it.
2022-09-22 18:26:05 +00:00
/// When editing such state, it should be reinstated before the edits, and shaders should be recreated
/// afterwards.
void reinstateRemovedState(osg::ref_ptr<osg::Node> node);
2016-02-18 16:08:18 +00:00
/// @see ShaderVisitor::setForceShaders
void setForceShaders(bool force);
bool getForceShaders() const;
2016-02-18 16:08:18 +00:00
void setClampLighting(bool clamp);
bool getClampLighting() const;
2016-02-18 16:08:18 +00:00
/// @see ShaderVisitor::setAutoUseNormalMaps
void setAutoUseNormalMaps(bool use);
/// @see ShaderVisitor::setNormalMapPattern
void setNormalMapPattern(const std::string& pattern);
2016-03-22 20:00:31 +00:00
/// @see ShaderVisitor::setNormalHeightMapPattern
void setNormalHeightMapPattern(const std::string& pattern);
2016-02-20 18:02:11 +00:00
void setAutoUseSpecularMaps(bool use);
void setSpecularMapPattern(const std::string& pattern);
void setApplyLightingToEnvMaps(bool apply);
void setSupportedLightingMethods(const SceneUtil::LightManager::SupportedMethods& supported);
bool isSupportedLightingMethod(SceneUtil::LightingMethod method) const;
2022-06-21 15:55:06 +00:00
void setOpaqueDepthTex(osg::ref_ptr<osg::Texture> texturePing, osg::ref_ptr<osg::Texture> texturePong);
2021-10-20 16:42:18 +00:00
osg::ref_ptr<osg::Texture> getOpaqueDepthTex(size_t frame);
enum class UBOBinding
{
2022-09-22 18:26:05 +00:00
// If we add more UBO's, we should probably assign their bindings dynamically according to the current count
// of UBO's in the programTemplate
2022-05-14 01:58:00 +00:00
LightBuffer,
PostProcessor
};
void setLightingMethod(SceneUtil::LightingMethod method);
SceneUtil::LightingMethod getLightingMethod() const;
2022-09-22 18:26:05 +00:00
2020-12-26 22:45:53 +00:00
void setConvertAlphaTestToAlphaToCoverage(bool convert);
void setAdjustCoverageForAlphaTest(bool adjustCoverage);
2021-02-21 18:38:15 +00:00
2022-09-22 18:26:05 +00:00
void setShaderPath(const std::filesystem::path& path);
/// Check if a given scene is loaded and if so, update its usage timestamp to prevent it from being unloaded
bool checkLoaded(VFS::Path::NormalizedView name, double referenceTime);
2015-03-26 17:02:51 +00:00
/// Get a read-only copy of this scene "template"
/// @note If the given filename does not exist or fails to load, an error marker mesh will be used instead.
/// If even the error marker mesh can not be found, an exception is thrown.
/// @note Thread safe.
2024-08-18 18:23:11 +00:00
osg::ref_ptr<const osg::Node> getTemplate(VFS::Path::NormalizedView path, bool compile = true);
2015-03-26 17:02:51 +00:00
/// Clone osg::Node safely.
/// @note Thread safe.
static osg::ref_ptr<osg::Node> cloneNode(const osg::Node* base);
2021-05-18 12:03:16 +00:00
void shareState(osg::ref_ptr<osg::Node> node);
/// Clone osg::Node and adjust it according to SceneManager's settings.
/// @note Thread safe.
osg::ref_ptr<osg::Node> getInstance(const osg::Node* base);
/// Instance the given scene template.
/// @see getTemplate
/// @note Thread safe.
2024-08-18 18:23:11 +00:00
osg::ref_ptr<osg::Node> getInstance(VFS::Path::NormalizedView path);
/// Instance the given scene template and immediately attach it to a parent node
/// @see getTemplate
/// @note Not thread safe, unless parentNode is not part of the main scene graph yet.
2024-08-18 18:23:11 +00:00
osg::ref_ptr<osg::Node> getInstance(VFS::Path::NormalizedView path, osg::Group* parentNode);
/// Attach the given scene instance to the given parent node
/// @note You should have the parentNode in its intended position before calling this method,
/// so that world space particles of the \a instance get transformed correctly.
/// @note Assumes the given instance was not attached to any parents before.
/// @note Not thread safe, unless parentNode is not part of the main scene graph yet.
void attachTo(osg::Node* instance, osg::Group* parentNode) const;
2015-03-26 17:02:51 +00:00
/// Manually release created OpenGL objects for the given graphics context. This may be required
/// in cases where multiple contexts are used over the lifetime of the application.
void releaseGLObjects(osg::State* state) override;
/// Set up an IncrementalCompileOperation for background compiling of loaded scenes.
void setIncrementalCompileOperation(osgUtil::IncrementalCompileOperation* ico);
osgUtil::IncrementalCompileOperation* getIncrementalCompileOperation();
Resource::ImageManager* getImageManager();
2015-11-10 16:00:33 +00:00
/// @param mask The node mask to apply to loaded particle system nodes.
void setParticleSystemMask(unsigned int mask);
2022-09-22 18:26:05 +00:00
/// @warning It is unsafe to call this method while the draw thread is using textures! call
/// Viewer::stopThreading first.
void setFilterSettings(
const std::string& magfilter, const std::string& minfilter, const std::string& mipmap, int maxAnisotropy);
2022-09-22 18:26:05 +00:00
/// Apply filter settings to the given texture. Note, when loading an object through this scene manager (i.e.
/// calling getTemplate or createInstance) the filter settings are applied automatically. This method is
/// provided for textures that were created outside of the SceneManager.
void applyFilterSettings(osg::Texture* tex);
2022-09-22 18:26:05 +00:00
/// Keep a copy of the texture data around in system memory? This is needed when using multiple graphics
/// contexts, otherwise should be disabled to reduce memory usage.
void setUnRefImageDataAfterApply(bool unref);
2016-02-09 17:33:02 +00:00
/// @see ResourceManager::updateCache
void updateCache(double referenceTime) override;
2016-02-09 17:33:02 +00:00
void clearCache() override;
2017-08-20 23:55:16 +00:00
void reportStats(unsigned int frameNumber, osg::Stats* stats) const override;
2022-05-14 01:58:00 +00:00
void setSupportsNormalsRT(bool supports) { mSupportsNormalsRT = supports; }
bool getSupportsNormalsRT() const { return mSupportsNormalsRT; }
2024-03-23 21:56:30 +00:00
void setUpNormalsRTForStateSet(osg::StateSet* stateset, bool enabled);
void setSoftParticles(bool enabled) { mSoftParticles = enabled; }
bool getSoftParticles() const { return mSoftParticles; }
void setWeatherParticleOcclusion(bool value) { mWeatherParticleOcclusion = value; }
2015-03-26 17:02:51 +00:00
private:
osg::ref_ptr<Shader::ShaderVisitor> createShaderVisitor(const std::string& shaderPrefix = "objects");
osg::ref_ptr<osg::Node> loadErrorMarker();
osg::ref_ptr<osg::Node> cloneErrorMarker();
std::unique_ptr<Shader::ShaderManager> mShaderManager;
2016-02-18 16:08:18 +00:00
bool mForceShaders;
bool mClampLighting;
bool mAutoUseNormalMaps;
std::string mNormalMapPattern;
2016-03-22 20:00:31 +00:00
std::string mNormalHeightMapPattern;
2016-02-20 18:02:11 +00:00
bool mAutoUseSpecularMaps;
std::string mSpecularMapPattern;
bool mApplyLightingToEnvMaps;
SceneUtil::LightingMethod mLightingMethod;
SceneUtil::LightManager::SupportedMethods mSupportedLightingMethods;
2020-12-26 22:45:53 +00:00
bool mConvertAlphaTestToAlphaToCoverage;
bool mAdjustCoverageForAlphaTest;
2022-05-14 01:58:00 +00:00
bool mSupportsNormalsRT;
2022-06-21 15:55:06 +00:00
std::array<osg::ref_ptr<osg::Texture>, 2> mOpaqueDepthTex;
bool mSoftParticles = false;
bool mWeatherParticleOcclusion = false;
2016-02-18 16:08:18 +00:00
osg::ref_ptr<Resource::SharedStateManager> mSharedStateManager;
2020-06-25 19:46:07 +00:00
mutable std::mutex mSharedStateMutex;
Resource::ImageManager* mImageManager;
Resource::NifFileManager* mNifFileManager;
Resource::BgsmFileManager* mBgsmFileManager;
2015-03-26 17:02:51 +00:00
osg::Texture::FilterMode mMinFilter;
osg::Texture::FilterMode mMagFilter;
int mMaxAnisotropy;
bool mUnRefImageDataAfterApply;
osg::ref_ptr<osgUtil::IncrementalCompileOperation> mIncrementalCompileOperation;
2015-11-10 16:00:33 +00:00
unsigned int mParticleSystemMask;
mutable osg::ref_ptr<osg::Node> mErrorMarker;
2015-11-10 16:00:33 +00:00
2015-05-08 15:52:35 +00:00
SceneManager(const SceneManager&);
2022-09-22 18:26:05 +00:00
void operator=(const SceneManager&);
2015-03-26 17:02:51 +00:00
};
}
#endif