2016-07-05 11 views
1

私はThree.jsでShaderMaterialを使用してPhongMaterialをシミュレートしようとしています。GLSLを使用したTHREE.ShaderMaterialの照明

私はシーンにライトを追加している:私は現場にMeshPhongMaterialを追加するとき

  var lightColor = new THREE.Color(0xffffff); 
      var aLight = new THREE.AmbientLight(lightColor); 
      scene.add(aLight); 
      var dLight = new THREE.DirectionalLight(lightColor,1.0); 
      dLight.name = "dLight"; 
      dLight.position.set(-1.0, 0.0, -0.3).normalize(); 
      scene.add(dLight); 

はすべてがクールです。今、私はShaderMaterialを使用しています:

 var shaderMaterial = new THREE.ShaderMaterial({ 

      uniforms:THREE.UniformsUtils.merge([ 

       THREE.UniformsLib["lights"], 

       { 
        diffuseMaterial: {type: "c", value: new THREE.Color(1,0,0)}, 
        specularMaterial: {type: "c", value: new THREE.Color(0.7,0.7,0.7)}, 
        ambientMaterial:{type:"c", value: new THREE.Color(0.8,0.2,0.2)}, 
        shininessMaterial: {type:"f", value: 16.0} 
       } 
      ]), 

      vertexShader: vs, 
      fragmentShader: fs, 
      lights:true 
     }); 

私のバーテックスシェーダのこと:

uniform vec3 diffuseMaterial; 
uniform vec3 specularMaterial; 
uniform vec3 ambientMaterial; 
uniform float shininessMaterial; 
uniform vec3 ambientLight; 
uniform vec3 directionalLightColor[NUM_DIR_LIGHTS]; 
uniform vec3 directionalLightDirection[NUM_DIR_LIGHTS]; 
uniform vec3 ambientLightColor[1]; 

varying vec3 fragColor; 

vec3 phong(vec3 p, vec3 n, vec3 v){ 

    vec3 fromLight = normalize(directionalLightDirection[0]); 
    vec3 toLight = -fromLight; 

    vec3 reflectLight = reflect(toLight,n); 

    float ndots = dot(n, toLight); 
    float vdotr = abs(dot(v,reflectLight)); 

    vec3 ambi = ambientMaterial * ambientLightColor[0]; 
    vec3 diff = diffuseMaterial * directionalLightColor[0] * ndots; 
    vec3 spec = specularMaterial * directionalLightColor[0] * pow(vdotr,shininessMaterial); 

    return ambi + diff + spec ; 
    //return ambi + diff; 
} 



void main() { 

    gl_PointSize = 3.0; 

    vec4 ecPosition=modelViewMatrix*vec4(position,1.0); 
    vec3 ecNormal= normalize(normalMatrix*normal); 

    bool useOrtho = projectionMatrix[2][3] == 0.0; 


    vec3 viewDir=useOrtho ? vec3(0,0,1) : normalize(-ecPosition.xyz); 

    fragColor=phong(ecPosition.xyz, ecNormal, viewDir); 


    gl_Position = projectionMatrix * 
        modelViewMatrix * 
        vec4(position,1.0); 
} 

しかし、私が得るすべてはthisです。拡散した部分や鏡面の部分だけが必要な場合は、this black oneとなります。私が間違っていることは何ですか?

+0

する必要があり、この – Zouch

+0

は、あなたがこれをやりたいと思っていることを確認あなたはチェックする価値があるかもしれませんフラグメントシェーダではなく頂点シェーダを使用しますか? – 2pha

答えて

0

ザ・ライン

float vdotr = abs(dot(v,reflectLight)); 

あなたはビューフレームにあなたの光を変換されていません

float vdotr = max(0,dot(v,reflectLight)); 
関連する問題