From dc8c5e6209451c1b88fe821ee9d90d18a46be8a1 Mon Sep 17 00:00:00 2001 From: refractionpcsx2 Date: Mon, 31 Jul 2023 16:17:39 +0100 Subject: [PATCH] GS/HW: Use texture alpha for 16bit textures in CalcAlphaMinMax --- pcsx2/GS/GSState.cpp | 9 ++++++--- pcsx2/GS/GSState.h | 2 +- 2 files changed, 7 insertions(+), 4 deletions(-) diff --git a/pcsx2/GS/GSState.cpp b/pcsx2/GS/GSState.cpp index 515174a4da..991a34860b 100644 --- a/pcsx2/GS/GSState.cpp +++ b/pcsx2/GS/GSState.cpp @@ -3689,7 +3689,8 @@ void GSState::CalcAlphaMinMax(const int tex_alpha_min, const int tex_alpha_max) return; // We wanted to force an update as we now know the alpha of the non-indexed texture. - int min = tex_alpha_min, max = tex_alpha_max; + // Limit max to 255 as we send 500 when we don't know, makes calculating 16bit easier. + int min = tex_alpha_min, max = std::min(tex_alpha_max, 255); if (IsCoverageAlpha()) { @@ -3715,8 +3716,10 @@ void GSState::CalcAlphaMinMax(const int tex_alpha_min, const int tex_alpha_max) a.w = env.TEXA.TA0; break; case 2: - a.y = env.TEXA.AEM ? 0 : std::min(env.TEXA.TA0, env.TEXA.TA1); - a.w = std::max(env.TEXA.TA0, env.TEXA.TA1); + // If we're using the alpha from the texture, not the whole range, we can just use tex_alpha_min/max. + // TA0/TA1 is precomputed with GSBlock::ReadAndExpandBlock16, so already worked out for tex_alpha. + a.y = (tex_alpha_max < 500) ? min : (env.TEXA.AEM ? 0 : std::min(env.TEXA.TA0, env.TEXA.TA1)); + a.w = (tex_alpha_max < 500) ? max : std::max(env.TEXA.TA0, env.TEXA.TA1); break; case 3: m_mem.m_clut.GetAlphaMinMax32(a.y, a.w); diff --git a/pcsx2/GS/GSState.h b/pcsx2/GS/GSState.h index 805b487fc4..c55c3ec273 100644 --- a/pcsx2/GS/GSState.h +++ b/pcsx2/GS/GSState.h @@ -175,7 +175,7 @@ protected: GSVertexTrace::VertexAlpha& GetAlphaMinMax() { if (!m_vt.m_alpha.valid) - CalcAlphaMinMax(0, 255); + CalcAlphaMinMax(0, 500); return m_vt.m_alpha; } struct TextureMinMaxResult