2014-02-14 08:46:34 +04:00
|
|
|
$input v_view, v_normal
|
|
|
|
|
|
|
|
/*
|
|
|
|
* Copyright 2014 Dario Manesku. All rights reserved.
|
|
|
|
* License: http://www.opensource.org/licenses/BSD-2-Clause
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "../common/common.sh"
|
|
|
|
|
|
|
|
uniform vec4 u_params;
|
|
|
|
uniform mat4 u_mtx;
|
|
|
|
uniform vec4 u_flags;
|
2015-05-29 01:27:00 +03:00
|
|
|
uniform vec4 u_rgbDiff;
|
|
|
|
uniform vec4 u_rgbSpec;
|
2014-02-14 08:46:34 +04:00
|
|
|
|
2015-06-07 03:12:29 +03:00
|
|
|
SAMPLERCUBE(s_texCube, 0);
|
|
|
|
SAMPLERCUBE(s_texCubeIrr, 1);
|
2014-02-14 08:46:34 +04:00
|
|
|
|
|
|
|
#define u_glossiness u_params.x
|
|
|
|
#define u_exposure u_params.y
|
|
|
|
#define u_diffspec u_params.z
|
|
|
|
|
|
|
|
#define u_doDiffuse u_flags.x
|
|
|
|
#define u_doSpecular u_flags.y
|
|
|
|
#define u_doDiffuseIbl u_flags.z
|
|
|
|
#define u_doSpecularIbl u_flags.w
|
|
|
|
|
|
|
|
vec3 fresnel(vec3 _cspec, float _dot)
|
|
|
|
{
|
|
|
|
return _cspec + (1.0 - _cspec) * pow(1.0 - _dot, 5);
|
|
|
|
}
|
|
|
|
|
|
|
|
void main()
|
|
|
|
{
|
2015-01-21 08:41:51 +03:00
|
|
|
vec3 light = vec3(0.0, 0.0, -1.0);
|
|
|
|
vec3 clight = vec3(1.0, 1.0, 1.0);
|
2014-02-14 08:46:34 +04:00
|
|
|
|
|
|
|
vec3 v = v_view;
|
|
|
|
vec3 n = normalize(v_normal);
|
|
|
|
vec3 l = normalize(light);
|
|
|
|
vec3 h = normalize(v + l);
|
|
|
|
|
|
|
|
float ndotl = clamp(dot(n, l), 0.0, 1.0); //diff
|
|
|
|
float ndoth = clamp(dot(n, h), 0.0, 1.0); //spec
|
|
|
|
float vdoth = clamp(dot(v, h), 0.0, 1.0); //spec fresnel
|
|
|
|
float ndotv = clamp(dot(n, v), 0.0, 1.0); //env spec fresnel
|
|
|
|
|
|
|
|
vec3 r = 2.0*ndotv*n - v; // reflect(v, n);
|
|
|
|
|
|
|
|
vec3 cubeR = normalize(mul(u_mtx, vec4(r, 0.0)).xyz);
|
|
|
|
vec3 cubeN = normalize(mul(u_mtx, vec4(n, 0.0)).xyz);
|
|
|
|
|
|
|
|
float mipLevel = min((1.0 - u_glossiness)*11.0 + 1.0, 8.0);
|
2015-06-07 03:12:29 +03:00
|
|
|
vec3 cenv = textureCubeLod(s_texCube, cubeR, mipLevel).xyz;
|
2014-02-14 08:46:34 +04:00
|
|
|
|
2015-05-29 01:27:00 +03:00
|
|
|
vec3 kd = u_rgbDiff.xyz;
|
|
|
|
vec3 ks = u_rgbSpec.xyz;
|
2014-02-14 08:46:34 +04:00
|
|
|
|
|
|
|
vec3 cs = ks * u_diffspec;
|
|
|
|
vec3 cd = kd * (1.0 - cs);
|
|
|
|
|
|
|
|
vec3 diff = cd;
|
2014-02-14 12:16:23 +04:00
|
|
|
float pwr = exp2(u_glossiness * 11.0 + 1.0);
|
2014-02-14 08:46:34 +04:00
|
|
|
vec3 spec = cs * pow(ndoth, pwr) * ( (pwr + 8.0)/8.0) * fresnel(cs, vdoth);
|
|
|
|
|
|
|
|
vec3 ambspec = fresnel(cs, ndotv) * cenv;
|
2015-06-07 03:12:29 +03:00
|
|
|
vec3 ambdiff = cd * textureCube(s_texCubeIrr, cubeN).xyz;
|
2014-02-14 08:46:34 +04:00
|
|
|
|
|
|
|
vec3 lc = ( diff * u_doDiffuse + spec * u_doSpecular ) * ndotl * clight;
|
|
|
|
vec3 ec = (ambdiff * u_doDiffuseIbl + ambspec * u_doSpecularIbl);
|
|
|
|
|
|
|
|
vec3 color = lc + ec;
|
|
|
|
color = color * exp2(u_exposure);
|
|
|
|
|
|
|
|
gl_FragColor.xyz = toFilmic(color);
|
|
|
|
gl_FragColor.w = 1.0;
|
|
|
|
}
|