diff --git a/Source/Core/VideoCommon/VertexShaderManager.cpp b/Source/Core/VideoCommon/VertexShaderManager.cpp index 680d1ad3ee..555819e072 100644 --- a/Source/Core/VideoCommon/VertexShaderManager.cpp +++ b/Source/Core/VideoCommon/VertexShaderManager.cpp @@ -38,6 +38,7 @@ static bool bProjectionChanged; static bool bViewportChanged; static bool bTexMtxInfoChanged; static bool bLightingConfigChanged; +static bool bProjectionGraphicsModChange; static BitSet32 nMaterialsChanged; static std::array nTransformMatricesChanged; // min,max static std::array nNormalMatricesChanged; // min,max @@ -63,6 +64,7 @@ void VertexShaderManager::Init() bViewportChanged = false; bTexMtxInfoChanged = false; bLightingConfigChanged = false; + bProjectionGraphicsModChange = false; std::memset(static_cast(&xfmem), 0, sizeof(xfmem)); constants = {}; @@ -322,9 +324,10 @@ void VertexShaderManager::SetConstants(const std::vector& textures) } if (bProjectionChanged || g_freelook_camera.GetController()->IsDirty() || - !projection_actions.empty()) + !projection_actions.empty() || bProjectionGraphicsModChange) { bProjectionChanged = false; + bProjectionGraphicsModChange = !projection_actions.empty(); const auto& rawProjection = xfmem.projection.rawProjection;