Files
bluflame/hgplus/ShaderMinifier/tests/real/extatique/skybox2.fs
2026-04-18 22:31:51 +02:00

142 lines
2.8 KiB
GLSL

varying vec3 wpos;
uniform vec3 eyePos;
uniform sampler2D tex;
uniform vec3 light1;
uniform vec3 light2;
uniform vec3 light3;
uniform vec3 light4;
vec3 getEnvColor(vec3 pos, vec2 coord)
{
vec3 color = texture2D(tex, coord * 0.05).xyz;
vec3 light1_dist = pos * 0.1 - vec3(-0.5,-0.5,-0.5);
vec3 light2_dist = pos * 0.1 - vec3(+0.5,+0.5,-0.5);
vec3 light3_dist = pos * 0.1 - vec3(-0.5,+0.5,+0.5);
vec3 light4_dist = pos * 0.1 - vec3(+0.5,-0.5,+0.5);
vec3 clight1 = light1 * vec3(max(0.0, 1.25 - 1.0 * dot(light1_dist, light1_dist)));
vec3 clight2 = light2 * vec3(max(0.0, 1.25 - 1.0 * dot(light2_dist, light2_dist)));
vec3 clight3 = light3 * vec3(max(0.0, 1.25 - 1.0 * dot(light3_dist, light3_dist)));
vec3 clight4 = light4 * vec3(max(0.0, 1.25 - 1.0 * dot(light4_dist, light4_dist)));
return color + clight1 + clight2 + clight3 + clight4;
}
float exp3(float x)
{
float y = max(-1.15365, x);
return 1.0 + y * (1.0 + y * (0.5 + y * 0.33333333));
}
vec3 rayColor(vec3 startPos, vec3 startDir)
{
vec3 total = vec3(0.0);
vec3 p = startPos;
vec3 dir = startDir;
vec3 blend = vec3(0.5);
vec3 dpos;
vec3 color = vec3(0.0);
vec3 ray;
vec3 nml;
vec2 coord;
vec3 newdir;
vec3 sample;
for (int i = 0; i < 3; ++i)
{
ray = 50.0 * dir;
nml = vec3(0.0);
coord = vec2(0.0);
dpos = p + ray;
if (abs(dpos.x) > 10.0)
{
if (dpos.x > 10.0)
{
ray *= ((9.99 - p.x) / ray.x);
nml = vec3(-1.0,0.0,0.0);
dpos = ray + p;
coord = dpos.yz;
color = getEnvColor(dpos, coord);
}
else
{
ray *= ((-9.99 - p.x) / ray.x);
nml = vec3(1.0,0.0,0.0);
dpos = ray + p;
coord = dpos.yz * vec2(-1.0,1.0);
color = getEnvColor(dpos, coord);
}
}
if (abs(dpos.y) > 10.0)
{
if (dpos.y > 10.0)
{
ray *= ((9.99 - p.y) / ray.y);
nml = vec3(0.0,-1.0,0.0);
dpos = ray + p;
coord = dpos.xz * vec2(-1.0,1.0);
color = getEnvColor(dpos, coord);
}
else
{
ray *= ((-9.99 - p.y) / ray.y);
nml = vec3(0.0,1.0,0.0);
dpos = ray + p;
coord = dpos.xz;
color = getEnvColor(dpos, coord);
}
}
if (abs(dpos.z) > 10.0)
{
if (dpos.z > 10.0)
{
ray *= ((9.99 - p.z) / ray.z);
nml = vec3(0.0,0.0,-1.0);
dpos = ray + p;
coord = dpos.xy * vec2(-1.0,1.0);
color = getEnvColor(dpos, coord);
}
else
{
ray *= ((-9.99 - p.z) / ray.z);
nml = vec3(0.0,0.0,1.0);
dpos = ray + p;
coord = dpos.xy;
color = getEnvColor(dpos, coord);
}
}
sample = color * vec3(exp3(-length(ray) * 0.04));
total += sample * blend;
blend *= sample;
newdir = reflect(dir, nml);
p = dpos;
dir = newdir;
}
return total;
}
void main()
{
vec3 env = rayColor(eyePos, normalize(wpos - eyePos));
gl_FragColor = gl_Color * vec4(env, 1.0);
}