来源:
float StrandSpecular (float3 T, float3 V, float3 L, float exponent)
{
float3 H = normalize(L + V);
float dotTH = dot(T, H);
float sinTH = sqrt(1.0 - dotTH*dotTH);
float dirAtten = smoothstep(-1.0, 0.0, dot(T, H));
return dirAtten * pow(sinTH, exponent);
}
smoothstep函数:
smoothstep(a, b, x)
{
x<a, 返回0;
x>b,返回1;
a<x<b,返回 w=(x-a)/(b-a), ww(3-2*w)
}
当dot(T,H)小于-1,生成0;
当dot(T,H)大于0,生成1;
当-1<dot(T,H)<0,返回smoothstep的值。
smoothstep函数里w=x+1。如图:
横坐标为dot(T,H)