2013-02-27 09:24:16 +04:00
|
|
|
$input v_texcoord0
|
|
|
|
|
|
|
|
/*
|
2024-01-14 12:56:36 +03:00
|
|
|
* Copyright 2011-2024 Branimir Karadzic. All rights reserved.
|
2022-01-15 22:59:06 +03:00
|
|
|
* License: https://github.com/bkaradzic/bgfx/blob/master/LICENSE
|
2013-02-27 09:24:16 +04:00
|
|
|
*/
|
|
|
|
|
|
|
|
#include "common.sh"
|
|
|
|
|
2015-05-29 01:27:00 +03:00
|
|
|
SAMPLER2D(s_texColor, 0);
|
|
|
|
SAMPLER2D(s_texLum, 1);
|
2013-02-27 09:24:16 +04:00
|
|
|
|
|
|
|
void main()
|
|
|
|
{
|
2015-05-29 01:27:00 +03:00
|
|
|
float lum = clamp(decodeRE8(texture2D(s_texLum, v_texcoord0) ), 0.1, 0.7);
|
2013-02-27 09:24:16 +04:00
|
|
|
|
|
|
|
vec3 rgb = vec3(0.0, 0.0, 0.0);
|
2015-05-29 01:27:00 +03:00
|
|
|
rgb += decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[0].xy) );
|
|
|
|
rgb += decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[1].xy) );
|
|
|
|
rgb += decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[2].xy) );
|
|
|
|
rgb += decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[3].xy) );
|
|
|
|
rgb += decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[4].xy) );
|
|
|
|
rgb += decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[5].xy) );
|
|
|
|
rgb += decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[6].xy) );
|
|
|
|
rgb += decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[7].xy) );
|
|
|
|
rgb += decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[8].xy) );
|
2013-02-27 09:24:16 +04:00
|
|
|
|
|
|
|
rgb *= 1.0/9.0;
|
|
|
|
|
|
|
|
float middleGray = u_tonemap.x;
|
|
|
|
float whiteSqr = u_tonemap.y;
|
2022-07-13 16:19:47 +03:00
|
|
|
float threshold = u_tonemap.z;
|
2013-02-27 09:24:16 +04:00
|
|
|
float offset = u_tonemap.w;
|
|
|
|
|
2022-07-13 16:19:47 +03:00
|
|
|
rgb = max(vec3_splat(0.0), rgb - threshold) * middleGray / (lum + 0.0001);
|
2013-02-27 09:24:16 +04:00
|
|
|
rgb = reinhard2(rgb, whiteSqr);
|
|
|
|
|
|
|
|
gl_FragColor = toGamma(vec4(rgb, 1.0) );
|
|
|
|
}
|