|
|
@ -36,8 +36,8 @@ Water::Water (Ogre::Camera *camera, SkyManager* sky, const ESM::Cell* cell) :
|
|
|
|
+ RV_Statics * Settings::Manager::getBool("reflect statics", "Water")
|
|
|
|
+ RV_Statics * Settings::Manager::getBool("reflect statics", "Water")
|
|
|
|
+ RV_StaticsSmall * Settings::Manager::getBool("reflect small statics", "Water")
|
|
|
|
+ RV_StaticsSmall * Settings::Manager::getBool("reflect small statics", "Water")
|
|
|
|
+ RV_Actors * Settings::Manager::getBool("reflect actors", "Water")
|
|
|
|
+ RV_Actors * Settings::Manager::getBool("reflect actors", "Water")
|
|
|
|
+ RV_Misc * Settings::Manager::getBool("reflect misc", "Water");
|
|
|
|
+ RV_Misc * Settings::Manager::getBool("reflect misc", "Water")
|
|
|
|
//+ RV_Sky;
|
|
|
|
+ RV_Sky;
|
|
|
|
mReflectDistance = Settings::Manager::getInt("reflect distance", "Water");
|
|
|
|
mReflectDistance = Settings::Manager::getInt("reflect distance", "Water");
|
|
|
|
|
|
|
|
|
|
|
|
mWaterNode = mSceneManager->getRootSceneNode()->createChildSceneNode();
|
|
|
|
mWaterNode = mSceneManager->getRootSceneNode()->createChildSceneNode();
|
|
|
@ -145,11 +145,14 @@ void Water::preRenderTargetUpdate(const RenderTargetEvent& evt)
|
|
|
|
if (mReflectDistance != 0)
|
|
|
|
if (mReflectDistance != 0)
|
|
|
|
mCamera->setFarClipDistance(mReflectDistance);
|
|
|
|
mCamera->setFarClipDistance(mReflectDistance);
|
|
|
|
|
|
|
|
|
|
|
|
if (evt.source == mReflectionTarget)
|
|
|
|
if (evt.source == mReflectionTarget)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mCamera->enableCustomNearClipPlane(Plane(Vector3::UNIT_Y, mTop));
|
|
|
|
Vector3 pos = mCamera->getRealPosition();
|
|
|
|
mCamera->enableReflection(Plane(Vector3::UNIT_Y, mTop));
|
|
|
|
pos.y = mTop*2 - pos.y;
|
|
|
|
}
|
|
|
|
mSky->setSkyPosition(pos);
|
|
|
|
|
|
|
|
mCamera->enableCustomNearClipPlane(Plane(Vector3::UNIT_Y, mTop));
|
|
|
|
|
|
|
|
mCamera->enableReflection(Plane(Vector3::UNIT_Y, mTop));
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void Water::postRenderTargetUpdate(const RenderTargetEvent& evt)
|
|
|
|
void Water::postRenderTargetUpdate(const RenderTargetEvent& evt)
|
|
|
@ -158,11 +161,12 @@ void Water::postRenderTargetUpdate(const RenderTargetEvent& evt)
|
|
|
|
|
|
|
|
|
|
|
|
mCamera->setFarClipDistance(mOldCameraFarClip);
|
|
|
|
mCamera->setFarClipDistance(mOldCameraFarClip);
|
|
|
|
|
|
|
|
|
|
|
|
if (evt.source == mReflectionTarget)
|
|
|
|
if (evt.source == mReflectionTarget)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
mCamera->disableReflection();
|
|
|
|
mSky->resetSkyPosition();
|
|
|
|
mCamera->disableCustomNearClipPlane();
|
|
|
|
mCamera->disableReflection();
|
|
|
|
}
|
|
|
|
mCamera->disableCustomNearClipPlane();
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
Ogre::MaterialPtr Water::createMaterial()
|
|
|
|
Ogre::MaterialPtr Water::createMaterial()
|
|
|
@ -199,4 +203,10 @@ Ogre::MaterialPtr Water::createMaterial()
|
|
|
|
return mat;
|
|
|
|
return mat;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void Water::setViewportBackground(const ColourValue& bg)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
if (mReflectionTarget)
|
|
|
|
|
|
|
|
mReflectionTarget->getViewport(0)->setBackgroundColour(bg);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} // namespace
|
|
|
|
} // namespace
|
|
|
|