kaliber/assets/demo/sky_without_nebula.glsl_fra...

44 lines
924 B
Plaintext
Raw Permalink Normal View History

2021-08-31 21:21:29 +00:00
#ifdef GL_ES
precision highp float;
#endif
IN(0) vec2 tex_coord_0;
UNIFORM_BEGIN
UNIFORM_V(vec2 scale)
UNIFORM_V(mat4 projection)
UNIFORM_F(vec2 sky_offset)
UNIFORM_END
FRAG_COLOR_OUT(frag_color)
float random(vec2 p) {
float sd = sin(dot(p, vec2(54.90898, 18.233)));
return fract(sd * 2671.6182);
}
float stars(in vec2 p, float num_cells, float size) {
vec2 n = p * num_cells;
vec2 i = floor(n);
vec2 a = n - i - random(i);
a /= num_cells * size;
float e = dot(a, a);
return smoothstep(0.94, 1.0, (1.0 - e * 35.0));
}
void main() {
vec2 layer1_coord = tex_coord_0 + PARAM(sky_offset);
vec2 layer2_coord = tex_coord_0 + PARAM(sky_offset) * 0.7;
2023-05-16 06:51:00 +00:00
vec3 result = vec3(0.);
2021-08-31 21:21:29 +00:00
float c = stars(layer1_coord, 8.0, 0.05);
result += vec3(0.97, 0.74, 0.74) * c;
c = stars(layer2_coord, 16.0, 0.025) * 0.5;
result += vec3(0.9, 0.9, 0.95) * c;
FRAG_COLOR(frag_color) = vec4(result, 1.0);
}