1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-16 18:29:55 +00:00

remove redunant conditional checks when getting uniforms

This commit is contained in:
glassmancody.info 2023-01-28 10:40:24 -08:00
parent 22c62a8c38
commit 165013ddd6

View file

@ -104,9 +104,7 @@ namespace MWRender
void apply(osg::StateSet* stateset, osg::NodeVisitor* nv) override void apply(osg::StateSet* stateset, osg::NodeVisitor* nv) override
{ {
auto* uProjectionMatrix = stateset->getUniform("projectionMatrix"); stateset->getUniform("projectionMatrix")->set(mProjectionMatrix);
if (uProjectionMatrix)
uProjectionMatrix->set(mProjectionMatrix);
if (mSkyRTT && nv->getVisitorType() == osg::NodeVisitor::CULL_VISITOR) if (mSkyRTT && nv->getVisitorType() == osg::NodeVisitor::CULL_VISITOR)
{ {
osg::Texture* skyTexture = mSkyRTT->getColorTexture(static_cast<osgUtil::CullVisitor*>(nv)); osg::Texture* skyTexture = mSkyRTT->getColorTexture(static_cast<osgUtil::CullVisitor*>(nv));
@ -120,18 +118,12 @@ namespace MWRender
void applyLeft(osg::StateSet* stateset, osgUtil::CullVisitor* nv) override void applyLeft(osg::StateSet* stateset, osgUtil::CullVisitor* nv) override
{ {
auto* uProjectionMatrix = stateset->getUniform("projectionMatrix"); stateset->getUniform("projectionMatrix")->set(getEyeProjectionMatrix(0));
if (uProjectionMatrix)
uProjectionMatrix->set(Stereo::Manager::instance().computeEyeViewOffset(0)
* Stereo::Manager::instance().computeEyeProjection(0, SceneUtil::AutoDepth::isReversed()));
} }
void applyRight(osg::StateSet* stateset, osgUtil::CullVisitor* nv) override void applyRight(osg::StateSet* stateset, osgUtil::CullVisitor* nv) override
{ {
auto* uProjectionMatrix = stateset->getUniform("projectionMatrix"); stateset->getUniform("projectionMatrix")->set(getEyeProjectionMatrix(1));
if (uProjectionMatrix)
uProjectionMatrix->set(Stereo::Manager::instance().computeEyeViewOffset(1)
* Stereo::Manager::instance().computeEyeProjection(1, SceneUtil::AutoDepth::isReversed()));
} }
void setProjectionMatrix(const osg::Matrixf& projectionMatrix) { mProjectionMatrix = projectionMatrix; } void setProjectionMatrix(const osg::Matrixf& projectionMatrix) { mProjectionMatrix = projectionMatrix; }
@ -145,6 +137,12 @@ namespace MWRender
} }
private: private:
osg::Matrixf getEyeProjectionMatrix(int view)
{
return Stereo::Manager::instance().computeEyeViewOffset(view)
* Stereo::Manager::instance().computeEyeProjection(view, SceneUtil::AutoDepth::isReversed());
}
osg::Matrixf mProjectionMatrix; osg::Matrixf mProjectionMatrix;
int mSkyTextureUnit = -1; int mSkyTextureUnit = -1;
SceneUtil::RTTNode* mSkyRTT = nullptr; SceneUtil::RTTNode* mSkyRTT = nullptr;
@ -160,8 +158,9 @@ namespace MWRender
: mLinearFac(0.f) : mLinearFac(0.f)
, mNear(0.f) , mNear(0.f)
, mFar(0.f) , mFar(0.f)
, mUsePlayerUniforms(usePlayerUniforms)
, mWindSpeed(0.f) , mWindSpeed(0.f)
, mSkyBlendingStartCoef(Settings::Manager::getFloat("sky blending start", "Fog"))
, mUsePlayerUniforms(usePlayerUniforms)
{ {
} }
@ -173,6 +172,7 @@ namespace MWRender
stateset->addUniform(new osg::Uniform("skyBlendingStart", 0.f)); stateset->addUniform(new osg::Uniform("skyBlendingStart", 0.f));
stateset->addUniform(new osg::Uniform("screenRes", osg::Vec2f{})); stateset->addUniform(new osg::Uniform("screenRes", osg::Vec2f{}));
stateset->addUniform(new osg::Uniform("isReflection", false)); stateset->addUniform(new osg::Uniform("isReflection", false));
if (mUsePlayerUniforms) if (mUsePlayerUniforms)
{ {
stateset->addUniform(new osg::Uniform("windSpeed", 0.0f)); stateset->addUniform(new osg::Uniform("windSpeed", 0.0f));
@ -182,36 +182,16 @@ namespace MWRender
void apply(osg::StateSet* stateset, osg::NodeVisitor* nv) override void apply(osg::StateSet* stateset, osg::NodeVisitor* nv) override
{ {
auto* uLinearFac = stateset->getUniform("linearFac"); stateset->getUniform("linearFac")->set(mLinearFac);
if (uLinearFac) stateset->getUniform("near")->set(mNear);
uLinearFac->set(mLinearFac); stateset->getUniform("far")->set(mFar);
stateset->getUniform("skyBlendingStart")->set(mFar * mSkyBlendingStartCoef);
auto* uNear = stateset->getUniform("near"); stateset->getUniform("screenRes")->set(mScreenRes);
if (uNear)
uNear->set(mNear);
auto* uFar = stateset->getUniform("far");
if (uFar)
uFar->set(mFar);
static const float mSkyBlendingStartCoef = Settings::Manager::getFloat("sky blending start", "Fog");
auto* uSkyBlendingStart = stateset->getUniform("skyBlendingStart");
if (uSkyBlendingStart)
uSkyBlendingStart->set(mFar * mSkyBlendingStartCoef);
auto* uScreenRes = stateset->getUniform("screenRes");
if (uScreenRes)
uScreenRes->set(mScreenRes);
if (mUsePlayerUniforms) if (mUsePlayerUniforms)
{ {
auto* windSpeed = stateset->getUniform("windSpeed"); stateset->getUniform("windSpeed")->set(mWindSpeed);
if (windSpeed) stateset->getUniform("playerPos")->set(mPlayerPos);
windSpeed->set(mWindSpeed);
auto* playerPos = stateset->getUniform("playerPos");
if (playerPos)
playerPos->set(mPlayerPos);
} }
} }
@ -231,8 +211,9 @@ namespace MWRender
float mLinearFac; float mLinearFac;
float mNear; float mNear;
float mFar; float mFar;
bool mUsePlayerUniforms;
float mWindSpeed; float mWindSpeed;
float mSkyBlendingStartCoef;
bool mUsePlayerUniforms;
osg::Vec3f mPlayerPos; osg::Vec3f mPlayerPos;
osg::Vec2f mScreenRes; osg::Vec2f mScreenRes;
}; };