HLSL Shader(Phong / w法线贴图)

时间:2012-06-23 11:36:33

标签: c++ directx hlsl pixel-shading

编辑:如果我使用普通地图进行计算,那么现在唯一的问题就是光来自相反的方向。如果我只使用:

n = normalize(Input.NorView);

似乎很好。

我开始用DirectX10学习一些HLSL着色,我试图使用法线贴图来计算我的phong闪电。 首先,这是我已经走了多远的一个例子:

http://i.stack.imgur.com/IFAo4.jpg

我不太确定这是否是我想用这个法线贴图完成的事情: http://i.stack.imgur.com/moQvf.jpg

我不知道......这看起来不是更像3Dish吗?也许我只是对法线贴图的使用有一个错误的理解,但在我的思维模式中,使用法线贴图通过添加基于法线贴图的阴影来使模型更加细致,因此它看起来更像是3D。

这是我的着色代码: 顶点着色器:

T3dVertexPSIn MeshVS(T3dVertexVSIn Input) {
    T3dVertexPSIn output = (T3dVertexPSIn) 0;
    float4 tempVar;

    output.Pos = mul(float4(Input.Pos.xyz, 1).xyzw, g_WorldViewProjection);

    output.Tex = Input.Tex;

    tempVar = mul(float4(Input.Pos.xyz, 1).xyzw, g_WorldView);
    output.PosView = tempVar.xyz;

    tempVar = mul(float4(Input.Nor.xyz, 0).xyzw, g_WorldViewNormals);
    output.NorView = tempVar.xyz;
    output.NorView = normalize(output.NorView);

    tempVar = mul(float4(Input.Tan.xyz, 0).xyzw, g_WorldViewNormals);
    output.TanView = tempVar.xyz;
    output.TanView = normalize(output.TanView);

    return output;
}

Pixel Shader:

float4 MeshPS(T3dVertexPSIn Input) : SV_Target0 {
    float4 output = (float4)0; //output color

    float3 N = normalize(Input.NorView);

    float3 T = Input.TanView;

    T = normalize(T - N * dot(N,T));
    float3 B = cross(T,N);

    column_major float3x3 mTBN= {T, B, N};
    float4 matDiffuse = g_Diffuse.Sample(samAnisotropic, Input.Tex);
    float4 matSpecular = g_Specular.Sample(samAnisotropic, Input.Tex);
    float4 matGlow = g_Glow.Sample(samAnisotropic, Input.Tex);
    float4 colLight = float4(1,1,1,1);
    float4 colLightAmbient = float4(1,1,1,1);
    float3 n = mul(g_Normal.Sample(samAnisotropic, Input.Tex).rgb * 2.0 - 1.0, mTBN);
    //float3 n = mul(float3x3(T,B,N), nT);
    //float3 n = normalize(Input.NorView);
    float4 I = g_LightDirView;
    float3 r = reflect(-I.xyz, n);
    float3 v = normalize(-Input.PosView);

    float cd = 0.5f, cs = 0.3f, ca = 0.1f, cg = 0.3f;



    output = cd*matDiffuse*saturate(dot(n,I.xyz))*colLight
            +cs*matSpecular*pow(saturate(dot(r.xyz,v)),10)*colLight
            +ca*matDiffuse*colLightAmbient
            +cg*matGlow;


    return output;
}

当我使用普通地图时,我也感觉闪电正在改变方向。但我不确定。 也许有人可以向我解释一下这个问题。 在此先感谢您的帮助!

2 个答案:

答案 0 :(得分:0)

法线贴图不会创建阴影。它简单地允许您重新评估每个纹素的光照。

答案 1 :(得分:0)

似乎我正在计算正常的错误,一些纹理也得到了错误的正常。