bgfx/examples/09-hdr/fs_hdr_lum.sc

39 lines
1.2 KiB
Python
Raw Normal View History

2013-02-27 00:24:16 -05:00
$input v_texcoord0
/*
2015-01-02 17:43:11 -05:00
* Copyright 2011-2015 Branimir Karadzic. All rights reserved.
2013-02-27 00:24:16 -05:00
* License: http://www.opensource.org/licenses/BSD-2-Clause
*/
#include "common.sh"
2015-05-28 18:27:00 -04:00
SAMPLER2D(s_texColor, 0);
2013-02-27 00:24:16 -05:00
void main()
{
float delta = 0.0001;
2015-05-28 18:27:00 -04:00
vec3 rgb0 = decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[0].xy) );
vec3 rgb1 = decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[1].xy) );
vec3 rgb2 = decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[2].xy) );
vec3 rgb3 = decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[3].xy) );
vec3 rgb4 = decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[4].xy) );
vec3 rgb5 = decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[5].xy) );
vec3 rgb6 = decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[6].xy) );
vec3 rgb7 = decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[7].xy) );
vec3 rgb8 = decodeRGBE8(texture2D(s_texColor, v_texcoord0+u_offset[8].xy) );
2013-02-27 00:24:16 -05:00
float avg = luma(rgb0).x
+ luma(rgb1).x
+ luma(rgb2).x
+ luma(rgb3).x
+ luma(rgb4).x
+ luma(rgb5).x
+ luma(rgb6).x
+ luma(rgb7).x
+ luma(rgb8).x
;
avg *= 1.0/9.0;
gl_FragColor = encodeRE8(avg);
}