2013-02-27 09:24:16 +04:00
|
|
|
/*
|
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/common.sh"
|
|
|
|
|
|
|
|
uniform vec4 u_offset[16];
|
|
|
|
uniform vec4 u_tonemap;
|
2015-05-29 01:27:00 +03:00
|
|
|
#define u_time u_tonemap.w
|
2013-02-27 09:24:16 +04:00
|
|
|
|
|
|
|
float reinhard(float _x)
|
|
|
|
{
|
|
|
|
return _x / (_x + 1.0);
|
|
|
|
}
|
|
|
|
|
|
|
|
vec3 reinhard(vec3 _x)
|
|
|
|
{
|
|
|
|
return _x / (_x + 1.0);
|
|
|
|
}
|
|
|
|
|
|
|
|
float reinhard2(float _x, float _whiteSqr)
|
|
|
|
{
|
|
|
|
return (_x * (1.0 + _x/_whiteSqr) ) / (1.0 + _x);
|
|
|
|
}
|
|
|
|
|
|
|
|
vec3 reinhard2(vec3 _x, float _whiteSqr)
|
|
|
|
{
|
|
|
|
return (_x * (1.0 + _x/_whiteSqr) ) / (1.0 + _x);
|
|
|
|
}
|
|
|
|
|
|
|
|
vec4 blur9(sampler2D _sampler, vec2 _uv0, vec4 _uv1, vec4 _uv2, vec4 _uv3, vec4 _uv4)
|
|
|
|
{
|
|
|
|
#define _BLUR9_WEIGHT_0 1.0
|
|
|
|
#define _BLUR9_WEIGHT_1 0.9
|
|
|
|
#define _BLUR9_WEIGHT_2 0.55
|
|
|
|
#define _BLUR9_WEIGHT_3 0.18
|
|
|
|
#define _BLUR9_WEIGHT_4 0.1
|
|
|
|
#define _BLUR9_NORMALIZE (_BLUR9_WEIGHT_0+2.0*(_BLUR9_WEIGHT_1+_BLUR9_WEIGHT_2+_BLUR9_WEIGHT_3+_BLUR9_WEIGHT_4) )
|
|
|
|
#define BLUR9_WEIGHT(_x) (_BLUR9_WEIGHT_##_x/_BLUR9_NORMALIZE)
|
|
|
|
|
|
|
|
vec4 blur;
|
|
|
|
blur = texture2D(_sampler, _uv0)*BLUR9_WEIGHT(0);
|
|
|
|
blur += texture2D(_sampler, _uv1.xy)*BLUR9_WEIGHT(1);
|
|
|
|
blur += texture2D(_sampler, _uv1.zw)*BLUR9_WEIGHT(1);
|
|
|
|
blur += texture2D(_sampler, _uv2.xy)*BLUR9_WEIGHT(2);
|
|
|
|
blur += texture2D(_sampler, _uv2.zw)*BLUR9_WEIGHT(2);
|
|
|
|
blur += texture2D(_sampler, _uv3.xy)*BLUR9_WEIGHT(3);
|
|
|
|
blur += texture2D(_sampler, _uv3.zw)*BLUR9_WEIGHT(3);
|
|
|
|
blur += texture2D(_sampler, _uv4.xy)*BLUR9_WEIGHT(4);
|
|
|
|
blur += texture2D(_sampler, _uv4.zw)*BLUR9_WEIGHT(4);
|
|
|
|
return blur;
|
|
|
|
}
|