2023-07-07 13:56:38 +01:00
|
|
|
#include "/lib/settings.glsl"
|
2023-01-12 15:00:14 -05:00
|
|
|
//Computes volumetric clouds at variable resolution (default 1/4 res)
|
2023-01-12 15:28:19 -05:00
|
|
|
|
2024-02-10 18:10:46 -05:00
|
|
|
#define USE_WEATHER_PARAMS
|
2023-01-12 15:00:14 -05:00
|
|
|
|
2024-02-10 18:10:46 -05:00
|
|
|
#ifdef Daily_Weather
|
|
|
|
flat varying vec3 dailyWeatherParams0;
|
|
|
|
flat varying vec3 dailyWeatherParams1;
|
|
|
|
#endif
|
2023-06-26 00:33:31 -04:00
|
|
|
|
2023-01-12 15:00:14 -05:00
|
|
|
flat varying vec3 sunColor;
|
2024-03-12 17:16:30 -04:00
|
|
|
// flat varying vec3 moonColor;
|
2023-07-25 22:48:08 -04:00
|
|
|
flat varying vec3 averageSkyCol;
|
2023-06-26 00:33:31 -04:00
|
|
|
|
|
|
|
flat varying float tempOffsets;
|
2023-10-07 22:18:20 -04:00
|
|
|
// uniform float far;
|
2023-06-26 00:33:31 -04:00
|
|
|
uniform float near;
|
2023-01-12 15:00:14 -05:00
|
|
|
uniform sampler2D depthtex0;
|
2024-02-05 16:04:37 -05:00
|
|
|
uniform sampler2D dhDepthTex;
|
2023-01-12 15:00:14 -05:00
|
|
|
// uniform sampler2D colortex4;
|
|
|
|
uniform sampler2D noisetex;
|
|
|
|
|
2024-02-05 16:04:37 -05:00
|
|
|
uniform sampler2D colortex12;
|
|
|
|
|
2023-04-16 16:18:26 -04:00
|
|
|
flat varying vec3 WsunVec;
|
2023-01-12 15:00:14 -05:00
|
|
|
uniform vec3 sunVec;
|
|
|
|
uniform vec2 texelSize;
|
|
|
|
uniform float frameTimeCounter;
|
|
|
|
uniform float rainStrength;
|
|
|
|
uniform int frameCounter;
|
|
|
|
uniform int framemod8;
|
|
|
|
uniform mat4 gbufferProjectionInverse;
|
|
|
|
uniform mat4 gbufferModelViewInverse;
|
|
|
|
uniform vec3 cameraPosition;
|
|
|
|
|
|
|
|
uniform mat4 gbufferModelView;
|
|
|
|
// flat varying vec2 TAA_Offset;
|
|
|
|
|
|
|
|
|
|
|
|
vec3 toScreenSpace(vec3 p) {
|
|
|
|
vec4 iProjDiag = vec4(gbufferProjectionInverse[0].x, gbufferProjectionInverse[1].y, gbufferProjectionInverse[2].zw);
|
|
|
|
vec3 p3 = p * 2. - 1.;
|
|
|
|
vec4 fragposition = iProjDiag * p3.xyzz + gbufferProjectionInverse[3];
|
|
|
|
return fragposition.xyz / fragposition.w;
|
|
|
|
}
|
2024-02-12 00:49:20 -05:00
|
|
|
|
2023-01-12 15:00:14 -05:00
|
|
|
float R2_dither(){
|
2024-03-01 22:48:09 -05:00
|
|
|
#ifdef TAA
|
2023-10-18 17:43:29 -04:00
|
|
|
vec2 coord = gl_FragCoord.xy + (frameCounter%40000) * 2.0;
|
2024-03-01 22:48:09 -05:00
|
|
|
#else
|
|
|
|
|
|
|
|
vec2 coord = gl_FragCoord.xy;
|
|
|
|
#endif
|
2023-01-12 15:00:14 -05:00
|
|
|
vec2 alpha = vec2(0.75487765, 0.56984026);
|
2023-10-18 17:43:29 -04:00
|
|
|
return fract(alpha.x * coord.x + alpha.y * coord.y ) ;
|
2023-01-12 15:00:14 -05:00
|
|
|
}
|
|
|
|
float interleaved_gradientNoise(){
|
|
|
|
vec2 alpha = vec2(0.75487765, 0.56984026);
|
|
|
|
vec2 coord = vec2(alpha.x * gl_FragCoord.x,alpha.y * gl_FragCoord.y)+ 1.0/1.6180339887 * frameCounter;
|
|
|
|
float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y));
|
|
|
|
return noise;
|
|
|
|
}
|
2023-10-07 22:18:20 -04:00
|
|
|
|
|
|
|
|
|
|
|
|
2023-01-12 15:00:14 -05:00
|
|
|
const vec2[8] offsets = vec2[8](vec2(1./8.,-3./8.),
|
|
|
|
vec2(-1.,3.)/8.,
|
|
|
|
vec2(5.0,1.)/8.,
|
|
|
|
vec2(-3,-5.)/8.,
|
|
|
|
vec2(-5.,5.)/8.,
|
|
|
|
vec2(-7.,-1.)/8.,
|
|
|
|
vec2(3,7.)/8.,
|
|
|
|
vec2(7.,-7.)/8.);
|
|
|
|
float blueNoise(){
|
2024-03-01 22:48:09 -05:00
|
|
|
#ifdef TAA
|
2024-03-12 17:16:30 -04:00
|
|
|
return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter);
|
2024-03-01 22:48:09 -05:00
|
|
|
#else
|
2024-03-12 17:16:30 -04:00
|
|
|
return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a);
|
2024-03-01 22:48:09 -05:00
|
|
|
#endif
|
2023-01-12 15:00:14 -05:00
|
|
|
}
|
|
|
|
|
2024-03-01 22:48:09 -05:00
|
|
|
|
2023-01-12 15:00:14 -05:00
|
|
|
vec3 normVec (vec3 vec){
|
|
|
|
return vec*inversesqrt(dot(vec,vec));
|
|
|
|
}
|
2023-06-29 00:10:03 -04:00
|
|
|
|
2023-10-07 22:18:20 -04:00
|
|
|
#include "/lib/lightning_stuff.glsl"
|
|
|
|
|
|
|
|
#include "/lib/sky_gradient.glsl"
|
|
|
|
#include "/lib/volumetricClouds.glsl"
|
|
|
|
#include "/lib/res_params.glsl"
|
|
|
|
|
2024-02-05 16:04:37 -05:00
|
|
|
|
2023-01-12 15:00:14 -05:00
|
|
|
//////////////////////////////VOID MAIN//////////////////////////////
|
|
|
|
//////////////////////////////VOID MAIN//////////////////////////////
|
|
|
|
//////////////////////////////VOID MAIN//////////////////////////////
|
|
|
|
//////////////////////////////VOID MAIN//////////////////////////////
|
|
|
|
//////////////////////////////VOID MAIN//////////////////////////////
|
|
|
|
|
2023-04-16 16:18:26 -04:00
|
|
|
|
2023-01-12 15:00:14 -05:00
|
|
|
void main() {
|
|
|
|
/* DRAWBUFFERS:0 */
|
|
|
|
|
2023-10-07 22:18:20 -04:00
|
|
|
#ifdef OVERWORLD_SHADER
|
|
|
|
#ifdef VOLUMETRIC_CLOUDS
|
|
|
|
vec2 halfResTC = vec2(floor(gl_FragCoord.xy)/CLOUDS_QUALITY/RENDER_SCALE+0.5+offsets[framemod8]*CLOUDS_QUALITY*RENDER_SCALE*0.5);
|
2023-01-12 15:00:14 -05:00
|
|
|
|
2024-02-05 16:04:37 -05:00
|
|
|
vec3 viewPos = toScreenSpace(vec3(halfResTC*texelSize,1.0));
|
2023-01-12 15:00:14 -05:00
|
|
|
|
2024-03-01 22:48:09 -05:00
|
|
|
vec4 VolumetricClouds = renderClouds(viewPos, vec2(R2_dither(), blueNoise()), sunColor/80.0, averageSkyCol/30.0);
|
2023-01-12 15:00:14 -05:00
|
|
|
|
2024-02-16 21:28:13 -05:00
|
|
|
// gl_FragData[0] = vec4(0.0,0.0,0.0,1.0);
|
2023-10-07 22:18:20 -04:00
|
|
|
gl_FragData[0] = VolumetricClouds;
|
2023-01-12 15:00:14 -05:00
|
|
|
|
|
|
|
|
2023-10-07 22:18:20 -04:00
|
|
|
#else
|
|
|
|
gl_FragData[0] = vec4(0.0,0.0,0.0,1.0);
|
|
|
|
#endif
|
2023-04-16 16:18:26 -04:00
|
|
|
#else
|
|
|
|
gl_FragData[0] = vec4(0.0,0.0,0.0,1.0);
|
2023-10-07 22:18:20 -04:00
|
|
|
#endif
|
|
|
|
}
|