99 lines
2.8 KiB
PostScript
99 lines
2.8 KiB
PostScript
|
/**
|
||
|
* @ Version: SCREEN SPACE SHADERS - UPDATE 21
|
||
|
* @ Description: SSR
|
||
|
* @ Modified time: 2024-06-03 09:01
|
||
|
* @ Author: https://www.moddb.com/members/ascii1457
|
||
|
* @ Mod: https://www.moddb.com/mods/stalker-anomaly/addons/screen-space-shaders
|
||
|
*/
|
||
|
|
||
|
//uniform float4 shader_param_7;
|
||
|
|
||
|
#include "screenspace_reflections.h"
|
||
|
|
||
|
float4x4 m_current; // Current projection matrix
|
||
|
float4x4 m_previous; // Previous projection matrix
|
||
|
float4 cam_pos;
|
||
|
|
||
|
Texture2D ssr_image;
|
||
|
Texture2D s_prev_pos;
|
||
|
Texture2D s_gloss_data;
|
||
|
Texture2D s_hud_mask;
|
||
|
|
||
|
float4 main(p_screen I) : SV_Target
|
||
|
{
|
||
|
// Sample buffers and prepare all requiered data ------------------
|
||
|
|
||
|
// Scale TexCoor
|
||
|
float2 tc = I.tc0 * ssr_setup.x;
|
||
|
float2 Pos2D = I.hpos * ssr_setup.x;
|
||
|
|
||
|
|
||
|
// Sample buffers
|
||
|
#ifndef USE_MSAA
|
||
|
float4 Pos = s_position.Sample( smp_nofilter, tc );
|
||
|
#else
|
||
|
float4 Pos = s_position.Load( int3( Pos2D, 0 ), 0 );
|
||
|
#endif
|
||
|
|
||
|
float4 GlossData = s_gloss_data.Sample( smp_linear, tc );
|
||
|
float HUD_mask = s_hud_mask.Sample(smp_nofilter, tc).r;
|
||
|
|
||
|
// Reconstruct Position, Normal and Material
|
||
|
float3 P = float3( Pos.z * ( Pos2D * pos_decompression_params.zw - pos_decompression_params.xy ), Pos.z );
|
||
|
float3 N = gbuf_unpack_normal( Pos.xy );
|
||
|
float mtl = gbuf_unpack_mtl( Pos.w );
|
||
|
|
||
|
// SSR ------------------------------------------------------------
|
||
|
float4 ssr_result = 0;
|
||
|
float2 noise = 0;
|
||
|
|
||
|
|
||
|
// Do the SSR
|
||
|
SSFX_ScreenSpaceReflections(tc, float4(P, mtl), N, GlossData, ssr_result, HUD_mask, noise, 0);
|
||
|
|
||
|
// Accumulation ---------------------------------------------------
|
||
|
|
||
|
// Position
|
||
|
float4 P4 = float4(P, 1.0);
|
||
|
|
||
|
// Get current
|
||
|
float4 p_current = mul(m_current, P4);
|
||
|
|
||
|
// Get previous
|
||
|
float4 p_previous = mul(m_previous, P4);
|
||
|
|
||
|
float3 current = p_current.xyz / p_current.w;
|
||
|
float3 previous = p_previous.xyz / p_previous.w;
|
||
|
|
||
|
// Reprojection UV
|
||
|
float2 uv_rp = float2(current.x - previous.x, current.y - previous.y) * HUD_mask;
|
||
|
uv_rp = float2(uv_rp.x, -uv_rp.y) * 0.5f;
|
||
|
|
||
|
// Prev Position + Reprojection UV
|
||
|
float4 prev_P = s_prev_pos.Sample( smp_linear, (tc - uv_rp) ); //
|
||
|
|
||
|
uv_rp /= ssr_setup.x;
|
||
|
|
||
|
// Disocclusion
|
||
|
float docc = abs(1.0f - P.z / prev_P.z) * 5.0f;
|
||
|
|
||
|
//float vel = saturate(distance(current.xy, previous.xy) * 10.0f);
|
||
|
|
||
|
// Offscreen check
|
||
|
int outoffsrc = any((I.tc0 - uv_rp) < 0) + any((I.tc0 - uv_rp) > (1.0 / ssr_setup.x));
|
||
|
|
||
|
// Previous frame + Reprojection UV
|
||
|
float4 prev = ssr_image.Sample(smp_linear, I.tc0 - uv_rp);
|
||
|
|
||
|
// 0 Current frame ~ 1 Prev frame 1 - 2 - 4
|
||
|
float weight = saturate((0.5f + (ssr_setup.x * 0.1f * HUD_mask)) - (outoffsrc + docc)); // + vel
|
||
|
|
||
|
// Apply gloss intensity data to avoid leaking
|
||
|
ssr_result.rgb *= saturate(GlossData.a * 10.0f); // 0.1f == 1.0f
|
||
|
|
||
|
// ----------------------------------------------------------------
|
||
|
|
||
|
// Mix with previous SSR results. Higher weight more of the previous frame used
|
||
|
return float4(lerp(ssr_result.rgb, prev.rgb, weight ), 1.0f);
|
||
|
}
|