#version 120 #define Bloom #define composite3 //it's composite4 but we don't need the extra define so use 3 instead #include "/shaders.settings" #ifdef Bloom varying vec2 texcoord; varying float eyeAdapt; uniform vec3 sunPosition; uniform vec3 upPosition; uniform ivec2 eyeBrightnessSmooth; uniform int worldTime; uniform float rainStrength; uniform float frameTimeCounter; const vec3 ToD[7] = vec3[7]( vec3(0.58597,0.16,0.025), vec3(0.58597,0.4,0.2), vec3(0.58597,0.52344,0.24680), vec3(0.58597,0.55422,0.34), vec3(0.58597,0.57954,0.38), vec3(0.58597,0.58,0.40), vec3(0.58597,0.58,0.40)); float luma(vec3 color) { return dot(color,vec3(0.299, 0.587, 0.114)); } #endif void main() { gl_Position = ftransform(); #ifdef Bloom texcoord = (gl_MultiTexCoord0).xy; //Sun/Moon position vec3 sunVec = normalize(sunPosition); vec3 upVec = vec3(0.0, 1.0, 0.0); //fix for loading shaderpacks in nether and end, optifine bug. float SdotU = dot(sunVec,upVec); float sunVisibility = pow(clamp(SdotU+0.15,0.0,0.15)/0.15,4.0); float moonVisibility = pow(clamp(-SdotU+0.15,0.0,0.15)/0.15,4.0); /*--------------------------------*/ //reduced the sun color to a 7 array float hour = max(mod(worldTime/1000.0+2.0,24.0)-2.0,0.0); //-0.1 float cmpH = max(-abs(floor(hour)-6.0)+6.0,0.0); //12 float cmpH1 = max(-abs(floor(hour)-5.0)+6.0,0.0); //1 vec3 temp = ToD[int(cmpH)]; vec3 temp2 = ToD[int(cmpH1)]; vec3 sunlight = mix(temp,temp2,fract(hour)); /*--------------------------------*/ //Lighting float eyebright = max(eyeBrightnessSmooth.y/255.0-0.5/16.0,0.0)*1.03225806452; float SkyL2 = mix(1.0,eyebright*eyebright,eyebright); vec2 trCalc = min(abs(worldTime-vec2(23250.0,12700.0)),750.0); float tr = max(min(trCalc.x,trCalc.y)/375.0-1.0,0.0); vec4 bounced = vec4(0.5*SkyL2,0.66*SkyL2,0.7,0.3); vec3 sun_ambient = bounced.w * (vec3(0.25,0.62,1.32)-rainStrength*vec3(0.11,0.32,1.07)) + sunlight*(bounced.x + bounced.z); const vec3 moonlight = vec3(0.0035, 0.0063, 0.0098); vec3 avgAmbient =(sun_ambient*sunVisibility + moonlight*moonVisibility)*eyebright*eyebright*(0.05+tr*0.15)*4.7+0.0006; eyeAdapt = log(clamp(luma(avgAmbient),0.007,80.0))/log(2.6)*0.35; eyeAdapt = 1.0/pow(2.6,eyeAdapt)*1.75; #endif }