mirror of
https://github.com/TES3MP/openmw-tes3mp.git
synced 2025-01-19 23:23:52 +00:00
Use simple water for the local map
This commit is contained in:
parent
09631385c3
commit
6ba9f561ea
4 changed files with 15 additions and 13 deletions
|
@ -173,7 +173,7 @@ osg::ref_ptr<osg::Camera> LocalMap::createOrthographicCamera(float x, float y, f
|
||||||
camera->setClearMask(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
camera->setClearMask(GL_COLOR_BUFFER_BIT | GL_DEPTH_BUFFER_BIT);
|
||||||
camera->setRenderOrder(osg::Camera::PRE_RENDER);
|
camera->setRenderOrder(osg::Camera::PRE_RENDER);
|
||||||
|
|
||||||
camera->setCullMask(Mask_Scene|Mask_Water|Mask_Terrain);
|
camera->setCullMask(Mask_Scene|Mask_SimpleWater|Mask_Terrain);
|
||||||
camera->setNodeMask(Mask_RenderToTexture);
|
camera->setNodeMask(Mask_RenderToTexture);
|
||||||
|
|
||||||
osg::ref_ptr<osg::StateSet> stateset = new osg::StateSet;
|
osg::ref_ptr<osg::StateSet> stateset = new osg::StateSet;
|
||||||
|
|
|
@ -191,7 +191,7 @@ namespace MWRender
|
||||||
mViewer->getCamera()->setComputeNearFarMode(osg::Camera::DO_NOT_COMPUTE_NEAR_FAR);
|
mViewer->getCamera()->setComputeNearFarMode(osg::Camera::DO_NOT_COMPUTE_NEAR_FAR);
|
||||||
mViewer->getCamera()->setCullingMode(cullingMode);
|
mViewer->getCamera()->setCullingMode(cullingMode);
|
||||||
|
|
||||||
mViewer->getCamera()->setCullMask(~(Mask_UpdateVisitor));
|
mViewer->getCamera()->setCullMask(~(Mask_UpdateVisitor|Mask_SimpleWater));
|
||||||
|
|
||||||
mNearClip = Settings::Manager::getFloat("near clip", "Camera");
|
mNearClip = Settings::Manager::getFloat("near clip", "Camera");
|
||||||
mViewDistance = Settings::Manager::getFloat("viewing distance", "Camera");
|
mViewDistance = Settings::Manager::getFloat("viewing distance", "Camera");
|
||||||
|
|
|
@ -16,18 +16,19 @@ namespace MWRender
|
||||||
Mask_Player = (1<<4),
|
Mask_Player = (1<<4),
|
||||||
Mask_Sky = (1<<5),
|
Mask_Sky = (1<<5),
|
||||||
Mask_Water = (1<<6),
|
Mask_Water = (1<<6),
|
||||||
Mask_Terrain = (1<<7),
|
Mask_SimpleWater = (1<<7),
|
||||||
Mask_FirstPerson = (1<<8),
|
Mask_Terrain = (1<<8),
|
||||||
|
Mask_FirstPerson = (1<<9),
|
||||||
|
|
||||||
// top level masks
|
// top level masks
|
||||||
Mask_Scene = (1<<9),
|
Mask_Scene = (1<<10),
|
||||||
Mask_GUI = (1<<10),
|
Mask_GUI = (1<<11),
|
||||||
|
|
||||||
// Set on a Geode
|
// Set on a Geode
|
||||||
Mask_ParticleSystem = (1<<11),
|
Mask_ParticleSystem = (1<<12),
|
||||||
|
|
||||||
// Set on cameras within the main scene graph
|
// Set on cameras within the main scene graph
|
||||||
Mask_RenderToTexture = (1<<12)
|
Mask_RenderToTexture = (1<<13)
|
||||||
|
|
||||||
// reserved: (1<<16) for SceneUtil::Mask_Lit
|
// reserved: (1<<16) for SceneUtil::Mask_Lit
|
||||||
};
|
};
|
||||||
|
|
|
@ -301,7 +301,6 @@ osg::ref_ptr<osg::Image> readPngImage (const std::string& file)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
Water::Water(osg::Group *parent, osg::Group* sceneRoot, Resource::ResourceSystem *resourceSystem, osgUtil::IncrementalCompileOperation *ico,
|
Water::Water(osg::Group *parent, osg::Group* sceneRoot, Resource::ResourceSystem *resourceSystem, osgUtil::IncrementalCompileOperation *ico,
|
||||||
const MWWorld::Fallback* fallback, const std::string& resourcePath)
|
const MWWorld::Fallback* fallback, const std::string& resourcePath)
|
||||||
: mParent(parent)
|
: mParent(parent)
|
||||||
|
@ -319,16 +318,18 @@ Water::Water(osg::Group *parent, osg::Group* sceneRoot, Resource::ResourceSystem
|
||||||
geode->addDrawable(waterGeom);
|
geode->addDrawable(waterGeom);
|
||||||
geode->setNodeMask(Mask_Water);
|
geode->setNodeMask(Mask_Water);
|
||||||
|
|
||||||
// TODO: node mask to use simple water for local map
|
|
||||||
|
|
||||||
if (ico)
|
if (ico)
|
||||||
ico->add(geode);
|
ico->add(geode);
|
||||||
|
|
||||||
//createSimpleWaterStateSet(mResourceSystem, geode);
|
|
||||||
|
|
||||||
mWaterNode = new osg::PositionAttitudeTransform;
|
mWaterNode = new osg::PositionAttitudeTransform;
|
||||||
mWaterNode->addChild(geode);
|
mWaterNode->addChild(geode);
|
||||||
|
|
||||||
|
// simple water fallback for the local map
|
||||||
|
osg::ref_ptr<osg::Geode> geode2 (osg::clone(geode.get(), osg::CopyOp::DEEP_COPY_NODES));
|
||||||
|
createSimpleWaterStateSet(mResourceSystem, geode2);
|
||||||
|
geode2->setNodeMask(Mask_SimpleWater);
|
||||||
|
mWaterNode->addChild(geode2);
|
||||||
|
|
||||||
mSceneRoot->addChild(mWaterNode);
|
mSceneRoot->addChild(mWaterNode);
|
||||||
|
|
||||||
setHeight(mTop);
|
setHeight(mTop);
|
||||||
|
|
Loading…
Reference in a new issue