1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677 |
- /**
- * @author miibond
- *
- * Full-screen tone-mapping shader based on http://www.cis.rit.edu/people/faculty/ferwerda/publications/sig02_paper.pdf
- */
- THREE.ToneMapShader = {
- uniforms: {
- "tDiffuse": { value: null },
- "averageLuminance": { value: 1.0 },
- "luminanceMap": { value: null },
- "maxLuminance": { value: 16.0 },
- "minLuminance": { value: 0.01 },
- "middleGrey": { value: 0.6 }
- },
- vertexShader: [
- "varying vec2 vUv;",
- "void main() {",
- " vUv = uv;",
- " gl_Position = projectionMatrix * modelViewMatrix * vec4( position, 1.0 );",
- "}"
- ].join( "\n" ),
- fragmentShader: [
- "#include <common>",
- "uniform sampler2D tDiffuse;",
- "varying vec2 vUv;",
- "uniform float middleGrey;",
- "uniform float minLuminance;",
- "uniform float maxLuminance;",
- "#ifdef ADAPTED_LUMINANCE",
- " uniform sampler2D luminanceMap;",
- "#else",
- " uniform float averageLuminance;",
- "#endif",
- "vec3 ToneMap( vec3 vColor ) {",
- " #ifdef ADAPTED_LUMINANCE",
- // Get the calculated average luminance
- " float fLumAvg = texture2D(luminanceMap, vec2(0.5, 0.5)).r;",
- " #else",
- " float fLumAvg = averageLuminance;",
- " #endif",
- // Calculate the luminance of the current pixel
- " float fLumPixel = linearToRelativeLuminance( vColor );",
- // Apply the modified operator (Eq. 4)
- " float fLumScaled = (fLumPixel * middleGrey) / max( minLuminance, fLumAvg );",
- " float fLumCompressed = (fLumScaled * (1.0 + (fLumScaled / (maxLuminance * maxLuminance)))) / (1.0 + fLumScaled);",
- " return fLumCompressed * vColor;",
- "}",
- "void main() {",
- " vec4 texel = texture2D( tDiffuse, vUv );",
- " gl_FragColor = vec4( ToneMap( texel.xyz ), texel.w );",
- "}"
- ].join( "\n" )
- };
|