Rasagar/Library/PackageCache/com.unity.render-pipelines.high-definition/Runtime/PostProcessing/Shaders/DoFCombine.compute

84 lines
3.0 KiB
Plaintext
Raw Normal View History

2024-08-26 13:07:20 -07:00
#include "Packages/com.unity.render-pipelines.core/ShaderLibrary/Common.hlsl"
#include "Packages/com.unity.render-pipelines.high-definition/Runtime/ShaderLibrary/ShaderVariables.hlsl"
#include "Packages/com.unity.render-pipelines.high-definition/Runtime/PostProcessing/Shaders/PostProcessDefines.hlsl"
#include "Packages/com.unity.render-pipelines.high-definition/Runtime/PostProcessing/Shaders/DepthOfFieldCommon.hlsl"
#include "Packages/com.unity.render-pipelines.high-definition/Runtime/RenderPipeline/Raytracing/Shaders/RaytracingSampling.hlsl"
#pragma only_renderers d3d11 playstation xboxone xboxseries vulkan metal switch
#pragma kernel KMain
#pragma multi_compile _ ENABLE_ALPHA
#pragma multi_compile _ FORCE_POINT_SAMPLING
#define GROUP_RES 8u
#define GROUP_SIZE (GROUP_RES * GROUP_RES)
CBUFFER_START(cb0)
float4 _Params;
float4 _Params2;
CBUFFER_END
#define NumRings _Params.x
#define MaxCoCRadius _Params.y
#define Anamorphism _Params.z
// Out-of-focus areas, computed at lower res
TEXTURE2D_X(_InputNearTexture);
// Here we write the final output
RW_TEXTURE2D_X(CTYPE, _OutputTexture);
#define ResScale 1.0f
#define OneOverResScale 1.0f
#define MaxColorMip 0.0f
#define AdaptiveSamplingWeights _Params2.xy
#define BlurResolution _Params2.z
#define InvBlurResolution _Params2.w
#include "Packages/com.unity.render-pipelines.high-definition/Runtime/PostProcessing/Shaders/DoFGatherUtils.hlsl"
[numthreads(GROUP_RES, GROUP_RES, 1)]
void KMain(uint3 dispatchThreadId : SV_DispatchThreadID)
{
UNITY_XR_ASSIGN_VIEW_INDEX(dispatchThreadId.z);
PositionInputs posInputs = GetPositionInput(float2(dispatchThreadId.xy), _PostProcessScreenSize.zw, uint2(GROUP_RES, GROUP_RES));
CTYPE output = 0;
int tileClass = GetTileClass(posInputs.positionSS);
if (tileClass == SLOW_INFOCUS_TILE)
{
SampleData centerSample;
centerSample.color = GetColorSample(posInputs.positionSS, 0);
centerSample.CoC = GetCoCRadius(posInputs.positionSS);
DoFTile tileData;
LoadTileData(posInputs.positionSS, centerSample, NumRings, tileData);
float4 outColor;
float outAlpha;
DoFGatherRings(posInputs, tileData, centerSample, outColor, outAlpha);
output.xyz = outColor.xyz;
#ifdef ENABLE_ALPHA
ComposeAlpha(output, centerSample.color.xyz, outAlpha);
#endif
}
else if (tileClass == FAST_DEFOCUS_TILE)
{
float2 uv = (posInputs.positionSS + 0.5) * _PostProcessScreenSize.zw;
uv = ClampAndScaleUV(uv, _PostProcessScreenSize.zw * BlurResolution, 0.5f, _RTHandlePostProcessScale.xy);
output = SAMPLE_TEXTURE2D_X_LOD(_InputNearTexture, s_linear_clamp_sampler, uv, 0.0).CTYPE_SWIZZLE;
}
else
{
output = GetColorSample(posInputs.positionSS, 0);
}
// Helper function to visualize tile types in case it is needed for debugging
//DebugTiles(posInputs.positionSS, output.xyz);
_OutputTexture[COORD_TEXTURE2D_X(posInputs.positionSS)] = (CTYPE)output;
}