mirror of
https://github.com/OpenMW/openmw.git
synced 2025-10-24 18:26:37 +00:00
Merge branch 'skyfix' into 'master'
Do not lose existing callbacks for sky node Closes #7427 See merge request OpenMW/openmw!3171
This commit is contained in:
commit
f34b57656a
2 changed files with 5 additions and 2 deletions
|
@ -147,7 +147,8 @@ namespace MWRender
|
||||||
|
|
||||||
void PrecipitationOccluder::enable()
|
void PrecipitationOccluder::enable()
|
||||||
{
|
{
|
||||||
mSkyNode->setCullCallback(new PrecipitationOcclusionUpdater(mDepthTexture));
|
mSkyCullCallback = new PrecipitationOcclusionUpdater(mDepthTexture);
|
||||||
|
mSkyNode->addCullCallback(mSkyCullCallback);
|
||||||
mCamera->setCullCallback(new DepthCameraUpdater);
|
mCamera->setCullCallback(new DepthCameraUpdater);
|
||||||
|
|
||||||
mRootNode->removeChild(mCamera);
|
mRootNode->removeChild(mCamera);
|
||||||
|
@ -156,8 +157,9 @@ namespace MWRender
|
||||||
|
|
||||||
void PrecipitationOccluder::disable()
|
void PrecipitationOccluder::disable()
|
||||||
{
|
{
|
||||||
mSkyNode->setCullCallback(nullptr);
|
mSkyNode->removeCullCallback(mSkyCullCallback);
|
||||||
mCamera->setCullCallback(nullptr);
|
mCamera->setCullCallback(nullptr);
|
||||||
|
mSkyCullCallback = nullptr;
|
||||||
|
|
||||||
mRootNode->removeChild(mCamera);
|
mRootNode->removeChild(mCamera);
|
||||||
}
|
}
|
||||||
|
|
|
@ -23,6 +23,7 @@ namespace MWRender
|
||||||
osg::Group* mSkyNode;
|
osg::Group* mSkyNode;
|
||||||
osg::Group* mSceneNode;
|
osg::Group* mSceneNode;
|
||||||
osg::Group* mRootNode;
|
osg::Group* mRootNode;
|
||||||
|
osg::ref_ptr<osg::Callback> mSkyCullCallback;
|
||||||
osg::ref_ptr<osg::Camera> mCamera;
|
osg::ref_ptr<osg::Camera> mCamera;
|
||||||
osg::ref_ptr<osg::Camera> mSceneCamera;
|
osg::ref_ptr<osg::Camera> mSceneCamera;
|
||||||
osg::ref_ptr<osg::Texture2D> mDepthTexture;
|
osg::ref_ptr<osg::Texture2D> mDepthTexture;
|
||||||
|
|
Loading…
Reference in a new issue