Danbias/Code/OysterGraphics/Shader/Passes/Light/LightPass.hlsl

42 lines
1.1 KiB
HLSL
Raw Normal View History

#include "Defines.hlsli"
#include "LightCalc.hlsli"
#include "PosManipulation.hlsli"
2014-01-08 07:01:59 +01:00
#include "SSAO.hlsli"
//todo
//LightCulling
2014-01-08 07:01:59 +01:00
//Calc Diff + Spec Done
//Calc Ambience Done
//Write Glow
[numthreads(16, 16, 1)]
2014-01-08 07:01:59 +01:00
void main( uint3 DTid : SV_DispatchThreadID, uint3 GTid : SV_GroupThreadID )
{
2014-01-28 13:48:15 +01:00
float2 UV = DTid.xy / Pixels;
2014-01-08 07:01:59 +01:00
UV.x = UV.x * 2 - 1;
UV.y = 1 - 2 * UV.y;
float3 ViewPos = ToVpos(DTid.xy, UV);
DiffSpec Shaded;
2014-01-28 13:48:15 +01:00
Shaded.Diffuse = float3(0,0,0);
Shaded.Specular = float3(0,0,0);
2014-01-08 07:01:59 +01:00
for(int i = 0; i < Lights; ++i)
{
DiffSpec light = LightCalc(Points[i], ViewPos, DTid.xy);
2014-01-08 07:01:59 +01:00
Shaded.Diffuse += light.Diffuse;
Shaded.Specular += light.Specular;
}
2014-02-10 09:35:03 +01:00
Diffuse[DTid.xy] = float4(Shaded.Diffuse * DiffuseGlow[DTid.xy].xyz,0);
Specular[DTid.xy] = float4(Shaded.Specular, 0);
2014-01-08 07:01:59 +01:00
2014-01-22 16:31:33 +01:00
if(DTid.x & 1 && DTid.y & 1 )
2014-01-08 07:01:59 +01:00
{
2014-01-22 16:31:33 +01:00
float AmbValue = GetSSAO(ViewPos, UV, DTid.xy, GTid.xy/2);
2014-02-03 12:09:11 +01:00
Ambient[DTid.xy/2] = float4(DiffuseGlow[DTid.xy].xyz, AmbValue);
2014-02-10 01:03:10 +01:00
Ambient[DTid.xy/2 + float2(Pixels.x/2, 0)] = GUI[DTid.xy];
2014-02-13 15:24:19 +01:00
Ambient[DTid.xy/2 + float2(0, Pixels.y/2)] = float4(DiffuseGlow[DTid.xy].xyz * DiffuseGlow[DTid.xy].w*10,1);
}
2014-01-08 07:01:59 +01:00
}