2021-07-24 21:11:47 -07:00

36 lines
1.0 KiB
Plaintext

//========== Copyright (c) Valve Corporation, All rights reserved. ==========//
#include "common_ps_fxc.h"
#define NUM_TAPS 18
struct PS_INPUT
{
float2 vPos : VPOS; // Normalized Screenpos, call ComputeScreenPos() to get useful 2D coordinates
};
sampler TexSampler : register( s0 );
float2 vDir : register( c0 ); // This will be [1,0] or [0,1]
float vCoeff[NUM_TAPS] : register( c33 );
float4 main( PS_INPUT i ) : COLOR
{
// Center tap at vPos
float4 sampleCenter = tex2D( TexSampler, saturate( ComputeScreenPos( i.vPos ) ) );
float4 accum = vCoeff[0] * sampleCenter;
// Positive and negative offsets per "loop" (we unroll because we can't actually index the constant store)
[unroll]
for ( int j=1; j < NUM_TAPS; j++ )
{
float4 sample0 = tex2D( TexSampler, saturate( ComputeScreenPos( i.vPos + ( vDir * j ) ) ) );
accum += vCoeff[j] * sample0;
float4 sample1 = tex2D( TexSampler, saturate( ComputeScreenPos( i.vPos - ( vDir * j ) ) ) );
accum += vCoeff[j] * sample1;
}
return max( 0, accum );
}