init
This commit is contained in:
commit
2fe6ca2f65
1473 changed files with 251771 additions and 0 deletions
107
gamedata/shaders/r2/ssao.ps.hlsl
Normal file
107
gamedata/shaders/r2/ssao.ps.hlsl
Normal file
|
|
@ -0,0 +1,107 @@
|
|||
#ifndef SSAO_1231242112
|
||||
#define SSAO_1231242112
|
||||
#include "common.hlsli"
|
||||
|
||||
#ifndef SSAO_QUALITY
|
||||
|
||||
float calc_ssao(float3 P, float3 N, float2 tc, float2 tcJ)
|
||||
{
|
||||
return 1.0;
|
||||
}
|
||||
|
||||
#else // SSAO_QUALITY
|
||||
|
||||
uniform sampler2D jitter0;
|
||||
// uniform float4 screen_res;
|
||||
uniform float4 pos_decompression_params;
|
||||
|
||||
#define SSAO_RADIUS 0.8
|
||||
#define rcp(x) (1.0f / (x))
|
||||
|
||||
float3 uv_to_eye(float2 uv, float eye_z)
|
||||
{
|
||||
uv = uv * float2(2.0f, 2.0f) - float2(1.0f, 1.0f);
|
||||
return float3(uv * pos_decompression_params.xy, 1.0f) * eye_z;
|
||||
}
|
||||
|
||||
/*
|
||||
SSAO Нагло украдено у Sir Lancevrot (с его разрешения)
|
||||
*/
|
||||
|
||||
float3 GetViewPos(float2 uv)
|
||||
{
|
||||
float3 tap_pos = tex2Dlod(s_position, float4(uv, 0.0f, 0.0f));
|
||||
return uv_to_eye(uv, tap_pos.z);
|
||||
}
|
||||
|
||||
float doPBAO(float2 uv, float3 pos, float3 n, float invRad, float bias, float selfOcc)
|
||||
{
|
||||
float3 p = GetViewPos(uv);
|
||||
float3 dist = p - pos;
|
||||
|
||||
float len = length(dist);
|
||||
float3 v = dist * rcp(len);
|
||||
|
||||
float atten = len * invRad;
|
||||
return max(-selfOcc, dot(n, v) - bias) * rcp(atten * atten + 1.0f);
|
||||
}
|
||||
|
||||
float calc_ssao(float3 pos, float3 normal, float2 tc0, float2 tcJ)
|
||||
{
|
||||
// define kernel
|
||||
float n = 0.0f;
|
||||
const float step = 0.875f;
|
||||
const float fScale = 0.57735f * 0.025f;
|
||||
|
||||
const float inv2 = 0.5f;
|
||||
const float inv5_3 = 0.188679245283f;
|
||||
const float inv8 = 0.125f;
|
||||
const float inv16 = 0.0625f;
|
||||
const float selfOcc = 0.0f; // range: 0.0f to 1.0f
|
||||
const float2 focalLen = rcp(pos_decompression_params.xy);
|
||||
|
||||
const float3 arrKernel[8] =
|
||||
{
|
||||
float3( 1.0, 1.0, 1.0) * fScale * (n += step),
|
||||
float3(-1.0, -1.0, -1.0) * fScale * (n += step),
|
||||
float3(-1.0, -1.0, 1.0) * fScale * (n += step),
|
||||
float3(-1.0, 1.0, -1.0) * fScale * (n += step),
|
||||
float3(-1.0, 1.0, 1.0) * fScale * (n += step),
|
||||
float3( 1.0, -1.0, -1.0) * fScale * (n += step),
|
||||
float3( 1.0, -1.0, 1.0) * fScale * (n += step),
|
||||
float3( 1.0, 1.0, -1.0) * fScale * (n += step),
|
||||
};
|
||||
|
||||
float2 tc1 = tc0 * screen_res.xy * 0.015625f;
|
||||
float3 rotSample = tex2D(jitter0, tc1).xyz;
|
||||
rotSample = normalize(rotSample - 0.5f);
|
||||
|
||||
pos = uv_to_eye(tc0, pos.z * 0.99f);
|
||||
|
||||
// calculate angle bias
|
||||
float bias = 0.0;
|
||||
|
||||
// calculate contrast
|
||||
float contrast = inv16 * rcp(1.0f - saturate(bias));
|
||||
|
||||
// calculate radius
|
||||
float radius = SSAO_RADIUS * saturate(pos.z * inv5_3) * (1.0f + pos.z * inv8);
|
||||
float invRad = rcp(radius);
|
||||
|
||||
float2 radius2D = radius * focalLen * rcp(pos.z);
|
||||
float ao = 0.0f;
|
||||
|
||||
// calculate ao
|
||||
[unroll]
|
||||
for (int i = 0; i < 8; ++i) {
|
||||
float2 deltaUV = reflect(arrKernel[i], rotSample) * radius2D;
|
||||
ao += doPBAO(tc0 + deltaUV, pos, normal, invRad, bias, selfOcc);
|
||||
ao += doPBAO(tc0 + deltaUV * inv2, pos, normal, invRad, bias, selfOcc);
|
||||
}
|
||||
|
||||
ao = 1.0f - (ao * contrast + selfOcc);
|
||||
return ao * ao * ao;
|
||||
}
|
||||
#endif
|
||||
#endif
|
||||
|
||||
Loading…
Add table
Add a link
Reference in a new issue