envmap_fragment.glsl.js 1.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192
  1. export default /* glsl */`
  2. #ifdef USE_ENVMAP
  3. #ifdef ENV_WORLDPOS
  4. vec3 cameraToFrag;
  5. if ( isOrthographic ) {
  6. cameraToFrag = normalize( vec3( - viewMatrix[ 0 ][ 2 ], - viewMatrix[ 1 ][ 2 ], - viewMatrix[ 2 ][ 2 ] ) );
  7. } else {
  8. cameraToFrag = normalize( vWorldPosition - cameraPosition );
  9. }
  10. // Transforming Normal Vectors with the Inverse Transformation
  11. vec3 worldNormal = inverseTransformDirection( normal, viewMatrix );
  12. #ifdef ENVMAP_MODE_REFLECTION
  13. vec3 reflectVec = reflect( cameraToFrag, worldNormal );
  14. #else
  15. vec3 reflectVec = refract( cameraToFrag, worldNormal, refractionRatio );
  16. #endif
  17. #else
  18. vec3 reflectVec = vReflect;
  19. #endif
  20. #ifdef ENVMAP_TYPE_CUBE
  21. vec4 envColor = textureCube( envMap, vec3( flipEnvMap * reflectVec.x, reflectVec.yz ) );
  22. #elif defined( ENVMAP_TYPE_CUBE_UV )
  23. vec4 envColor = textureCubeUV( envMap, reflectVec, 0.0 );
  24. #elif defined( ENVMAP_TYPE_EQUIREC )
  25. vec2 sampleUV;
  26. reflectVec = normalize( reflectVec );
  27. sampleUV.y = asin( clamp( reflectVec.y, - 1.0, 1.0 ) ) * RECIPROCAL_PI + 0.5;
  28. sampleUV.x = atan( reflectVec.z, reflectVec.x ) * RECIPROCAL_PI2 + 0.5;
  29. vec4 envColor = texture2D( envMap, sampleUV );
  30. #elif defined( ENVMAP_TYPE_SPHERE )
  31. reflectVec = normalize( reflectVec );
  32. vec3 reflectView = normalize( ( viewMatrix * vec4( reflectVec, 0.0 ) ).xyz + vec3( 0.0, 0.0, 1.0 ) );
  33. vec4 envColor = texture2D( envMap, reflectView.xy * 0.5 + 0.5 );
  34. #else
  35. vec4 envColor = vec4( 0.0 );
  36. #endif
  37. #ifndef ENVMAP_TYPE_CUBE_UV
  38. envColor = envMapTexelToLinear( envColor );
  39. #endif
  40. #ifdef ENVMAP_BLENDING_MULTIPLY
  41. outgoingLight = mix( outgoingLight, outgoingLight * envColor.xyz, specularStrength * reflectivity );
  42. #elif defined( ENVMAP_BLENDING_MIX )
  43. outgoingLight = mix( outgoingLight, envColor.xyz, specularStrength * reflectivity );
  44. #elif defined( ENVMAP_BLENDING_ADD )
  45. outgoingLight += envColor.xyz * specularStrength * reflectivity;
  46. #endif
  47. #endif
  48. `;