ACESFilmicToneMappingShader.js 1.9 KB

1234567891011121314151617181920212223242526272829303132
  1. ( function () {
  2. /**
  3. * ACES Filmic Tone Mapping Shader by Stephen Hill
  4. * source: https://github.com/selfshadow/ltc_code/blob/master/webgl/shaders/ltc/ltc_blit.fs
  5. *
  6. * this implementation of ACES is modified to accommodate a brighter viewing environment.
  7. * the scale factor of 1/0.6 is subjective. see discussion in #19621.
  8. */
  9. var ACESFilmicToneMappingShader = {
  10. uniforms: {
  11. 'tDiffuse': {
  12. value: null
  13. },
  14. 'exposure': {
  15. value: 1.0
  16. }
  17. },
  18. vertexShader: [ 'varying vec2 vUv;', 'void main() {', ' vUv = uv;', ' gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );', '}' ].join( '\n' ),
  19. fragmentShader: [ '#define saturate(a) clamp( a, 0.0, 1.0 )', 'uniform sampler2D tDiffuse;', 'uniform float exposure;', 'varying vec2 vUv;', 'vec3 RRTAndODTFit( vec3 v ) {', ' vec3 a = v * ( v + 0.0245786 ) - 0.000090537;', ' vec3 b = v * ( 0.983729 * v + 0.4329510 ) + 0.238081;', ' return a / b;', '}', 'vec3 ACESFilmicToneMapping( vec3 color ) {', // sRGB => XYZ => D65_2_D60 => AP1 => RRT_SAT
  20. ' const mat3 ACESInputMat = mat3(', ' vec3( 0.59719, 0.07600, 0.02840 ),', // transposed from source
  21. ' vec3( 0.35458, 0.90834, 0.13383 ),', ' vec3( 0.04823, 0.01566, 0.83777 )', ' );', // ODT_SAT => XYZ => D60_2_D65 => sRGB
  22. ' const mat3 ACESOutputMat = mat3(', ' vec3( 1.60475, -0.10208, -0.00327 ),', // transposed from source
  23. ' vec3( -0.53108, 1.10813, -0.07276 ),', ' vec3( -0.07367, -0.00605, 1.07602 )', ' );', ' color = ACESInputMat * color;', // Apply RRT and ODT
  24. ' color = RRTAndODTFit( color );', ' color = ACESOutputMat * color;', // Clamp to [0, 1]
  25. ' return saturate( color );', '}', 'void main() {', ' vec4 tex = texture2D( tDiffuse, vUv );', ' tex.rgb *= exposure / 0.6;', // pre-exposed, outside of the tone mapping function
  26. ' gl_FragColor = vec4( ACESFilmicToneMapping( tex.rgb ), tex.a );', '}' ].join( '\n' )
  27. };
  28. THREE.ACESFilmicToneMappingShader = ACESFilmicToneMappingShader;
  29. } )();