2016-10-04 03:33:42 +08:00
|
|
|
[vertex]
|
|
|
|
|
|
|
|
|
|
|
|
layout(location=0) in highp vec4 vertex_attrib;
|
2017-05-26 00:53:59 +08:00
|
|
|
#if defined(USE_CUBEMAP) || defined(USE_PANORAMA)
|
2016-10-04 03:33:42 +08:00
|
|
|
layout(location=4) in vec3 cube_in;
|
|
|
|
#else
|
2016-10-30 07:48:09 +08:00
|
|
|
layout(location=4) in vec2 uv_in;
|
2016-10-04 03:33:42 +08:00
|
|
|
#endif
|
2016-10-30 07:48:09 +08:00
|
|
|
layout(location=5) in vec2 uv2_in;
|
2016-10-04 03:33:42 +08:00
|
|
|
|
2017-05-26 00:53:59 +08:00
|
|
|
#if defined(USE_CUBEMAP) || defined(USE_PANORAMA)
|
2016-10-04 03:33:42 +08:00
|
|
|
out vec3 cube_interp;
|
|
|
|
#else
|
|
|
|
out vec2 uv_interp;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
out vec2 uv2_interp;
|
|
|
|
|
2017-06-27 09:58:03 +08:00
|
|
|
#ifdef USE_COPY_SECTION
|
|
|
|
|
|
|
|
uniform vec4 copy_section;
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2016-10-04 03:33:42 +08:00
|
|
|
void main() {
|
|
|
|
|
2017-05-26 00:53:59 +08:00
|
|
|
#if defined(USE_CUBEMAP) || defined(USE_PANORAMA)
|
2016-10-04 03:33:42 +08:00
|
|
|
cube_interp = cube_in;
|
|
|
|
#else
|
|
|
|
uv_interp = uv_in;
|
2017-06-09 11:23:50 +08:00
|
|
|
#ifdef V_FLIP
|
|
|
|
uv_interp.y = 1.0-uv_interp.y;
|
|
|
|
#endif
|
|
|
|
|
2016-10-04 03:33:42 +08:00
|
|
|
#endif
|
|
|
|
uv2_interp = uv2_in;
|
|
|
|
gl_Position = vertex_attrib;
|
2017-06-27 09:58:03 +08:00
|
|
|
|
|
|
|
#ifdef USE_COPY_SECTION
|
|
|
|
|
|
|
|
uv_interp = copy_section.xy + uv_interp * copy_section.zw;
|
|
|
|
gl_Position.xy = (copy_section.xy + (gl_Position.xy * 0.5 + 0.5) * copy_section.zw) * 2.0 - 1.0;
|
|
|
|
#endif
|
|
|
|
|
2016-10-04 03:33:42 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
[fragment]
|
|
|
|
|
2017-05-26 00:53:59 +08:00
|
|
|
#define M_PI 3.14159265359
|
2016-10-04 03:33:42 +08:00
|
|
|
|
2017-05-26 00:53:59 +08:00
|
|
|
|
|
|
|
#if defined(USE_CUBEMAP) || defined(USE_PANORAMA)
|
2016-10-04 03:33:42 +08:00
|
|
|
in vec3 cube_interp;
|
|
|
|
#else
|
|
|
|
in vec2 uv_interp;
|
2017-05-26 00:53:59 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef USE_CUBEMAP
|
|
|
|
uniform samplerCube source_cube; //texunit:0
|
|
|
|
#else
|
2016-10-21 18:27:13 +08:00
|
|
|
uniform sampler2D source; //texunit:0
|
2016-10-04 03:33:42 +08:00
|
|
|
#endif
|
|
|
|
|
2017-05-30 09:11:33 +08:00
|
|
|
|
|
|
|
#ifdef USE_MULTIPLIER
|
|
|
|
uniform float multiplier;
|
|
|
|
#endif
|
|
|
|
|
2017-05-26 00:53:59 +08:00
|
|
|
#ifdef USE_PANORAMA
|
|
|
|
|
|
|
|
vec4 texturePanorama(vec3 normal,sampler2D pano ) {
|
|
|
|
|
|
|
|
vec2 st = vec2(
|
|
|
|
atan(normal.x, normal.z),
|
|
|
|
acos(normal.y)
|
|
|
|
);
|
|
|
|
|
|
|
|
if(st.x < 0.0)
|
|
|
|
st.x += M_PI*2.0;
|
|
|
|
|
|
|
|
st/=vec2(M_PI*2.0,M_PI);
|
|
|
|
|
|
|
|
return textureLod(pano,st,0.0);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
2016-10-21 18:27:13 +08:00
|
|
|
|
2016-10-30 07:48:09 +08:00
|
|
|
float sRGB_gamma_correct(float c){
|
|
|
|
float a = 0.055;
|
|
|
|
if(c < 0.0031308)
|
|
|
|
return 12.92*c;
|
|
|
|
else
|
|
|
|
return (1.0+a)*pow(c, 1.0/2.4) - a;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-10-21 18:27:13 +08:00
|
|
|
uniform float stuff;
|
2016-11-30 06:55:12 +08:00
|
|
|
uniform vec2 pixel_size;
|
2016-10-21 18:27:13 +08:00
|
|
|
|
2016-10-04 03:33:42 +08:00
|
|
|
in vec2 uv2_interp;
|
|
|
|
|
2017-06-06 09:33:01 +08:00
|
|
|
|
|
|
|
#ifdef USE_BCS
|
|
|
|
|
|
|
|
uniform vec3 bcs;
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef USE_COLOR_CORRECTION
|
|
|
|
|
|
|
|
uniform sampler2D color_correction; //texunit:1
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
2016-10-21 18:27:13 +08:00
|
|
|
layout(location = 0) out vec4 frag_color;
|
2016-10-04 03:33:42 +08:00
|
|
|
|
2017-06-06 09:33:01 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
2016-10-04 03:33:42 +08:00
|
|
|
void main() {
|
|
|
|
|
|
|
|
//vec4 color = color_interp;
|
|
|
|
|
2017-05-26 00:53:59 +08:00
|
|
|
#ifdef USE_PANORAMA
|
|
|
|
|
|
|
|
vec4 color = texturePanorama( normalize(cube_interp), source );
|
|
|
|
|
|
|
|
#elif defined(USE_CUBEMAP)
|
2016-10-21 18:27:13 +08:00
|
|
|
vec4 color = texture( source_cube, normalize(cube_interp) );
|
|
|
|
|
|
|
|
#else
|
|
|
|
vec4 color = texture( source, uv_interp );
|
|
|
|
#endif
|
|
|
|
|
2017-05-26 00:53:59 +08:00
|
|
|
|
|
|
|
|
2016-10-30 07:48:09 +08:00
|
|
|
#ifdef LINEAR_TO_SRGB
|
|
|
|
//regular Linear -> SRGB conversion
|
|
|
|
vec3 a = vec3(0.055);
|
|
|
|
color.rgb = mix( (vec3(1.0)+a)*pow(color.rgb,vec3(1.0/2.4))-a , 12.92*color.rgb , lessThan(color.rgb,vec3(0.0031308)));
|
|
|
|
#endif
|
|
|
|
|
2017-06-24 19:58:27 +08:00
|
|
|
#ifdef SRGB_TO_LINEAR
|
|
|
|
|
|
|
|
color.rgb = mix(pow((color.rgb + vec3(0.055)) * (1.0 / (1 + 0.055)),vec3(2.4)),color.rgb * (1.0 / 12.92),lessThan(color.rgb,vec3(0.04045)));
|
|
|
|
#endif
|
|
|
|
|
2016-10-30 07:48:09 +08:00
|
|
|
#ifdef DEBUG_GRADIENT
|
|
|
|
color.rg=uv_interp;
|
|
|
|
color.b=0.0;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef DISABLE_ALPHA
|
|
|
|
color.a=1.0;
|
|
|
|
#endif
|
2016-10-21 18:27:13 +08:00
|
|
|
|
2016-11-30 06:55:12 +08:00
|
|
|
|
|
|
|
#ifdef GAUSSIAN_HORIZONTAL
|
|
|
|
color*=0.38774;
|
|
|
|
color+=texture( source, uv_interp+vec2( 1.0, 0.0)*pixel_size )*0.24477;
|
|
|
|
color+=texture( source, uv_interp+vec2( 2.0, 0.0)*pixel_size )*0.06136;
|
|
|
|
color+=texture( source, uv_interp+vec2(-1.0, 0.0)*pixel_size )*0.24477;
|
|
|
|
color+=texture( source, uv_interp+vec2(-2.0, 0.0)*pixel_size )*0.06136;
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef GAUSSIAN_VERTICAL
|
|
|
|
color*=0.38774;
|
|
|
|
color+=texture( source, uv_interp+vec2( 0.0, 1.0)*pixel_size )*0.24477;
|
|
|
|
color+=texture( source, uv_interp+vec2( 0.0, 2.0)*pixel_size )*0.06136;
|
|
|
|
color+=texture( source, uv_interp+vec2( 0.0,-1.0)*pixel_size )*0.24477;
|
|
|
|
color+=texture( source, uv_interp+vec2( 0.0,-2.0)*pixel_size )*0.06136;
|
|
|
|
#endif
|
|
|
|
|
2017-06-06 09:33:01 +08:00
|
|
|
#ifdef USE_BCS
|
|
|
|
|
|
|
|
color.rgb = mix(vec3(0.0),color.rgb,bcs.x);
|
|
|
|
color.rgb = mix(vec3(0.5),color.rgb,bcs.y);
|
|
|
|
color.rgb = mix(vec3(dot(vec3(1.0),color.rgb)*0.33333),color.rgb,bcs.z);
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef USE_COLOR_CORRECTION
|
|
|
|
|
|
|
|
color.r = texture(color_correction,vec2(color.r,0.0)).r;
|
|
|
|
color.g = texture(color_correction,vec2(color.g,0.0)).g;
|
|
|
|
color.b = texture(color_correction,vec2(color.b,0.0)).b;
|
|
|
|
#endif
|
|
|
|
|
2017-05-30 09:11:33 +08:00
|
|
|
#ifdef USE_MULTIPLIER
|
|
|
|
color.rgb*=multiplier;
|
|
|
|
#endif
|
2016-10-04 03:33:42 +08:00
|
|
|
frag_color = color;
|
|
|
|
}
|
|
|
|
|