浏览代码

Make projector code dependent on the cookie

Projector lights now sample a white texture if no cookie has been assigned.
/RenderPassXR_Sandbox
Evgenii Golubev 8 年前
当前提交
640bf8c6
共有 2 个文件被更改,包括 23 次插入22 次删除
  1. 5
      Assets/ScriptableRenderPipeline/HDRenderPipeline/Lighting/TilePass/TilePass.cs
  2. 40
      Assets/ScriptableRenderPipeline/HDRenderPipeline/Material/Lit/Lit.hlsl

5
Assets/ScriptableRenderPipeline/HDRenderPipeline/Lighting/TilePass/TilePass.cs


lightData.cookieIndex = m_CookieTexArray.FetchSlice(light.light.cookie);
}
}
else if (additionalLightData.archetype == LightArchetype.Projector)
{
// Projectors lights must always have a cookie texture.
lightData.cookieIndex = m_CookieTexArray.FetchSlice(Texture2D.whiteTexture);
}
if (additionalshadowData)
{

40
Assets/ScriptableRenderPipeline/HDRenderPipeline/Material/Lit/Lit.hlsl


}
//-----------------------------------------------------------------------------
// EvaluateBSDF_Directional
// EvaluateBSDF_Directional (supports directional and box projector lights)
//-----------------------------------------------------------------------------
void EvaluateBSDF_Directional(LightLoopContext lightLoopContext,

float3 positionWS = posInput.positionWS;
// Compute the NDC position (in [-1, 1]^2) by projecting 'positionWS' onto the near plane.
// 'lightData.right' and 'lightData.up' are pre-scaled on CPU.
float3 lightToSurface = positionWS - lightData.positionWS;
float2 positionNDC = float2(dot(lightToSurface, lightData.right), dot(lightToSurface, lightData.up));
bool isInBounds = abs(positionNDC.x) <= 1 && abs(positionNDC.y) <= 1;

}
//-----------------------------------------------------------------------------
// EvaluateBSDF_Punctual
// EvaluateBSDF_Punctual (supports spot, point and projector lights)
//-----------------------------------------------------------------------------
void EvaluateBSDF_Punctual( LightLoopContext lightLoopContext,

float3 positionWS = posInput.positionWS;
int lightType = lightData.lightType;
// Translate and rotate 'positionWS' into the light space.
float3 lightToSurface = positionWS - lightData.positionWS;
float3x3 lightToWorld = float3x3(lightData.right, lightData.up, lightData.forward);
float3 positionLS = mul(lightToSurface, transpose(lightToWorld));
// Compute the NDC position (in [-1, 1]^2) by projecting 'positionWS' onto the plane at 1m distance.
// Box projector lights require no perspective division.
float2 positionNDC = (lightType != GPULIGHTTYPE_PROJECTOR_BOX && lightType != GPULIGHTTYPE_POINT) ? positionLS.xy / positionLS.z : positionLS.xy;
bool isInBounds = abs(positionNDC.x) <= 1 && abs(positionNDC.y) <= 1;
// Do not clip point lights.
float clipFactor = (lightType == GPULIGHTTYPE_POINT || isInBounds) ? 1 : 0;
float3 lightToSurface = positionWS - lightData.positionWS;
float attenuation = clipFactor;
attenuation *= (lightType != GPULIGHTTYPE_PROJECTOR_BOX) ? GetDistanceAttenuation(unL, lightData.invSqrAttenuationRadius) : 1;
float attenuation = (lightType != GPULIGHTTYPE_PROJECTOR_BOX) ? GetDistanceAttenuation(unL, lightData.invSqrAttenuationRadius) : 1;
// Reminder: lights are oriented backward (-Z)
attenuation *= GetAngleAttenuation(L, -lightData.forward, lightData.angleScale, lightData.angleOffset);
float NdotL = dot(bsdfData.normalWS, L);

illuminance *= shadow;
}
// Projector lights always have a cookie.
// Translate and rotate 'positionWS' into the light space.
// 'lightData.right' and 'lightData.up' are pre-scaled on CPU.
float3x3 lightToWorld = float3x3(lightData.right, lightData.up, lightData.forward);
float3 positionLS = mul(lightToSurface, transpose(lightToWorld));
// Identical to 'positionLS', but saves us 2x VGPR.
float3 coord = float3(positionNDC, positionLS.z);
float4 c = SampleCookieCube(lightLoopContext, coord, lightData.cookieIndex);
float4 c = SampleCookieCube(lightLoopContext, positionLS, lightData.cookieIndex);
// Use premultiplied alpha to save 1x VGPR.
cookie = c.rgb * c.a;

// Compute the NDC position (in [-1, 1]^2) by projecting 'positionWS' onto the plane at 1m distance.
// Box projector lights require no perspective division.
float2 positionNDC = (lightType != GPULIGHTTYPE_PROJECTOR_BOX) ? positionLS.xy / positionLS.z : positionLS.xy;
bool isInBounds = abs(positionNDC.x) <= 1 && abs(positionNDC.y) <= 1;
// Remap the texture coordinates from [-1, 1]^2 to [0, 1]^2.
float2 coord = positionNDC * 0.5 + 0.5;

// Use premultiplied alpha to save 1x VGPR.
cookie = c.rgb * c.a;
cookie = c.rgb * (c.a * (isInBounds ? 1 : 0));
}
}

正在加载...
取消
保存