Files
2025-07-13 23:16:20 +08:00

63 lines
2.3 KiB
HLSL

#ifndef HBAO_DEINTERLEAVING_INCLUDED
#define HBAO_DEINTERLEAVING_INCLUDED
#include "HBAO_Common.cginc"
struct DeinterleavedOutput {
float4 Z00 : SV_Target0;
float4 Z10 : SV_Target1;
float4 Z01 : SV_Target2;
float4 Z11 : SV_Target3;
};
DeinterleavedOutput DeinterleaveDepth_Frag(Varyings input)
{
UNITY_SETUP_STEREO_EYE_INDEX_POST_VERTEX(input);
DeinterleavedOutput o;
float2 pos = floor(input.uv * _DeinterleavedAO_TexelSize.zw) * 4.0;
float2 uv00 = (pos + _Deinterleave_Offset00 + 0.5) * _ReinterleavedAO_TexelSize.xy;
float2 uv10 = (pos + _Deinterleave_Offset10 + 0.5) * _ReinterleavedAO_TexelSize.xy;
float2 uv01 = (pos + _Deinterleave_Offset01 + 0.5) * _ReinterleavedAO_TexelSize.xy;
float2 uv11 = (pos + _Deinterleave_Offset11 + 0.5) * _ReinterleavedAO_TexelSize.xy;
o.Z00 = FetchRawDepth(uv00).rrrr;
o.Z10 = FetchRawDepth(uv10).rrrr;
o.Z01 = FetchRawDepth(uv01).rrrr;
o.Z11 = FetchRawDepth(uv11).rrrr;
return o;
}
DeinterleavedOutput DeinterleaveNormals_Frag(Varyings input)
{
UNITY_SETUP_STEREO_EYE_INDEX_POST_VERTEX(input);
DeinterleavedOutput o;
float2 pos = floor(input.uv * _DeinterleavedAO_TexelSize.zw) * 4.0;
float2 uv00 = (pos + _Deinterleave_Offset00 + 0.5) * _ReinterleavedAO_TexelSize.xy;
float2 uv10 = (pos + _Deinterleave_Offset10 + 0.5) * _ReinterleavedAO_TexelSize.xy;
float2 uv01 = (pos + _Deinterleave_Offset01 + 0.5) * _ReinterleavedAO_TexelSize.xy;
float2 uv11 = (pos + _Deinterleave_Offset11 + 0.5) * _ReinterleavedAO_TexelSize.xy;
o.Z00 = float4(FetchViewNormals(uv00, _ReinterleavedAO_TexelSize.xy) * 0.5 + 0.5, 0);
o.Z10 = float4(FetchViewNormals(uv10, _ReinterleavedAO_TexelSize.xy) * 0.5 + 0.5, 0);
o.Z01 = float4(FetchViewNormals(uv01, _ReinterleavedAO_TexelSize.xy) * 0.5 + 0.5, 0);
o.Z11 = float4(FetchViewNormals(uv11, _ReinterleavedAO_TexelSize.xy) * 0.5 + 0.5, 0);
return o;
}
half4 ReinterleaveAO_Frag(Varyings input) : SV_Target
{
UNITY_SETUP_STEREO_EYE_INDEX_POST_VERTEX(input);
float2 offset = fmod(floor(input.uv * _ReinterleavedAO_TexelSize.zw), 4.0);
float2 uv = (floor(input.uv * _DeinterleavedAO_TexelSize.zw) + (offset * _DeinterleavedAO_TexelSize.zw) + 0.5) * _ReinterleavedAO_TexelSize.xy;
return UNITY_SAMPLE_SCREENSPACE_TEXTURE(_MainTex, uv);
}
#endif // HBAO_DEINTERLEAVING_INCLUDED