0

Android OpenGL プロジェクトにスペキュラー ライトニングを追加しようとしていますが、私の例でわかるように、ライトはオブジェクトの一部にのみ投影されます。

ここに画像の説明を入力

私のフラグメント シェーダーでは、次のように色を計算します。

float dot(vec3 v1, vec3 v2)
{
    return v1.x * v2.x + v1.y * v2.y + v1.z * v2.z;
}

void main()
{
    float distSqr = dot(lightDir, lightDir);
    float att = clamp(1.0 - 0.001 * sqrt(distSqr), 0.0, 1.0);
    vec3 L = lightDir * inversesqrt(distSqr);

    vec4 baseColor = texture2D(texture1, tCoord);

    vec3 N = normalize(baseColor.xyz * 2.0 - 1.0);

    vec3 E = normalize(eyeVec);

    vec3 reflectV = reflect(-L, N);

    vec4 ambientTerm = baseColor;

    // base * diffuse * max(dot(N, L), 0.0)
    vec4 diffuseTerm = baseColor * matDiffuse * max(dot(N, L), 0.0);
    //vec4 diffuseTerm = baseColor * gl_FrontMaterial.diffuse * max(dot(N, L), 0.0);

    // spec * pow(max(dot(reflectV, E), 0.0), shininess)
    vec4 specularTerm = matSpecular * pow(max(dot(reflectV, E), 0.0), 5.0);
    //vec4 specularTerm = vec4(1.0, 1.0, 1.0, 1.0) * pow(max(dot(reflectV, E), 0.0), 5.0);

    gl_FragColor = (ambientTerm + diffuseTerm + specularTerm) * att;
}

ライトの位置: 0、2、2

さらに情報が必要な場合は、お尋ねください。

4

1 に答える 1

0

問題は頂点シェーダーでした。

コードは次のとおりです。

EyespaceNormal = vec3(u_mvMatrix * vec4(a_normal, 1.0));
vec3 eyespaceTangent = vec3(u_mvMatrix * vec4(tangent, 1.0));

そしてあるべきです

EyespaceNormal = vec3(mat3(u_mvMatrix) * a_normal);
vec3 eyespaceTangent = vec3(mat3(u_mvMatrix) * tangent);
于 2013-11-14T12:09:55.787 に答える