From 2ee66349356dc705a5a74eb5ebfddd0a59b4b4cb Mon Sep 17 00:00:00 2001 From: Xonk Date: Sun, 16 Apr 2023 16:18:26 -0400 Subject: [PATCH] surprise commit new stuff reworked clouds, general lighting, end and nether shaders still WIP lighting is more balanced in general. --- shaders/block.properties | 2 +- shaders/composite.fsh | 3 +- shaders/composite1.fsh | 1267 +++++++++++++++++ shaders/composite1.vsh | 70 + shaders/composite10.fsh | 107 +- shaders/composite10.vsh | 2 +- shaders/composite11.fsh | 179 ++- shaders/composite11.vsh | 35 +- shaders/composite12.fsh | 62 - shaders/composite12.vsh | 23 - shaders/composite14.fsh | 105 -- shaders/composite14.vsh | 18 - shaders/composite15.fsh | 129 -- shaders/composite15.vsh | 24 - shaders/composite2.fsh | 1242 ++-------------- shaders/composite2.vsh | 98 +- shaders/composite3.fsh | 299 +++- shaders/composite3.vsh | 40 +- shaders/composite4.fsh | 46 + shaders/{world1/texture => }/composite4.vsh | 13 +- shaders/composite5.fsh | 814 ++++++----- shaders/composite5.vsh | 104 +- shaders/composite6.fsh | 329 +---- shaders/composite6.vsh | 50 +- shaders/composite7.fsh | 68 +- shaders/composite7.vsh | 14 +- shaders/composite8.fsh | 474 +----- shaders/composite8.vsh | 27 +- shaders/composite9.fsh | 100 +- shaders/composite9.vsh | 13 +- shaders/deferred.fsh | 51 +- shaders/deferred.vsh | 8 +- shaders/deferred1.fsh | 38 +- shaders/deferred1.vsh | 11 + shaders/entity.properties | 8 +- shaders/final.fsh | 4 +- shaders/gbuffers_all_particles.fsh | 81 +- shaders/gbuffers_all_particles.vsh | 7 +- shaders/gbuffers_all_solid.fsh | 113 +- shaders/gbuffers_all_solid.vsh | 127 +- shaders/gbuffers_all_translucent.fsh | 330 +++-- shaders/gbuffers_all_translucent.vsh | 50 +- shaders/gbuffers_beaconbeam.fsh | 37 +- shaders/gbuffers_beaconbeam.vsh | 59 +- shaders/gbuffers_entities.vsh | 2 +- shaders/gbuffers_hand.fsh | 1 + shaders/gbuffers_hand_water.fsh | 1 + shaders/gbuffers_hand_water.vsh | 1 + shaders/gbuffers_skytextured.fsh | 21 +- shaders/gbuffers_skytextured.vsh | 33 - shaders/gbuffers_spidereyes.fsh | 34 +- shaders/gbuffers_spidereyes.vsh | 39 +- shaders/lang/en_us.lang | 6 +- shaders/lib/PhotonGTAO.glsl | 186 +++ shaders/lib/climate_settings.glsl | 46 +- shaders/lib/diffuse_lighting.glsl | 61 + shaders/lib/end_fog.glsl | 346 +++++ shaders/lib/nether_fog.glsl | 168 +++ shaders/lib/oceans.glsl | 120 ++ shaders/lib/settings.glsl | 122 +- shaders/lib/sky_gradient.glsl | 4 +- shaders/lib/specular.glsl | 522 ++++--- shaders/lib/volumetricClouds.glsl | 514 +++---- shaders/lib/volumetricFog.glsl | 118 +- shaders/lib/waterBump.glsl | 75 +- shaders/programs/all_particles.fsh | 81 ++ shaders/programs/all_particles.vsh | 45 + .../all_solid.fsh} | 307 ++-- shaders/programs/all_solid.vsh | 140 ++ shaders/programs/all_translucent.fsh | 576 ++++++++ .../all_translucent.vsh} | 39 +- shaders/shaders.properties | 92 +- shaders/shadow.fsh | 2 + shaders/world-1/block.properties | 20 - shaders/world-1/composite15.fsh | 45 +- shaders/world-1/composite15.vsh | 4 +- shaders/world-1/composite2.fsh | 442 +++--- shaders/world-1/composite2.vsh | 33 +- shaders/world-1/composite3.fsh | 79 + .../{world1/lib => world-1}/composite3.vsh | 15 +- shaders/world-1/composite5.fsh | 271 ---- shaders/world-1/composite5.vsh | 51 - shaders/world-1/composite6.fsh | 157 +- shaders/world-1/composite8.fsh | 142 +- shaders/world-1/composite8.vsh | 3 + shaders/world-1/composite9.fsh | 8 - shaders/world-1/deferred.fsh | 69 +- shaders/world-1/deferred.vsh | 180 ++- shaders/world-1/deferred2.fsh | 30 + shaders/world-1/deferred2.vsh | 11 + shaders/world-1/final.fsh | 15 +- shaders/world-1/final.vsh | 4 +- shaders/world-1/gbuffers_all_solid.vsh | 213 --- shaders/world-1/gbuffers_all_translucent.fsh | 624 -------- shaders/world-1/gbuffers_armor_glint.fsh | 31 +- shaders/world-1/gbuffers_armor_glint.vsh | 26 +- shaders/world-1/gbuffers_basic.fsh | 4 +- shaders/world-1/gbuffers_basic.vsh | 5 +- shaders/world-1/gbuffers_block.fsh | 4 +- shaders/world-1/gbuffers_block.vsh | 4 +- shaders/world-1/gbuffers_clouds.fsh | 9 - shaders/world-1/gbuffers_clouds.vsh | 14 - shaders/world-1/gbuffers_entities.fsh | 3 +- shaders/world-1/gbuffers_entities.vsh | 2 +- shaders/world-1/gbuffers_hand.fsh | 2 +- shaders/world-1/gbuffers_hand.vsh | 3 +- shaders/world-1/gbuffers_hand_water.fsh | 115 +- shaders/world-1/gbuffers_hand_water.vsh | 55 +- shaders/world-1/gbuffers_terrain.fsh | 3 +- shaders/world-1/gbuffers_terrain.vsh | 3 +- shaders/world-1/gbuffers_textured.fsh | 115 +- shaders/world-1/gbuffers_textured.vsh | 73 +- shaders/world-1/gbuffers_textured_lit.fsh | 115 +- shaders/world-1/gbuffers_textured_lit.vsh | 57 +- shaders/world-1/gbuffers_water.fsh | 333 +---- shaders/world-1/gbuffers_water.vsh | 88 +- shaders/world-1/lib/ACES.glsl | 382 ----- shaders/world-1/lib/ACESSPL.glsl | 115 -- shaders/world-1/lib/ACEST.glsl | 63 - shaders/world-1/lib/ROBOBO_sky.glsl | 157 -- shaders/world-1/lib/Shadow_Params.glsl | 22 - shaders/world-1/lib/clouds.glsl | 16 - shaders/world-1/lib/color_dither.glsl | 46 - shaders/world-1/lib/color_transforms.glsl | 131 -- shaders/world-1/lib/composite3.fsh | 78 - shaders/world-1/lib/projections.glsl | 55 - shaders/world-1/lib/sky_gradient.glsl | 84 -- shaders/world-1/lib/specular.glsl | 410 ------ shaders/world-1/lib/stars.glsl | 48 - shaders/world-1/lib/texFiltering.glsl | 19 - shaders/world-1/lib/util.glsl | 196 --- shaders/world-1/lib/volumetricClouds.glsl | 282 ---- shaders/world-1/lib/volumetricFog.glsl | 118 -- shaders/world-1/lib/waterBump.glsl | 38 - shaders/world-1/lib/waterOptions.glsl | 21 - shaders/world-1/shaders.properties | 121 -- shaders/world-1/texture/composite4.fsh | 37 - shaders/world-1/texture/composite4.vsh | 19 - shaders/world-1/texture/noises.png | Bin 695035 -> 0 bytes shaders/world-1/texture/noises.png.mcmeta | 7 - shaders/world1/block.properties | 20 - shaders/world1/composite.fsh | 467 ++++++ shaders/world1/composite.vsh | 51 + shaders/world1/composite10.fsh | 500 ++++++- shaders/world1/composite10.vsh | 18 +- shaders/world1/composite12.fsh | 61 - shaders/world1/composite12.vsh | 21 - shaders/world1/composite14.fsh | 103 -- shaders/world1/composite14.vsh | 17 - shaders/world1/composite15.fsh | 512 ------- shaders/world1/composite15.vsh | 25 - shaders/world1/composite2.fsh | 596 +------- shaders/world1/composite2.vsh | 60 +- shaders/world1/composite3.fsh | 187 +++ .../{world-1/lib => world1}/composite3.vsh | 0 shaders/world1/composite4.fsh | 361 +++++ shaders/world1/composite4.vsh | 20 + shaders/world1/composite5.fsh | 278 +--- shaders/world1/composite5.vsh | 44 +- shaders/world1/composite6.fsh | 235 +-- shaders/world1/composite6.vsh | 14 +- .../{composite11.fsh => composite7.fsh} | 0 .../{composite11.vsh => composite7.vsh} | 0 shaders/world1/composite8.fsh | 345 +---- shaders/world1/composite8.vsh | 26 +- shaders/world1/composite9.fsh | 114 +- shaders/world1/deferred.fsh | 67 +- shaders/world1/deferred.vsh | 187 ++- shaders/world1/deferred1.fsh | 87 -- shaders/world1/deferred1.vsh | 21 - shaders/world1/deferred2.fsh | 30 + shaders/world1/deferred2.vsh | 11 + shaders/world1/final.fsh | 15 +- shaders/world1/final.vsh | 4 +- shaders/world1/gbuffers_all_solid.fsh | 411 ------ shaders/world1/gbuffers_all_solid.vsh | 213 --- shaders/world1/gbuffers_all_translucent.fsh | 624 -------- shaders/world1/gbuffers_all_translucent.vsh | 112 -- shaders/world1/gbuffers_armor_glint.fsh | 31 +- shaders/world1/gbuffers_armor_glint.vsh | 26 +- shaders/world1/gbuffers_basic.fsh | 4 +- shaders/world1/gbuffers_basic.vsh | 5 +- shaders/world1/gbuffers_block.fsh | 4 +- shaders/world1/gbuffers_block.vsh | 4 +- shaders/world1/gbuffers_clouds.fsh | 9 - shaders/world1/gbuffers_clouds.vsh | 14 - shaders/world1/gbuffers_entities.fsh | 3 +- shaders/world1/gbuffers_entities.vsh | 2 +- shaders/world1/gbuffers_hand.fsh | 2 +- shaders/world1/gbuffers_hand.vsh | 3 +- shaders/world1/gbuffers_hand_water.fsh | 115 +- shaders/world1/gbuffers_hand_water.vsh | 55 +- shaders/world1/gbuffers_terrain.fsh | 3 +- shaders/world1/gbuffers_terrain.vsh | 3 +- shaders/world1/gbuffers_textured.fsh | 115 +- shaders/world1/gbuffers_textured.vsh | 73 +- shaders/world1/gbuffers_textured_lit.fsh | 115 +- shaders/world1/gbuffers_textured_lit.vsh | 57 +- shaders/world1/gbuffers_water.fsh | 333 +---- shaders/world1/gbuffers_water.vsh | 88 +- shaders/world1/lib/ACES.glsl | 382 ----- shaders/world1/lib/ACESSPL.glsl | 115 -- shaders/world1/lib/ACEST.glsl | 63 - shaders/world1/lib/ROBOBO_sky.glsl | 157 -- shaders/world1/lib/Shadow_Params.glsl | 22 - shaders/world1/lib/clouds.glsl | 16 - shaders/world1/lib/color_dither.glsl | 46 - shaders/world1/lib/color_transforms.glsl | 131 -- shaders/world1/lib/composite3.fsh | 78 - shaders/world1/lib/projections.glsl | 55 - shaders/world1/lib/sky_gradient.glsl | 84 -- shaders/world1/lib/specular.glsl | 334 ----- shaders/world1/lib/stars.glsl | 48 - shaders/world1/lib/texFiltering.glsl | 19 - shaders/world1/lib/util.glsl | 196 --- shaders/world1/lib/volumetricClouds.glsl | 342 ----- shaders/world1/lib/volumetricFog.glsl | 118 -- shaders/world1/lib/waterBump.glsl | 38 - shaders/world1/lib/waterOptions.glsl | 21 - shaders/world1/shaders.properties | 121 -- shaders/world1/texture/composite4.fsh | 37 - shaders/world1/texture/noises.png | Bin 695035 -> 0 bytes shaders/world1/texture/noises.png.mcmeta | 7 - 223 files changed, 8807 insertions(+), 16872 deletions(-) create mode 100644 shaders/composite1.fsh create mode 100644 shaders/composite1.vsh delete mode 100644 shaders/composite12.fsh delete mode 100644 shaders/composite12.vsh delete mode 100644 shaders/composite14.fsh delete mode 100644 shaders/composite14.vsh delete mode 100644 shaders/composite15.fsh delete mode 100644 shaders/composite15.vsh create mode 100644 shaders/composite4.fsh rename shaders/{world1/texture => }/composite4.vsh (72%) create mode 100644 shaders/lib/PhotonGTAO.glsl create mode 100644 shaders/lib/diffuse_lighting.glsl create mode 100644 shaders/lib/end_fog.glsl create mode 100644 shaders/lib/nether_fog.glsl create mode 100644 shaders/lib/oceans.glsl create mode 100644 shaders/programs/all_particles.fsh create mode 100644 shaders/programs/all_particles.vsh rename shaders/{world-1/gbuffers_all_solid.fsh => programs/all_solid.fsh} (52%) create mode 100644 shaders/programs/all_solid.vsh create mode 100644 shaders/programs/all_translucent.fsh rename shaders/{world-1/gbuffers_all_translucent.vsh => programs/all_translucent.vsh} (86%) delete mode 100644 shaders/world-1/block.properties create mode 100644 shaders/world-1/composite3.fsh rename shaders/{world1/lib => world-1}/composite3.vsh (69%) delete mode 100644 shaders/world-1/composite5.fsh delete mode 100644 shaders/world-1/composite5.vsh create mode 100644 shaders/world-1/deferred2.fsh create mode 100644 shaders/world-1/deferred2.vsh delete mode 100644 shaders/world-1/gbuffers_all_solid.vsh delete mode 100644 shaders/world-1/gbuffers_all_translucent.fsh delete mode 100644 shaders/world-1/gbuffers_clouds.fsh delete mode 100644 shaders/world-1/gbuffers_clouds.vsh delete mode 100644 shaders/world-1/lib/ACES.glsl delete mode 100644 shaders/world-1/lib/ACESSPL.glsl delete mode 100644 shaders/world-1/lib/ACEST.glsl delete mode 100644 shaders/world-1/lib/ROBOBO_sky.glsl delete mode 100644 shaders/world-1/lib/Shadow_Params.glsl delete mode 100644 shaders/world-1/lib/clouds.glsl delete mode 100644 shaders/world-1/lib/color_dither.glsl delete mode 100644 shaders/world-1/lib/color_transforms.glsl delete mode 100644 shaders/world-1/lib/composite3.fsh delete mode 100644 shaders/world-1/lib/projections.glsl delete mode 100644 shaders/world-1/lib/sky_gradient.glsl delete mode 100644 shaders/world-1/lib/specular.glsl delete mode 100644 shaders/world-1/lib/stars.glsl delete mode 100644 shaders/world-1/lib/texFiltering.glsl delete mode 100644 shaders/world-1/lib/util.glsl delete mode 100644 shaders/world-1/lib/volumetricClouds.glsl delete mode 100644 shaders/world-1/lib/volumetricFog.glsl delete mode 100644 shaders/world-1/lib/waterBump.glsl delete mode 100644 shaders/world-1/lib/waterOptions.glsl delete mode 100644 shaders/world-1/shaders.properties delete mode 100644 shaders/world-1/texture/composite4.fsh delete mode 100644 shaders/world-1/texture/composite4.vsh delete mode 100644 shaders/world-1/texture/noises.png delete mode 100644 shaders/world-1/texture/noises.png.mcmeta delete mode 100644 shaders/world1/block.properties create mode 100644 shaders/world1/composite.fsh create mode 100644 shaders/world1/composite.vsh delete mode 100644 shaders/world1/composite12.fsh delete mode 100644 shaders/world1/composite12.vsh delete mode 100644 shaders/world1/composite14.fsh delete mode 100644 shaders/world1/composite14.vsh delete mode 100644 shaders/world1/composite15.fsh delete mode 100644 shaders/world1/composite15.vsh create mode 100644 shaders/world1/composite3.fsh rename shaders/{world-1/lib => world1}/composite3.vsh (100%) create mode 100644 shaders/world1/composite4.fsh create mode 100644 shaders/world1/composite4.vsh rename shaders/world1/{composite11.fsh => composite7.fsh} (100%) rename shaders/world1/{composite11.vsh => composite7.vsh} (100%) delete mode 100644 shaders/world1/deferred1.fsh delete mode 100644 shaders/world1/deferred1.vsh create mode 100644 shaders/world1/deferred2.fsh create mode 100644 shaders/world1/deferred2.vsh delete mode 100644 shaders/world1/gbuffers_all_solid.fsh delete mode 100644 shaders/world1/gbuffers_all_solid.vsh delete mode 100644 shaders/world1/gbuffers_all_translucent.fsh delete mode 100644 shaders/world1/gbuffers_all_translucent.vsh delete mode 100644 shaders/world1/gbuffers_clouds.fsh delete mode 100644 shaders/world1/gbuffers_clouds.vsh delete mode 100644 shaders/world1/lib/ACES.glsl delete mode 100644 shaders/world1/lib/ACESSPL.glsl delete mode 100644 shaders/world1/lib/ACEST.glsl delete mode 100644 shaders/world1/lib/ROBOBO_sky.glsl delete mode 100644 shaders/world1/lib/Shadow_Params.glsl delete mode 100644 shaders/world1/lib/clouds.glsl delete mode 100644 shaders/world1/lib/color_dither.glsl delete mode 100644 shaders/world1/lib/color_transforms.glsl delete mode 100644 shaders/world1/lib/composite3.fsh delete mode 100644 shaders/world1/lib/projections.glsl delete mode 100644 shaders/world1/lib/sky_gradient.glsl delete mode 100644 shaders/world1/lib/specular.glsl delete mode 100644 shaders/world1/lib/stars.glsl delete mode 100644 shaders/world1/lib/texFiltering.glsl delete mode 100644 shaders/world1/lib/util.glsl delete mode 100644 shaders/world1/lib/volumetricClouds.glsl delete mode 100644 shaders/world1/lib/volumetricFog.glsl delete mode 100644 shaders/world1/lib/waterBump.glsl delete mode 100644 shaders/world1/lib/waterOptions.glsl delete mode 100644 shaders/world1/shaders.properties delete mode 100644 shaders/world1/texture/composite4.fsh delete mode 100644 shaders/world1/texture/noises.png delete mode 100644 shaders/world1/texture/noises.png.mcmeta diff --git a/shaders/block.properties b/shaders/block.properties index 626537e..515ad75 100644 --- a/shaders/block.properties +++ b/shaders/block.properties @@ -7,7 +7,7 @@ block.10001 = minecraft:beetroots minecraft:potatoes minecraft:carrots minecraft:wheat minecraft:nether_wart minecraft:kelp minecraft:large_fern:half=upper minecraft:peony:half=upper minecraft:rose_bush:half=upper minecraft:lilac:half=upper minecraft:crimson_roots minecraft:nether_sprouts minecraft:warped_roots minecraft:seagrass minecraft:tall_seagrass:half=upper minecraft:sunflower:half=upper minecraft:tall_grass:half=upper minecraft:wither_rose minecraft:lily_of_the_valley minecraft:cornflower minecraft:sweet_berry_bush minecraft:oxeye_daisy minecraft:pink_tulip minecraft:white_tulip minecraft:orange_tulip minecraft:red_tulip minecraft:azure_bluet minecraft:allium minecraft:blue_orchid minecraft:poppy minecraft:dandelion minecraft:grass minecraft:dead_bush minecraft:oak_sapling minecraft:spruce_sapling minecraft:birch_sapling minecraft:jungle_sapling minecraft:acacia_sapling minecraft:dark_oak_sapling minecraft:fern ##air waving - block.10003 = minecraft:mangrove_leaves minecraft:vine minecraft:oak_leaves minecraft:spruce_leaves minecraft:birch_leaves minecraft:jungle_leaves minecraft:acacia_leaves minecraft:dark_oak_leaves + block.10003 = minecraft:cherry_leaves minecraft:mangrove_leaves minecraft:vine minecraft:oak_leaves minecraft:spruce_leaves minecraft:birch_leaves minecraft:jungle_leaves minecraft:acacia_leaves minecraft:dark_oak_leaves ####### ----- SSS ----- ####### diff --git a/shaders/composite.fsh b/shaders/composite.fsh index a18c18e..96d2a24 100644 --- a/shaders/composite.fsh +++ b/shaders/composite.fsh @@ -195,7 +195,6 @@ void main() { float LabSSS = 0.0; #endif - #ifndef Variable_Penumbra_Shadows if (translucent && !hand) minshadowfilt += 25; #endif @@ -217,7 +216,7 @@ void main() { #ifdef Variable_Penumbra_Shadows - if (NdotL > 0.000 || LabSSS > 0.0 || translucent || translucent2 || translucent3 || translucent4) { + if (NdotL > 0.0 || LabSSS >= 0.0) { vec3 p3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; diff --git a/shaders/composite1.fsh b/shaders/composite1.fsh new file mode 100644 index 0000000..be26cf4 --- /dev/null +++ b/shaders/composite1.fsh @@ -0,0 +1,1267 @@ +#version 120 +//Render sky, volumetric clouds, direct lighting +#extension GL_EXT_gpu_shader4 : enable + +#include "lib/settings.glsl" + +const bool colortex5MipmapEnabled = true; +const bool colortex12MipmapEnabled = true; +// const bool colortex4MipmapEnabled = true; + +const bool shadowHardwareFiltering = true; +flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) +flat varying vec3 avgAmbient; +// flat varying vec3 ambientUp; +// flat varying vec3 ambientLeft; +// flat varying vec3 ambientRight; +// flat varying vec3 ambientB; +// flat varying vec3 ambientF; +// flat varying vec3 ambientDown; +flat varying vec3 WsunVec; +flat varying vec2 TAA_Offset; +flat varying float tempOffsets; + + +uniform float eyeAltitude; +/* +const int colortex12Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) +const int colortex11Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) +const int colortex15Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) +*/ + + +flat varying vec3 zMults; +uniform sampler2D colortex0;//clouds +uniform sampler2D colortex1;//albedo(rgb),material(alpha) RGBA16 +// uniform sampler2D colortex4;//Skybox +uniform sampler2D colortex3; +uniform sampler2D colortex5; +uniform sampler2D colortex7; // normal +uniform sampler2D colortex6; // Noise +uniform sampler2D colortex8; // specular +// uniform sampler2D colortex9; // specular +uniform sampler2D colortex10; // specular +uniform sampler2D colortex11; // specular +uniform sampler2D colortex12; // specular +uniform sampler2D colortex13; // specular +uniform sampler2D colortex14; // specular +uniform sampler2D colortex15; // specular +uniform sampler2D colortex16; // specular +uniform sampler2D depthtex1;//depth +uniform sampler2D depthtex0;//depth +uniform sampler2D noisetex;//depth +uniform sampler2DShadow shadow; +varying vec4 normalMat; +uniform int heldBlockLightValue; +uniform int frameCounter; +uniform int isEyeInWater; +uniform float far; +uniform float near; +uniform float nightVision; +uniform float frameTimeCounter; +uniform float rainStrength; +uniform mat4 gbufferProjection; +uniform mat4 gbufferProjectionInverse; +uniform mat4 gbufferModelViewInverse; +uniform mat4 gbufferPreviousModelView; +uniform mat4 gbufferPreviousProjection; +uniform vec3 previousCameraPosition; +uniform mat4 shadowModelView; +uniform mat4 shadowProjection; +uniform mat4 gbufferModelView; +// uniform float viewWidth; +// uniform float viewHeight; +uniform float aspectRatio; +uniform vec2 texelSize; +uniform vec3 cameraPosition; +uniform vec3 sunVec; +uniform ivec2 eyeBrightnessSmooth; +uniform ivec2 eyeBrightness; + +// uniform int worldTime; + +#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) + +#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) + + +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; +} + +vec3 toScreenSpacePrev(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; +} +vec3 worldToView(vec3 p3) { + vec4 pos = vec4(p3, 0.0); + pos = gbufferModelView * pos; + return pos.xyz; +} + + +float ld(float dist) { + return (2.0 * near) / (far + near - dist * (far - near)); +} +vec3 ld(vec3 dist) { + return (2.0 * near) / (far + near - dist * (far - near)); +} +vec3 srgbToLinear2(vec3 srgb){ + return mix( + srgb / 12.92, + pow(.947867 * srgb + .0521327, vec3(2.4) ), + step( .04045, srgb ) + ); +} +vec3 blackbody2(float Temp) +{ + float t = pow(Temp, -1.5); + float lt = log(Temp); + + vec3 col = vec3(0.0); + col.x = 220000.0 * t + 0.58039215686; + col.y = 0.39231372549 * lt - 2.44549019608; + col.y = Temp > 6500. ? 138039.215686 * t + 0.72156862745 : col.y; + col.z = 0.76078431372 * lt - 5.68078431373; + col = clamp(col,0.0,1.0); + col = Temp < 1000. ? col * Temp * 0.001 : col; + + return srgbToLinear2(col); +} + +vec3 normVec (vec3 vec){ + return vec*inversesqrt(dot(vec,vec)); +} +vec3 viewToWorld(vec3 viewPosition) { + vec4 pos; + pos.xyz = viewPosition; + pos.w = 0.0; + pos = gbufferModelViewInverse * pos; + return pos.xyz; +} +#include "lib/res_params.glsl" +#include "lib/Shadow_Params.glsl" +#include "lib/color_transforms.glsl" +#include "lib/sky_gradient.glsl" +#include "lib/stars.glsl" +#include "lib/volumetricClouds.glsl" +#include "lib/waterBump.glsl" +#include "lib/specular.glsl" + +#include "lib/diffuse_lighting.glsl" + +float lengthVec (vec3 vec){ + return sqrt(dot(vec,vec)); +} +#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) +float triangularize(float dither) +{ + float center = dither*2.0-1.0; + dither = center*inversesqrt(abs(center)); + return clamp(dither-fsign(center),0.0,1.0); +} + + +float interleaved_gradientNoise(){ + // vec2 coord = gl_FragCoord.xy + (frameCounter%40000); + vec2 coord = gl_FragCoord.xy + frameTimeCounter; + // vec2 coord = gl_FragCoord.xy; + float noise = fract( 52.9829189 * fract( (coord.x * 0.06711056) + (coord.y * 0.00583715)) ); + return noise ; +} + +vec2 R2_dither(){ + vec2 alpha = vec2(0.75487765, 0.56984026); + return vec2(fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y + 1.0/1.6180339887 * frameCounter), fract((1.0-alpha.x) * gl_FragCoord.x + (1.0-alpha.y) * gl_FragCoord.y + 1.0/1.6180339887 * frameCounter)); +} +float blueNoise(){ + return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * (frameCounter*0.5+0.5) ); +} +vec4 blueNoise(vec2 coord){ + return texelFetch2D(colortex6, ivec2(coord )%512, 0) ; +} +vec3 fp10Dither(vec3 color,float dither){ + const vec3 mantissaBits = vec3(6.,6.,5.); + vec3 exponent = floor(log2(color)); + return color + dither*exp2(-mantissaBits)*exp2(exponent); +} + +vec3 decode (vec2 encn){ + vec3 n = vec3(0.0); + encn = encn * 2.0 - 1.0; + n.xy = abs(encn); + n.z = 1.0 - n.x - n.y; + n.xy = n.z <= 0.0 ? (1.0 - n.yx) * sign(encn) : encn; + return clamp(normalize(n.xyz),-1.0,1.0); +} +vec2 decodeVec2(float a){ + const vec2 constant1 = 65535. / vec2( 256., 65536.); + const float constant2 = 256. / 255.; + return fract( a * constant1 ) * constant2 ; +} + + +vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter,float distort){ + float alpha0 = sampleNumber/nb; + float alpha = (sampleNumber+jitter)/nb; + float angle = jitter*6.28 + alpha * 84.0 * 6.28; + + float sin_v, cos_v; + + sin_v = sin(angle); + cos_v = cos(angle); + + return vec2(cos_v, sin_v)*sqrt(alpha); +} +vec3 toShadowSpaceProjected(vec3 p3){ + p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; + p3 = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; + p3 = diagonal3(shadowProjection) * p3 + shadowProjection[3].xyz; + return p3; +} + +vec2 R2_samples(int n){ + vec2 alpha = vec2(0.75487765, 0.56984026); + return fract(alpha * n); +} + +vec2 tapLocation(int sampleNumber, float spinAngle,int nb, float nbRot,float r0){ + float alpha = (float(sampleNumber*1.0f + r0) * (1.0 / (nb))); + float angle = alpha * (nbRot * 3.14) + spinAngle*3.14; + + float ssR = alpha; + float sin_v, cos_v; + + sin_v = sin(angle); + cos_v = cos(angle); + + return vec2(cos_v, sin_v)*ssR; +} + + +void waterVolumetrics(inout vec3 inColor, vec3 rayStart, vec3 rayEnd, float estEndDepth, float estSunDepth, float rayLength, float dither, vec3 waterCoefs, vec3 scatterCoef, vec3 ambient, vec3 lightSource, float VdotL){ + inColor *= exp(-rayLength * waterCoefs); //No need to take the integrated value + int spCount = rayMarchSampleCount; + vec3 start = toShadowSpaceProjected(rayStart); + vec3 end = toShadowSpaceProjected(rayEnd); + vec3 dV = (end-start); + //limit ray length at 32 blocks for performance and reducing integration error + //you can't see above this anyway + float maxZ = min(rayLength,12.0)/(1e-8+rayLength); + dV *= maxZ; + + rayLength *= maxZ; + + float dY = normalize(mat3(gbufferModelViewInverse) * rayEnd).y * rayLength; + estEndDepth *= maxZ; + estSunDepth *= maxZ; + + vec3 absorbance = vec3(1.0); + vec3 vL = vec3(0.0); + + float phase = phaseg(VdotL,0.7) * 1.5 + 0.1; + + vec3 wpos = mat3(gbufferModelViewInverse) * rayStart + gbufferModelViewInverse[3].xyz; + vec3 dVWorld = (wpos-gbufferModelViewInverse[3].xyz); + // vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; + + float expFactor = 11.0; + for (int i=0;i -near) ? + (-near -position.z) / dir.z : far*sqrt(3.) ; + vec3 direction = toClipSpace3(position+dir*rayLength)-clipPosition; //convert to clip space + direction.xyz = direction.xyz/max(abs(direction.x)/texelSize.x,abs(direction.y)/texelSize.y); //fixed step size + vec3 stepv = direction * 3.0 * clamp(MC_RENDER_QUALITY,1.,2.0)*vec3(RENDER_SCALE,1.0); + + vec3 spos = clipPosition*vec3(RENDER_SCALE,1.0); + // spos.xy += (TAA_Offset*(texelSize/4))*RENDER_SCALE ; + spos += stepv*dither ; + + for (int i = 0; i < int(quality); i++) { + spos += stepv; + + float sp = texture2D(depthtex1,spos.xy).x; + + if( sp < spos.z) { + float dist = abs(linZ(sp)-linZ(spos.z))/linZ(spos.z); + if (dist < 0.015 ) return i / quality; + } + } + return 1.0; +} + +vec2 tapLocation_alternate( + int sampleNumber, + float spinAngle, + int nb, + float nbRot, + float r0 +){ + float alpha = (float(sampleNumber*1.0f + r0) * (1.0 / (nb))); + float angle = alpha * (nbRot * 3.14) ; + + float ssR = alpha + spinAngle*3.14; + float sin_v, cos_v; + + sin_v = sin(angle); + cos_v = cos(angle); + + return vec2(cos_v, sin_v)*ssR; +} + + +void ssAO(inout vec3 lighting, vec3 fragpos,float mulfov, vec2 noise, vec3 normal, vec2 texcoord, vec3 ambientCoefs, vec2 lightmap){ + + ivec2 pos = ivec2(gl_FragCoord.xy); + const float tan70 = tan(70.*3.14/180.); + + float dist = 1.0 + clamp(fragpos.z*fragpos.z/50.0,0,2); // shrink sample size as distance increases + + float mulfov2 = gbufferProjection[1][1]/(tan70 * dist); + float maxR2 = fragpos.z*fragpos.z*mulfov2*2.*5/50.0; + + + float rd = mulfov2 * 0.1 ; + //pre-rotate direction + float n = 0.0; + + float occlusion = 0.0; + + vec2 acc = -(TAA_Offset*(texelSize/2))*RENDER_SCALE ; + + int seed = (frameCounter%40000)*2 + (1+frameCounter); + float randomDir = fract(R2_samples(seed).y + noise.x ) * 1.61803398874 ; + vec3 NormalSpecific = viewToWorld(normal); + for (int j = 0; j < 7 ;j++) { + + vec2 sp = tapLocation_alternate(j, 0.0, 7, 20, randomDir); + // vec2 sp = vogel_disk_7[j]; + float thing = sp.y < 0.0 && clamp(floor(abs(NormalSpecific.y)*2.0),0.0,1.0) < 1.0 ? rd * 10: rd; + + + vec2 sampleOffset = sp*thing; + vec2 sampleOffset2 = sp*rd ; + sampleOffset = min(sampleOffset, sampleOffset2); + // vec2 sampleOffset = sp*rd; + + ivec2 offset = ivec2(gl_FragCoord.xy + sampleOffset*vec2(viewWidth,viewHeight*aspectRatio)*RENDER_SCALE); + + if (offset.x >= 0 && offset.y >= 0 && offset.x < viewWidth*RENDER_SCALE.x && offset.y < viewHeight*RENDER_SCALE.y ) { + vec3 t0 = toScreenSpace(vec3(offset*texelSize+acc+0.5*texelSize,texelFetch2D(depthtex1,offset,0).x) * vec3(1.0/RENDER_SCALE, 1.0) ); + vec3 vec = t0.xyz - fragpos; + float dsquared = dot(vec,vec); + + if (dsquared > 1e-5){ + if (dsquared < maxR2){ + float NdotV = clamp(dot(vec*inversesqrt(dsquared), normalize(normal)),0.,1.); + occlusion += NdotV * clamp(1.0-dsquared/maxR2,0.0,1.0); + + // float NdotV2 = clamp(dot(vec*inversesqrt(dsquared), normalize(RPnormal)),0.,1.); + // occlusion.y += NdotV2 * clamp(1.0-dsquared/maxR2,0.0,1.0); + } + n += 1; + } + } + } + + occlusion *= mix(2.5, 2.0 , clamp(floor(abs(NormalSpecific.y)*2.0),0.0,1.0)); + occlusion = max(1.0 - occlusion/n, 0.0); + + lighting = lighting*max(occlusion,pow(lightmap.x,4)); +} +vec3 DoContrast(vec3 Color, float strength){ + + float Contrast = log(strength); + + return clamp(mix(vec3(0.5), Color, Contrast) ,0,255); +} + + +void ssDO(inout vec3 lighting, vec3 fragpos,float mulfov, vec2 noise, vec3 normal, vec3 RPnormal, vec2 texcoord, vec3 ambientCoefs, vec2 lightmap, float sunlight){ + const int Samples = 7; + vec3 Radiance = vec3(0); + float occlusion = 0.0; + + ivec2 pos = ivec2(gl_FragCoord.xy); + const float tan70 = tan(70.*3.14/180.); + + // float dist = 1.0 + clamp(fragpos.z*fragpos.z/50.0,0,2); // shrink sample size as distance increases + + float mulfov2 = gbufferProjection[1][1]/(tan70 ); + float maxR2 = fragpos.z*fragpos.z*mulfov2*2.*5/50.0; + + + float rd = mulfov2 * 0.1 ; + + + vec2 acc = -(TAA_Offset*(texelSize/2))*RENDER_SCALE ; + + vec3 NormalSpecific = viewToWorld(normal); + + + for (int j = 0; j < Samples ;j++) { + + vec2 sp = tapLocation_alternate(j, 0.0, 7, 20, blueNoise()); + float thing = sp.y < 0.0 && clamp(floor(abs(NormalSpecific.y)*2.0),0.0,1.0) < 1.0 ? rd * 10: rd; + + + vec2 sampleOffset = sp*thing; + vec2 sampleOffset2 = sp*rd ; + sampleOffset = sampleOffset2; + + ivec2 offset = ivec2(gl_FragCoord.xy + sampleOffset*vec2(viewWidth,viewHeight*aspectRatio)*RENDER_SCALE); + + if (offset.x >= 0 && offset.y >= 0 && offset.x < viewWidth*RENDER_SCALE.x && offset.y < viewHeight*RENDER_SCALE.y ) { + vec3 t0 = toScreenSpace(vec3(offset*texelSize+acc+0.5*texelSize,texelFetch2D(depthtex1,offset,0).x) * vec3(1.0/RENDER_SCALE, 1.0) ); + + + vec3 vec = t0.xyz - fragpos; + float dsquared = dot(vec,vec); + + float NdotV2 = clamp(dot(vec*inversesqrt(dsquared), normalize(RPnormal)),0.,1.); + + if (dsquared < maxR2){ + // float NdotV = clamp(dot(vec*inversesqrt(dsquared), normalize(normal)),0.,1.); + // occlusion += NdotV * clamp(1.0-dsquared/maxR2,0.0,1.0); + + + vec3 previousPosition = mat3(gbufferModelViewInverse) * t0 + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; + previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; + previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; + + if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0){ + Radiance += NdotV2*texture2D(colortex5,previousPosition.xy).rgb ; + } + + } + } + } + + lighting = vec3(1) + Radiance/Samples; +} + +vec3 RT(vec3 dir, vec3 position, float noise, float stepsizes){ + float dist = 1.0 + clamp(position.z*position.z/50.0,0,2); // shrink sample size as distance increases + + float stepSize = stepsizes / dist; + int maxSteps = STEPS; + vec3 clipPosition = toClipSpace3(position); + float rayLength = ((position.z + dir.z * sqrt(3.0)*far) > -sqrt(3.0)*near) ? + (-sqrt(3.0)*near -position.z) / dir.z : sqrt(3.0)*far; + vec3 end = toClipSpace3(position+dir*rayLength) ; + vec3 direction = end-clipPosition ; //convert to clip space + + float len = max(abs(direction.x)/texelSize.x,abs(direction.y)/texelSize.y)/stepSize; + //get at which length the ray intersects with the edge of the screen + vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; + + float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z)*2000.0; + + vec3 stepv = direction/len; + + int iterations = min(int(min(len, mult*len)-2), maxSteps); + + //Do one iteration for closest texel (good contact shadows) + vec3 spos = clipPosition*vec3(RENDER_SCALE,1.0) ; + spos.xy += TAA_Offset*texelSize*0.5*RENDER_SCALE; + spos += stepv/(stepSize/2); + + float distancered = 1.0 + clamp(position.z*position.z/50.0,0,2); // shrink sample size as distance increases + + for(int i = 0; i < iterations; i++){ + if (spos.x < 0.0 || spos.y < 0.0 || spos.z < 0.0 || spos.x > 1.0 || spos.y > 1.0 || spos.z > 1.0) return vec3(1.1); + spos += stepv*noise; + + float sp = sqrt(texelFetch2D(colortex4,ivec2(spos.xy/ texelSize/4),0).w/65000.0); + float currZ = linZ(spos.z); + + if( sp < currZ) { + float dist = abs(sp-currZ)/currZ; + if (dist <= 0.1) return vec3(spos.xy, invLinZ(sp))/vec3(RENDER_SCALE,1.0); + } + } + return vec3(1.1); +} + +vec3 cosineHemisphereSample(vec2 Xi, float roughness){ + float r = sqrt(Xi.x); + float theta = 2.0 * 3.14159265359 * Xi.y; + + float x = r * cos(theta); + float y = r * sin(theta); + + return vec3(x, y, sqrt(clamp(1.0 - Xi.x,0.,1.))); +} +vec3 TangentToWorld(vec3 N, vec3 H, float roughness){ + vec3 UpVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0); + vec3 T = normalize(cross(UpVector, N)); + vec3 B = cross(N, T); + + return vec3((T * H.x) + (B * H.y) + (N * H.z)); +} + + +// void rtAO(inout vec3 lighting, vec3 normal, vec2 noise, vec3 fragpos, float lightmap, float inShadow){ +// int nrays = 4; +// float occlude = 0.0; + +// float indoor = clamp(pow(lightmap,2)*2,0.0,AO_Strength); + +// for (int i = 0; i < nrays; i++){ +// int seed = (frameCounter%40000)*nrays+i; +// vec2 ij = fract(R2_samples(seed) + noise.rg); + + +// vec3 rayDir = TangentToWorld( normal, normalize(cosineHemisphereSample(ij,1.0)) ,1.0) ; + +// #ifdef HQ_SSGI +// vec3 rayHit = rayTrace_GI( mat3(gbufferModelView) * rayDir, fragpos, blueNoise(), 30.); // ssr rt +// #else +// vec3 rayHit = RT(mat3(gbufferModelView)*rayDir, fragpos, blueNoise(), 24.); // choc sspt +// #endif + +// // vec3 lightDir = normalize(vec3(0.2,0.8,0.2)); +// // float skyLightDir = dot(rayDir,lightDir); // the positons where the occlusion happens + +// float skyLightDir = rayDir.y > 0.0 ? 1.0 : max(rayDir.y,1.0-indoor); // the positons where the occlusion happens +// // if (rayHit.z > 1.0) occlude += skyLightDir; + +// occlude += normalize(rayHit.z - 1.0) / (1.1-rayDir.y); + + +// } +// // occlude = mix( occlude,1, inShadow); +// // occlude = occlude*0.5 + 0.5; +// // lighting *= 2.5; +// lighting *= occlude/nrays; +// } + + +void rtAO(inout vec3 lighting, vec3 normal, vec2 noise, vec3 fragpos, float lightmap, float inShadow){ + int nrays = 4; + float occlude = 0.0; + + float indoor = clamp(pow(lightmap,2)*2,0.0,AO_Strength); + + for (int i = 0; i < nrays; i++){ + int seed = (frameCounter%40000)*nrays+i; + vec2 ij = fract(R2_samples(seed) + noise.rg); + + + vec3 rayDir = TangentToWorld( normal, normalize(cosineHemisphereSample(ij,1.0)) ,1.0) ; + + #ifdef HQ_SSGI + vec3 rayHit = rayTrace_GI( mat3(gbufferModelView) * rayDir, fragpos, blueNoise(), 30.); // ssr rt + #else + vec3 rayHit = RT(mat3(gbufferModelView)*rayDir, fragpos, blueNoise(), 24.); // choc sspt + #endif + + // vec3 lightDir = normalize(vec3(0.2,0.8,0.2)); + // float skyLightDir = dot(rayDir,lightDir); // the positons where the occlusion happens + + float skyLightDir = rayDir.y > 0.0 ? 1.0 : max(rayDir.y,1.0-indoor); // the positons where the occlusion happens + if (rayHit.z > 1.0) occlude += max(rayDir.y,1-AO_Strength); + + + } + // occlude = mix( occlude,1, inShadow); + // occlude = occlude*0.5 + 0.5; + lighting *= 2.5; + lighting *= mix(occlude/nrays,1.0,0) ; +} + +// void rtGI(inout vec3 lighting, vec3 normal,vec2 noise,vec3 fragpos, float lightmap, vec3 albedo, float inShadow){ +// int nrays = RAY_COUNT; +// vec3 intRadiance = vec3(0.0); +// vec3 occlude = vec3(0.0); + +// lighting *= 1.50; +// float indoor = clamp(pow(lightmap,2)*2,0.0,AO_Strength); + +// for (int i = 0; i < nrays; i++){ +// int seed = (frameCounter%40000)*nrays+i; +// vec2 ij = fract(R2_samples(seed) + noise ); + +// vec3 rayDir = TangentToWorld(normal, normalize(cosineHemisphereSample(ij,1.0)) ,1.0); + +// #ifdef HQ_SSGI +// vec3 rayHit = rayTrace_GI( mat3(gbufferModelView) * rayDir, fragpos, blueNoise(), 50.); // ssr rt +// #else +// vec3 rayHit = RT(mat3(gbufferModelView)*rayDir, fragpos, blueNoise(), 30.); // choc sspt +// #endif + +// float skyLightDir = rayDir.y > 0.0 ? 1.0 : max(rayDir.y,1.0-indoor); // the positons where the occlusion happens + +// if (rayHit.z < 1.){ +// vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rayHit) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; +// previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; +// previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; +// if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) + +// intRadiance = DoContrast(texture2D(colortex5,previousPosition.xy).rgb) ; +// else +// intRadiance += lighting*skyLightDir; // make sure ambient light exists but at screen edges when you turn + + +// }else{ +// intRadiance += lighting*skyLightDir; +// } +// } +// lighting = intRadiance/nrays; +// } + + +void rtGI(inout vec3 lighting, vec3 normal,vec2 noise,vec3 fragpos, float lightmap, vec3 albedo){ + int nrays = RAY_COUNT; + vec3 intRadiance = vec3(0.0); + float occlusion = 0.0; + + // lighting *= 1.50; + float indoor = clamp(pow(lightmap,2)*2,0.0,AO_Strength); + + for (int i = 0; i < nrays; i++){ + int seed = (frameCounter%40000)*nrays+i; + vec2 ij = fract(R2_samples(seed) + noise ); + + vec3 rayDir = TangentToWorld(normal, normalize(cosineHemisphereSample(ij,1.0)) ,1.0); + + #ifdef HQ_SSGI + vec3 rayHit = rayTrace_GI( mat3(gbufferModelView) * rayDir, fragpos, blueNoise(), 50.); // ssr rt + #else + vec3 rayHit = RT(mat3(gbufferModelView)*rayDir, fragpos, blueNoise(), 30.); // choc sspt + #endif + + float skyLightDir = rayDir.y > 0.0 ? 0.0 : 0.0; // the positons where the occlusion happens + + // vec3 AO = lighting * (normalize(rayHit.z - 1.0) / (1.1-rayDir.y)); + if (rayHit.z < 1){ + vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rayHit)+ gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; + + previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; + previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; + + if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0){ + // intRadiance = DoContrast(texture2DLod(colortex5,previousPosition.xy,0).rgb, 55.0 ) * GI_Strength ; + intRadiance = texture2DLod(colortex5,previousPosition.xy,0).rgb * GI_Strength ; + } + + + occlusion += 1.0; + } + + } + lighting = lighting * (1.0-occlusion/nrays) + intRadiance/nrays; +} + + + + + +void SubsurfaceScattering(inout float SSS, float Scattering, float Density, float LabDenisty){ + #ifdef LabPBR_subsurface_scattering + float labcurve = pow(LabDenisty,LabSSS_Curve); + // beers law + SSS = clamp(exp( Scattering * -(10 - LabDenisty*7)), 0.0, labcurve); + if (abs(Scattering-0.1) < 0.0004 ) SSS = labcurve; + #else + // beers law + SSS = clamp(exp(Scattering * -Density), 0.0, 1.0); + if (abs(Scattering-0.1) < 0.0004 ) SSS = 1.0; + #endif +} + + + + +vec3 SubsurfaceScattering_2(vec3 albedo, float Scattering, float Density, float LabDenisty, float lightPos, bool yeSSS){ + if(!yeSSS) return vec3(0.0); + + float density = Density; + + #ifdef LabPBR_subsurface_scattering + float labcurve = pow(LabDenisty,LabSSS_Curve); + density = sqrt(30 - labcurve*15); + #endif + + vec3 absorbed = max(1.0 - albedo,0.0) * density; + // absorbed = vec3(1.); + + vec3 scatter = exp(-sqrt(Scattering * absorbed)) * exp(Scattering * -density); + // float gloop = (1.0-exp(sqrt(Scattering) * -density)); + // vec3 scatter = mix(vec3(1.0), max(albedo - gloop * (1-labcurve),0.0), gloop) * exp(Scattering * -density); + + #ifdef LabPBR_subsurface_scattering + scatter *= labcurve; + #endif + + scatter *= 0.5 + CustomPhase(lightPos, 1.0,30.0)*20; + + return scatter; +} + +float densityAtPosSNOW(in vec3 pos){ + pos /= 18.; + pos.xz *= 0.5; + vec3 p = floor(pos); + vec3 f = fract(pos); + f = (f*f) * (3.-2.*f); + vec2 uv = p.xz + f.xz + p.y * vec2(0.0,193.0); + vec2 coord = uv / 512.0; + vec2 xy = texture2D(noisetex, coord).yx; + return mix(xy.r,xy.g, f.y); +} + +// Emin's and Gri's combined ideas to stop peter panning and light leaking, also has little shadowacne so thats nice +// https://www.complementary.dev/reimagined +// https://github.com/gri573 +void GriAndEminShadowFix( + inout vec3 WorldPos, + vec3 FlatNormal, + float VanillaAO, + float SkyLightmap, + bool Entities +){ + float DistanceOffset = clamp(0.1 + length(WorldPos) / (shadowMapResolution*0.20), 0.0,1.0) ; + vec3 Bias = FlatNormal * DistanceOffset; // adjust the bias thingy's strength as it gets farther away. + + // stop lightleaking + if(SkyLightmap < 0.1 && !Entities) { + WorldPos += mix(Bias, 0.5 * (0.5 - fract(WorldPos + cameraPosition + FlatNormal*0.01 ) ), VanillaAO) ; + }else{ + WorldPos += Bias; + } +} + +void LabEmission( + inout vec3 Lighting, + vec3 Albedo, + float Emission +){ + // if( Emission < 255.0/255.0 ) Lighting = mix(Lighting, Albedo * Emissive_Brightness, pow(Emission, Emissive_Curve)); // old method.... idk why + if( Emission < 255.0/255.0 ) Lighting += (Albedo * Emissive_Brightness) * pow(Emission, Emissive_Curve); +} + + + + + +#include "lib/PhotonGTAO.glsl" + +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +void main() { + + vec2 texcoord = gl_FragCoord.xy*texelSize; + + + + + float z0 = texture2D(depthtex0,texcoord).x; + float z = texture2D(depthtex1,texcoord).x; + float TranslucentDepth = clamp( ld(z0)-ld(z0) ,0.0,1.0); + + vec2 tempOffset=TAA_Offset; + vec3 fragpos = toScreenSpace(vec3(texcoord/RENDER_SCALE-vec2(tempOffset)*texelSize*0.5,z)); + vec3 fragpos_rtshadow = toScreenSpace(vec3(texcoord/RENDER_SCALE,z)); + vec3 fragpos_handfix = fragpos; + + if ( z < 0.56) fragpos_handfix.z /= MC_HAND_DEPTH; // fix lighting on hand + + vec3 p3 = mat3(gbufferModelViewInverse) * fragpos; + vec3 np3 = normVec(p3); + + p3 += gbufferModelViewInverse[3].xyz; + + + float dirtAmount = Dirt_Amount; + vec3 waterEpsilon = vec3(Water_Absorb_R, Water_Absorb_G, Water_Absorb_B); + + vec3 dirtEpsilon = vec3(Dirt_Absorb_R, Dirt_Absorb_G, Dirt_Absorb_B); + vec3 totEpsilon = dirtEpsilon*dirtAmount + waterEpsilon; + vec3 scatterCoef = dirtAmount * vec3(Dirt_Scatter_R, Dirt_Scatter_G, Dirt_Scatter_B) / pi; + + + #ifdef AEROCHROME_MODE + totEpsilon *= 10.0; + scatterCoef *= 0.1; + #endif + + float noise = blueNoise(); + + + float iswaterstuff = texture2D(colortex7,texcoord).a ; + bool iswater = iswaterstuff > 0.99; + + vec4 data = texture2D(colortex1,texcoord); // terraom + vec4 dataUnpacked0 = vec4(decodeVec2(data.x),decodeVec2(data.y)); + vec4 dataUnpacked1 = vec4(decodeVec2(data.z),decodeVec2(data.w)); + vec4 dataUnpacked2 = vec4(decodeVec2(data.z),decodeVec2(data.w)); + vec3 normal = decode(dataUnpacked0.yw); + // Color // + vec3 albedo = toLinear(vec3(dataUnpacked0.xz,dataUnpacked1.x)); + vec4 translucentCol = texture2D(colortex13,texcoord); // translucents + + // Specular // + vec4 SpecularTex = texture2D(colortex8,texcoord); + + // Normal // + vec4 normalAndAO = texture2D(colortex15,texcoord); + vec3 FlatNormals = normalAndAO.rgb * 2.0 - 1.0; + vec3 slopednormal = normal; + + #ifdef POM + #ifdef Horrible_slope_normals + vec3 ApproximatedFlatNormal = normalize(cross(dFdx(p3), dFdy(p3))); // it uses depth that has POM written to it. + slopednormal = normalize(clamp(normal, ApproximatedFlatNormal*2.0 - 1.0, ApproximatedFlatNormal*2.0 + 1.0) ); + #endif + #endif + + float vanilla_AO = normalAndAO.a; + normalAndAO.a = clamp(pow(normalAndAO.a*5,4),0,1); + + + vec2 lightmap = dataUnpacked1.yz; + + bool translucent = abs(dataUnpacked1.w-0.5) <0.01; // Strong translucency + bool translucent2 = abs(dataUnpacked1.w-0.6) <0.01; // Weak translucency + bool translucent3 = abs(dataUnpacked1.w-0.55) <0.01; // all blocks + bool translucent4 = abs(dataUnpacked1.w-0.65) <0.01; // Weak translucency + bool entities = abs(dataUnpacked1.w-0.45) < 0.01; + + bool hand = abs(dataUnpacked1.w-0.75) < 0.01; + bool blocklights = abs(dataUnpacked1.w-0.8) <0.01; + + vec3 filtered = vec3(1.412,1.0,0.0); + if (!hand) filtered = texture2D(colortex3,texcoord).rgb; + vec3 ambientCoefs = normal/dot(abs(normal),vec3(1.)); + + float lightleakfix = clamp(eyeBrightness.y/240.0 + lightmap.y,0.0,1.0); + + vec3 DirectLightColor = (lightCol.rgb/80.0); + DirectLightColor *= clamp(abs(WsunVec.y)*2,0.,1.); + + float cloudShadow = 1.0; + + if ( z >= 1.) { //sky + vec3 background = vec3(0.0); + background += stars(vec3(np3.x,abs(np3.y),np3.z)) * 5.0; + + #ifndef ambientLight_only + background += drawSun(dot(lightCol.a * WsunVec, np3),0, DirectLightColor,vec3(0.0)) ; // sun + background += drawSun(dot(lightCol.a * -WsunVec, np3),0, blackbody2(Moon_temp)/500.,vec3(0.0)); // moon + #endif + + background *= clamp( (np3.y+ 0.02)*5.0 + (eyeAltitude - 319)/800000 ,0.0,1.0); + + vec3 skyTEX = skyFromTex(np3,colortex4)/150.0 * 5.0; + background += skyTEX; + // eclipse + // color *=max(1.0 - drawSun(dot(lightCol.a * WsunVec, (np3-0.0002)*1.001),0, vec3(1),vec3(0.0)),0.0); + + + vec4 cloud = texture2D_bicubic(colortex0,texcoord*CLOUDS_QUALITY); + background = background*cloud.a + cloud.rgb; + + gl_FragData[0].rgb = clamp(fp10Dither(background ,triangularize(noise)),0.0,65000.); + + }else{//land + + ////// ----- direct ----- ////// + + vec3 Direct_lighting = vec3(1.0); + + float NdotL = dot(slopednormal,WsunVec); + NdotL = clamp((-15 + NdotL*255.0) / 240.0 ,0.0,1.0); + float Shadows = clamp(1.0 - filtered.b,0.0,1.0); + + if (abs(filtered.y-0.1) < 0.0004 && !iswater) Shadows = clamp((lightmap.y-0.85)*25,0,1); + + vec3 SSS; + float SSS_strength; + float LabSSS = clamp((-65.0 + SpecularTex.z * 255.0) / 190.0 ,0.0,1.0); + + if (NdotL > 0.001) { + + vec3 p3_shadow = mat3(gbufferModelViewInverse) * fragpos_handfix + gbufferModelViewInverse[3].xyz; + + GriAndEminShadowFix(p3_shadow, viewToWorld(FlatNormals), normalAndAO.a, lightmap.y, entities); + + + vec3 projectedShadowPosition = mat3(shadowModelView) * p3_shadow + shadowModelView[3].xyz; + projectedShadowPosition = diagonal3(shadowProjection) * projectedShadowPosition + shadowProjection[3].xyz; + + //apply distortion + float distortFactor = calcDistort(projectedShadowPosition.xy); + projectedShadowPosition.xy *= distortFactor; + + //do shadows only if on shadow map + if (abs(projectedShadowPosition.x) < 1.0-1.5/shadowMapResolution && abs(projectedShadowPosition.y) < 1.0-1.5/shadowMapResolution && abs(projectedShadowPosition.z) < 6.0){ + + float diffthresh = 0.0; + // if(hand && eyeBrightness.y/240. > 0.0) diffthresh = 0.0003; + + projectedShadowPosition = projectedShadowPosition * vec3(0.5,0.5,0.5/6.0) + vec3(0.5); + Shadows = 0.0; + + float rdMul = filtered.x*distortFactor*d0*k/shadowMapResolution; + + for(int i = 0; i < SHADOW_FILTER_SAMPLE_COUNT; i++){ + // if(hand) noise = 0.0; + vec2 offsetS = tapLocation(i,SHADOW_FILTER_SAMPLE_COUNT,1.618,noise,0.0); + float weight = 1.0+(i+noise)*rdMul/SHADOW_FILTER_SAMPLE_COUNT*shadowMapResolution; + float isShadow = shadow2D(shadow,vec3(projectedShadowPosition + vec3(rdMul*offsetS,-diffthresh*weight))).x; + + Shadows += isShadow/SHADOW_FILTER_SAMPLE_COUNT; + } + } + } + + #ifdef Sub_surface_scattering + #ifdef Variable_Penumbra_Shadows + SSS_strength = 1000; + if (translucent) SSS_strength = 2; // low Density + else if (translucent2) SSS_strength = 5; /// medium Density + else if (translucent3) SSS_strength = 10; // misc Desnity + else if (translucent4) SSS_strength = 10; // mob Debsity + + bool hasSSS = SSS_strength < 1000 || LabSSS > 0.0; + + // if(hasSSS) SubsurfaceScattering(SSS, filtered.y, SSS_strength, LabSSS) ; + + SSS = SubsurfaceScattering_2(albedo, filtered.y, SSS_strength, LabSSS, clamp(dot(np3, WsunVec),0.0,1.0), hasSSS) ; + + + // if (isEyeInWater == 0) SSS *= lightleakfix; // light leak fix + #endif + + + + if (!hand){ + + if (abs(filtered.y-0.1) < 0.0004 && ( !translucent || !translucent2 || !translucent3 || !translucent4 ) ) SSS = vec3(0.0); + + #ifndef SCREENSPACE_CONTACT_SHADOWS + + if (abs(filtered.y-0.1) < 0.0004 && ( translucent || translucent2 || translucent4 ) ) SSS = clamp((lightmap.y-0.87)*25,0,1) * clamp(pow(1+dot(WsunVec,normal),25),0,1) * vec3(1); + + #else + vec3 vec = lightCol.a*sunVec; + float screenShadow = rayTraceShadow(vec, fragpos_rtshadow, interleaved_gradientNoise()); + screenShadow *= screenShadow ; + + #ifdef Variable_Penumbra_Shadows + Shadows = min(screenShadow, Shadows); + if (abs(filtered.y-0.1) < 0.0004 && ( translucent || translucent2 ) ) SSS = vec3(Shadows); + // #else + + #endif + + + #endif + } + + #ifdef Variable_Penumbra_Shadows + SSS *= 1.0-NdotL*Shadows; + #endif + #else + SSS = 0.0; + #endif + + #ifdef VOLUMETRIC_CLOUDS + #ifdef CLOUDS_SHADOWS + cloudShadow = GetCloudShadow(p3); + Shadows *= cloudShadow; + SSS *= cloudShadow; + #endif + #endif + + ////// ----- indirect ----- ////// + + vec3 Indirect_lighting = vec3(1.0); + + // float skylight = clamp(abs(normal.y+1),0.0,1.0); + float skylight = clamp(abs(ambientCoefs.y+1.0),0.35,2.0); + + + #if indirect_effect == 2 || indirect_effect == 3 || indirect_effect == 4 + if (!hand) skylight = 1.0; + #endif + + // do this to make underwater shading easier. + vec2 newLightmap = lightmap.xy; + if((isEyeInWater == 0 && iswater) || (isEyeInWater == 1 && !iswater)) newLightmap.y = min(newLightmap.y+0.1,1.0); + + + // vec3 LavaGlow = vec3(TORCH_R,TORCH_G,TORCH_B); + // float thething = pow(clamp(2.0 + dot(viewToWorld(FlatNormals),np3),0.0,2.0),3.0); + // // LavaGlow *= thething*0.25+0.75; + // LavaGlow *= mix((2.0-thething)*0.5+0.5, thething*0.25+0.75, sqrt(lightmap.x)); + + Indirect_lighting = DoAmbientLighting(avgAmbient, vec3(TORCH_R,TORCH_G,TORCH_B), newLightmap.xy, skylight); + + + + + vec3 AO = vec3(1.0); + vec3 debug = vec3(0.0); + + // vanilla AO + #if indirect_effect == 0 + // AO = vec3(mix(1.0 - exp2(-5 * pow(1-vanilla_AO,3)), 1.0, pow(newLightmap.x,4))) ; + AO = vec3( exp( (vanilla_AO*vanilla_AO) * -5) ) ; + #endif + + // SSAO + vanilla AO + #if indirect_effect == 1 + // AO *= mix(1.0 - exp2(-5 * pow(1-vanilla_AO,3)),1.0, pow(newLightmap.x,4)); + + AO = vec3( exp( (vanilla_AO*vanilla_AO) * -3) ) ; + if (!hand) ssAO(AO, fragpos, 1.0, blueNoise(gl_FragCoord.xy).rg, FlatNormals , texcoord, ambientCoefs, newLightmap.xy); + #endif + + // GTAO + #if indirect_effect == 2 + int seed = (frameCounter%40000); + vec2 r2 = fract(R2_samples(seed) + blueNoise(gl_FragCoord.xy).rg); + if (!hand) AO = ambient_occlusion(vec3(texcoord/RENDER_SCALE-vec2(tempOffset)*texelSize*0.5,z), fragpos, worldToView(slopednormal), r2, debug) * vec3(1.0); + #endif + + // RTAO + #if indirect_effect == 3 + if (!hand) rtAO(AO, normal, blueNoise(gl_FragCoord.xy).rg, fragpos, newLightmap.y, NdotL*Shadows); + #endif + + // SSGI + #if indirect_effect == 4 + if (!hand) rtGI(gl_FragData[0].rgb, normal, blueNoise(gl_FragCoord.xy).rg, fragpos, newLightmap.y, albedo); + #endif + + #ifndef AO_in_sunlight + AO = mix(AO,vec3(1.0), min(NdotL*Shadows,1.0)); + #endif + + Indirect_lighting *= AO; + + ////// ----- Under Water Shading ----- ////// + + vec3 waterabsorb_speculars = vec3(1); + if ((isEyeInWater == 0 && iswater) || (isEyeInWater == 1 && !iswater)){ + + vec3 fragpos0 = toScreenSpace(vec3(texcoord/RENDER_SCALE-vec2(tempOffset)*texelSize*0.5,z0)); + float Vdiff = distance(fragpos,fragpos0); + float VdotU = np3.y; + float estimatedDepth = Vdiff * abs(VdotU); //assuming water plane + estimatedDepth = estimatedDepth; + // make it such that the estimated depth flips to be correct when entering water. + + if (isEyeInWater == 1) estimatedDepth = (1.0-lightmap.y)*16.0; + + float estimatedSunDepth = Vdiff; //assuming water plane + vec3 Absorbtion = exp2(-totEpsilon*estimatedDepth); + + // caustics... + float Direct_caustics = waterCaustics(mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition, WsunVec); + float Ambient_Caustics = waterCaustics(mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition, vec3(0.5, 1.0, 0.5)); + + // apply caustics to the lightting + DirectLightColor *= 0.5 + max(pow(Direct_caustics*2,2),0.0); + Indirect_lighting *= 0.5 + max(pow(Ambient_Caustics,2),0.0); + + // directLightCol *= Direct_caustics; + // Indirect_lighting *= Ambient_Caustics*0.5+0.5; + + // apply water absorbtion to the lighting + // waterabsorb_speculars.rgb *= Absorbtion; + + DirectLightColor *= Absorbtion; + // Indirect_lighting *= Absorbtion; + + } + + + + ////// ----- Finalize ----- ////// + + #ifdef Seasons + #ifdef Snowy_Winter + vec3 snow_p3 = p3 + cameraPosition; + float SnowPatches = densityAtPosSNOW(vec3(snow_p3.x,snow_p3.y/48.,snow_p3.z) *250); + SnowPatches = 1.0 - clamp( exp(pow(SnowPatches,3.5) * -100.0) ,0,1); + SnowPatches *= clamp(sqrt(normal.y),0,1) * clamp(pow(lightmap.y,25)*25,0,1); + + if(!hand && !iswater){ + albedo = mix(albedo, vec3(0.8,0.9,1.0), SnowPatches); + SpecularTex.rg = mix(SpecularTex.rg, vec2(1,0.05), SnowPatches); + } + #endif + #endif + + Direct_lighting = DoDirectLighting(DirectLightColor, Shadows, NdotL, 0.0); + + + #ifdef ambientLight_only + Direct_lighting = vec3(0.0); + #endif + + + //combine all light sources + vec3 FINAL_COLOR = Direct_lighting + Indirect_lighting; + + #ifdef Variable_Penumbra_Shadows + FINAL_COLOR += SSS*DirectLightColor; + #endif + + FINAL_COLOR *= albedo; + + #ifdef Specular_Reflections + MaterialReflections(FINAL_COLOR, SpecularTex.r, SpecularTex.ggg, albedo, WsunVec, (Shadows*NdotL)*DirectLightColor, lightmap.y, slopednormal, np3, fragpos, vec3(blueNoise(gl_FragCoord.xy).rg, interleaved_gradientNoise()), hand, entities); + #endif + + // #ifdef LabPBR_Emissives + LabEmission(FINAL_COLOR, albedo, SpecularTex.a); + // #endif + + gl_FragData[0].rgb = FINAL_COLOR; + } + + ////// ----- Apply Clouds ----- ////// + // gl_FragData[0].rgb = gl_FragData[0].rgb *cloud.a + cloud.rgb; + + ////// ----- Under Water Fog ----- ////// + + if (iswater){ + vec3 fragpos0 = toScreenSpace(vec3(texcoord/RENDER_SCALE-vec2(tempOffset)*texelSize*0.5,z0)); + float Vdiff = distance(fragpos,fragpos0); + float VdotU = np3.y; + float estimatedDepth = Vdiff * abs(VdotU) ; //assuming water plane + float estimatedSunDepth = estimatedDepth/abs(WsunVec.y); //assuming water plane + + float custom_lightmap_T = texture2D(colortex14, texcoord).x; // y = torch + + vec3 ambientColVol = (avgAmbient * 8./150./1.5) * max(custom_lightmap_T,0.005); + vec3 lightColVol = (lightCol.rgb / 80.) ; + + if (isEyeInWater == 0) waterVolumetrics(gl_FragData[0].rgb, fragpos0, fragpos, estimatedDepth , estimatedSunDepth, Vdiff, noise, totEpsilon, scatterCoef, ambientColVol, lightColVol, dot(np3, WsunVec)); + } + + // phasefunc = phaseg(clamp(dot(np3, WsunVec),0.0,1.0), 0.5)*10; + + // gl_FragData[0].rgb = vec3(1.0); + // if(z < 1) gl_FragData[0].rgb = Custom_GGX(normal, -np3, WsunVec, SpecularTex.r, SpecularTex.g) * vec3(1.0); + + + /* DRAWBUFFERS:3 */ +} \ No newline at end of file diff --git a/shaders/composite1.vsh b/shaders/composite1.vsh new file mode 100644 index 0000000..eb0bb24 --- /dev/null +++ b/shaders/composite1.vsh @@ -0,0 +1,70 @@ +#version 120 +#extension GL_EXT_gpu_shader4 : enable +#include "lib/settings.glsl" + +flat varying vec3 WsunVec; +flat varying vec3 avgAmbient; +flat varying vec4 lightCol; +flat varying float tempOffsets; +flat varying vec2 TAA_Offset; +flat varying vec3 zMults; + +attribute vec4 mc_Entity; +uniform sampler2D colortex4; +varying vec4 lmtexcoord; +// varying float vanilla_ao; + +uniform float far; +uniform float near; +uniform mat4 gbufferModelViewInverse; +uniform vec3 sunPosition; +uniform float sunElevation; +uniform int frameCounter; + +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.); + + +#include "/lib/util.glsl" +#include "/lib/res_params.glsl" +void main() { + gl_Position = ftransform(); + + #ifdef TAA_UPSCALING + gl_Position.xy = (gl_Position.xy*0.5+0.5)*RENDER_SCALE*2.0-1.0; + #endif + + tempOffsets = HaltonSeq2(frameCounter%10000); + TAA_Offset = offsets[frameCounter%8]; + #ifndef TAA + TAA_Offset = vec2(0.0); + #endif + + // vec3 sc = texelFetch2D(colortex4,ivec2(6,37),0).rgb; + // ambientUp = texelFetch2D(colortex4,ivec2(0,37),0).rgb; + // ambientDown = texelFetch2D(colortex4,ivec2(1,37),0).rgb; + // ambientLeft = texelFetch2D(colortex4,ivec2(2,37),0).rgb; + // ambientRight = texelFetch2D(colortex4,ivec2(3,37),0).rgb; + // ambientB = texelFetch2D(colortex4,ivec2(4,37),0).rgb; + // ambientF = texelFetch2D(colortex4,ivec2(5,37),0).rgb; + + avgAmbient = texelFetch2D(colortex4,ivec2(0,37),0).rgb; + + + + vec3 sc = texelFetch2D(colortex4,ivec2(6,37),0).rgb; + lightCol.a = float(sunElevation > 1e-5)*2-1.; + lightCol.rgb = sc; + + WsunVec = lightCol.a*normalize(mat3(gbufferModelViewInverse) *sunPosition); + zMults = vec3((far * near)*2.0,far+near,far-near); + + + +} diff --git a/shaders/composite10.fsh b/shaders/composite10.fsh index 3cf27fe..06b5762 100644 --- a/shaders/composite10.fsh +++ b/shaders/composite10.fsh @@ -1,12 +1,80 @@ #version 120 + #include "lib/settings.glsl" -//downsample 1st pass (half res) for bloom +//Merge and upsample the blurs into a 1/4 res bloom buffer #include "lib/res_params.glsl" uniform sampler2D colortex3; -uniform sampler2D colortex8; +uniform sampler2D colortex6; + uniform vec2 texelSize; uniform float viewWidth; uniform float viewHeight; + +float w0(float a) +{ + return (1.0/6.0)*(a*(a*(-a + 3.0) - 3.0) + 1.0); +} + +float w1(float a) +{ + return (1.0/6.0)*(a*a*(3.0*a - 6.0) + 4.0); +} + +float w2(float a) +{ + return (1.0/6.0)*(a*(a*(-3.0*a + 3.0) + 3.0) + 1.0); +} + +float w3(float a) +{ + return (1.0/6.0)*(a*a*a); +} + +float g0(float a) +{ + return w0(a) + w1(a); +} + +float g1(float a) +{ + return w2(a) + w3(a); +} + +float h0(float a) +{ + return -1.0 + w1(a) / (w0(a) + w1(a)); +} + +float h1(float a) +{ + return 1.0 + w3(a) / (w2(a) + w3(a)); +} + +vec4 texture2D_bicubic(sampler2D tex, vec2 uv) +{ + vec4 texelSize = vec4(texelSize,1.0/texelSize); + uv = uv*texelSize.zw; + vec2 iuv = floor( uv ); + vec2 fuv = fract( uv ); + + float g0x = g0(fuv.x); + float g1x = g1(fuv.x); + float h0x = h0(fuv.x); + float h1x = h1(fuv.x); + float h0y = h0(fuv.y); + float h1y = h1(fuv.y); + + vec2 p0 = (vec2(iuv.x + h0x, iuv.y + h0y) - 0.5) * texelSize.xy; + vec2 p1 = (vec2(iuv.x + h1x, iuv.y + h0y) - 0.5) * texelSize.xy; + vec2 p2 = (vec2(iuv.x + h0x, iuv.y + h1y) - 0.5) * texelSize.xy; + vec2 p3 = (vec2(iuv.x + h1x, iuv.y + h1y) - 0.5) * texelSize.xy; + + return g0(fuv.y) * (g0x * texture2D(tex, p0) + + g1x * texture2D(tex, p1)) + + g1(fuv.y) * (g0x * texture2D(tex, p2) + + g1x * texture2D(tex, p3)); +} + //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -14,31 +82,24 @@ uniform float viewHeight; //////////////////////////////VOID MAIN////////////////////////////// void main() { +/* DRAWBUFFERS:3 */ +vec2 resScale = vec2(1920.,1080.)/(max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))/BLOOM_QUALITY); +vec2 texcoord = ((gl_FragCoord.xy)*2.+0.5)*texelSize; +vec3 bloom = texture2D_bicubic(colortex3,texcoord/2.0).rgb; //1/4 res -/* DRAWBUFFERS:6 */ -vec2 resScale = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))/vec2(1920.,1080.); -vec2 quarterResTC = gl_FragCoord.xy*texelSize*2.; +bloom += texture2D_bicubic(colortex6,texcoord/4.).rgb; //1/8 res - //0.5 - gl_FragData[0] = texture2D(colortex3,quarterResTC-1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex3,quarterResTC+1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(-1.0*texelSize.x,1.0*texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(1.0*texelSize.x,-1.0*texelSize.y))/4.*0.5; +bloom += texture2D_bicubic(colortex6,texcoord/8.+vec2(0.25*resScale.x+2.5*texelSize.x,.0)).rgb; //1/16 res - //0.25 - gl_FragData[0] += texture2D(colortex3,quarterResTC-2.0*vec2(texelSize.x,0.0))/2.*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(0.0,texelSize.y))/2.*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(0,-texelSize.y))/2*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(-texelSize.x,0.0))/2*0.125; +bloom += texture2D_bicubic(colortex6,texcoord/16.+vec2(0.375*resScale.x+4.5*texelSize.x,.0)).rgb; //1/32 res - //0.125 - gl_FragData[0] += texture2D(colortex3,quarterResTC-2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(-2.0*texelSize.x,2.0*texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(2.0*texelSize.x,-2.0*texelSize.y))/4.*0.125; +bloom += texture2D_bicubic(colortex6,texcoord/32.+vec2(0.4375*resScale.x+6.5*texelSize.x,.0)).rgb*1.0; //1/64 res +bloom += texture2D_bicubic(colortex6,texcoord/64.+vec2(0.46875*resScale.x+8.5*texelSize.x,.0)).rgb*1.0; //1/128 res +bloom += texture2D_bicubic(colortex6,texcoord/128.+vec2(0.484375*resScale.x+10.5*texelSize.x,.0)).rgb*1.0; //1/256 res - //0.125 - gl_FragData[0] += texture2D(colortex3,quarterResTC)*0.125; +//bloom = texture2D_bicubic(colortex6,texcoord).rgb*6.; //1/8 res - gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); +gl_FragData[0].rgb = bloom*2.; + +gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); } diff --git a/shaders/composite10.vsh b/shaders/composite10.vsh index 23439b2..97113b9 100644 --- a/shaders/composite10.vsh +++ b/shaders/composite10.vsh @@ -14,5 +14,5 @@ void main() { vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); gl_Position = ftransform(); //*0.51 to avoid errors when sampling outside since clearing is disabled - gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.26*BLOOM_QUALITY/clampedRes*vec2(1920.0,1080.)*2-1.0; + gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.51*BLOOM_QUALITY/clampedRes*vec2(1920.0,1080.)*2.0-1.0; } diff --git a/shaders/composite11.fsh b/shaders/composite11.fsh index 513baa1..4b457bd 100644 --- a/shaders/composite11.fsh +++ b/shaders/composite11.fsh @@ -1,62 +1,149 @@ #version 120 -#include "lib/settings.glsl" -//6 Horizontal gaussian blurs and horizontal downsampling -#include "lib/res_params.glsl" +//Vignetting, applies bloom, applies exposure and tonemaps the final image +#extension GL_EXT_gpu_shader4 : enable -uniform sampler2D colortex6; -uniform vec2 texelSize; +#include "/lib/settings.glsl" + +#include "/lib/res_params.glsl" + + +flat varying vec4 exposure; +flat varying vec2 rodExposureDepth; varying vec2 texcoord; + +const bool colortex5MipmapEnabled = true; +// uniform sampler2D colortex4; +uniform sampler2D colortex5; +uniform sampler2D colortex3; +// uniform sampler2D colortex6; +uniform sampler2D colortex7; +// uniform sampler2D colortex10; +// uniform sampler2D colortex8; // specular +// uniform sampler2D colortex9; // specular +uniform sampler2D depthtex0; +uniform sampler2D depthtex1; +uniform sampler2D noisetex; +uniform vec2 texelSize; + +uniform ivec2 eyeBrightnessSmooth; uniform float viewWidth; uniform float viewHeight; -vec2 resScale = vec2(1920.,1080.)/max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))*BLOOM_QUALITY; -vec3 gauss1D(vec2 coord,vec2 dir,float alpha,int maxIT){ - vec4 tot = vec4(0.); - float maxTC = 0.25*resScale.x; - float minTC = 0.; - for (int i = -maxIT;i minTC && spCoord.x < maxTC); - } - return tot.rgb/max(1.0,tot.a); +uniform float frameTimeCounter; +uniform int frameCounter; +uniform int isEyeInWater; +uniform float near; +uniform float aspectRatio; +uniform float far; +uniform float rainStrength; +uniform float screenBrightness; +uniform vec4 Moon_Weather_properties; // R = cloud coverage G = fog density + +uniform int framemod8; +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.); + +uniform mat4 gbufferModelViewInverse; +uniform mat4 gbufferProjectionInverse; +vec4 Weather_properties = Moon_Weather_properties; + +#include "/lib/color_transforms.glsl" +#include "/lib/color_dither.glsl" +// #include "lib/biome_specifics.glsl" +#include "/lib/bokeh.glsl" + +float cdist(vec2 coord) { + return max(abs(coord.s-0.5),abs(coord.t-0.5))*2.0; +} +float blueNoise(){ + return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); +} +float ld(float depth) { + return (2.0 * near) / (far + near - depth * (far - near)); // (-depth * (far - near)) = (2.0 * near)/ld - far - near } -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// +// blindness fogs +uniform float blindness; +uniform float darknessFactor; void main() { -/* DRAWBUFFERS:6 */ + /* DRAWBUFFERS:7 */ + float vignette = (1.5-dot(texcoord-0.5,texcoord-0.5)*2.); + vec3 col = texture2D(colortex5,texcoord).rgb; -vec2 texcoord = (gl_FragCoord.xy*vec2(2.0,4.0))*texelSize; -vec2 gaussDir = vec2(1.0,0.0); -gl_FragData[0].rgb = vec3(0.0); -vec2 tc2 = texcoord*vec2(2.0,1.)/2.; -if (tc2.x < 1.0*resScale.x && tc2.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(tc2/2,gaussDir,0.16,0); + #if DOF_QUALITY >= 0 + /*--------------------------------*/ + float z = ld(texture2D(depthtex0, texcoord.st*RENDER_SCALE).r)*far; + #ifdef AUTOFOCUS + float focus = rodExposureDepth.y*far; + #else + float focus = MANUAL_FOCUS*screenBrightness; + #endif + float pcoc = min(abs(aperture * (focal/100.0 * (z - focus)) / (z * (focus - focal/100.0))),texelSize.x*15.0); + #ifdef FAR_BLUR_ONLY + pcoc *= float(z > focus); + #endif + float noise = blueNoise()*6.28318530718; + mat2 noiseM = mat2( cos( noise ), -sin( noise ), + sin( noise ), cos( noise ) + ); + vec3 bcolor = vec3(0.); + float nb = 0.0; + vec2 bcoord = vec2(0.0); + /*--------------------------------*/ + float dofLodLevel = pcoc * 200.0; + for ( int i = 0; i < BOKEH_SAMPLES; i++) { + bcolor += texture2DLod(colortex5, texcoord.xy + bokeh_offsets[i]*pcoc*vec2(DOF_ANAMORPHIC_RATIO,aspectRatio), dofLodLevel).rgb; + } + col = bcolor/BOKEH_SAMPLES; + #endif -vec2 tc4 = texcoord*vec2(4.0,1.)/2.-vec2(0.5*resScale.x+4.0*texelSize.x,0.)*2.0; -if (tc4.x > 0.0 && tc4.y > 0.0 && tc4.x < 1.0*resScale.x && tc4.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(tc4/2,gaussDir,0.16,3); + vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); -vec2 tc8 = texcoord*vec2(8.0,1.)/2.-vec2(0.75*resScale.x+8.*texelSize.x,0.)*4.0; -if (tc8.x > 0.0 && tc8.y > 0.0 && tc8.x < 1.0*resScale.x && tc8.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(tc8/2,gaussDir,0.035,6); -vec2 tc16 = texcoord*vec2(8.0,1./2.)-vec2(0.875*resScale.x+12.*texelSize.x,0.)*8.0; -if (tc16.x > 0.0 && tc16.y > 0.0 && tc16.x < 1.0*resScale.x && tc16.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(tc16/2,gaussDir,0.0085,12); -vec2 tc32 = texcoord*vec2(16.0,1./2.)-vec2(0.9375*resScale.x+16.*texelSize.x,0.)*16.0; -if (tc32.x > 0.0 && tc32.y > 0.0 && tc32.x < 1.0*resScale.x && tc32.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(tc32/2,gaussDir,0.002,28); + vec3 bloom = texture2D(colortex3,texcoord/clampedRes*vec2(1920.,1080.)*0.5*BLOOM_QUALITY).rgb/2./7.0; -vec2 tc64 = texcoord*vec2(32.0,1./2.)-vec2(0.96875*resScale.x+20.*texelSize.x,0.)*32.0; -if (tc64.x > 0.0 && tc64.y > 0.0 && tc64.x < 1.0*resScale.x && tc64.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(tc64/2,gaussDir,0.0005,60); + float lightScat = clamp(BLOOM_STRENGTH * 0.05 * pow(exposure.a ,0.2) ,0.0,1.0)*vignette; -gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); -} + float VL_abs = texture2D(colortex7,texcoord*RENDER_SCALE).r; + float purkinje = rodExposureDepth.x/(1.0+rodExposureDepth.x)*Purkinje_strength; + + VL_abs = clamp( (1.0-VL_abs)*BLOOMY_FOG*0.75*(1.0-purkinje),0.0,1.0)*clamp(1.0-pow(cdist(texcoord.xy),15.0),0.0,1.0); + + float lightleakfix = clamp(eyeBrightnessSmooth.y/240.0,0.0,1.0); + + col = (mix(col,bloom,VL_abs)+bloom*lightScat)* mix(exposure.rgb,min(exposure.rgb,0.01), 0); + + //Purkinje Effect + float lum = dot(col,vec3(0.15,0.3,0.55)); + float lum2 = dot(col,vec3(0.85,0.7,0.45))/2; + float rodLum = lum2*400.; + float rodCurve = mix(1.0, rodLum/(2.5+rodLum), purkinje); + col = mix(clamp(lum,0.0,0.05)*Purkinje_Multiplier*vec3(Purkinje_R, Purkinje_G, Purkinje_B)+1.5e-3, col, rodCurve); + +// #ifdef display_LUT +// vec2 movedTC = texcoord ; +// if(movedTC.x < 0.4 ) col.rgb = texture2D(colortex4,movedTC/2).rgb * 0.001; +// #endif + + + + + #ifndef USE_ACES_COLORSPACE_APPROXIMATION + col = LinearTosRGB(TONEMAP(col)); + #else + col = col * ACESInputMat; + col = TONEMAP(col); + + col = LinearTosRGB(clamp(col * ACESOutputMat, 0.0, 1.0)); + #endif + + + gl_FragData[0].rgb = clamp(int8Dither(col,texcoord),0.0,1.0); +} \ No newline at end of file diff --git a/shaders/composite11.vsh b/shaders/composite11.vsh index 568bb90..fb9777e 100644 --- a/shaders/composite11.vsh +++ b/shaders/composite11.vsh @@ -1,9 +1,24 @@ #version 120 +#extension GL_EXT_gpu_shader4 : enable #include "lib/settings.glsl" -#include "lib/res_params.glsl" -uniform float viewWidth; -uniform float viewHeight; + + varying vec2 texcoord; +flat varying vec4 exposure; +flat varying vec2 rodExposureDepth; +uniform sampler2D colortex4; + +uniform vec2 texelSize; +uniform int framemod8; +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.); + //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -11,11 +26,13 @@ varying vec2 texcoord; //////////////////////////////VOID MAIN////////////////////////////// void main() { - vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.0))/BLOOM_QUALITY; + + gl_Position = ftransform(); - //0-0.25 - gl_Position.y = (gl_Position.y*0.5+0.5)*0.25/clampedRes.y*1080.0*2.0-1.0; - //0-0.5 - gl_Position.x = (gl_Position.x*0.5+0.5)*0.5/clampedRes.x*1920.0*2.0-1.0; - texcoord = gl_MultiTexCoord0.xy/clampedRes*vec2(1920.,1080.); + + + texcoord = gl_MultiTexCoord0.xy; + exposure=vec4(texelFetch2D(colortex4,ivec2(10,37),0).r*vec3(FinalR,FinalG,FinalB),texelFetch2D(colortex4,ivec2(10,37),0).r); + rodExposureDepth = texelFetch2D(colortex4,ivec2(14,37),0).rg; + rodExposureDepth.y = sqrt(rodExposureDepth.y/65000.0); } diff --git a/shaders/composite12.fsh b/shaders/composite12.fsh deleted file mode 100644 index da17b54..0000000 --- a/shaders/composite12.fsh +++ /dev/null @@ -1,62 +0,0 @@ -#version 120 -#include "lib/settings.glsl" -//6 Vertical gaussian blurs and vertical downsampling -#include "lib/res_params.glsl" - - -uniform sampler2D colortex6; -uniform vec2 texelSize; -varying vec2 texcoord; -uniform float viewWidth; -uniform float viewHeight; -vec2 resScale = vec2(1920.,1080.)/max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))*BLOOM_QUALITY; -vec3 gauss1D(vec2 coord,vec2 dir,float alpha,int maxIT){ - vec4 tot = vec4(0.); - float maxTC = 0.25*resScale.y; - float minTC = 0.; - for (int i = -maxIT;i minTC && spCoord.y < maxTC); - } - return tot.rgb/max(1.0,tot.a); -} - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { -/* DRAWBUFFERS:6 */ -vec2 texcoord = (gl_FragCoord.xy*vec2(2.0,4.0))*texelSize; - -vec2 gaussDir = vec2(0.0,1.0); -gl_FragData[0].rgb = vec3(0.0); -vec2 tc2 = texcoord*vec2(2.0,1.); -if (tc2.x < 1.0*resScale.x && tc2.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord/vec2(2.0,4.0),gaussDir,0.16,0); - -vec2 tc4 = texcoord*vec2(4.0,2.)-vec2(0.5*resScale.x+4.0*texelSize.x,0.)*4.0; -if (tc4.x > 0.0 && tc4.y > 0.0 && tc4.x < 1.0*resScale.x && tc4.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord/vec2(2.0,2.0),gaussDir,0.16,3); - -vec2 tc8 = texcoord*vec2(8.0,4.)-vec2(0.75*resScale.x+8.*texelSize.x,0.)*8.0; -if (tc8.x > 0.0 && tc8.y > 0.0 && tc8.x < 1.0*resScale.x && tc8.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,2.0)/vec2(2.0,2.0),gaussDir,0.035,6); - -vec2 tc16 = texcoord*vec2(16.0,8.)-vec2(0.875*resScale.x+12.*texelSize.x,0.)*16.0; -if (tc16.x > 0.0 && tc16.y > 0.0 && tc16.x < 1.0*resScale.x && tc16.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,4.0)/vec2(2.0,2.0),gaussDir,0.0085,12); - -vec2 tc32 = texcoord*vec2(32.0,16.)-vec2(0.9375*resScale.x+16.*texelSize.x,0.)*32.0; -if (tc32.x > 0.0 && tc32.y > 0.0 && tc32.x < 1.0*resScale.x && tc32.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,8.0)/vec2(2.0,2.0),gaussDir,0.002,30); - -vec2 tc64 = texcoord*vec2(64.0,32.)-vec2(0.96875*resScale.x+20.*texelSize.x,0.)*64.0; -if (tc64.x > 0.0 && tc64.y > 0.0 && tc64.x < 1.0*resScale.x && tc64.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,16.0)/vec2(2.0,2.0),gaussDir,0.0005,60); - -gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); -} diff --git a/shaders/composite12.vsh b/shaders/composite12.vsh deleted file mode 100644 index 82dc7ae..0000000 --- a/shaders/composite12.vsh +++ /dev/null @@ -1,23 +0,0 @@ -#version 120 - -#include "lib/settings.glsl" -#include "lib/res_params.glsl" -uniform float viewWidth; -uniform float viewHeight; -varying vec2 texcoord; -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.0))/BLOOM_QUALITY; - gl_Position = ftransform(); - //0-0.25 - gl_Position.y = (gl_Position.y*0.5+0.5)*0.25/clampedRes.y*1080.0*2.0-1.0; - //0-0.5 - gl_Position.x = (gl_Position.x*0.5+0.5)*0.5/clampedRes.x*1920.0*2.0-1.0; - texcoord = gl_MultiTexCoord0.xy/clampedRes*vec2(1920.,1080.); - -} diff --git a/shaders/composite14.fsh b/shaders/composite14.fsh deleted file mode 100644 index 06b5762..0000000 --- a/shaders/composite14.fsh +++ /dev/null @@ -1,105 +0,0 @@ -#version 120 - -#include "lib/settings.glsl" -//Merge and upsample the blurs into a 1/4 res bloom buffer -#include "lib/res_params.glsl" -uniform sampler2D colortex3; -uniform sampler2D colortex6; - -uniform vec2 texelSize; -uniform float viewWidth; -uniform float viewHeight; - -float w0(float a) -{ - return (1.0/6.0)*(a*(a*(-a + 3.0) - 3.0) + 1.0); -} - -float w1(float a) -{ - return (1.0/6.0)*(a*a*(3.0*a - 6.0) + 4.0); -} - -float w2(float a) -{ - return (1.0/6.0)*(a*(a*(-3.0*a + 3.0) + 3.0) + 1.0); -} - -float w3(float a) -{ - return (1.0/6.0)*(a*a*a); -} - -float g0(float a) -{ - return w0(a) + w1(a); -} - -float g1(float a) -{ - return w2(a) + w3(a); -} - -float h0(float a) -{ - return -1.0 + w1(a) / (w0(a) + w1(a)); -} - -float h1(float a) -{ - return 1.0 + w3(a) / (w2(a) + w3(a)); -} - -vec4 texture2D_bicubic(sampler2D tex, vec2 uv) -{ - vec4 texelSize = vec4(texelSize,1.0/texelSize); - uv = uv*texelSize.zw; - vec2 iuv = floor( uv ); - vec2 fuv = fract( uv ); - - float g0x = g0(fuv.x); - float g1x = g1(fuv.x); - float h0x = h0(fuv.x); - float h1x = h1(fuv.x); - float h0y = h0(fuv.y); - float h1y = h1(fuv.y); - - vec2 p0 = (vec2(iuv.x + h0x, iuv.y + h0y) - 0.5) * texelSize.xy; - vec2 p1 = (vec2(iuv.x + h1x, iuv.y + h0y) - 0.5) * texelSize.xy; - vec2 p2 = (vec2(iuv.x + h0x, iuv.y + h1y) - 0.5) * texelSize.xy; - vec2 p3 = (vec2(iuv.x + h1x, iuv.y + h1y) - 0.5) * texelSize.xy; - - return g0(fuv.y) * (g0x * texture2D(tex, p0) + - g1x * texture2D(tex, p1)) + - g1(fuv.y) * (g0x * texture2D(tex, p2) + - g1x * texture2D(tex, p3)); -} - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { -/* DRAWBUFFERS:3 */ -vec2 resScale = vec2(1920.,1080.)/(max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))/BLOOM_QUALITY); -vec2 texcoord = ((gl_FragCoord.xy)*2.+0.5)*texelSize; -vec3 bloom = texture2D_bicubic(colortex3,texcoord/2.0).rgb; //1/4 res - -bloom += texture2D_bicubic(colortex6,texcoord/4.).rgb; //1/8 res - -bloom += texture2D_bicubic(colortex6,texcoord/8.+vec2(0.25*resScale.x+2.5*texelSize.x,.0)).rgb; //1/16 res - -bloom += texture2D_bicubic(colortex6,texcoord/16.+vec2(0.375*resScale.x+4.5*texelSize.x,.0)).rgb; //1/32 res - -bloom += texture2D_bicubic(colortex6,texcoord/32.+vec2(0.4375*resScale.x+6.5*texelSize.x,.0)).rgb*1.0; //1/64 res -bloom += texture2D_bicubic(colortex6,texcoord/64.+vec2(0.46875*resScale.x+8.5*texelSize.x,.0)).rgb*1.0; //1/128 res -bloom += texture2D_bicubic(colortex6,texcoord/128.+vec2(0.484375*resScale.x+10.5*texelSize.x,.0)).rgb*1.0; //1/256 res - -//bloom = texture2D_bicubic(colortex6,texcoord).rgb*6.; //1/8 res - -gl_FragData[0].rgb = bloom*2.; - -gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); -} diff --git a/shaders/composite14.vsh b/shaders/composite14.vsh deleted file mode 100644 index 97113b9..0000000 --- a/shaders/composite14.vsh +++ /dev/null @@ -1,18 +0,0 @@ -#version 120 -#include "lib/settings.glsl" -#include "lib/res_params.glsl" -uniform float viewWidth; -uniform float viewHeight; -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - //Improves performances and makes sure bloom radius stays the same at high resolution (>1080p) - vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); - gl_Position = ftransform(); - //*0.51 to avoid errors when sampling outside since clearing is disabled - gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.51*BLOOM_QUALITY/clampedRes*vec2(1920.0,1080.)*2.0-1.0; -} diff --git a/shaders/composite15.fsh b/shaders/composite15.fsh deleted file mode 100644 index 60ebfb3..0000000 --- a/shaders/composite15.fsh +++ /dev/null @@ -1,129 +0,0 @@ -#version 120 -//Vignetting, applies bloom, applies exposure and tonemaps the final image -#extension GL_EXT_gpu_shader4 : enable - -#include "/lib/settings.glsl" - -#include "/lib/res_params.glsl" - - -flat varying vec4 exposure; -flat varying vec2 rodExposureDepth; -varying vec2 texcoord; -uniform sampler2D colortex4; -const bool colortex5MipmapEnabled = true; -uniform sampler2D colortex5; -uniform sampler2D colortex3; -uniform sampler2D colortex6; -uniform sampler2D colortex7; -uniform sampler2D colortex8; // specular -// uniform sampler2D colortex9; // specular -uniform sampler2D depthtex0; -uniform sampler2D depthtex1; -uniform sampler2D noisetex; -uniform vec2 texelSize; - -uniform ivec2 eyeBrightnessSmooth; -uniform float viewWidth; -uniform float viewHeight; -uniform float frameTimeCounter; -uniform int frameCounter; -uniform int isEyeInWater; -uniform float near; -uniform float aspectRatio; -uniform float far; -uniform float rainStrength; -uniform float screenBrightness; -uniform vec4 Moon_Weather_properties; // R = cloud coverage G = fog density - -uniform mat4 gbufferModelViewInverse; -uniform mat4 gbufferProjectionInverse; -vec4 Weather_properties = Moon_Weather_properties; - -#include "/lib/color_transforms.glsl" -#include "/lib/color_dither.glsl" -// #include "lib/biome_specifics.glsl" -#include "/lib/bokeh.glsl" - -float cdist(vec2 coord) { - return max(abs(coord.s-0.5),abs(coord.t-0.5))*2.0; -} -float blueNoise(){ - return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); -} -float ld(float depth) { - return (2.0 * near) / (far + near - depth * (far - near)); // (-depth * (far - near)) = (2.0 * near)/ld - far - near -} - -// blindness fogs -uniform float blindness; -uniform float darknessFactor; - -void main() { - /* DRAWBUFFERS:7 */ - float vignette = (1.5-dot(texcoord-0.5,texcoord-0.5)*2.); - vec3 col = texture2D(colortex5,texcoord).rgb; - - #if DOF_QUALITY >= 0 - /*--------------------------------*/ - float z = ld(texture2D(depthtex0, texcoord.st*RENDER_SCALE).r)*far; - #ifdef AUTOFOCUS - float focus = rodExposureDepth.y*far; - #else - float focus = MANUAL_FOCUS*screenBrightness; - #endif - float pcoc = min(abs(aperture * (focal/100.0 * (z - focus)) / (z * (focus - focal/100.0))),texelSize.x*15.0); - #ifdef FAR_BLUR_ONLY - pcoc *= float(z > focus); - #endif - float noise = blueNoise()*6.28318530718; - mat2 noiseM = mat2( cos( noise ), -sin( noise ), - sin( noise ), cos( noise ) - ); - vec3 bcolor = vec3(0.); - float nb = 0.0; - vec2 bcoord = vec2(0.0); - /*--------------------------------*/ - float dofLodLevel = pcoc * 200.0; - for ( int i = 0; i < BOKEH_SAMPLES; i++) { - bcolor += texture2DLod(colortex5, texcoord.xy + bokeh_offsets[i]*pcoc*vec2(DOF_ANAMORPHIC_RATIO,aspectRatio), dofLodLevel).rgb; - } - col = bcolor/BOKEH_SAMPLES; - #endif - - vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); - - - vec3 bloom = texture2D(colortex3,texcoord/clampedRes*vec2(1920.,1080.)*0.5*BLOOM_QUALITY).rgb/2./7.0; - - float lightScat = clamp(BLOOM_STRENGTH * 0.05 * pow(exposure.a ,0.2) ,0.0,1.0)*vignette; - - float VL_abs = texture2D(colortex7,texcoord*RENDER_SCALE).r; - float purkinje = rodExposureDepth.x/(1.0+rodExposureDepth.x)*Purkinje_strength; - - VL_abs = clamp( (1.0-VL_abs)*BLOOMY_FOG*0.75*(1.0-purkinje),0.0,1.0)*clamp(1.0-pow(cdist(texcoord.xy),15.0),0.0,1.0); - - float lightleakfix = clamp(eyeBrightnessSmooth.y/240.0,0.0,1.0); - col = (mix(col,bloom,VL_abs)+bloom*lightScat)* mix(exposure.rgb,min(exposure.rgb,0.01), 0); - - //Purkinje Effect - float lum = dot(col,vec3(0.15,0.3,0.55)); - float lum2 = dot(col,vec3(0.85,0.7,0.45))/2; - float rodLum = lum2*400.; - float rodCurve = mix(1.0, rodLum/(2.5+rodLum), purkinje); - col = mix(clamp(lum,0.0,0.05)*Purkinje_Multiplier*vec3(Purkinje_R, Purkinje_G, Purkinje_B)+1.5e-3, col, rodCurve); - - #ifndef USE_ACES_COLORSPACE_APPROXIMATION - col = LinearTosRGB(TONEMAP(col)); - #else - col = col * ACESInputMat; - col = TONEMAP(col); - col = LinearTosRGB(clamp(col * ACESOutputMat, 0.0, 1.0)); - #endif - gl_FragData[0].rgb = clamp(int8Dither(col,texcoord),0.0,1.0); - - - - - -} \ No newline at end of file diff --git a/shaders/composite15.vsh b/shaders/composite15.vsh deleted file mode 100644 index d9072cb..0000000 --- a/shaders/composite15.vsh +++ /dev/null @@ -1,24 +0,0 @@ -#version 120 -#extension GL_EXT_gpu_shader4 : enable -#include "lib/settings.glsl" - - -varying vec2 texcoord; -flat varying vec4 exposure; -flat varying vec2 rodExposureDepth; -uniform sampler2D colortex4; - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - - gl_Position = ftransform(); - texcoord = gl_MultiTexCoord0.xy; - exposure=vec4(texelFetch2D(colortex4,ivec2(10,37),0).r*vec3(FinalR,FinalG,FinalB),texelFetch2D(colortex4,ivec2(10,37),0).r); - rodExposureDepth = texelFetch2D(colortex4,ivec2(14,37),0).rg; - rodExposureDepth.y = sqrt(rodExposureDepth.y/65000.0); -} diff --git a/shaders/composite2.fsh b/shaders/composite2.fsh index 7b36d1f..4e85ee2 100644 --- a/shaders/composite2.fsh +++ b/shaders/composite2.fsh @@ -1,14 +1,14 @@ #version 120 -//Render sky, volumetric clouds, direct lighting +//Volumetric fog rendering #extension GL_EXT_gpu_shader4 : enable #include "lib/settings.glsl" -const bool colortex5MipmapEnabled = true; -// const bool colortex4MipmapEnabled = true; -\ -const bool shadowHardwareFiltering = true; -flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) +flat varying vec3 sunColor; +flat varying vec3 moonColor; +flat varying vec3 avgAmbient2; + +flat varying vec4 lightCol; flat varying vec3 ambientUp; flat varying vec3 ambientLeft; flat varying vec3 ambientRight; @@ -16,291 +16,67 @@ flat varying vec3 ambientB; flat varying vec3 ambientF; flat varying vec3 ambientDown; flat varying vec3 avgAmbient; -flat varying vec3 WsunVec; -flat varying vec2 TAA_Offset; flat varying float tempOffsets; - - -/* -const int colortex12Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) -const int colortex11Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) -const int colortex15Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) -*/ - - -uniform sampler2D colortex0;//clouds -uniform sampler2D colortex1;//albedo(rgb),material(alpha) RGBA16 -// uniform sampler2D colortex4;//Skybox -uniform sampler2D colortex3; -uniform sampler2D colortex5; -uniform sampler2D colortex7; // normal -uniform sampler2D colortex6; // Noise -uniform sampler2D colortex8; // specular -// uniform sampler2D colortex9; // specular -uniform sampler2D colortex10; // specular -uniform sampler2D colortex11; // specular -uniform sampler2D colortex12; // specular -uniform sampler2D colortex13; // specular -uniform sampler2D colortex14; // specular -uniform sampler2D colortex15; // specular -uniform sampler2D colortex16; // specular -uniform sampler2D depthtex1;//depth -uniform sampler2D depthtex0;//depth -uniform sampler2D noisetex;//depth +flat varying float fogAmount; +flat varying float VFAmount; +flat varying float FogSchedule; +uniform sampler2D noisetex; +uniform sampler2D depthtex0; +uniform sampler2D depthtex1; uniform sampler2DShadow shadow; -varying vec4 normalMat; -uniform int heldBlockLightValue; -uniform int frameCounter; -uniform int isEyeInWater; -uniform float far; -uniform float nightVision; -uniform float near; -uniform float frameTimeCounter; -uniform float rainStrength; -uniform mat4 gbufferProjection; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferModelViewInverse; -uniform mat4 gbufferPreviousModelView; -uniform mat4 gbufferPreviousProjection; -uniform vec3 previousCameraPosition; -uniform mat4 shadowModelView; -uniform mat4 shadowProjection; -uniform mat4 gbufferModelView; -// uniform float viewWidth; -// uniform float viewHeight; -uniform float aspectRatio; -uniform vec2 texelSize; -uniform vec3 cameraPosition; +flat varying vec3 refractedSunVec; +flat varying vec3 WsunVec; + +// uniform sampler2D colortex1; +// uniform sampler2D colortex3; +// // uniform sampler2D colortex0; +// uniform sampler2D colortex7; +// uniform sampler2D colortex13; +// uniform sampler2D colortex4; + uniform vec3 sunVec; +uniform float far; +uniform float near; +uniform int frameCounter; +uniform float rainStrength; +uniform float sunElevation; uniform ivec2 eyeBrightnessSmooth; -uniform ivec2 eyeBrightness; - -// uniform int worldTime; - -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) - -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) +uniform float frameTimeCounter; +uniform int isEyeInWater; +uniform vec2 texelSize; -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; -} - -vec3 toScreenSpacePrev(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; -} -vec3 worldToView(vec3 p3) { - vec4 pos = vec4(p3, 0.0); - pos = gbufferModelView * pos; - return pos.xyz; -} - - -float ld(float dist) { - return (2.0 * near) / (far + near - dist * (far - near)); -} -vec3 ld(vec3 dist) { - return (2.0 * near) / (far + near - dist * (far - near)); -} -vec3 srgbToLinear2(vec3 srgb){ - return mix( - srgb / 12.92, - pow(.947867 * srgb + .0521327, vec3(2.4) ), - step( .04045, srgb ) - ); -} -vec3 blackbody2(float Temp) -{ - float t = pow(Temp, -1.5); - float lt = log(Temp); - - vec3 col = vec3(0.0); - col.x = 220000.0 * t + 0.58039215686; - col.y = 0.39231372549 * lt - 2.44549019608; - col.y = Temp > 6500. ? 138039.215686 * t + 0.72156862745 : col.y; - col.z = 0.76078431372 * lt - 5.68078431373; - col = clamp(col,0.0,1.0); - col = Temp < 1000. ? col * Temp * 0.001 : col; - - return srgbToLinear2(col); -} - -vec3 normVec (vec3 vec){ - return vec*inversesqrt(dot(vec,vec)); -} -vec3 viewToWorld(vec3 viewPosition) { - vec4 pos; - pos.xyz = viewPosition; - pos.w = 0.0; - pos = gbufferModelViewInverse * pos; - return pos.xyz; -} -// #include "lib/settings.glsl" -// #include "lib/biome_specifics.glsl" -#include "lib/res_params.glsl" #include "lib/Shadow_Params.glsl" #include "lib/color_transforms.glsl" +#include "lib/color_dither.glsl" +#include "lib/projections.glsl" #include "lib/sky_gradient.glsl" -#include "lib/stars.glsl" +#include "/lib/res_params.glsl" +// #include "lib/biome_specifics.glsl" + +#define TIMEOFDAYFOG #include "lib/volumetricClouds.glsl" -#include "lib/waterBump.glsl" -#include "lib/specular.glsl" -// #include "/lib/climate_settings.glsl" -float lengthVec (vec3 vec){ - return sqrt(dot(vec,vec)); -} -#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) -float triangularize(float dither) -{ - float center = dither*2.0-1.0; - dither = center*inversesqrt(abs(center)); - return clamp(dither-fsign(center),0.0,1.0); -} - - -float interleaved_gradientNoise(){ - // vec2 coord = gl_FragCoord.xy + (frameCounter%40000); - vec2 coord = gl_FragCoord.xy + frameTimeCounter; - // vec2 coord = gl_FragCoord.xy; - float noise = fract( 52.9829189 * fract( (coord.x * 0.06711056) + (coord.y * 0.00583715)) ); - return noise ; -} - float blueNoise(){ return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); } -vec4 blueNoise(vec2 coord){ - return texelFetch2D(colortex6, ivec2(coord )%512 , 0); -} -vec3 fp10Dither(vec3 color,float dither){ - const vec3 mantissaBits = vec3(6.,6.,5.); - vec3 exponent = floor(log2(color)); - return color + dither*exp2(-mantissaBits)*exp2(exponent); -} - -vec3 decode (vec2 encn){ - vec3 n = vec3(0.0); - encn = encn * 2.0 - 1.0; - n.xy = abs(encn); - n.z = 1.0 - n.x - n.y; - n.xy = n.z <= 0.0 ? (1.0 - n.yx) * sign(encn) : encn; - return clamp(normalize(n.xyz),-1.0,1.0); -} -vec2 decodeVec2(float a){ - const vec2 constant1 = 65535. / vec2( 256., 65536.); - const float constant2 = 256. / 255.; - return fract( a * constant1 ) * constant2 ; -} - - -vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter,float distort){ - float alpha0 = sampleNumber/nb; - float alpha = (sampleNumber+jitter)/nb; - float angle = jitter*6.28 + alpha * 84.0 * 6.28; - - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*sqrt(alpha); -} -vec3 toShadowSpaceProjected(vec3 p3){ - p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; - p3 = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; - p3 = diagonal3(shadowProjection) * p3 + shadowProjection[3].xyz; - return p3; -} - -vec2 R2_samples(int n){ +float R2_dither(){ vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha * n); + return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y + 1.0/1.6180339887 * frameCounter) ; } - -vec2 tapLocation(int sampleNumber, float spinAngle,int nb, float nbRot,float r0){ - float alpha = (float(sampleNumber*1.0f + r0) * (1.0 / (nb))); - float angle = alpha * (nbRot * 3.14) + spinAngle*3.14; - - float ssR = alpha; - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*ssR; +float R2_dither2(){ + vec2 alpha = vec2(0.75487765, 0.56984026); + return fract(alpha.x *(1- gl_FragCoord.x) + alpha.y * (1-gl_FragCoord.y) + 1.0/1.6180339887 * frameCounter) ; +} +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; } -void waterVolumetrics(inout vec3 inColor, vec3 rayStart, vec3 rayEnd, float estEndDepth, float estSunDepth, float rayLength, float dither, vec3 waterCoefs, vec3 scatterCoef, vec3 ambient, vec3 lightSource, float VdotL){ - inColor *= exp(-rayLength * waterCoefs); //No need to take the integrated value - int spCount = rayMarchSampleCount; - vec3 start = toShadowSpaceProjected(rayStart); - vec3 end = toShadowSpaceProjected(rayEnd); - vec3 dV = (end-start); - //limit ray length at 32 blocks for performance and reducing integration error - //you can't see above this anyway - float maxZ = min(rayLength,32.0)/(1e-8+rayLength); - dV *= maxZ; - vec3 dVWorld = -mat3(gbufferModelViewInverse) * (rayEnd - rayStart) * maxZ; - rayLength *= maxZ; - float dY = normalize(mat3(gbufferModelViewInverse) * rayEnd).y * rayLength; - estEndDepth *= maxZ; - estSunDepth *= maxZ; - vec3 absorbance = vec3(1.0); - vec3 vL = vec3(0.0); - float phase = 2*mix(phaseg(VdotL, 0.4),phaseg(VdotL, 0.8),0.5); - float expFactor = 11.0; - vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; - for (int i=0;i -near) ? - (-near -position.z) / dir.z : far*sqrt(3.) ; - vec3 direction = toClipSpace3(position+dir*rayLength)-clipPosition; //convert to clip space - direction.xyz = direction.xyz/max(abs(direction.x)/texelSize.x,abs(direction.y)/texelSize.y); //fixed step size - vec3 stepv = direction *3. * clamp(MC_RENDER_QUALITY,1.,2.0)*vec3(RENDER_SCALE,1.0); - - vec3 spos = clipPosition*vec3(RENDER_SCALE,1.0); - spos.xy += (TAA_Offset*(texelSize/4))*RENDER_SCALE ; - spos += stepv; - - for (int i = 0; i < int(quality); i++) { - spos += stepv*(dither*0.2 +0.8) *0.5; - // spos += stepv; - - float sp = texture2D(depthtex1,spos.xy).x; - - if( sp < spos.z) { - float dist = abs(linZ(sp)-linZ(spos.z))/linZ(spos.z); - if (dist < 0.015 ) return 0.0; - } - } - return 1.0; +vec3 normVec (vec3 vec){ + return vec*inversesqrt(dot(vec,vec)); } - -vec2 tapLocation_alternate( - int sampleNumber, - float spinAngle, - int nb, - float nbRot, - float r0 -){ - float alpha = (float(sampleNumber*1.0f + r0) * (1.0 / (nb))); - float angle = alpha * (nbRot * 3.14) ; - - float ssR = alpha + spinAngle*3.14; - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*ssR; -} -vec2 hash21(float p) -{ - vec3 p3 = fract(vec3(p) * vec3(.1031, .1030, .0973)); - p3 += dot(p3, p3.yzx + 33.33); - return fract((p3.xx+p3.yz)*p3.zy); - -} - -vec2 vogel_disk_7[7] = vec2[]( - vec2(0.2506005557551467 , -0.08481388042204699) , - vec2(-0.3579961502930998 , 0.22787736539225004) , - vec2(0.035586177529474045, -0.6801399443380787) , - vec2(0.4135705583782951 , 0.4763465923710499) , - vec2(-0.8061879331972175 , -0.2244701335533563) , - vec2(0.7312484456783402 , -0.560572449689252) , - vec2(-0.26682165385093876, 0.8457724502394341) -); - -void ssAO(inout vec3 lighting, vec3 fragpos,float mulfov, vec2 noise, vec3 normal, vec2 texcoord, vec3 ambientCoefs, vec2 lightmap, float sunlight){ - - ivec2 pos = ivec2(gl_FragCoord.xy); - const float tan70 = tan(70.*3.14/180.); - - float dist = 1.0 + clamp(fragpos.z*fragpos.z/50.0,0,2); // shrink sample size as distance increases - - float mulfov2 = gbufferProjection[1][1]/(tan70 * dist); - float maxR2 = fragpos.z*fragpos.z*mulfov2*2.*5/50.0; - - - float rd = mulfov2 * 0.1 ; - //pre-rotate direction - float n = 0.0; - - float occlusion = 0.0; - - vec2 acc = -(TAA_Offset*(texelSize/2))*RENDER_SCALE ; - - int seed = (frameCounter%40000)*2 + (1+frameCounter); - float randomDir = fract(R2_samples(seed).y + noise.x ) * 1.61803398874 ; - vec3 NormalSpecific = viewToWorld(normal); - for (int j = 0; j < 7 ;j++) { - - vec2 sp = tapLocation_alternate(j, 0.0, 7, 20, randomDir); - // vec2 sp = vogel_disk_7[j]; - // float thing = sp.y < 0.0 && clamp(floor(abs(NormalSpecific.y)*2.0),0.0,1.0) < 1.0 ? rd * 10: rd; - - - // vec2 sampleOffset = sp*thing; - // vec2 sampleOffset2 = sp*rd ; - // sampleOffset = min(sampleOffset, sampleOffset2); - vec2 sampleOffset = sp*rd; - - ivec2 offset = ivec2(gl_FragCoord.xy + sampleOffset*vec2(viewWidth,viewHeight*aspectRatio)*RENDER_SCALE); - - if (offset.x >= 0 && offset.y >= 0 && offset.x < viewWidth*RENDER_SCALE.x && offset.y < viewHeight*RENDER_SCALE.y ) { - vec3 t0 = toScreenSpace(vec3(offset*texelSize+acc+0.5*texelSize,texelFetch2D(depthtex1,offset,0).x) * vec3(1.0/RENDER_SCALE, 1.0) ); - vec3 vec = t0.xyz - fragpos; - float dsquared = dot(vec,vec); - - if (dsquared > 1e-5){ - if (dsquared < maxR2){ - float NdotV = clamp(dot(vec*inversesqrt(dsquared), normalize(normal)),0.,1.); - occlusion += NdotV * clamp(1.0-dsquared/maxR2,0.0,1.0); - - // float NdotV2 = clamp(dot(vec*inversesqrt(dsquared), normalize(RPnormal)),0.,1.); - // occlusion.y += NdotV2 * clamp(1.0-dsquared/maxR2,0.0,1.0); - } - n += 1; - } - } - } - - // occlusion *= mix(2.5, 2.0 , clamp(floor(abs(NormalSpecific.y)*2.0),0.0,1.0)); - occlusion = max(1.0 - (occlusion*2.0)/n, 0.0); - // float skylight = clamp(abs(ambientCoefs.y+1),0.5,1.25) * clamp(abs(ambientCoefs.y+0.5),1.0,1.25); - float skylight = clamp(abs(ambientCoefs.y+1),0.5,2.0) ; - // lighting *= 0.5; - lighting *= mix(1.0,skylight,1); - - lighting = lighting*max(occlusion,pow(lightmap.x,4)); -} -vec3 DoContrast(vec3 Color){ - - float Contrast = log(50.0); - - return clamp(mix(vec3(0.5), Color, Contrast) ,0,255); -} - - -void ssDO(inout vec3 lighting, vec3 fragpos,float mulfov, vec2 noise, vec3 normal, vec3 RPnormal, vec2 texcoord, vec3 ambientCoefs, vec2 lightmap, float sunlight){ - const int Samples = 7; - vec3 Radiance = vec3(0); - float occlusion = 0.0; - - ivec2 pos = ivec2(gl_FragCoord.xy); - const float tan70 = tan(70.*3.14/180.); - - // float dist = 1.0 + clamp(fragpos.z*fragpos.z/50.0,0,2); // shrink sample size as distance increases - - float mulfov2 = gbufferProjection[1][1]/(tan70 ); - float maxR2 = fragpos.z*fragpos.z*mulfov2*2.*5/50.0; - - - float rd = mulfov2 * 0.1 ; - - - vec2 acc = -(TAA_Offset*(texelSize/2))*RENDER_SCALE ; - - vec3 NormalSpecific = viewToWorld(normal); - - - for (int j = 0; j < Samples ;j++) { - - vec2 sp = tapLocation_alternate(j, 0.0, 7, 20, blueNoise()); - float thing = sp.y < 0.0 && clamp(floor(abs(NormalSpecific.y)*2.0),0.0,1.0) < 1.0 ? rd * 10: rd; - - - vec2 sampleOffset = sp*thing; - vec2 sampleOffset2 = sp*rd ; - sampleOffset = sampleOffset2; - - ivec2 offset = ivec2(gl_FragCoord.xy + sampleOffset*vec2(viewWidth,viewHeight*aspectRatio)*RENDER_SCALE); - - if (offset.x >= 0 && offset.y >= 0 && offset.x < viewWidth*RENDER_SCALE.x && offset.y < viewHeight*RENDER_SCALE.y ) { - vec3 t0 = toScreenSpace(vec3(offset*texelSize+acc+0.5*texelSize,texelFetch2D(depthtex1,offset,0).x) * vec3(1.0/RENDER_SCALE, 1.0) ); - - - vec3 vec = t0.xyz - fragpos; - float dsquared = dot(vec,vec); - - float NdotV2 = clamp(dot(vec*inversesqrt(dsquared), normalize(RPnormal)),0.,1.); - - if (dsquared < maxR2){ - // float NdotV = clamp(dot(vec*inversesqrt(dsquared), normalize(normal)),0.,1.); - // occlusion += NdotV * clamp(1.0-dsquared/maxR2,0.0,1.0); - - - vec3 previousPosition = mat3(gbufferModelViewInverse) * t0 + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; - previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; - previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; - - if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0){ - Radiance += NdotV2*texture2D(colortex5,previousPosition.xy).rgb ; - } - - } - } - } - - lighting = vec3(1) + Radiance/Samples; -} - -vec3 RT(vec3 dir, vec3 position, float noise, float stepsizes){ - float dist = 1.0 + clamp(position.z*position.z/50.0,0,2); // shrink sample size as distance increases - - float stepSize = stepsizes / dist; - int maxSteps = STEPS; - vec3 clipPosition = toClipSpace3(position); - float rayLength = ((position.z + dir.z * sqrt(3.0)*far) > -sqrt(3.0)*near) ? - (-sqrt(3.0)*near -position.z) / dir.z : sqrt(3.0)*far; - vec3 end = toClipSpace3(position+dir*rayLength) ; - vec3 direction = end-clipPosition ; //convert to clip space - - float len = max(abs(direction.x)/texelSize.x,abs(direction.y)/texelSize.y)/stepSize; - //get at which length the ray intersects with the edge of the screen - vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; - - float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z)*2000.0; - - vec3 stepv = direction/len; - - int iterations = min(int(min(len, mult*len)-2), maxSteps); - - //Do one iteration for closest texel (good contact shadows) - vec3 spos = clipPosition*vec3(RENDER_SCALE,1.0) ; - spos.xy += TAA_Offset*texelSize*0.5*RENDER_SCALE; - spos += stepv/(stepSize/2); - - for(int i = 0; i < iterations; i++){ - if (spos.x < 0.0 || spos.y < 0.0 || spos.z < 0.0 || spos.x > 1.0 || spos.y > 1.0 || spos.z > 1.0) return vec3(1.1); - spos += stepv*noise; - - float sp = sqrt(texelFetch2D(colortex4,ivec2(spos.xy/ texelSize/4),0).w/65000.0); - float currZ = linZ(spos.z); - - if( sp < currZ) { - float dist = abs(sp-currZ)/currZ; - if (dist <= 0.075) return vec3(spos.xy, invLinZ(sp))/vec3(RENDER_SCALE,1.0); - } - } - return vec3(1.1); -} - -vec3 cosineHemisphereSample(vec2 Xi, float roughness){ - float r = sqrt(Xi.x); - float theta = 2.0 * 3.14159265359 * Xi.y; - - float x = r * cos(theta); - float y = r * sin(theta); - - return vec3(x, y, sqrt(clamp(1.0 - Xi.x,0.,1.))); -} -vec3 TangentToWorld(vec3 N, vec3 H, float roughness){ - vec3 UpVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0); - vec3 T = normalize(cross(UpVector, N)); - vec3 B = cross(N, T); - - return vec3((T * H.x) + (B * H.y) + (N * H.z)); -} - - -void rtAO(inout vec3 lighting, vec3 normal, vec2 noise, vec3 fragpos, float lightmap, float inShadow){ - int nrays = 4; - float occlude = 0.0; - - float indoor = clamp(pow(lightmap,2)*2,0.0,AO_Strength); - - for (int i = 0; i < nrays; i++){ - int seed = (frameCounter%40000)*nrays+i; - vec2 ij = fract(R2_samples(seed) + noise.rg); - - - vec3 rayDir = TangentToWorld( normal, normalize(cosineHemisphereSample(ij,1.0)) ,1.0) ; - - #ifdef HQ_SSGI - vec3 rayHit = rayTrace_GI( mat3(gbufferModelView) * rayDir, fragpos, blueNoise(), 30.); // ssr rt - #else - vec3 rayHit = RT(mat3(gbufferModelView)*rayDir, fragpos, blueNoise(), 24.); // choc sspt - #endif - - // vec3 lightDir = normalize(vec3(0.2,0.8,0.2)); - // float skyLightDir = dot(rayDir,lightDir); // the positons where the occlusion happens - - float skyLightDir = rayDir.y > 0.0 ? 1.0 : max(rayDir.y,1.0-indoor); // the positons where the occlusion happens - // if (rayHit.z > 1.0) occlude += skyLightDir; - - occlude += normalize(rayHit.z - 1.0) / (1.1-rayDir.y); - - - } - // occlude = mix( occlude,1, inShadow); - // occlude = occlude*0.5 + 0.5; - // lighting *= 2.5; - lighting *= occlude/nrays; -} - - - -// void rtGI(inout vec3 lighting, vec3 normal,vec2 noise,vec3 fragpos, float lightmap, vec3 albedo, float inShadow){ -// int nrays = RAY_COUNT; -// vec3 intRadiance = vec3(0.0); -// vec3 occlude = vec3(0.0); - -// lighting *= 1.50; -// float indoor = clamp(pow(lightmap,2)*2,0.0,AO_Strength); - -// for (int i = 0; i < nrays; i++){ -// int seed = (frameCounter%40000)*nrays+i; -// vec2 ij = fract(R2_samples(seed) + noise ); - -// vec3 rayDir = TangentToWorld(normal, normalize(cosineHemisphereSample(ij,1.0)) ,1.0); - -// #ifdef HQ_SSGI -// vec3 rayHit = rayTrace_GI( mat3(gbufferModelView) * rayDir, fragpos, blueNoise(), 50.); // ssr rt -// #else -// vec3 rayHit = RT(mat3(gbufferModelView)*rayDir, fragpos, blueNoise(), 30.); // choc sspt -// #endif - -// float skyLightDir = rayDir.y > 0.0 ? 1.0 : max(rayDir.y,1.0-indoor); // the positons where the occlusion happens - -// if (rayHit.z < 1.){ -// vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rayHit) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; -// previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; -// previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; -// if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) - -// intRadiance = DoContrast(texture2D(colortex5,previousPosition.xy).rgb) ; -// else -// intRadiance += lighting*skyLightDir; // make sure ambient light exists but at screen edges when you turn - - -// }else{ -// intRadiance += lighting*skyLightDir; -// } -// } -// lighting = intRadiance/nrays; -// } - - -void rtGI(inout vec3 lighting, vec3 normal,vec2 noise,vec3 fragpos, float lightmap, vec3 albedo, float inShadow){ - int nrays = RAY_COUNT; - vec3 intRadiance = vec3(0.0); - vec3 occlusion = vec3(0.0); - vec3 sunlight =vec3(0); - - // lighting *= 1.50; - float indoor = clamp(pow(lightmap,2)*2,0.0,AO_Strength); - - for (int i = 0; i < nrays; i++){ - int seed = (frameCounter%40000)*nrays+i; - vec2 ij = fract(R2_samples(seed) + noise ); - - vec3 rayDir = TangentToWorld(normal, normalize(cosineHemisphereSample(ij,1.0)) ,1.0); - - #ifdef HQ_SSGI - vec3 rayHit = rayTrace_GI( mat3(gbufferModelView) * rayDir, fragpos, blueNoise(), 50.); // ssr rt - #else - vec3 rayHit = RT(mat3(gbufferModelView)*rayDir, fragpos, blueNoise(), 30.); // choc sspt - #endif - - // float skyLightDir = rayDir.y > 0.0 ? 1.0 : max(rayDir.y,1.0-indoor); // the positons where the occlusion happens - - // vec3 AO = lighting * (normalize(rayHit.z - 1.0) / (1.1-rayDir.y)); - if (rayHit.z < 1){ - vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rayHit)+ gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; - - previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; - previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; - - if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0){ - intRadiance = DoContrast(texture2D(colortex5,previousPosition.xy).rgb ) ; +void waterVolumetrics(inout vec3 inColor, vec3 rayStart, vec3 rayEnd, float estEyeDepth, float estSunDepth, float rayLength, float dither, vec3 waterCoefs, vec3 scatterCoef, vec3 ambient, vec3 lightSource, float VdotL){ + int spCount = 8; + + vec3 start = toShadowSpaceProjected(rayStart); + vec3 end = toShadowSpaceProjected(rayEnd); + vec3 dV = (end-start); + + //limit ray length at 32 blocks for performance and reducing integration error + //you can't see above this anyway + float maxZ = min(rayLength,32.0)/(1e-8+rayLength); + dV *= maxZ; + vec3 dVWorld = mat3(gbufferModelViewInverse) * (rayEnd - rayStart) * maxZ; + rayLength *= maxZ; + float dY = normalize(mat3(gbufferModelViewInverse) * rayEnd).y * rayLength; + vec3 absorbance = vec3(1.0); + vec3 vL = vec3(0.0); + // float phase = 2*mix(phaseg(VdotL, 0.4),phaseg(VdotL, 0.8),0.5); + float phase = phaseg(VdotL,0.7) * 1.5 + 0.02; + float expFactor = 11.0; + vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; + vec3 WsunVec = mat3(gbufferModelViewInverse) * sunVec * lightCol.a; + float cloudShadow = 1; + for (int i=0;i 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0){ - // intRadiance += DoContrast(texture2D(colortex5,previousPosition.xy).rgb) ; - // }else{ - // intRadiance += lighting; - // } - // // occlude += 1.0; - - // }else{ - // intRadiance += lighting; - // } - - // occlude = (lighting/nrays)*(normalize(rayHit.z - 1.0) / (1.1-rayDir.y)); - - } - lighting = occlusion + intRadiance/nrays; -} - - - -float GetCloudShadow(vec3 eyePlayerPos){ - vec3 p3 = (eyePlayerPos + cameraPosition) - Cloud_Height; - vec3 cloudPos = p3*Cloud_Size + WsunVec/abs(WsunVec.y) * ((3250 - 3250*0.35) - p3.y*Cloud_Size) ; - float shadow = getCloudDensity(cloudPos, 1); - // float shadow = (getCloudDensity(cloudPos, 1) + HighAltitudeClouds(cloudPos)) / 2.0; - - shadow = clamp(exp(-shadow*6),0.0,1.0); - - // float timething = (worldTime%24000)*1.0; - // float fadestart_evening = clamp(1.0 - clamp(timething-11500.0 ,0.0,2000.0)/1000. ,0.0,1.0); - // float fadeend_evening = clamp( clamp(14000.0-timething ,0.0,2000.0)/1000. ,0.0,1.0); - - // float fadestart_morning = clamp(clamp(23500.0-timething ,0.0,2000.0)/1000. ,0.0,1.0); - // float fadeend_morning = clamp(1.0 - clamp(timething-200.0 ,0.0,2000.0)/1000. ,0.0,1.0); - - // float TheSettingSun = fadeend_morning; - - return shadow ; -} - -void SubsurfaceScattering(inout float SSS, float Scattering, float Density, float LabDenisty){ - #ifdef LabPBR_subsurface_scattering - float labcurve = pow(LabDenisty,LabSSS_Curve); - SSS = clamp(exp( -(10 - LabDenisty*7) * sqrt(Scattering) ), 0.0, labcurve); - if (abs(Scattering-0.1) < 0.0004 ) SSS = labcurve; - #else - SSS = clamp(exp( -Density * sqrt(Scattering) ), 0.0, 1.0); - if (abs(Scattering-0.1) < 0.0004 ) SSS = 1.0; - #endif -} - - -float densityAtPosSNOW(in vec3 pos){ - pos /= 18.; - pos.xz *= 0.5; - vec3 p = floor(pos); - vec3 f = fract(pos); - f = (f*f) * (3.-2.*f); - vec2 uv = p.xz + f.xz + p.y * vec2(0.0,193.0); - vec2 coord = uv / 512.0; - vec2 xy = texture2D(noisetex, coord).yx; - return mix(xy.r,xy.g, f.y); -} - -// Emin's and Gri's combined ideas to stop peter panning and light leaking, also has little shadowacne so thats nice -// https://www.complementary.dev/reimagined -// https://github.com/gri573 -void GriAndEminShadowFix( - inout vec3 WorldPos, - vec3 FlatNormal, - float VanillaAO, - float SkyLightmap, - bool Entities -){ - float DistanceOffset = clamp(0.1 + length(WorldPos) / (shadowMapResolution*0.20), 0.0,1.0) ; - vec3 Bias = FlatNormal * DistanceOffset; // adjust the bias thingy's strength as it gets farther away. - - // stop lightleaking - if(SkyLightmap < 0.1 && !Entities) { - WorldPos += mix(Bias, 0.5 * (0.5 - fract(WorldPos + cameraPosition + FlatNormal*0.01 ) ), VanillaAO) ; - }else{ - WorldPos += Bias; - } + inColor += vL; } +#include "lib/volumetricFog.glsl" //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// + void main() { +/* DRAWBUFFERS:0 */ + float lightleakfix = max(eyeBrightnessSmooth.y,0)/240.; - vec2 texcoord = gl_FragCoord.xy*texelSize; - float dirtAmount = Dirt_Amount; - vec3 waterEpsilon = vec3(Water_Absorb_R, Water_Absorb_G, Water_Absorb_B); - - vec3 dirtEpsilon = vec3(Dirt_Absorb_R, Dirt_Absorb_G, Dirt_Absorb_B); - vec3 totEpsilon = dirtEpsilon*dirtAmount + waterEpsilon; - vec3 scatterCoef = dirtAmount * vec3(Dirt_Scatter_R, Dirt_Scatter_G, Dirt_Scatter_B) / pi; - vec2 tempOffset=TAA_Offset; - - #ifdef AEROCHROME_MODE - totEpsilon *= 10.0; - scatterCoef *= 0.1; - #endif - - float noise = blueNoise(); - - float z0 = texture2D(depthtex0,texcoord).x; - float z = texture2D(depthtex1,texcoord).x; - - vec3 fragpos = toScreenSpace(vec3(texcoord/RENDER_SCALE-vec2(tempOffset)*texelSize*0.5,z)); - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos; - vec3 np3 = normVec(p3); - p3 += gbufferModelViewInverse[3].xyz; - - float iswaterstuff = texture2D(colortex7,texcoord).a ; - bool iswater = iswaterstuff > 0.99; - vec4 SpecularTex = texture2D(colortex8,texcoord); - - vec4 data = texture2D(colortex1,texcoord); // terraom - vec4 dataUnpacked0 = vec4(decodeVec2(data.x),decodeVec2(data.y)); - vec4 dataUnpacked1 = vec4(decodeVec2(data.z),decodeVec2(data.w)); - vec4 dataUnpacked2 = vec4(decodeVec2(data.z),decodeVec2(data.w)); - vec3 albedo = toLinear(vec3(dataUnpacked0.xz,dataUnpacked1.x)); - - vec4 translucentCol = texture2D(colortex13,texcoord); // translucents - - - vec3 normal = decode(dataUnpacked0.yw); - - vec4 normalAndAO = texture2D(colortex15,texcoord); - float vanilla_AO = normalAndAO.a; - - normalAndAO.a = clamp(pow(normalAndAO.a*5,4),0,1); - vec3 FlatNormals = normalAndAO.rgb * 2.0 - 1.0; - - vec3 geometryNormal = normalize(cross(dFdx(p3), dFdy(p3))); - #ifdef Horrible_slope_normals - vec3 slope_normal = normalize(clamp(normal, geometryNormal*2.0 - 1.0,geometryNormal*2.0 + 1.0)); - #else - vec3 slope_normal = normal; - #endif - - - - vec2 lightmap = dataUnpacked1.yz; - - bool translucent = abs(dataUnpacked1.w-0.5) <0.01; // Strong translucency - bool translucent2 = abs(dataUnpacked1.w-0.6) <0.01; // Weak translucency - bool translucent3 = abs(dataUnpacked1.w-0.55) <0.01; // all blocks - bool translucent4 = abs(dataUnpacked1.w-0.65) <0.01; // Weak translucency - bool entities = abs(dataUnpacked1.w-0.45) <0.01; - - bool hand = abs(dataUnpacked1.w-0.75) < 0.01; - bool blocklights = abs(dataUnpacked1.w-0.8) <0.01; - - vec3 filtered = vec3(1.412,1.0,0.0); - if (!hand) filtered = texture2D(colortex3,texcoord).rgb; - - float Diffuse_final = 1.0; - - vec3 ambientCoefs = slope_normal/dot(abs(slope_normal),vec3(1.)); - - float cloudShadow = 1.0; - - vec3 color = vec3(0.0); - - vec3 skyTEX = skyFromTex(np3,colortex4)/150. ; - - float lightleakfix = clamp(eyeBrightness.y/240.0 + lightmap.y,0.0,1.0); - - if ( z >= 1.) { //sky - vec4 cloud = texture2D_bicubic(colortex0,texcoord*CLOUDS_QUALITY); - - color += stars(np3); - - #ifndef ambientLight_only - // #ifdef Allow_Vanilla_sky - // vec3 SkyTextured = toLinear(texture2D(colortex12,texcoord).rgb); - // color += SkyTextured * (lightCol.a == 1 ? lightCol.rgb : 0.75 + blackbody2(Moon_temp)) * sqrt(luma(SkyTextured)); - // #else - color += drawSun(dot(lightCol.a * WsunVec, np3),0, lightCol.rgb/150.,vec3(0.0)) ; // sun - color += drawSun(dot(lightCol.a * -WsunVec, np3),0, blackbody2(Moon_temp)/500.,vec3(0.0)); // moon - // #endif - #endif - - color *= clamp(normalize(np3-0.02).y*5.0,0.0,1.0); // fade from the approximated base of the cloud plane, so it doesnt peek under it. - - color += skyTEX; - color = color*cloud.a+cloud.rgb; + vec2 tc = floor(gl_FragCoord.xy)/VL_RENDER_RESOLUTION*texelSize+0.5*texelSize; + float z = texture2D(depthtex0,tc).x; - gl_FragData[0].rgb = clamp(fp10Dither(color * 5.0,triangularize(noise)),0.0,65000.); - - }else{//land + if (isEyeInWater == 0){ + vec3 fragpos = toScreenSpace(vec3(tc/RENDER_SCALE,z)); - ////// ----- direct ----- ////// - - vec3 Direct_lighting = vec3(1.0); - vec3 directLightCol = lightCol.rgb; - - float NdotL = dot(slope_normal,WsunVec); - float diffuseSun = clamp((-15 + NdotL*255.0) / 240.0 ,0.0,1.0); - - float shading = clamp(1.0 - filtered.b,0.0,1.0); - if (abs(filtered.y-0.1) < 0.0004 && !iswater) shading = clamp((lightmap.y-0.85)*25,0,1); + vec4 VL_Fog = getVolumetricRays(fragpos,blueNoise(),avgAmbient); - float SSS = 0.0; - float LabSSS = clamp((-65.0 + SpecularTex.z * 255.0) / 190.0 ,0.0,1.0); - float SSS_strength = 0.0; - float scattering = 0.0; + gl_FragData[0] = clamp(VL_Fog,0.0,65000.); + } else { - if (diffuseSun > 0.001) { + float dirtAmount = Dirt_Amount; + vec3 waterEpsilon = vec3(Water_Absorb_R, Water_Absorb_G, Water_Absorb_B); + vec3 dirtEpsilon = vec3(Dirt_Absorb_R, Dirt_Absorb_G, Dirt_Absorb_B); + vec3 totEpsilon = dirtEpsilon*dirtAmount + waterEpsilon; + vec3 scatterCoef = dirtAmount * vec3(Dirt_Scatter_R, Dirt_Scatter_G, Dirt_Scatter_B); - GriAndEminShadowFix(p3, viewToWorld(FlatNormals), normalAndAO.a, lightmap.y, entities); - // p3 += getShadowBias(p3,FlatNormals, diffuseSun, lightmap.y, normalAndAO.a); - - vec3 projectedShadowPosition = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; - projectedShadowPosition = diagonal3(shadowProjection) * projectedShadowPosition + shadowProjection[3].xyz; - - //apply distortion - float distortFactor = calcDistort(projectedShadowPosition.xy); - projectedShadowPosition.xy *= distortFactor; - - //do shadows only if on shadow map - if (abs(projectedShadowPosition.x) < 1.0-1.5/shadowMapResolution && abs(projectedShadowPosition.y) < 1.0-1.5/shadowMapResolution && abs(projectedShadowPosition.z) < 6.0){ - - float diffthresh = 0.0; - if(hand && eyeBrightness.y/240. > 0.0) diffthresh = 0.0003; - - projectedShadowPosition = projectedShadowPosition * vec3(0.5,0.5,0.5/6.0) + vec3(0.5); - shading = 0.0; - - float rdMul = filtered.x*distortFactor*d0*k/shadowMapResolution; - - for(int i = 0; i < SHADOW_FILTER_SAMPLE_COUNT; i++){ - if(hand) noise = 0.0; - vec2 offsetS = tapLocation(i,SHADOW_FILTER_SAMPLE_COUNT,1.618,noise,0.0); - float weight = 1.0+(i+noise)*rdMul/SHADOW_FILTER_SAMPLE_COUNT*shadowMapResolution; - float isShadow = shadow2D(shadow,vec3(projectedShadowPosition + vec3(rdMul*offsetS,-diffthresh*weight))).x; - - shading += isShadow/SHADOW_FILTER_SAMPLE_COUNT; - } - } - } - - #ifdef CAVE_LIGHT_LEAK_FIX - if (isEyeInWater == 0 || (iswater && isEyeInWater == 1) ) shading = mix(0.0, shading, lightleakfix); + #ifdef AEROCHROME_MODE + totEpsilon *= 2.0; + scatterCoef *= 10.0; #endif - #ifdef Sub_surface_scattering - #ifdef Variable_Penumbra_Shadows - - if (translucent) SSS_strength = 3; // strong sss - else if (translucent2) SSS_strength = 5; /// weak sss - else if (translucent3) SSS_strength = 5; // misc sss - else if (translucent4) SSS_strength = 10; // mob sss - else SSS_strength = -1; // anything less than zero is no SSS + vec3 fragpos = toScreenSpace(vec3(tc/RENDER_SCALE,z)); + float noise = R2_dither(); + vec3 vl = vec3(0.0); + float estEyeDepth = clamp((14.0-eyeBrightnessSmooth.y/255.0*16.0)/14.0,0.,1.0); + estEyeDepth *= estEyeDepth*estEyeDepth*34.0; - bool hasSSS = SSS_strength > 0.0 || LabSSS > 0.0 ; - - if(hasSSS) SubsurfaceScattering(SSS, filtered.y, SSS_strength, LabSSS) ; - - if (isEyeInWater == 0) SSS *= lightleakfix; // light leak fix - #endif + estEyeDepth = max(Water_Top_Layer - cameraPosition.y,0.0); - - if (!hand){ - - if (abs(filtered.y-0.1) < 0.0004 && ( !translucent || !translucent2 || !translucent3 || !translucent4 ) ) SSS = 0.0; - - #ifndef SCREENSPACE_CONTACT_SHADOWS - - if (abs(filtered.y-0.1) < 0.0004 && ( translucent || translucent2 || translucent4 ) ) SSS = clamp((lightmap.y-0.87)*25,0,1) * clamp(pow(1+dot(WsunVec,normal),25),0,1); - - #else - vec3 vec = lightCol.a*sunVec; - float screenShadow = rayTraceShadow(vec, fragpos, interleaved_gradientNoise()); - - #ifdef Variable_Penumbra_Shadows - shading = min(screenShadow, shading); - if (abs(filtered.y-0.1) < 0.0004 && ( translucent || translucent2 ) ) SSS = shading; - // #else - - #endif - - - #endif - } - - #ifdef Variable_Penumbra_Shadows - SSS = clamp(SSS, diffuseSun*shading, 1.0); - SSS = (phaseg(clamp(dot(np3, WsunVec),0.0,1.0), 0.5) * 10.0 + 1.0 ) * SSS ; - #endif - #else - SSS = 0.0; - #endif - - - #ifdef VOLUMETRIC_CLOUDS - #ifdef CLOUDS_SHADOWS - cloudShadow = GetCloudShadow(p3); - shading *= cloudShadow; - SSS *= cloudShadow; - #endif - #endif - - Diffuse_final = diffuseSun * shading ; - - ////// ----- indirect ----- ////// - - vec3 Indirect_lighting = vec3(1.0); - - // vec3 ambientLight = vec3(0.0); - vec3 ambientLight = avgAmbient * 2.0; - vec3 custom_lightmap = texture2D(colortex4, (vec2(lightmap.x, pow(lightmap.y,2))*15.0+0.5+vec2(0.0,19.))*texelSize).rgb*8./150./3.; // y = torch - - custom_lightmap.x = max(custom_lightmap.x, Diffuse_final * 8./150./3. ); // make it so that sunlight color is the same even where ambient light is dark - - // apply ambient light to the sky lightmap and do adjustments - ambientLight = ambientLight * custom_lightmap.x + custom_lightmap.z; - if( (isEyeInWater == 1 && !iswater) ) ambientLight = avgAmbient * 8./150./3.; - ambientLight *= ambient_brightness; - - // add torch lightmap to ambientlight and do adjustments - vec3 Lightsources = custom_lightmap.y * vec3(TORCH_R,TORCH_G,TORCH_B); - if(hand) Lightsources *= 0.15; - - // if(blocklights) Lightsources *= 0.3; - - if(custom_lightmap.y > 10.0) Lightsources *= 0.3; - // Lightsources *= 0.0; - - - ambientLight += Lightsources; - - // debug for direct or ambient - #ifdef ambientLight_only - directLightCol = vec3(0); - #endif - #ifdef ambientLight_only - Indirect_lighting = vec3(0); - #endif - - - - #if indirect_effect == 0 - ambientLight *= 1.0 - exp2(-5 * pow(1-vanilla_AO,3)) ; - float skylight = clamp(abs(ambientCoefs.y+1),0.35,2.0) ; - ambientLight *= skylight; - #endif - #if indirect_effect == 1 - // ambientLight *= mix(1.0 - exp2(-5 * pow(1-vanilla_AO,2)), 1.0, diffuseSun*shading) ; - if (!hand) ssAO(ambientLight, fragpos, 1.0, blueNoise(gl_FragCoord.xy).rg, FlatNormals , texcoord, ambientCoefs, lightmap.xy, diffuseSun*shading ) ; - #endif - #if indirect_effect == 2 - if (!hand) rtAO(ambientLight, slope_normal, blueNoise(gl_FragCoord.xy).rg, fragpos, lightmap.y, diffuseSun*shading); - #endif - #if indirect_effect == 3 - if (!hand) rtGI(ambientLight, slope_normal, blueNoise(gl_FragCoord.xy).rg, fragpos, lightmap.y, (directLightCol/127.0), diffuseSun*shading); - #endif - #if indirect_effect == 4 - if (!hand) ssDO(ambientLight, fragpos, 1.0, blueNoise(gl_FragCoord.xy).rg, FlatNormals, worldToView(slope_normal) , texcoord, ambientCoefs, lightmap.xy, diffuseSun*shading ) ; - #endif - - - vec3 waterabsorb_speculars = vec3(1); - - if ((iswater && isEyeInWater == 0) || (!iswater && isEyeInWater == 1) || iswaterstuff == 1.0){ - - vec3 fragpos0 = toScreenSpace(vec3(texcoord/RENDER_SCALE-vec2(tempOffset)*texelSize*0.5,z0)); - float Vdiff = distance(fragpos,fragpos0); - float VdotU = np3.y; - float estimatedDepth = Vdiff * abs(VdotU); //assuming water plane - float estimatedDepth2 = Vdiff * abs(VdotU); //assuming water plane - if (isEyeInWater == 1){ - Vdiff = length(fragpos); - estimatedDepth = clamp((15.5-lightmap.y*16.0)/15.5,0.,1.0); - estimatedDepth *= estimatedDepth*estimatedDepth*32.0; - - #ifndef lightMapDepthEstimation - estimatedDepth = max(Water_Top_Layer - (cameraPosition.y+p3.y),0.0); - #endif - - estimatedDepth2 = clamp((15.5-lightmap.y*16.0)/15.5,0.,1.0); - estimatedDepth2 *= estimatedDepth2*estimatedDepth2*32.0; - } - - float estimatedSunDepth = estimatedDepth/abs(WsunVec.y); //assuming water plane - vec3 thething = exp2(-totEpsilon*estimatedSunDepth); - - float estimatedSunDepth2 = estimatedDepth2/abs(WsunVec.y); //assuming water plane - vec3 thething2 = max(exp2(-totEpsilon*estimatedSunDepth2),0.01); - // water absorbtion for the sunlight. when this isnt active, the water fog is - if (isEyeInWater == 1) directLightCol *= thething*(0.91-pow(1.0-WsunVec.y,5.0)*0.86); - - // allow the sun specular reflection to have water absorbtion when looking at it from outside the water - // waterabsorb_speculars.rgb = (iswater && isEyeInWater == 0) ? waterabsorb_speculars.rgb * thething*(0.91-pow(1.0-WsunVec.y,5.0)*0.86) : waterabsorb_speculars.rgb; - waterabsorb_speculars.rgb = waterabsorb_speculars.rgb*thething; - // caustics... - float Direct_caustics = waterCaustics(mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition, WsunVec); - float Ambient_Caustics = waterCaustics(mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition, vec3(0.5, 1.0, 0.5)); - - // apply caustics to the sunlight - directLightCol *= 0.5 + max(pow(Direct_caustics*2,2),0.0); - - - // interpolate between normal ambient light to a different ambient light with caustics and water absorbtion - Ambient_Caustics = 0.5 + max(pow(Ambient_Caustics,2),0.0); - // vec3 underwater_ambient = max(Ambient_Caustics ,0.0) ; - - - // if( (isEyeInWater == 1 && iswater) || (isEyeInWater == 1 && !iswater) ) Indirect_lighting *= 8./150./3.*0.5; - if( isEyeInWater == 1 && !iswater ) Indirect_lighting = Indirect_lighting*thething + Indirect_lighting*Ambient_Caustics*thething2 + Lightsources ; - - - //combine all light sources - // Direct_lighting = max(Diffuse_final ,SSS) * (directLightCol/127.0); - // gl_FragData[0].rgb = (Indirect_lighting + Direct_lighting) * albedo; - - } - #ifdef Seasons - #ifdef Snowy_Winter - float SnowPatches = densityAtPosSNOW(vec3(p3.x,p3.y/48.,p3.z)*250); - SnowPatches = 1.0 - clamp( exp(pow(SnowPatches,3.5) * -100.0) ,0,1); - SnowPatches *= clamp(sqrt(normal.y),0,1) * clamp(pow(lightmap.y,25)*25,0,1); - - if(!hand && !iswater){ - albedo = mix(albedo, vec3(0.8,0.9,1.0), SnowPatches); - SpecularTex.rg = mix(SpecularTex.rg, vec2(1,0.05), SnowPatches); - } - #endif - #endif - // do this after water and stuff is done because yea - - Indirect_lighting = ambientLight; - //combine all light sources - Direct_lighting = (Diffuse_final + SSS) * (directLightCol/127.0) ; - // Direct_lighting = max(Diffuse_final ,SSS) * (directLightCol/127.0) ; - gl_FragData[0].rgb = (Indirect_lighting + Direct_lighting) * albedo; - - #ifdef Specular_Reflections - vec3 fragpos_spec = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize/RENDER_SCALE,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); - vec3 p3_spec = mat3(gbufferModelViewInverse) * fragpos_spec; - vec3 np3_spec = normVec(p3_spec); - - MaterialReflections(texcoord, gl_FragData[0].rgb, SpecularTex.r, SpecularTex.ggg, albedo, WsunVec, lightCol.rgb * waterabsorb_speculars, Diffuse_final , lightmap.y, slope_normal, np3, fragpos, vec3(blueNoise(gl_FragCoord.xy).rg, interleaved_gradientNoise()), hand); - #endif - - #ifdef LabPBR_Emissives - gl_FragData[0].rgb = SpecularTex.a < 255.0/255.0 ? mix(gl_FragData[0].rgb, albedo * Emissive_Brightness , SpecularTex.a) + Direct_lighting*albedo : gl_FragData[0].rgb; - #endif + waterVolumetrics(vl, vec3(0.0), fragpos, estEyeDepth, estEyeDepth, length(fragpos), noise, totEpsilon, scatterCoef, (ambientUp*8./150./3.*0.5) , lightCol.rgb*8./150./3.0*(1.0-pow(1.0-sunElevation*lightCol.a,5.0)), dot(normalize(fragpos), normalize(sunVec) )); + gl_FragData[0] = clamp(vec4(vl,1.0),0.000001,65000.); } - - - #ifdef Glass_Tint - // glass tint. - vec4 glassColor = texture2D(colortex13,texcoord); - - #ifdef BorderFog - float fog = 1.0 - clamp( exp2(-pow(length(fragpos / far),10.)*4.0) ,0.0,1.0); - if(z < 1.0 && isEyeInWater == 0 && glassColor.a > 0.0) gl_FragData[0].rgb = mix(gl_FragData[0].rgb, skyTEX * 5.0, fog*lightleakfix ) ; - #endif - - float colorstrength = 0.75; - glassColor.rgb *= 5.; - if(glassColor.a > 0.0 && !iswater && (iswaterstuff < 0.1 && iswaterstuff > 0.0 )) gl_FragData[0].rgb = gl_FragData[0].rgb*glassColor.rgb + gl_FragData[0].rgb * clamp(pow(1.0-luma(glassColor.rgb),5.),0,1); - #endif - - - if (iswater){ - vec3 fragpos0 = toScreenSpace(vec3(texcoord/RENDER_SCALE-vec2(tempOffset)*texelSize*0.5,z0)); - float Vdiff = distance(fragpos,fragpos0); - float VdotU = np3.y; - float estimatedDepth = Vdiff * abs(VdotU); //assuming water plane - float estimatedSunDepth = estimatedDepth/abs(WsunVec.y); //assuming water plane - - float custom_lightmap_T = texture2D(colortex14, texcoord).x; // y = torch - - vec3 ambientColVol = avgAmbient * 8./150./1.5 * max(custom_lightmap_T,0.0025); - vec3 lightColVol = lightCol.rgb * 8./127. * max(lightleakfix,0.0); - - if (isEyeInWater == 0) waterVolumetrics(gl_FragData[0].rgb, fragpos0, fragpos, estimatedDepth, estimatedSunDepth, Vdiff, noise, totEpsilon, scatterCoef, ambientColVol, lightColVol, dot(np3, WsunVec)); - } - - /* RENDERTARGETS:3 */ -} \ No newline at end of file +} diff --git a/shaders/composite2.vsh b/shaders/composite2.vsh index f59ec90..6c1b5d7 100644 --- a/shaders/composite2.vsh +++ b/shaders/composite2.vsh @@ -1,32 +1,51 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable + #include "lib/settings.glsl" -flat varying vec3 WsunVec; -flat varying vec3 avgAmbient; +flat varying vec4 lightCol; flat varying vec3 ambientUp; flat varying vec3 ambientLeft; flat varying vec3 ambientRight; flat varying vec3 ambientB; flat varying vec3 ambientF; flat varying vec3 ambientDown; -flat varying vec4 lightCol; -flat varying float tempOffsets; + + +flat varying vec3 sunColor; +flat varying vec3 moonColor; +flat varying vec3 avgAmbient; + flat varying vec2 TAA_Offset; -flat varying vec3 zMults; -attribute vec4 mc_Entity; +flat varying float tempOffsets; + +flat varying float fogAmount; +flat varying float VFAmount; +flat varying float FogSchedule; + + +flat varying vec3 WsunVec; +flat varying vec3 refractedSunVec; + uniform sampler2D colortex4; -varying vec4 lmtexcoord; -// varying float vanilla_ao; - -uniform float far; -uniform float near; -uniform mat4 gbufferModelViewInverse; uniform vec3 sunPosition; uniform float sunElevation; +uniform float rainStrength; +uniform int isEyeInWater; uniform int frameCounter; +// uniform int worldTime; +uniform mat4 gbufferModelViewInverse; + +#include "/lib/util.glsl" +#include "/lib/res_params.glsl" +// #include "lib/biome_specifics.glsl" + + +float luma(vec3 color) { + return dot(color,vec3(0.21, 0.72, 0.07)); +} const vec2[8] offsets = vec2[8](vec2(1./8.,-3./8.), vec2(-1.,3.)/8., vec2(5.0,1.)/8., @@ -35,24 +54,27 @@ const vec2[8] offsets = vec2[8](vec2(1./8.,-3./8.), vec2(-7.,-1.)/8., vec2(3,7.)/8., vec2(7.,-7.)/8.); +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// - -#include "/lib/util.glsl" -#include "/lib/res_params.glsl" void main() { + tempOffsets = HaltonSeq2(frameCounter%10000); gl_Position = ftransform(); - + gl_Position.xy = (gl_Position.xy*0.5+0.5)*(0.01+VL_RENDER_RESOLUTION)*2.0-1.0; #ifdef TAA_UPSCALING gl_Position.xy = (gl_Position.xy*0.5+0.5)*RENDER_SCALE*2.0-1.0; #endif - - tempOffsets = HaltonSeq2(frameCounter%10000); - TAA_Offset = offsets[frameCounter%8]; - #ifndef TAA - TAA_Offset = vec2(0.0); - #endif - vec3 sc = texelFetch2D(colortex4,ivec2(6,37),0).rgb; + + sunColor = texelFetch2D(colortex4,ivec2(12,37),0).rgb; + moonColor = texelFetch2D(colortex4,ivec2(13,37),0).rgb; + avgAmbient = texelFetch2D(colortex4,ivec2(1,37),0).rgb; + // avgAmbient = texelFetch2D(colortex4,ivec2(11,37),0).rgb; + + // ambientUp = texelFetch2D(colortex4,ivec2(0,37),0).rgb; // ambientDown = texelFetch2D(colortex4,ivec2(1,37),0).rgb; // ambientLeft = texelFetch2D(colortex4,ivec2(2,37),0).rgb; @@ -60,16 +82,32 @@ void main() { // ambientB = texelFetch2D(colortex4,ivec2(4,37),0).rgb; // ambientF = texelFetch2D(colortex4,ivec2(5,37),0).rgb; - avgAmbient = texelFetch2D(colortex4,ivec2(0,37),0).rgb; - - lightCol.a = float(sunElevation > 1e-5)*2-1.; lightCol.rgb = sc; + TAA_Offset = offsets[frameCounter%8]; + #ifndef TAA + TAA_Offset = vec2(0.0); + #endif + + #ifndef VL_Clouds_Shadows + lightCol.rgb *= (1.0-rainStrength*0.9); + #endif + // float Time = worldTime%24000; + + // FogSchedule = clamp( (Time - 9000)/9000 ,0,1); + // // float fogAmount0 = 1/3000.+FOG_TOD_MULTIPLIER*(1/100.*(clamp(modWT-11000.,0.,2000.0)/2000.+(1.0-clamp(modWT,0.,3000.0)/3000.))*(clamp(modWT-11000.,0.,2000.0)/2000.+(1.0-clamp(modWT,0.,3000.0)/3000.)) + 1/120.*clamp(modWT-13000.,0.,1000.0)/1000.*(1.0-clamp(modWT-23000.,0.,1000.0)/1000.)); + + // float fogAmount0 = TimeOfDayFog; + + // // VFAmount = CLOUDY_FOG_AMOUNT*(fogAmount0*fogAmount0+FOG_RAIN_MULTIPLIER*1.0/20000.*rainStrength); + // VFAmount = fogAmount0; + // fogAmount = BASE_FOG_AMOUNT*(fogAmount0+max(FOG_RAIN_MULTIPLIER*1/10.*rainStrength , FOG_TOD_MULTIPLIER*1/50.*clamp(modWT-13000.,0.,1000.0)/1000.*(1.0-clamp(modWT-23000.,0.,1000.0)/1000.))); + + + + WsunVec = lightCol.a*normalize(mat3(gbufferModelViewInverse) *sunPosition); - zMults = vec3((far * near)*2.0,far+near,far-near); - - - + refractedSunVec = refract(WsunVec, -vec3(0.0,1.0,0.0), 1.0/1.33333); } diff --git a/shaders/composite3.fsh b/shaders/composite3.fsh index d8d05ab..c7be7d4 100644 --- a/shaders/composite3.fsh +++ b/shaders/composite3.fsh @@ -1,80 +1,305 @@ #version 120 -//Render sky, volumetric clouds, direct lighting +//Horizontal bilateral blur for volumetric fog + Forward rendered objects + Draw volumetric fog #extension GL_EXT_gpu_shader4 : enable #include "lib/settings.glsl" -uniform vec2 texelSize; +flat varying vec3 zMults; +flat varying vec2 TAA_Offset; + + + +uniform sampler2D noisetex; uniform sampler2D depthtex0; uniform sampler2D depthtex1; +uniform sampler2D colortex0; +uniform sampler2D colortex1; +uniform sampler2D colortex2; uniform sampler2D colortex3; +// uniform sampler2D colortex4; +uniform sampler2D colortex5; +uniform sampler2D colortex6; +uniform sampler2D colortex7; +uniform sampler2D colortex8; +uniform sampler2D colortex9; +uniform sampler2D colortex11; uniform sampler2D colortex13; -uniform sampler2D colortex4; +uniform sampler2D colortex15; +uniform vec2 texelSize; -uniform int frameCounter; +flat varying vec3 noooormal; +flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) +flat varying vec3 WsunVec; + +uniform vec3 sunVec; uniform float frameTimeCounter; - -uniform vec3 cameraPosition; - -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferModelViewInverse; -flat varying vec2 TAA_Offset; -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) - -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) - +uniform int frameCounter; uniform float far; uniform float near; +uniform mat4 gbufferModelViewInverse; +uniform mat4 gbufferModelView; +uniform mat4 gbufferPreviousModelView; +uniform mat4 gbufferProjectionInverse; +uniform mat4 gbufferProjection; +uniform mat4 gbufferPreviousProjection; +uniform vec3 cameraPosition; +uniform vec3 previousCameraPosition; +uniform int isEyeInWater; +uniform ivec2 eyeBrightnessSmooth; +uniform float rainStrength; +uniform float blindness; +uniform float darknessFactor; +uniform float darknessLightFactor; + +#include "lib/waterBump.glsl" +#include "/lib/res_params.glsl" + +#include "lib/sky_gradient.glsl" +#include "lib/volumetricClouds.glsl" +// #include "lib/biome_specifics.glsl" + + + +#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) +#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) + +float ld(float depth) { + return 1.0 / (zMults.y - depth * zMults.z); // (-depth * (far - near)) = (2.0 * near)/ld - far - near +} +float luma(vec3 color) { + return dot(color,vec3(0.21, 0.72, 0.07)); +} +vec3 toLinear(vec3 sRGB){ + return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); +} 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; } + + +// #include "lib/specular.glsl" + + + + +vec4 BilateralUpscale(sampler2D tex, sampler2D depth,vec2 coord,float frDepth, vec2 distort){ + coord = coord; + vec4 vl = vec4(0.0); + float sum = 0.0; + mat3x3 weights; + const ivec2 scaling = ivec2(1.0/VL_RENDER_RESOLUTION); + ivec2 posD = ivec2(coord*VL_RENDER_RESOLUTION + distort)*scaling; + ivec2 posVl = ivec2(coord*VL_RENDER_RESOLUTION + distort); + float dz = zMults.x; + ivec2 pos = (ivec2(gl_FragCoord.xy+frameCounter) % 2 )*2; + + ivec2 tcDepth = posD + ivec2(-2,-2) * scaling + pos * scaling; + float dsample = ld(texelFetch2D(depth,tcDepth,0).r); + float w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; + vl += texelFetch2D(tex,posVl+ivec2(-2)+pos,0)*w; + sum += w; + + tcDepth = posD + ivec2(-2,0) * scaling + pos * scaling; + dsample = ld(texelFetch2D(depth,tcDepth,0).r); + w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; + vl += texelFetch2D(tex,posVl+ivec2(-2,0)+pos,0)*w; + sum += w; + + tcDepth = posD + ivec2(0) + pos * scaling; + dsample = ld(texelFetch2D(depth,tcDepth,0).r); + w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; + vl += texelFetch2D(tex,posVl+ivec2(0)+pos,0)*w; + sum += w; + + tcDepth = posD + ivec2(0,-2) * scaling + pos * scaling; + dsample = ld(texelFetch2D(depth,tcDepth,0).r); + w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; + vl += texelFetch2D(tex,posVl+ivec2(0,-2)+pos,0)*w; + sum += w; + + return vl/sum; +} + +vec3 decode (vec2 encn){ + vec3 n = vec3(0.0); + encn = encn * 2.0 - 1.0; + n.xy = abs(encn); + n.z = 1.0 - n.x - n.y; + n.xy = n.z <= 0.0 ? (1.0 - n.yx) * sign(encn) : encn; + return clamp(normalize(n.xyz),-1.0,1.0); +} + +vec2 decodeVec2(float a){ + const vec2 constant1 = 65535. / vec2( 256., 65536.); + const float constant2 = 256. / 255.; + return fract( a * constant1 ) * constant2 ; +} + +vec3 worldToView(vec3 worldPos) { + vec4 pos = vec4(worldPos, 0.0); + pos = gbufferModelView * pos; + return pos.xyz; +} +float blueNoise(){ + return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); +} +vec4 blueNoise(vec2 coord){ + return texelFetch2D(colortex6, ivec2(coord )%512 , 0); +} vec3 normVec (vec3 vec){ return vec*inversesqrt(dot(vec,vec)); } -uniform int isEyeInWater; -uniform ivec2 eyeBrightnessSmooth; -uniform float blindness; -uniform float darknessFactor; - -#include "lib/sky_gradient.glsl" +float interleaved_gradientNoise(){ + vec2 coord = gl_FragCoord.xy; + float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)); + return noise; +} +vec3 viewToWorld(vec3 viewPosition) { + vec4 pos; + pos.xyz = viewPosition; + pos.w = 0.0; + pos = gbufferModelViewInverse * pos; + return pos.xyz; +} void main() { - /* DRAWBUFFERS:3 */ + vec2 texcoord = gl_FragCoord.xy*texelSize; + /* DRAWBUFFERS:73 */ - vec2 texcoord = gl_FragCoord.xy*texelSize; - gl_FragData[0].rgb = texture2D(colortex3, texcoord).rgb; + vec4 trpData = texture2D(colortex7,texcoord); - ///////////////// border fog + bool iswater = trpData.a > 0.99; + float translucentAlpha = trpData.a; + + // vec4 speculartex = texture2D(colortex8,texcoord); // translucents + // float sunlight = speculartex.b; + + //3x3 bilateral upscale from half resolution + float z = texture2D(depthtex0,texcoord).x; + float z2 = texture2D(depthtex1,texcoord).x; + float frDepth = ld(z2); + + // vec4 vl = texture2D(colortex0,texcoord * 0.5); + + + vec4 data = texture2D(colortex11,texcoord); // translucents + vec4 dataUnpacked0 = vec4(decodeVec2(data.x),decodeVec2(data.y)); + vec4 dataUnpacked1 = vec4(decodeVec2(data.z),decodeVec2(data.w)); + + vec3 normals = mat3(gbufferModelViewInverse) * worldToView(decode(dataUnpacked0.yw) ); + + vec4 data_terrain = texture2D(colortex1,texcoord); // terraom + vec4 dataUnpacked1_terrain = vec4(decodeVec2(data_terrain.z),decodeVec2(data_terrain.w)); + + bool hand = (abs(dataUnpacked1_terrain.w-0.75) < 0.01); + + float lightleakfix = clamp((eyeBrightnessSmooth.y )/240.0,0.0,1.0); + + + float rainDrops = clamp(texture2D(colortex9,texcoord).a, 0.0,1.0); // bloomy rain effect + + + vec4 Translucent_Programs = texture2D(colortex2,texcoord); // the shader for all translucent progams. -#ifdef BorderFog vec2 tempOffset = TAA_Offset; - float z = texture2D(depthtex0,texcoord).x; - - vec3 fragpos = toScreenSpace(vec3(texcoord -vec2(tempOffset)*texelSize*0.5,z)); + vec3 fragpos = toScreenSpace(vec3(texcoord/RENDER_SCALE-vec2(tempOffset)*texelSize*0.5,z)); + vec3 fragpos2 = toScreenSpace(vec3(texcoord/RENDER_SCALE-vec2(tempOffset)*texelSize*0.5,z2)); vec3 p3 = mat3(gbufferModelViewInverse) * fragpos; vec3 np3 = normVec(p3); - vec3 worldpos = p3 + (gbufferModelViewInverse[3].xyz+cameraPosition) ; + + vec2 refractedCoord = texcoord; + float glassdepth = clamp((ld(z2) - ld(z)) * 0.5,0.0,0.15); + + #ifdef Refraction + refractedCoord += (normals.xy * glassdepth) * RENDER_SCALE; + + float refractedalpha = texture2D(colortex13,refractedCoord).a; + if(refractedalpha <= 0.0) refractedCoord = texcoord; // remove refracted coords on solids + #endif + + // underwater squiggles + // if(isEyeInWater == 1 && !iswater) refractedCoord = texcoord + pow(texture2D(noisetex,texcoord - vec2(0,frameTimeCounter/25)).b - 0.5, 2.0)*0.05; - vec3 sky = skyFromTex(np3,colortex4) / 150. * 5.; + vec3 color = texture2D(colortex3,refractedCoord).rgb; - float fog = 1.0 - clamp( exp(-pow(length(fragpos / far),10.)*4.0) ,0.0,1.0); - + #ifdef BorderFog + vec3 sky = skyFromTex(np3,colortex4) / 150. * 5.0; + float fog = 1.0 - clamp(exp(-pow(length(fragpos / far),10.)*4.0) ,0.0,1.0); + float heightFalloff = clamp( pow(abs(np3.y-1.01),5) ,0,1) ; - float lightleakfix = clamp(eyeBrightnessSmooth.y/240.0,0.0,1.0); - float heightFalloff = clamp( pow(abs(np3.y-1.01),10) ,0,1) ; - // if(z < 1.0 && isEyeInWater == 0) + if(z < 1.0 && isEyeInWater == 0) color.rgb = mix(color.rgb, sky, fog*heightFalloff* lightleakfix); + #endif - if(z < 1.0 && isEyeInWater == 0) gl_FragData[0].rgb = mix(gl_FragData[0].rgb, sky, fog*lightleakfix*heightFalloff ) ; + vec4 vl = BilateralUpscale(colortex0,depthtex1,gl_FragCoord.xy,frDepth, vec2(0.0)); + + if (Translucent_Programs.a > 0.0){ + #ifdef Glass_Tint + vec3 GlassAlbedo = texture2D(colortex13,texcoord).rgb * 5.0; + color = color*GlassAlbedo.rgb + color * clamp(pow(1.0-luma(GlassAlbedo.rgb),10.),0.0,1.0); + #endif + + color = color*(1.0-Translucent_Programs.a) + Translucent_Programs.rgb; + + #ifdef BorderFog + if(z < 1.0 && isEyeInWater == 0) color.rgb = mix(color.rgb, sky, fog * heightFalloff * lightleakfix); + #endif + } -#endif + //cave fog + #ifdef Cave_fog + if (isEyeInWater == 0){ + float fogdistfade = 1.0 - clamp( exp(-pow(length(fragpos / far),2.)*5.0) ,0.0,1.0); + float fogfade = clamp( exp(clamp( np3.y*0.5 +0.5,0,1) * -6.0) ,0.0,1.0); + + color.rgb = mix(color.rgb, vec3(CaveFogColor_R,CaveFogColor_G,CaveFogColor_B)*fogfade, fogdistfade * (1.0-lightleakfix) * (1.0-darknessFactor)* clamp( 1.5 - np3.y,0.,1)) ; + } + #endif + + // underwater fog + if (isEyeInWater == 1){ + float fogfade = clamp(exp(-length(fragpos) /5. ) ,0.0,1.0); + color.rgb *= fogfade; + vl.a *= fogfade*0.70+0.3 ; + } + + + color *= vl.a; + color += vl.rgb; + + if(rainDrops > 0.0) vl.a *= clamp(exp2(-rainDrops*5),0.,1.); // bloomy rain effect + gl_FragData[0].r = vl.a; + + /// lava. + if (isEyeInWater == 2){ + color.rgb = vec3(4.0,0.5,0.1); + } + + /// powdered snow + if (isEyeInWater == 3){ + color.rgb = mix(color.rgb,vec3(10,15,20),clamp(length(fragpos)*0.5,0.,1.)); + vl.a = 0.0; + } + + // blidnesss + color.rgb *= mix(1.0,clamp( exp(pow(length(fragpos)*(blindness*0.2),2) * -5),0.,1.) , blindness); + + // darkness effect + color.rgb *= mix(1.0, (1.0-darknessLightFactor*2.0) * clamp(1.0-pow(length(fragpos2)*(darknessFactor*0.07),2.0),0.0,1.0), darknessFactor); + + #ifdef display_LUT + vec2 movedTC = texcoord ; + if(texcoord.x < 0.45 ) color.rgb = texture2D(colortex4,movedTC).rgb / 150. * 5.0; + #endif + + gl_FragData[1].rgb = clamp(color.rgb,0.0,68000.0); } \ No newline at end of file diff --git a/shaders/composite3.vsh b/shaders/composite3.vsh index a047572..bd893f8 100644 --- a/shaders/composite3.vsh +++ b/shaders/composite3.vsh @@ -2,13 +2,20 @@ #extension GL_EXT_gpu_shader4 : enable #include "lib/settings.glsl" -flat varying float tempOffsets; +flat varying vec4 lightCol; +flat varying vec3 WsunVec; + +uniform mat4 gbufferModelViewInverse; uniform int frameCounter; +uniform vec3 sunPosition; +uniform float sunElevation; + flat varying vec2 TAA_Offset; - -#include "/lib/util.glsl" +uniform sampler2D colortex4; +flat varying vec3 zMults; +uniform float far; +uniform float near; #include "/lib/res_params.glsl" - const vec2[8] offsets = vec2[8](vec2(1./8.,-3./8.), vec2(-1.,3.)/8., vec2(5.0,1.)/8., @@ -18,13 +25,30 @@ const vec2[8] offsets = vec2[8](vec2(1./8.,-3./8.), vec2(3,7.)/8., vec2(7.,-7.)/8.); -void main() { - gl_Position = ftransform(); - + +flat varying vec3 noooormal; +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// - TAA_Offset = offsets[frameCounter%8]; +void main() { + zMults = vec3(1.0/(far * near),far+near,far-near); + gl_Position = ftransform(); #ifdef TAA_UPSCALING gl_Position.xy = (gl_Position.xy*0.5+0.5)*RENDER_SCALE*2.0-1.0; #endif + TAA_Offset = offsets[frameCounter%8]; + #ifndef TAA + TAA_Offset = vec2(0.0); + #endif + vec3 sc = texelFetch2D(colortex4,ivec2(6,37),0).rgb; + lightCol.a = float(sunElevation > 1e-5)*2-1.; + lightCol.rgb = sc; + + WsunVec = lightCol.a*normalize(mat3(gbufferModelViewInverse) *sunPosition); + + vec3 noooormal = normalize(gl_NormalMatrix * gl_Normal); } diff --git a/shaders/composite4.fsh b/shaders/composite4.fsh new file mode 100644 index 0000000..b9d938b --- /dev/null +++ b/shaders/composite4.fsh @@ -0,0 +1,46 @@ +#version 120 +#extension GL_EXT_gpu_shader4 : enable + +#include "lib/settings.glsl" +uniform sampler2D colortex3; +// Compute 3x3 min max for TAA + +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// + +void main() { +/* DRAWBUFFERS:06 */ + ivec2 center = ivec2(gl_FragCoord.xy); + vec3 current = texelFetch2D(colortex3, center, 0).rgb; + vec3 cMin = current; + vec3 cMax = current; + current = texelFetch2D(colortex3, center + ivec2(-1, -1), 0).rgb; + cMin = min(cMin, current); + cMax = max(cMax, current); + current = texelFetch2D(colortex3, center + ivec2(-1, 0), 0).rgb; + cMin = min(cMin, current); + cMax = max(cMax, current); + current = texelFetch2D(colortex3, center + ivec2(-1, 1), 0).rgb; + cMin = min(cMin, current); + cMax = max(cMax, current); + current = texelFetch2D(colortex3, center + ivec2(0, -1), 0).rgb; + cMin = min(cMin, current); + cMax = max(cMax, current); + current = texelFetch2D(colortex3, center + ivec2(0, 1), 0).rgb; + cMin = min(cMin, current); + cMax = max(cMax, current); + current = texelFetch2D(colortex3, center + ivec2(1, -1), 0).rgb; + cMin = min(cMin, current); + cMax = max(cMax, current); + current = texelFetch2D(colortex3, center + ivec2(1, 0), 0).rgb; + cMin = min(cMin, current); + cMax = max(cMax, current); + current = texelFetch2D(colortex3, center + ivec2(1, 1), 0).rgb; + cMin = min(cMin, current); + cMax = max(cMax, current); + gl_FragData[0].rgb = cMax; + gl_FragData[1].rgb = cMin; +} diff --git a/shaders/world1/texture/composite4.vsh b/shaders/composite4.vsh similarity index 72% rename from shaders/world1/texture/composite4.vsh rename to shaders/composite4.vsh index e6e3e92..09df2ce 100644 --- a/shaders/world1/texture/composite4.vsh +++ b/shaders/composite4.vsh @@ -1,10 +1,9 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable -varying vec2 texcoord; -flat varying vec3 zMults; -uniform float far; -uniform float near; +#include "lib/settings.glsl" + +#include "/lib/res_params.glsl" //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -12,8 +11,8 @@ uniform float near; //////////////////////////////VOID MAIN////////////////////////////// void main() { - zMults = vec3((far * near)*2.0,far+near,far-near); gl_Position = ftransform(); - texcoord = gl_MultiTexCoord0.xy; - + #ifdef TAA_UPSCALING + gl_Position.xy = (gl_Position.xy*0.5+0.5)*RENDER_SCALE*2.0-1.0; + #endif } diff --git a/shaders/composite5.fsh b/shaders/composite5.fsh index add8ab3..4fc6450 100644 --- a/shaders/composite5.fsh +++ b/shaders/composite5.fsh @@ -1,388 +1,518 @@ #version 120 -//Volumetric fog rendering +//Temporal Anti-Aliasing + Dynamic exposure calculations (vertex shader) + #extension GL_EXT_gpu_shader4 : enable #include "lib/settings.glsl" +#include "lib/res_params.glsl" -flat varying vec4 lightCol; -flat varying vec3 ambientUp; -flat varying vec3 ambientLeft; -flat varying vec3 ambientRight; -flat varying vec3 ambientB; -flat varying vec3 ambientF; -flat varying vec3 ambientDown; -flat varying vec3 avgAmbient; + +//TAA OPTIONS + +const int noiseTextureResolution = 32; + + +/* +const int colortex0Format = RGBA16F; // low res clouds (deferred->composite2) + low res VL (composite5->composite15) +const int colortex1Format = RGBA16; //terrain gbuffer (gbuffer->composite2) +const int colortex2Format = RGBA16F; //forward + transparencies (gbuffer->composite4) +const int colortex3Format = R11F_G11F_B10F; //frame buffer + bloom (deferred6->final) +const int colortex4Format = RGBA16F; //light values and skyboxes (everything) + + +const int colortex6Format = R11F_G11F_B10F; //additionnal buffer for bloom (composite3->final) +const int colortex7Format = RGBA8; //Final output, transparencies id (gbuffer->composite4) +const int colortex8Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) +const int colortex9Format = RGBA8; //Final output, transparencies id (gbuffer->composite4) +const int colortex10Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) + +const int colortex13Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) +// const int colortex15Format = RGBA16F; // flat normals and vanilla +*/ +//no need to clear the buffers, saves a few fps +/* +const bool colortex0Clear = false; +const bool colortex1Clear = false; +const bool colortex2Clear = true; +const bool colortex3Clear = false; +const bool colortex4Clear = false; +const bool colortex5Clear = false; +const bool colortex6Clear = false; +const bool colortex7Clear = false; +*/ + + + +#ifdef SCREENSHOT_MODE + /* + const int colortex5Format = RGBA32F; //TAA buffer (everything) + */ +#else + /* + const int colortex5Format = R11F_G11F_B10F; //TAA buffer (everything) + */ +#endif + +varying vec2 texcoord; +flat varying float exposureA; flat varying float tempOffsets; -flat varying float fogAmount; -flat varying float VFAmount; -flat varying float FogSchedule; -uniform sampler2D noisetex; + +uniform sampler2D colortex0; +uniform sampler2D colortex1; +uniform sampler2D colortex3; +uniform sampler2D colortex5; +uniform sampler2D colortex6; +// uniform sampler2D colortex10; +uniform sampler2D colortex13; + uniform sampler2D depthtex0; uniform sampler2D depthtex1; -uniform sampler2DShadow shadow; -flat varying vec3 refractedSunVec; -flat varying vec3 WsunVec; -uniform sampler2D colortex1; -uniform sampler2D colortex2; -uniform sampler2D colortex3; -// uniform sampler2D colortex4; - -uniform vec3 sunVec; -uniform float far; -uniform float near; -uniform int frameCounter; -uniform float rainStrength; -uniform float sunElevation; -uniform ivec2 eyeBrightnessSmooth; -uniform float frameTimeCounter; -uniform int isEyeInWater; uniform vec2 texelSize; - - -#include "lib/Shadow_Params.glsl" -#include "lib/color_transforms.glsl" -#include "lib/color_dither.glsl" +uniform float frameTimeCounter; +uniform float viewHeight; +uniform float viewWidth; +uniform int frameCounter; +uniform int framemod8; +uniform vec3 previousCameraPosition; +uniform mat4 gbufferPreviousModelView; +#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) #include "lib/projections.glsl" -#include "lib/sky_gradient.glsl" -#include "/lib/res_params.glsl" -// #include "lib/biome_specifics.glsl" - -#define TIMEOFDAYFOG -#include "lib/volumetricClouds.glsl" -float blueNoise(){ - return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); +float luma(vec3 color) { + return dot(color,vec3(0.21, 0.72, 0.07)); +} +float interleaved_gradientNoise(){ + return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+tempOffsets); +} +float triangularize(float dither) +{ + float center = dither*2.0-1.0; + dither = center*inversesqrt(abs(center)); + return clamp(dither-fsign(center),0.0,1.0); +} +vec3 fp10Dither(vec3 color,float dither){ + const vec3 mantissaBits = vec3(6.,6.,5.); + vec3 exponent = floor(log2(color)); + return color + dither*exp2(-mantissaBits)*exp2(exponent); +} + + +//returns the projected coordinates of the closest point to the camera in the 3x3 neighborhood +vec3 closestToCamera5taps(vec2 texcoord, sampler2D depth) +{ + vec2 du = vec2(texelSize.x*2., 0.0); + vec2 dv = vec2(0.0, texelSize.y*2.); + + vec3 dtl = vec3(texcoord,0.) + vec3(-texelSize, texture2D(depth, texcoord - dv - du).x); + vec3 dtr = vec3(texcoord,0.) + vec3( texelSize.x, -texelSize.y, texture2D(depth, texcoord - dv + du).x); + vec3 dmc = vec3(texcoord,0.) + vec3( 0.0, 0.0, texture2D(depth, texcoord).x); + vec3 dbl = vec3(texcoord,0.) + vec3(-texelSize.x, texelSize.y, texture2D(depth, texcoord + dv - du).x); + vec3 dbr = vec3(texcoord,0.) + vec3( texelSize.x, texelSize.y, texture2D(depth, texcoord + dv + du).x); + + vec3 dmin = dmc; + dmin = dmin.z > dtr.z? dtr : dmin; + dmin = dmin.z > dtl.z? dtl : dmin; + dmin = dmin.z > dbl.z? dbl : dmin; + dmin = dmin.z > dbr.z? dbr : dmin; + #ifdef TAA_UPSCALING + dmin.xy = dmin.xy/RENDER_SCALE; + #endif + return dmin; +} + +//Modified texture interpolation from inigo quilez +vec4 smoothfilter(in sampler2D tex, in vec2 uv) +{ + vec2 textureResolution = vec2(viewWidth,viewHeight); + uv = uv*textureResolution + 0.5; + vec2 iuv = floor( uv ); + vec2 fuv = fract( uv ); + uv = iuv + fuv*fuv*fuv*(fuv*(fuv*6.0-15.0)+10.0); + uv = (uv - 0.5)/textureResolution; + return texture2D( tex, uv); +} +//Due to low sample count we "tonemap" the inputs to preserve colors and smoother edges +vec3 weightedSample(sampler2D colorTex, vec2 texcoord){ + vec3 wsample = texture2D(colorTex,texcoord).rgb*exposureA; + return wsample/(1.0+luma(wsample)); + +} + + +//from : https://gist.github.com/TheRealMJP/c83b8c0f46b63f3a88a5986f4fa982b1 +vec4 SampleTextureCatmullRom(sampler2D tex, vec2 uv, vec2 texSize ) +{ + // We're going to sample a a 4x4 grid of texels surrounding the target UV coordinate. We'll do this by rounding + // down the sample location to get the exact center of our "starting" texel. The starting texel will be at + // location [1, 1] in the grid, where [0, 0] is the top left corner. + vec2 samplePos = uv * texSize; + vec2 texPos1 = floor(samplePos - 0.5) + 0.5; + + // Compute the fractional offset from our starting texel to our original sample location, which we'll + // feed into the Catmull-Rom spline function to get our filter weights. + vec2 f = samplePos - texPos1; + + // Compute the Catmull-Rom weights using the fractional offset that we calculated earlier. + // These equations are pre-expanded based on our knowledge of where the texels will be located, + // which lets us avoid having to evaluate a piece-wise function. + vec2 w0 = f * ( -0.5 + f * (1.0 - 0.5*f)); + vec2 w1 = 1.0 + f * f * (-2.5 + 1.5*f); + vec2 w2 = f * ( 0.5 + f * (2.0 - 1.5*f) ); + vec2 w3 = f * f * (-0.5 + 0.5 * f); + + // Work out weighting factors and sampling offsets that will let us use bilinear filtering to + // simultaneously evaluate the middle 2 samples from the 4x4 grid. + vec2 w12 = w1 + w2; + vec2 offset12 = w2 / (w1 + w2); + + // Compute the final UV coordinates we'll use for sampling the texture + vec2 texPos0 = texPos1 - vec2(1.0); + vec2 texPos3 = texPos1 + vec2(2.0); + vec2 texPos12 = texPos1 + offset12; + + texPos0 *= texelSize; + texPos3 *= texelSize; + texPos12 *= texelSize; + + vec4 result = vec4(0.0); + result += texture2D(tex, vec2(texPos0.x, texPos0.y)) * w0.x * w0.y; + result += texture2D(tex, vec2(texPos12.x, texPos0.y)) * w12.x * w0.y; + result += texture2D(tex, vec2(texPos3.x, texPos0.y)) * w3.x * w0.y; + + result += texture2D(tex, vec2(texPos0.x, texPos12.y)) * w0.x * w12.y; + result += texture2D(tex, vec2(texPos12.x, texPos12.y)) * w12.x * w12.y; + result += texture2D(tex, vec2(texPos3.x, texPos12.y)) * w3.x * w12.y; + + result += texture2D(tex, vec2(texPos0.x, texPos3.y)) * w0.x * w3.y; + result += texture2D(tex, vec2(texPos12.x, texPos3.y)) * w12.x * w3.y; + result += texture2D(tex, vec2(texPos3.x, texPos3.y)) * w3.x * w3.y; + + return result; } float R2_dither(){ vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y + 1.0/1.6180339887 * frameCounter) ; + return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y + 1.0/1.6180339887 * frameCounter); } -float R2_dither2(){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha.x *(1- gl_FragCoord.x) + alpha.y * (1-gl_FragCoord.y) + 1.0/1.6180339887 * frameCounter) ; -} -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; +//approximation from SMAA presentation from siggraph 2016 +vec3 FastCatmulRom(sampler2D colorTex, vec2 texcoord, vec4 rtMetrics, float sharpenAmount) +{ + vec2 position = rtMetrics.zw * texcoord; + vec2 centerPosition = floor(position - 0.5) + 0.5; + vec2 f = position - centerPosition; + vec2 f2 = f * f; + vec2 f3 = f * f2; + + float c = sharpenAmount; + vec2 w0 = -c * f3 + 2.0 * c * f2 - c * f; + vec2 w1 = (2.0 - c) * f3 - (3.0 - c) * f2 + 1.0; + vec2 w2 = -(2.0 - c) * f3 + (3.0 - 2.0 * c) * f2 + c * f; + vec2 w3 = c * f3 - c * f2; + + vec2 w12 = w1 + w2; + vec2 tc12 = rtMetrics.xy * (centerPosition + w2 / w12); + vec3 centerColor = texture2D(colorTex, vec2(tc12.x, tc12.y)).rgb; + + vec2 tc0 = rtMetrics.xy * (centerPosition - 1.0); + vec2 tc3 = rtMetrics.xy * (centerPosition + 2.0); + vec4 color = vec4(texture2D(colorTex, vec2(tc12.x, tc0.y )).rgb, 1.0) * (w12.x * w0.y ) + + vec4(texture2D(colorTex, vec2(tc0.x, tc12.y)).rgb, 1.0) * (w0.x * w12.y) + + vec4(centerColor, 1.0) * (w12.x * w12.y) + + vec4(texture2D(colorTex, vec2(tc3.x, tc12.y)).rgb, 1.0) * (w3.x * w12.y) + + vec4(texture2D(colorTex, vec2(tc12.x, tc3.y )).rgb, 1.0) * (w12.x * w3.y ); + return color.rgb/color.a; + } -float phaseRayleigh(float cosTheta) { - const vec2 mul_add = vec2(0.1, 0.28) /acos(-1.0); - return cosTheta * mul_add.x + mul_add.y; // optimized version from [Elek09], divided by 4 pi for energy conservation -} +vec3 clip_aabb(vec3 q,vec3 aabb_min, vec3 aabb_max) + { + vec3 p_clip = 0.5 * (aabb_max + aabb_min); + vec3 e_clip = 0.5 * (aabb_max - aabb_min) + 0.00000001; -float GetCloudShadow(vec3 eyePlayerPos){ - vec3 worldPos = (eyePlayerPos + cameraPosition) - Cloud_Height; - vec3 cloudPos = worldPos*Cloud_Size + WsunVec/abs(WsunVec.y) * ((3250 - 3250*0.35) - worldPos.y*Cloud_Size) ; - float shadow = getCloudDensity(cloudPos, 1); - - shadow = clamp(exp(-shadow*5),0.0,1.0); - - return shadow ; -} - -float densityAtPosFog(in vec3 pos){ - pos /= 18.; - pos.xz *= 0.5; - vec3 p = floor(pos); - vec3 f = fract(pos); - f = (f*f) * (3.-2.*f); - vec2 uv = p.xz + f.xz + p.y * vec2(0.0,193.0); - vec2 coord = uv / 512.0; - vec2 xy = texture2D(noisetex, coord).yx; - return mix(xy.r,xy.g, f.y); -} - -float fog_densities_atmospheric = 24 * Haze_amount; // this is seperate from the cloudy and uniform fog. - -float cloudVol(in vec3 pos){ - - vec3 samplePos = pos*vec3(1.0,1./24.,1.0); - vec3 samplePos2 = pos*vec3(1.0,1./48.,1.0); - - - float mult = exp( -max((pos.y - SEA_LEVEL) / 35.,0.0)); - - float fog_shape = 1-densityAtPosFog(samplePos * 24.0); - float fog_eroded = 1-densityAtPosFog( samplePos2 * 200.0); - - float CloudyFog = max( (fog_shape*2.0 - fog_eroded*0.5) - 1.2, 0.0) * mult; - float UniformFog = exp2( -max((pos.y - SEA_LEVEL) / 25.,0.0)); - - float RainFog = max(fog_shape*10. - 7.,0.5) * exp2( -max((pos.y - SEA_LEVEL) / 25.,0.0)) * 5. * rainStrength; - - TimeOfDayFog(UniformFog, CloudyFog); - - return CloudyFog + UniformFog + RainFog; -} - -mat2x3 getVolumetricRays( - float dither, - vec3 fragpos, - float dither2 -){ - //project pixel position into projected shadowmap space - vec3 wpos = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - vec3 fragposition = mat3(shadowModelView) * wpos + shadowModelView[3].xyz; - fragposition = diagonal3(shadowProjection) * fragposition + shadowProjection[3].xyz; - - //project view origin into projected shadowmap space - vec3 start = toShadowSpaceProjected(vec3(0.)); - - //rayvector into projected shadow map space - //we can use a projected vector because its orthographic projection - //however we still have to send it to curved shadow map space every step - vec3 dV = fragposition-start; - vec3 dVWorld = (wpos-gbufferModelViewInverse[3].xyz); - - float maxLength = min(length(dVWorld),far)/length(dVWorld); - dV *= maxLength; - dVWorld *= maxLength; - - //apply dither - vec3 progress = start.xyz; - vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; - - vec3 vL = vec3(0.); - - float SdotV = dot(sunVec,normalize(fragpos))*lightCol.a; - float dL = length(dVWorld); - - //Mie phase + somewhat simulates multiple scattering (Horizon zero down cloud approx) - float mie = phaseg(SdotV,0.7)*5.0 + 1.0; - float rayL = phaseRayleigh(SdotV); - - // Makes fog more white idk how to simulate it correctly - vec3 sunColor = lightCol.rgb / 127.0; - vec3 skyCol0 = (ambientUp / 150. * 5.); // * max(abs(WsunVec.y)/150.0,0.); - - vec3 rC = vec3(fog_coefficientRayleighR*1e-6, fog_coefficientRayleighG*1e-5, fog_coefficientRayleighB*1e-5); - vec3 mC = vec3(fog_coefficientMieR*1e-6, fog_coefficientMieG*1e-6, fog_coefficientMieB*1e-6); - - float mu = 1.0; - float muS = mu; - vec3 absorbance = vec3(1.0); - float expFactor = 11.0; - vec3 WsunVec = mat3(gbufferModelViewInverse) * sunVec * lightCol.a; - - float cloudShadow = 1.0; - - for (int i=0;i 1.0) + return vec3(p_clip) + v_clip / ma_unit; + else + return q; } - return mat2x3(vL,absorbance); +vec3 toClipSpace3Prev(vec3 viewSpacePosition) { + return projMAD(gbufferPreviousProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; } -float waterCaustics(vec3 wPos, vec3 lightSource) { // water waves - - vec2 pos = wPos.xz + (lightSource.xz/lightSource.y*wPos.y); - if(isEyeInWater==1) pos = wPos.xz - (lightSource.xz/lightSource.y*wPos.y); // fix the fucky - vec2 movement = vec2(-0.035*frameTimeCounter); - float caustic = 0.0; - float weightSum = 0.0; - float radiance = 2.39996; - mat2 rotationMatrix = mat2(vec2(cos(radiance), -sin(radiance)), vec2(sin(radiance), cos(radiance))); - - const vec2 wave_size[4] = vec2[]( - vec2(64.), - vec2(32.,16.), - vec2(16.,32.), - vec2(48.) - ); - - for (int i = 0; i < 4; i++){ - pos = rotationMatrix * pos; - - vec2 speed = movement; - float waveStrength = 1.0; - - if( i == 0) { - speed *= 0.15; - waveStrength = 2.0; - } - - float small_wave = texture2D(noisetex, pos / wave_size[i] + speed ).b * waveStrength; - - caustic += max( 1.0-sin( 1.0-pow( 0.5+sin( small_wave*3.0 )*0.5, 25.0) ), 0); - - weightSum -= exp2(caustic*0.1); - } - return caustic / weightSum; +vec3 tonemap(vec3 col){ + return col/(1+luma(col)); } -vec3 normVec (vec3 vec){ - return vec*inversesqrt(dot(vec,vec)); +vec3 invTonemap(vec3 col){ + return col/(1-luma(col)); } -void waterVolumetrics(inout vec3 inColor, vec3 rayStart, vec3 rayEnd, float estEyeDepth, float estSunDepth, float rayLength, float dither, vec3 waterCoefs, vec3 scatterCoef, vec3 ambient, vec3 lightSource, float VdotL){ - int spCount = 8; +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.); - vec3 start = toShadowSpaceProjected(rayStart); - vec3 end = toShadowSpaceProjected(rayEnd); - vec3 dV = (end-start); - //limit ray length at 32 blocks for performance and reducing integration error - //you can't see above this anyway - float maxZ = min(rayLength,32.0)/(1e-8+rayLength); - dV *= maxZ; - vec3 dVWorld = mat3(gbufferModelViewInverse) * (rayEnd - rayStart) * maxZ; - rayLength *= maxZ; - float dY = normalize(mat3(gbufferModelViewInverse) * rayEnd).y * rayLength; - vec3 absorbance = vec3(1.0); - vec3 vL = vec3(0.0); - float phase = 2*mix(phaseg(VdotL, 0.4),phaseg(VdotL, 0.8),0.5); - float expFactor = 11.0; - vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; - vec3 WsunVec = mat3(gbufferModelViewInverse) * sunVec * lightCol.a; - float cloudShadow = 1; - for (int i=0;i vec3(0.0) ) closestToCamera = closestToCamera - EntityVelocity; + + #ifndef CLOSEST_VELOCITY + vec3 closestToCamera = vec3(texcoord,texture2D(depthtex1,adjTC).x); + #endif + + //reproject previous frame + vec3 fragposition = toScreenSpace(closestToCamera); + fragposition = mat3(gbufferModelViewInverse) * fragposition + gbufferModelViewInverse[3].xyz + (cameraPosition - previousCameraPosition); + + vec3 previousPosition = mat3(gbufferPreviousModelView) * fragposition + gbufferPreviousModelView[3].xyz; + previousPosition = toClipSpace3Prev(previousPosition) ; + + + + + vec2 velocity = previousPosition.xy - closestToCamera.xy; + previousPosition.xy = texcoord + velocity ; + // previousPosition -= abs(EntityVelocity); + + DEBUG = previousPosition; + + //reject history if off-screen and early exit + if (previousPosition.x < 0.0 || previousPosition.y < 0.0 || previousPosition.x > 1.0 || previousPosition.y > 1.0) + return smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).xyz; + + #ifdef TAA_UPSCALING + vec3 albedoCurrent0 = smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).xyz; + // Interpolating neighboorhood clampling boundaries between pixels + vec3 cMax = texture2D(colortex0, adjTC).rgb; + vec3 cMin = texture2D(colortex6, adjTC).rgb; + #else + vec3 albedoCurrent0 = texture2D(colortex3, adjTC).rgb; + vec3 albedoCurrent1 = texture2D(colortex3, adjTC + vec2(texelSize.x,texelSize.y)).rgb; + vec3 albedoCurrent2 = texture2D(colortex3, adjTC + vec2(texelSize.x,-texelSize.y)).rgb; + vec3 albedoCurrent3 = texture2D(colortex3, adjTC + vec2(-texelSize.x,-texelSize.y)).rgb; + vec3 albedoCurrent4 = texture2D(colortex3, adjTC + vec2(-texelSize.x,texelSize.y)).rgb; + vec3 albedoCurrent5 = texture2D(colortex3, adjTC + vec2(0.0,texelSize.y)).rgb; + vec3 albedoCurrent6 = texture2D(colortex3, adjTC + vec2(0.0,-texelSize.y)).rgb; + vec3 albedoCurrent7 = texture2D(colortex3, adjTC + vec2(-texelSize.x,0.0)).rgb; + vec3 albedoCurrent8 = texture2D(colortex3, adjTC + vec2(texelSize.x,0.0)).rgb; + //Assuming the history color is a blend of the 3x3 neighborhood, we clamp the history to the min and max of each channel in the 3x3 neighborhood + vec3 cMax = max(max(max(albedoCurrent0,albedoCurrent1),albedoCurrent2),max(albedoCurrent3,max(albedoCurrent4,max(albedoCurrent5,max(albedoCurrent6,max(albedoCurrent7,albedoCurrent8)))))); + vec3 cMin = min(min(min(albedoCurrent0,albedoCurrent1),albedoCurrent2),min(albedoCurrent3,min(albedoCurrent4,min(albedoCurrent5,min(albedoCurrent6,min(albedoCurrent7,albedoCurrent8)))))); + albedoCurrent0 = smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).rgb; + #endif + + #ifndef NO_CLIP + vec3 albedoPrev = max(FastCatmulRom(colortex5, previousPosition.xy,vec4(texelSize, 1.0/texelSize), 0.75).xyz, 0.0); + vec3 finalcAcc = clamp(albedoPrev,cMin,cMax); + + //Increases blending factor when far from AABB and in motion, reduces ghosting + float isclamped = distance(albedoPrev,finalcAcc)/luma(albedoPrev) * 0.5; + float movementRejection = (0.12+isclamped)*clamp(length(velocity/texelSize),0.0,1.0); + + float test = 0.05; + if(hand) movementRejection *= 5; + if(istranslucent) test = 0.1; + + //Blend current pixel with clamped history, apply fast tonemap beforehand to reduce flickering + // vec3 supersampled = invTonemap(mix(tonemap(finalcAcc),tonemap(albedoCurrent0),clamp(BLEND_FACTOR + movementRejection, min(luma(motionVector) *255,1.0),1.))); + + vec3 supersampled = invTonemap(mix(tonemap(finalcAcc),tonemap(albedoCurrent0),clamp(BLEND_FACTOR + movementRejection, test,1.))); + #endif + + + #ifdef NO_CLIP + vec3 albedoPrev = texture2D(colortex5, previousPosition.xy).xyz; + vec3 supersampled = mix(albedoPrev,albedoCurrent0,clamp(0.05,0.,1.)); + #endif + + //De-tonemap + return supersampled; +} + + +vec3 decode (vec2 encn){ + vec3 n = vec3(0.0); + encn = encn * 2.0 - 1.0; + n.xy = abs(encn); + n.z = 1.0 - n.x - n.y; + n.xy = n.z <= 0.0 ? (1.0 - n.yx) * sign(encn) : encn; + return clamp(normalize(n.xyz),-1.0,1.0); +} +vec2 decodeVec2(float a){ + const vec2 constant1 = 65535. / vec2( 256., 65536.); + const float constant2 = 256. / 255.; + return fract( a * constant1 ) * constant2 ; +} +vec2 R2_samples(int n){ + vec2 alpha = vec2(0.75487765, 0.56984026); + return fract(alpha * n)*2.-1.0; +} +vec4 TAA_hq_render(){ + #ifdef TAA_UPSCALING + vec2 adjTC = clamp(texcoord*RENDER_SCALE, vec2(0.0),RENDER_SCALE-texelSize*2.); + #else + vec2 adjTC = texcoord; + #endif + + //use velocity from the nearest texel from camera in a 3x3 box in order to improve edge quality in motion + #ifdef CLOSEST_VELOCITY + vec3 closestToCamera = closestToCamera5taps(adjTC,depthtex0); + #endif + + #ifndef CLOSEST_VELOCITY + vec3 closestToCamera = vec3(texcoord,texture2D(depthtex0,adjTC).x); + #endif + + //reproject previous frame + vec3 fragposition = toScreenSpace(closestToCamera); + fragposition = mat3(gbufferModelViewInverse) * fragposition + gbufferModelViewInverse[3].xyz + (cameraPosition - previousCameraPosition); + vec3 previousPosition = mat3(gbufferPreviousModelView) * fragposition + gbufferPreviousModelView[3].xyz; + previousPosition = toClipSpace3Prev(previousPosition); + vec2 velocity = previousPosition.xy - closestToCamera.xy; + previousPosition.xy = texcoord + velocity; + + // //reject history if off-screen and early exit + if (previousPosition.x < 0.0 || previousPosition.y < 0.0 || previousPosition.x > 1.0 || previousPosition.y > 1.0) + return vec4(smoothfilter(colortex3, adjTC + R2_samples(frameCounter)*texelSize*0.5).xyz, 1.0); + + vec3 albedoCurrent0 = smoothfilter(colortex3, adjTC + R2_samples(frameCounter)*texelSize*0.5).xyz; + + float rej = 0.0; + vec4 albedoPrev = texture2D(colortex5, previousPosition.xy); + vec3 supersampled = albedoPrev.rgb * albedoPrev.a + albedoCurrent0; + + if (length(velocity) > 1e-6) return vec4(albedoCurrent0,1.0); + return vec4(supersampled/(albedoPrev.a+1.0), albedoPrev.a+1.0); +} void main() { -/* DRAWBUFFERS:0 */ - float lightleakfix = max(eyeBrightnessSmooth.y,0)/240.; - if (isEyeInWater == 0){ +/* DRAWBUFFERS:5 */ - vec2 tc = floor(gl_FragCoord.xy)/VL_RENDER_RESOLUTION*texelSize+0.5*texelSize; - float z = texture2D(depthtex0,tc).x; - vec3 fragpos = toScreenSpace(vec3(tc/RENDER_SCALE,z)); - float noise = blueNoise(); - mat2x3 vl = getVolumetricRays(noise,fragpos,blueNoise()); - float absorbance = dot(vl[1],vec3(0.22,0.71,0.07)); - gl_FragData[0] = clamp(vec4(vl[0],absorbance),0.000001,65000.); - } else { - float dirtAmount = Dirt_Amount; - vec3 waterEpsilon = vec3(Water_Absorb_R, Water_Absorb_G, Water_Absorb_B); - vec3 dirtEpsilon = vec3(Dirt_Absorb_R, Dirt_Absorb_G, Dirt_Absorb_B); - vec3 totEpsilon = dirtEpsilon*dirtAmount + waterEpsilon; - vec3 scatterCoef = dirtAmount * vec3(Dirt_Scatter_R, Dirt_Scatter_G, Dirt_Scatter_B); - #ifdef AEROCHROME_MODE - totEpsilon *= 2.0; - scatterCoef *= 10.0; + gl_FragData[0].a = 1.0; +#ifndef SPLIT_RENDER + #ifdef SCREENSHOT_MODE + + + vec4 color = TAA_hq_render(); + gl_FragData[0] = color; + + + #else + #ifdef TAA + vec4 data = texture2D(colortex1,texcoord* RENDER_SCALE); // terraom + vec4 dataUnpacked1 = vec4(decodeVec2(data.z),decodeVec2(data.w)); + bool hand = abs(dataUnpacked1.w-0.75) < 0.01; + bool translucentCol = texture2D(colortex13,texcoord * RENDER_SCALE).a > 0.0; // translucents + vec3 color = vec3(0.0); + + // vec3 motionVector = texture2D(colortex10,texcoord).xyz ; + // vec3 motionVector = texelFetch(colortex10, ivec2(gl_FragCoord.xy), 0).xyz * 2 - 1; + + // if((motionVector.x+motionVector.y+motionVector.z) / 3 < 0.00001) motionVector = vec3(0.0); + // vec3 viewpos = motionVector; + // // vec3 eyepos = mat3(gbufferModelViewInverse) * viewpos; + // // vec3 worldPos = eyepos + (cameraPosition + gbufferModelViewInverse[3].xyz); + // // vec3 feetPos = worldPos - cameraPosition; + + // vec4 clippos = gbufferProjection * vec4(motionVector,1.0); + + // vec3 ndcPos = projectAndDivide(gbufferProjectionInverse, viewpos); + // vec3 screenPos = ndcPos * 0.5 + 0.5; + + + vec3 DEBUG = vec3(0.0); + color += TAA_hq(hand, translucentCol, vec3(0.0),DEBUG); + + + gl_FragData[0].rgb = clamp(fp10Dither(color ,triangularize(R2_dither())),6.11*1e-5,65000.0); + // gl_FragData[0].rgb = motionVector; #endif - vec2 tc = floor(gl_FragCoord.xy)/VL_RENDER_RESOLUTION*texelSize+0.5*texelSize; - float z = texture2D(depthtex0,tc).x; - vec3 fragpos = toScreenSpace(vec3(tc/RENDER_SCALE,z)); - float noise = R2_dither(); - vec3 vl = vec3(0.0); - float estEyeDepth = clamp((14.0-eyeBrightnessSmooth.y/255.0*16.0)/14.0,0.,1.0); - estEyeDepth *= estEyeDepth*estEyeDepth*34.0; - - #ifndef lightMapDepthEstimation - estEyeDepth = max(Water_Top_Layer - cameraPosition.y,0.0); + #ifndef TAA + vec3 color = clamp(fp10Dither(texture2D(colortex3,texcoord).rgb,triangularize(interleaved_gradientNoise())),0.,65000.); + gl_FragData[0].rgb = color; #endif + #endif +#endif + + + + +#ifdef SPLIT_RENDER + if(texcoord.x > 0.5){ + + vec4 color = TAA_hq_render(); + gl_FragData[0] = color; + + }else{ + vec4 data = texture2D(colortex1,texcoord* RENDER_SCALE); // terraom + vec4 dataUnpacked1 = vec4(decodeVec2(data.z),decodeVec2(data.w)); + bool hand = abs(dataUnpacked1.w-0.75) < 0.01; + bool translucentCol = texture2D(colortex13,texcoord * RENDER_SCALE).a > 0.0; // translucents + + + + vec3 color = TAA_hq(hand, translucentCol); + gl_FragData[0].rgb = clamp(fp10Dither(color ,triangularize(R2_dither())),6.11*1e-5,65000.0); - waterVolumetrics(vl, vec3(0.0), fragpos, estEyeDepth, estEyeDepth, length(fragpos), noise, totEpsilon, scatterCoef, (ambientUp*8./150./3.*0.5) , lightCol.rgb*8./150./3.0*(1.0-pow(1.0-sunElevation*lightCol.a,5.0)), dot(normalize(fragpos), normalize(sunVec) )); - gl_FragData[0] = clamp(vec4(vl,1.0),0.000001,65000.); } +#endif } diff --git a/shaders/composite5.vsh b/shaders/composite5.vsh index 568251e..3c77d0c 100644 --- a/shaders/composite5.vsh +++ b/shaders/composite5.vsh @@ -3,110 +3,16 @@ #include "lib/settings.glsl" -flat varying vec4 lightCol; -flat varying vec3 ambientUp; -flat varying vec3 ambientLeft; -flat varying vec3 ambientRight; -flat varying vec3 ambientB; -flat varying vec3 ambientF; -flat varying vec3 ambientDown; - - -flat varying vec3 sunColor; -flat varying vec3 moonColor; -flat varying vec3 avgAmbient; - -flat varying vec2 TAA_Offset; - +varying vec2 texcoord; +flat varying float exposureA; flat varying float tempOffsets; - -flat varying float fogAmount; -flat varying float VFAmount; -flat varying float FogSchedule; - - -flat varying vec3 WsunVec; -flat varying vec3 refractedSunVec; - uniform sampler2D colortex4; -uniform vec3 sunPosition; -uniform float sunElevation; -uniform float rainStrength; -uniform int isEyeInWater; uniform int frameCounter; -// uniform int worldTime; -uniform mat4 gbufferModelViewInverse; - - #include "/lib/util.glsl" -#include "/lib/res_params.glsl" -// #include "lib/biome_specifics.glsl" - - -float luma(vec3 color) { - return dot(color,vec3(0.21, 0.72, 0.07)); -} -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.); -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - void main() { + tempOffsets = HaltonSeq2(frameCounter%10000); gl_Position = ftransform(); - gl_Position.xy = (gl_Position.xy*0.5+0.5)*(0.01+VL_RENDER_RESOLUTION)*2.0-1.0; - #ifdef TAA_UPSCALING - gl_Position.xy = (gl_Position.xy*0.5+0.5)*RENDER_SCALE*2.0-1.0; - #endif - vec3 sc = texelFetch2D(colortex4,ivec2(6,37),0).rgb; - - sunColor = texelFetch2D(colortex4,ivec2(12,37),0).rgb; - moonColor = texelFetch2D(colortex4,ivec2(13,37),0).rgb; - avgAmbient = texelFetch2D(colortex4,ivec2(11,37),0).rgb; - - - ambientUp = texelFetch2D(colortex4,ivec2(0,37),0).rgb; - ambientDown = texelFetch2D(colortex4,ivec2(1,37),0).rgb; - ambientLeft = texelFetch2D(colortex4,ivec2(2,37),0).rgb; - ambientRight = texelFetch2D(colortex4,ivec2(3,37),0).rgb; - ambientB = texelFetch2D(colortex4,ivec2(4,37),0).rgb; - ambientF = texelFetch2D(colortex4,ivec2(5,37),0).rgb; - - - lightCol.a = float(sunElevation > 1e-5)*2-1.; - lightCol.rgb = sc; - - TAA_Offset = offsets[frameCounter%8]; - #ifndef TAA - TAA_Offset = vec2(0.0); - #endif - - #ifndef VL_Clouds_Shadows - lightCol.rgb *= (1.0-rainStrength*0.9); - #endif - // float Time = worldTime%24000; - - // FogSchedule = clamp( (Time - 9000)/9000 ,0,1); - // // float fogAmount0 = 1/3000.+FOG_TOD_MULTIPLIER*(1/100.*(clamp(modWT-11000.,0.,2000.0)/2000.+(1.0-clamp(modWT,0.,3000.0)/3000.))*(clamp(modWT-11000.,0.,2000.0)/2000.+(1.0-clamp(modWT,0.,3000.0)/3000.)) + 1/120.*clamp(modWT-13000.,0.,1000.0)/1000.*(1.0-clamp(modWT-23000.,0.,1000.0)/1000.)); - - // float fogAmount0 = TimeOfDayFog; - - // // VFAmount = CLOUDY_FOG_AMOUNT*(fogAmount0*fogAmount0+FOG_RAIN_MULTIPLIER*1.0/20000.*rainStrength); - // VFAmount = fogAmount0; - // fogAmount = BASE_FOG_AMOUNT*(fogAmount0+max(FOG_RAIN_MULTIPLIER*1/10.*rainStrength , FOG_TOD_MULTIPLIER*1/50.*clamp(modWT-13000.,0.,1000.0)/1000.*(1.0-clamp(modWT-23000.,0.,1000.0)/1000.))); - - - - - WsunVec = lightCol.a*normalize(mat3(gbufferModelViewInverse) *sunPosition); - refractedSunVec = refract(WsunVec, -vec3(0.0,1.0,0.0), 1.0/1.33333); + texcoord = gl_MultiTexCoord0.xy; + exposureA = texelFetch2D(colortex4,ivec2(10,37),0).r; } diff --git a/shaders/composite6.fsh b/shaders/composite6.fsh index 5f61ee9..937e315 100644 --- a/shaders/composite6.fsh +++ b/shaders/composite6.fsh @@ -1,313 +1,50 @@ #version 120 -//Horizontal bilateral blur for volumetric fog + Forward rendered objects + Draw volumetric fog -#extension GL_EXT_gpu_shader4 : enable +//downsample 1st pass (half res) for bloom + #include "lib/settings.glsl" - -flat varying vec3 zMults; -flat varying vec2 TAA_Offset; - - -/* -const int colortex11Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) -*/ - - -uniform sampler2D noisetex; -uniform sampler2D depthtex0; -uniform sampler2D depthtex1; -uniform sampler2D colortex0; -uniform sampler2D colortex1; -uniform sampler2D colortex2; -uniform sampler2D colortex3; -// uniform sampler2D colortex4; uniform sampler2D colortex5; -uniform sampler2D colortex6; -uniform sampler2D colortex7; -uniform sampler2D colortex8; -uniform sampler2D colortex9; -uniform sampler2D colortex11; -uniform sampler2D colortex13; -uniform sampler2D colortex15; +// uniform sampler2D colortex8; uniform vec2 texelSize; +uniform float viewWidth; +uniform float viewHeight; -flat varying vec3 noooormal; -flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) -flat varying vec3 WsunVec; +#include "lib/res_params.glsl" -uniform vec3 sunVec; -uniform float frameTimeCounter; -uniform int frameCounter; -uniform float far; -uniform float near; -uniform mat4 gbufferModelViewInverse; -uniform mat4 gbufferModelView; -uniform mat4 gbufferPreviousModelView; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferProjection; -uniform mat4 gbufferPreviousProjection; -uniform vec3 cameraPosition; -uniform vec3 previousCameraPosition; - -uniform int isEyeInWater; -uniform ivec2 eyeBrightnessSmooth; -uniform float rainStrength; -uniform float blindness; -uniform float darknessFactor; -uniform float darknessLightFactor; -uniform float nightVision; - -#include "lib/waterBump.glsl" -#include "/lib/res_params.glsl" - -#include "lib/sky_gradient.glsl" -#include "lib/volumetricClouds.glsl" -// #include "lib/biome_specifics.glsl" - - - -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) - -float ld(float depth) { - return 1.0 / (zMults.y - depth * zMults.z); // (-depth * (far - near)) = (2.0 * near)/ld - far - near -} -float luma(vec3 color) { - return dot(color,vec3(0.21, 0.72, 0.07)); -} -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} -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; -} - - -// #include "lib/specular.glsl" - - - - -vec4 BilateralUpscale(sampler2D tex, sampler2D depth,vec2 coord,float frDepth){ - coord = coord; - vec4 vl = vec4(0.0); - float sum = 0.0; - mat3x3 weights; - const ivec2 scaling = ivec2(1.0/VL_RENDER_RESOLUTION); - ivec2 posD = ivec2(coord*VL_RENDER_RESOLUTION)*scaling; - ivec2 posVl = ivec2(coord*VL_RENDER_RESOLUTION); - float dz = zMults.x; - ivec2 pos = (ivec2(gl_FragCoord.xy+frameCounter) % 2 )*2; - - ivec2 tcDepth = posD + ivec2(-2,-2) * scaling + pos * scaling; - float dsample = ld(texelFetch2D(depth,tcDepth,0).r); - float w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(-2)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(-2,0) * scaling + pos * scaling; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(-2,0)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(0) + pos * scaling; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(0)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(0,-2) * scaling + pos * scaling; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(0,-2)+pos,0)*w; - sum += w; - - return vl/sum; -} - -vec3 decode (vec2 encn){ - vec3 n = vec3(0.0); - encn = encn * 2.0 - 1.0; - n.xy = abs(encn); - n.z = 1.0 - n.x - n.y; - n.xy = n.z <= 0.0 ? (1.0 - n.yx) * sign(encn) : encn; - return clamp(normalize(n.xyz),-1.0,1.0); -} - -vec2 decodeVec2(float a){ - const vec2 constant1 = 65535. / vec2( 256., 65536.); - const float constant2 = 256. / 255.; - return fract( a * constant1 ) * constant2 ; -} - -vec3 worldToView(vec3 worldPos) { - vec4 pos = vec4(worldPos, 0.0); - pos = gbufferModelView * pos; - return pos.xyz; -} -float blueNoise(){ - return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); -} -vec4 blueNoise(vec2 coord){ - return texelFetch2D(colortex6, ivec2(coord )%512 , 0); -} -vec3 normVec (vec3 vec){ - return vec*inversesqrt(dot(vec,vec)); -} - -float interleaved_gradientNoise(){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)); - return noise; -} -vec3 viewToWorld(vec3 viewPosition) { - vec4 pos; - pos.xyz = viewPosition; - pos.w = 0.0; - pos = gbufferModelViewInverse * pos; - return pos.xyz; -} void main() { - vec2 texcoord = gl_FragCoord.xy*texelSize; - /* DRAWBUFFERS:73 */ - - vec4 transparencies = texture2D(colortex2,texcoord); - vec4 trpData = texture2D(colortex7,texcoord); - - vec4 speculartex = texture2D(colortex8,texcoord); // translucents - float sunlight = speculartex.b; - - bool iswater = trpData.a > 0.99; - float translucentAlpha = trpData.a; - - //3x3 bilateral upscale from half resolution - float z = texture2D(depthtex0,texcoord).x; - float z2 = texture2D(depthtex1,texcoord).x; - float frDepth = ld(z2); - vec4 vl = BilateralUpscale(colortex0,depthtex1,gl_FragCoord.xy,frDepth); - // vec4 vl = texture2D(colortex0,texcoord * 0.5); +/* DRAWBUFFERS:3 */ - vec4 data = texture2D(colortex11,texcoord); // translucents - vec4 dataUnpacked0 = vec4(decodeVec2(data.x),decodeVec2(data.y)); - vec4 dataUnpacked1 = vec4(decodeVec2(data.z),decodeVec2(data.w)); +vec2 resScale = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))/vec2(1920.,1080.); +vec2 quarterResTC = gl_FragCoord.xy*texelSize*2.*resScale/BLOOM_QUALITY; - vec3 normals = mat3(gbufferModelViewInverse) * worldToView(decode(dataUnpacked0.yw) ); +// float emissives1 = texture2D(colortex8,quarterResTC).a; +// float emissives2 = emissives1 < 1.0 ? emissives1 : 0.0; - vec4 data_terrain = texture2D(colortex1,texcoord); // terraom - vec4 dataUnpacked1_terrain = vec4(decodeVec2(data_terrain.z),decodeVec2(data_terrain.w)); + // 0.5 + gl_FragData[0] = texture2D(colortex5,quarterResTC-1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; + gl_FragData[0] += texture2D(colortex5,quarterResTC+1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; + gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(-1.0*texelSize.x,1.0*texelSize.y))/4.*0.5; + gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(1.0*texelSize.x,-1.0*texelSize.y))/4.*0.5; - bool hand = (abs(dataUnpacked1_terrain.w-0.75) < 0.01); + //0.25 + gl_FragData[0] += texture2D(colortex5,quarterResTC-2.0*vec2(texelSize.x,0.0))/2.*0.125; + gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(0.0,texelSize.y))/2.*0.125; + gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(0,-texelSize.y))/2*0.125; + gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(-texelSize.x,0.0))/2*0.125; + + //0.125 + gl_FragData[0] += texture2D(colortex5,quarterResTC-2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; + gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; + gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(-2.0*texelSize.x,2.0*texelSize.y))/4.*0.125; + gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(2.0*texelSize.x,-2.0*texelSize.y))/4.*0.125; + + //0.125 + gl_FragData[0] += texture2D(colortex5,quarterResTC)*0.125; - vec2 refractedCoord = texcoord; - - float rainDrops = clamp(texture2D(colortex9,texcoord).a, 0.0,1.0); // bloomy rain effect + gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); + if (quarterResTC.x > 1.0 - 3.5*texelSize.x || quarterResTC.y > 1.0 -3.5*texelSize.y || quarterResTC.x < 3.5*texelSize.x || quarterResTC.y < 3.5*texelSize.y) gl_FragData[0].rgb = vec3(0.0); - - vec2 tempOffset = TAA_Offset; - vec3 fragpos = toScreenSpace(vec3(texcoord/RENDER_SCALE-vec2(tempOffset)*texelSize*0.5,z)); - vec3 fragpos2 = toScreenSpace(vec3(texcoord/RENDER_SCALE-vec2(tempOffset)*texelSize*0.5,z2)); - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos; - vec3 np3 = normVec(p3); - - #ifdef Refraction - vec3 worldPos = p3 + cameraPosition; - - // thank you sixthsurge, though i may be doing stuff weirdly with the tangent, it works... as far as i can tell. - vec3 geometryNormal = normalize(cross(dFdx(worldPos), dFdy(worldPos))); - - vec3 geometryNormal2 = geometryNormal; - vec3 tangent = geometryNormal2.y > 0.50 || geometryNormal2.y < -0.50 ? normalize(cross(vec3(0,0,1),geometryNormal)) : normalize(cross(vec3(0.0, 1.0, 0.0), geometryNormal)); - - // vec3 tangent = normalize(cross(vec3(1.0, 1.0, 1.0), geometryNormal)) ; - vec3 bitangent = normalize(cross(tangent, geometryNormal)) ; - mat3 tbn = mat3(tangent, bitangent, geometryNormal); - vec3 tangentSpaceNormal = normals * tbn; - - float dist = clamp(ld(fragpos.z)*100,0,0.15); // shrink as distance increases - - if( translucentAlpha > 0.0) refractedCoord += (tangentSpaceNormal.xy * dist ) * RENDER_SCALE; - - bool glass = texture2D(colortex7,refractedCoord).a > 0.0 && texture2D(colortex13,texcoord).a > 0.0; - if(!glass) refractedCoord = texcoord; - #endif - - // underwater squiggles - // if(isEyeInWater == 1 && !iswater) refractedCoord = texcoord + pow(texture2D(noisetex,texcoord - vec2(0,frameTimeCounter/25)).b - 0.5, 2.0)*0.05; - - - vec3 color = texture2D(colortex3,refractedCoord).rgb; - - if (frDepth > 2.5/far || transparencies.a < 0.99 || !hand) color = color * (1.0-transparencies.a) + transparencies.rgb*10.; // Discount fix for transparencies through hand - - - - float dirtAmount = Dirt_Amount; - vec3 waterEpsilon = vec3(Water_Absorb_R, Water_Absorb_G, Water_Absorb_B); - vec3 dirtEpsilon = vec3(Dirt_Absorb_R, Dirt_Absorb_G, Dirt_Absorb_B); - vec3 totEpsilon = dirtEpsilon*dirtAmount + waterEpsilon; - - color *= vl.a ; - - if(rainDrops > 0.0) { - // refractedCoord = mix(refractedCoord, vec2(texcoord.x,texcoord.y * 0.9 + 0.05), rainStrength) ; - vl.a *= clamp(exp2(-rainDrops*5),0.,1.); // bloomy rain effect - } - - - float lightleakfix = clamp((eyeBrightnessSmooth.y )/240.0,0.0,1.0); - - //cave fog - #ifdef Cave_fog - if (isEyeInWater == 0){ - float fogdistfade = 1.0 - clamp( exp(-pow(length(fragpos / far),2.)*5.0) ,0.0,1.0); - float fogfade = clamp( exp(clamp( np3.y*0.5 +0.5,0,1) * -6.0) ,0.0,1.0); - - color.rgb = mix(color.rgb, vec3(CaveFogColor_R,CaveFogColor_G,CaveFogColor_B)*fogfade, fogdistfade * (1.0-lightleakfix) * (1.0-darknessFactor)* clamp( 1.5 - np3.y,0.,1)) ; - // color.rgb = mix(color.rgb, vec3(CaveFogColor_R,CaveFogColor_G,CaveFogColor_B)*fogfade, fogdistfade) ; - } - #endif - - // underwater fog - if (isEyeInWater == 1){ - float fogfade = clamp(exp(-length(fragpos) /9. ) ,0.0,1.0); - color.rgb *= fogfade; - vl.a *= fogfade*0.70+0.3 ; - } - - color += vl.rgb; - gl_FragData[0].r = vl.a; - - /// lava. - if (isEyeInWater == 2){ - color.rgb = vec3(4.0,0.5,0.1); - } - - /// powdered snow - if (isEyeInWater == 3){ - color.rgb = mix(color.rgb,vec3(10,15,20),clamp(length(fragpos)*0.5,0.,1.)); - vl.a = 0.0; - } - - // blidnesss - // color.rgb *= mix(1.0, clamp(1.5-pow(length(fragpos2)*(blindness*0.2),2.0),0.0,1.0), blindness); - color.rgb *= mix(1.0, clamp( exp(pow(length(fragpos)*(blindness*0.2),2) * -5),0.,1.) , blindness); - - // darkness effect - color.rgb *= mix(1.0, (1.0-darknessLightFactor*2.0) * clamp(1.0-pow(length(fragpos2)*(darknessFactor*0.07),2.0),0.0,1.0), darknessFactor); - - - gl_FragData[1].rgb = clamp(color.rgb,0.0,68000.0); - - #ifdef display_LUT - gl_FragData[1].rgb = texture2D(colortex4,texcoord/2.5).rgb *0.035; - #endif - - // gl_FragData[1].rgb =mix(vec3(0.2,0.5,1), vec3(0,0,0), clamp( exp2(pow(clamp(0.5-np3.y,0,1) ,2)* -0.5) ,0,1)); -} \ No newline at end of file +} diff --git a/shaders/composite6.vsh b/shaders/composite6.vsh index bd893f8..97113b9 100644 --- a/shaders/composite6.vsh +++ b/shaders/composite6.vsh @@ -1,32 +1,8 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable - #include "lib/settings.glsl" -flat varying vec4 lightCol; -flat varying vec3 WsunVec; - -uniform mat4 gbufferModelViewInverse; -uniform int frameCounter; -uniform vec3 sunPosition; -uniform float sunElevation; - -flat varying vec2 TAA_Offset; -uniform sampler2D colortex4; -flat varying vec3 zMults; -uniform float far; -uniform float near; -#include "/lib/res_params.glsl" -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.); - - -flat varying vec3 noooormal; +#include "lib/res_params.glsl" +uniform float viewWidth; +uniform float viewHeight; //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -34,21 +10,9 @@ flat varying vec3 noooormal; //////////////////////////////VOID MAIN////////////////////////////// void main() { - zMults = vec3(1.0/(far * near),far+near,far-near); + //Improves performances and makes sure bloom radius stays the same at high resolution (>1080p) + vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); gl_Position = ftransform(); - #ifdef TAA_UPSCALING - gl_Position.xy = (gl_Position.xy*0.5+0.5)*RENDER_SCALE*2.0-1.0; - #endif - - TAA_Offset = offsets[frameCounter%8]; - #ifndef TAA - TAA_Offset = vec2(0.0); - #endif - vec3 sc = texelFetch2D(colortex4,ivec2(6,37),0).rgb; - lightCol.a = float(sunElevation > 1e-5)*2-1.; - lightCol.rgb = sc; - - WsunVec = lightCol.a*normalize(mat3(gbufferModelViewInverse) *sunPosition); - - vec3 noooormal = normalize(gl_NormalMatrix * gl_Normal); + //*0.51 to avoid errors when sampling outside since clearing is disabled + gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.51*BLOOM_QUALITY/clampedRes*vec2(1920.0,1080.)*2.0-1.0; } diff --git a/shaders/composite7.fsh b/shaders/composite7.fsh index b9d938b..600234b 100644 --- a/shaders/composite7.fsh +++ b/shaders/composite7.fsh @@ -1,10 +1,12 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable - #include "lib/settings.glsl" +//downsample 1st pass (half res) for bloom +#include "lib/res_params.glsl" uniform sampler2D colortex3; -// Compute 3x3 min max for TAA - +// uniform sampler2D colortex8; +uniform vec2 texelSize; +uniform float viewWidth; +uniform float viewHeight; //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -12,35 +14,31 @@ uniform sampler2D colortex3; //////////////////////////////VOID MAIN////////////////////////////// void main() { -/* DRAWBUFFERS:06 */ - ivec2 center = ivec2(gl_FragCoord.xy); - vec3 current = texelFetch2D(colortex3, center, 0).rgb; - vec3 cMin = current; - vec3 cMax = current; - current = texelFetch2D(colortex3, center + ivec2(-1, -1), 0).rgb; - cMin = min(cMin, current); - cMax = max(cMax, current); - current = texelFetch2D(colortex3, center + ivec2(-1, 0), 0).rgb; - cMin = min(cMin, current); - cMax = max(cMax, current); - current = texelFetch2D(colortex3, center + ivec2(-1, 1), 0).rgb; - cMin = min(cMin, current); - cMax = max(cMax, current); - current = texelFetch2D(colortex3, center + ivec2(0, -1), 0).rgb; - cMin = min(cMin, current); - cMax = max(cMax, current); - current = texelFetch2D(colortex3, center + ivec2(0, 1), 0).rgb; - cMin = min(cMin, current); - cMax = max(cMax, current); - current = texelFetch2D(colortex3, center + ivec2(1, -1), 0).rgb; - cMin = min(cMin, current); - cMax = max(cMax, current); - current = texelFetch2D(colortex3, center + ivec2(1, 0), 0).rgb; - cMin = min(cMin, current); - cMax = max(cMax, current); - current = texelFetch2D(colortex3, center + ivec2(1, 1), 0).rgb; - cMin = min(cMin, current); - cMax = max(cMax, current); - gl_FragData[0].rgb = cMax; - gl_FragData[1].rgb = cMin; + +/* DRAWBUFFERS:6 */ +vec2 resScale = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))/vec2(1920.,1080.); +vec2 quarterResTC = gl_FragCoord.xy*texelSize*2.; + + //0.5 + gl_FragData[0] = texture2D(colortex3,quarterResTC-1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; + gl_FragData[0] += texture2D(colortex3,quarterResTC+1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; + gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(-1.0*texelSize.x,1.0*texelSize.y))/4.*0.5; + gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(1.0*texelSize.x,-1.0*texelSize.y))/4.*0.5; + + //0.25 + gl_FragData[0] += texture2D(colortex3,quarterResTC-2.0*vec2(texelSize.x,0.0))/2.*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(0.0,texelSize.y))/2.*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(0,-texelSize.y))/2*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(-texelSize.x,0.0))/2*0.125; + + //0.125 + gl_FragData[0] += texture2D(colortex3,quarterResTC-2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(-2.0*texelSize.x,2.0*texelSize.y))/4.*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(2.0*texelSize.x,-2.0*texelSize.y))/4.*0.125; + + //0.125 + gl_FragData[0] += texture2D(colortex3,quarterResTC)*0.125; + + gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); } diff --git a/shaders/composite7.vsh b/shaders/composite7.vsh index 09df2ce..23439b2 100644 --- a/shaders/composite7.vsh +++ b/shaders/composite7.vsh @@ -1,9 +1,8 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable - #include "lib/settings.glsl" - -#include "/lib/res_params.glsl" +#include "lib/res_params.glsl" +uniform float viewWidth; +uniform float viewHeight; //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -11,8 +10,9 @@ //////////////////////////////VOID MAIN////////////////////////////// void main() { + //Improves performances and makes sure bloom radius stays the same at high resolution (>1080p) + vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); gl_Position = ftransform(); - #ifdef TAA_UPSCALING - gl_Position.xy = (gl_Position.xy*0.5+0.5)*RENDER_SCALE*2.0-1.0; - #endif + //*0.51 to avoid errors when sampling outside since clearing is disabled + gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.26*BLOOM_QUALITY/clampedRes*vec2(1920.0,1080.)*2-1.0; } diff --git a/shaders/composite8.fsh b/shaders/composite8.fsh index 0461935..513baa1 100644 --- a/shaders/composite8.fsh +++ b/shaders/composite8.fsh @@ -1,452 +1,62 @@ #version 120 -//Temporal Anti-Aliasing + Dynamic exposure calculations (vertex shader) - -#extension GL_EXT_gpu_shader4 : enable - #include "lib/settings.glsl" +//6 Horizontal gaussian blurs and horizontal downsampling #include "lib/res_params.glsl" - -//TAA OPTIONS - -const int noiseTextureResolution = 32; - -const int RGBA32F = 1; -const int R11F_G11F_B10F = 1; -#ifdef SCREENSHOT_MODE - const int colortex5Format = RGBA32F; //TAA buffer (everything) -#else - const int colortex5Format = R11F_G11F_B10F; //TAA buffer (everything) -#endif - - -/* -const int colortex0Format = RGBA16F; // low res clouds (deferred->composite2) + low res VL (composite5->composite15) -const int colortex1Format = RGBA16; //terrain gbuffer (gbuffer->composite2) -const int colortex2Format = RGBA16F; //forward + transparencies (gbuffer->composite4) -const int colortex3Format = R11F_G11F_B10F; //frame buffer + bloom (deferred6->final) -const int colortex4Format = RGBA16F; //light values and skyboxes (everything) - -const int colortex6Format = R11F_G11F_B10F; //additionnal buffer for bloom (composite3->final) -const int colortex7Format = RGBA8; //Final output, transparencies id (gbuffer->composite4) -const int colortex8Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) -const int colortex9Format = RGBA8; //Final output, transparencies id (gbuffer->composite4) -const int colortex10Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) -const int colortex13Format = RGBA16F; //Final output, transparencies id (gbuffer->composite4) -// const int colortex15Format = RGBA16F; // flat normals and vanilla -*/ -//no need to clear the buffers, saves a few fps -/* -const bool colortex0Clear = false; -const bool colortex1Clear = false; -const bool colortex2Clear = true; -const bool colortex3Clear = false; -const bool colortex4Clear = false; -const bool colortex5Clear = false; -const bool colortex6Clear = false; -const bool colortex7Clear = false; -*/ -varying vec2 texcoord; -flat varying float exposureA; -flat varying float tempOffsets; -uniform sampler2D colortex3; -uniform sampler2D colortex5; -uniform sampler2D colortex0; uniform sampler2D colortex6; -uniform sampler2D colortex7; -uniform sampler2D colortex1; -uniform sampler2D colortex10; -uniform sampler2D colortex13; -uniform sampler2D depthtex0; -uniform sampler2D depthtex1; - uniform vec2 texelSize; -uniform float frameTimeCounter; -uniform float viewHeight; +varying vec2 texcoord; uniform float viewWidth; -uniform int frameCounter; -uniform int framemod8; -uniform vec3 previousCameraPosition; -uniform mat4 gbufferPreviousModelView; -#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) -#include "lib/projections.glsl" - - -float luma(vec3 color) { - return dot(color,vec3(0.21, 0.72, 0.07)); -} -float interleaved_gradientNoise(){ - return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+tempOffsets); -} -float triangularize(float dither) -{ - float center = dither*2.0-1.0; - dither = center*inversesqrt(abs(center)); - return clamp(dither-fsign(center),0.0,1.0); -} -vec3 fp10Dither(vec3 color,float dither){ - const vec3 mantissaBits = vec3(6.,6.,5.); - vec3 exponent = floor(log2(color)); - return color + dither*exp2(-mantissaBits)*exp2(exponent); -} - - -//returns the projected coordinates of the closest point to the camera in the 3x3 neighborhood -vec3 closestToCamera5taps(vec2 texcoord, sampler2D depth) -{ - vec2 du = vec2(texelSize.x*2., 0.0); - vec2 dv = vec2(0.0, texelSize.y*2.); - - vec3 dtl = vec3(texcoord,0.) + vec3(-texelSize, texture2D(depth, texcoord - dv - du).x); - vec3 dtr = vec3(texcoord,0.) + vec3( texelSize.x, -texelSize.y, texture2D(depth, texcoord - dv + du).x); - vec3 dmc = vec3(texcoord,0.) + vec3( 0.0, 0.0, texture2D(depth, texcoord).x); - vec3 dbl = vec3(texcoord,0.) + vec3(-texelSize.x, texelSize.y, texture2D(depth, texcoord + dv - du).x); - vec3 dbr = vec3(texcoord,0.) + vec3( texelSize.x, texelSize.y, texture2D(depth, texcoord + dv + du).x); - - vec3 dmin = dmc; - dmin = dmin.z > dtr.z? dtr : dmin; - dmin = dmin.z > dtl.z? dtl : dmin; - dmin = dmin.z > dbl.z? dbl : dmin; - dmin = dmin.z > dbr.z? dbr : dmin; - #ifdef TAA_UPSCALING - dmin.xy = dmin.xy/RENDER_SCALE; - #endif - return dmin; -} - -//Modified texture interpolation from inigo quilez -vec4 smoothfilter(in sampler2D tex, in vec2 uv) -{ - vec2 textureResolution = vec2(viewWidth,viewHeight); - uv = uv*textureResolution + 0.5; - vec2 iuv = floor( uv ); - vec2 fuv = fract( uv ); - uv = iuv + fuv*fuv*fuv*(fuv*(fuv*6.0-15.0)+10.0); - uv = (uv - 0.5)/textureResolution; - return texture2D( tex, uv); -} -//Due to low sample count we "tonemap" the inputs to preserve colors and smoother edges -vec3 weightedSample(sampler2D colorTex, vec2 texcoord){ - vec3 wsample = texture2D(colorTex,texcoord).rgb*exposureA; - return wsample/(1.0+luma(wsample)); - -} - - -//from : https://gist.github.com/TheRealMJP/c83b8c0f46b63f3a88a5986f4fa982b1 -vec4 SampleTextureCatmullRom(sampler2D tex, vec2 uv, vec2 texSize ) -{ - // We're going to sample a a 4x4 grid of texels surrounding the target UV coordinate. We'll do this by rounding - // down the sample location to get the exact center of our "starting" texel. The starting texel will be at - // location [1, 1] in the grid, where [0, 0] is the top left corner. - vec2 samplePos = uv * texSize; - vec2 texPos1 = floor(samplePos - 0.5) + 0.5; - - // Compute the fractional offset from our starting texel to our original sample location, which we'll - // feed into the Catmull-Rom spline function to get our filter weights. - vec2 f = samplePos - texPos1; - - // Compute the Catmull-Rom weights using the fractional offset that we calculated earlier. - // These equations are pre-expanded based on our knowledge of where the texels will be located, - // which lets us avoid having to evaluate a piece-wise function. - vec2 w0 = f * ( -0.5 + f * (1.0 - 0.5*f)); - vec2 w1 = 1.0 + f * f * (-2.5 + 1.5*f); - vec2 w2 = f * ( 0.5 + f * (2.0 - 1.5*f) ); - vec2 w3 = f * f * (-0.5 + 0.5 * f); - - // Work out weighting factors and sampling offsets that will let us use bilinear filtering to - // simultaneously evaluate the middle 2 samples from the 4x4 grid. - vec2 w12 = w1 + w2; - vec2 offset12 = w2 / (w1 + w2); - - // Compute the final UV coordinates we'll use for sampling the texture - vec2 texPos0 = texPos1 - vec2(1.0); - vec2 texPos3 = texPos1 + vec2(2.0); - vec2 texPos12 = texPos1 + offset12; - - texPos0 *= texelSize; - texPos3 *= texelSize; - texPos12 *= texelSize; - - vec4 result = vec4(0.0); - result += texture2D(tex, vec2(texPos0.x, texPos0.y)) * w0.x * w0.y; - result += texture2D(tex, vec2(texPos12.x, texPos0.y)) * w12.x * w0.y; - result += texture2D(tex, vec2(texPos3.x, texPos0.y)) * w3.x * w0.y; - - result += texture2D(tex, vec2(texPos0.x, texPos12.y)) * w0.x * w12.y; - result += texture2D(tex, vec2(texPos12.x, texPos12.y)) * w12.x * w12.y; - result += texture2D(tex, vec2(texPos3.x, texPos12.y)) * w3.x * w12.y; - - result += texture2D(tex, vec2(texPos0.x, texPos3.y)) * w0.x * w3.y; - result += texture2D(tex, vec2(texPos12.x, texPos3.y)) * w12.x * w3.y; - result += texture2D(tex, vec2(texPos3.x, texPos3.y)) * w3.x * w3.y; - - return result; -} -float R2_dither(){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y + 1.0/1.6180339887 * frameCounter); -} -//approximation from SMAA presentation from siggraph 2016 -vec3 FastCatmulRom(sampler2D colorTex, vec2 texcoord, vec4 rtMetrics, float sharpenAmount) -{ - vec2 position = rtMetrics.zw * texcoord; - vec2 centerPosition = floor(position - 0.5) + 0.5; - vec2 f = position - centerPosition; - vec2 f2 = f * f; - vec2 f3 = f * f2; - - float c = sharpenAmount; - vec2 w0 = -c * f3 + 2.0 * c * f2 - c * f; - vec2 w1 = (2.0 - c) * f3 - (3.0 - c) * f2 + 1.0; - vec2 w2 = -(2.0 - c) * f3 + (3.0 - 2.0 * c) * f2 + c * f; - vec2 w3 = c * f3 - c * f2; - - vec2 w12 = w1 + w2; - vec2 tc12 = rtMetrics.xy * (centerPosition + w2 / w12); - vec3 centerColor = texture2D(colorTex, vec2(tc12.x, tc12.y)).rgb; - - vec2 tc0 = rtMetrics.xy * (centerPosition - 1.0); - vec2 tc3 = rtMetrics.xy * (centerPosition + 2.0); - vec4 color = vec4(texture2D(colorTex, vec2(tc12.x, tc0.y )).rgb, 1.0) * (w12.x * w0.y ) + - vec4(texture2D(colorTex, vec2(tc0.x, tc12.y)).rgb, 1.0) * (w0.x * w12.y) + - vec4(centerColor, 1.0) * (w12.x * w12.y) + - vec4(texture2D(colorTex, vec2(tc3.x, tc12.y)).rgb, 1.0) * (w3.x * w12.y) + - vec4(texture2D(colorTex, vec2(tc12.x, tc3.y )).rgb, 1.0) * (w12.x * w3.y ); - return color.rgb/color.a; - -} - -vec3 clip_aabb(vec3 q,vec3 aabb_min, vec3 aabb_max) - { - vec3 p_clip = 0.5 * (aabb_max + aabb_min); - vec3 e_clip = 0.5 * (aabb_max - aabb_min) + 0.00000001; - - vec3 v_clip = q - vec3(p_clip); - vec3 v_unit = v_clip.xyz / e_clip; - vec3 a_unit = abs(v_unit); - float ma_unit = max(a_unit.x, max(a_unit.y, a_unit.z)); - - if (ma_unit > 1.0) - return vec3(p_clip) + v_clip / ma_unit; - else - return q; +uniform float viewHeight; +vec2 resScale = vec2(1920.,1080.)/max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))*BLOOM_QUALITY; +vec3 gauss1D(vec2 coord,vec2 dir,float alpha,int maxIT){ + vec4 tot = vec4(0.); + float maxTC = 0.25*resScale.x; + float minTC = 0.; + for (int i = -maxIT;i minTC && spCoord.x < maxTC); } -vec3 toClipSpace3Prev(vec3 viewSpacePosition) { - return projMAD(gbufferPreviousProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; + return tot.rgb/max(1.0,tot.a); } -vec3 tonemap(vec3 col){ - return col/(1+luma(col)); -} -vec3 invTonemap(vec3 col){ - return col/(1-luma(col)); -} -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.); -vec3 TAA_hq(bool hand, bool istranslucent){ - #ifdef TAA_UPSCALING - vec2 adjTC = clamp(texcoord*RENDER_SCALE, vec2(0.0),RENDER_SCALE-texelSize*2.); - #else - vec2 adjTC = texcoord; - #endif - - //use velocity from the nearest texel from camera in a 3x3 box in order to improve edge quality in motion - #ifdef CLOSEST_VELOCITY - vec3 closestToCamera = closestToCamera5taps(adjTC, depthtex0); - #endif - - #ifndef CLOSEST_VELOCITY - vec3 closestToCamera = vec3(texcoord,texture2D(depthtex1,adjTC).x); - #endif - - //reproject previous frame - vec3 fragposition = toScreenSpace(closestToCamera); - fragposition = mat3(gbufferModelViewInverse) * fragposition + gbufferModelViewInverse[3].xyz + (cameraPosition - previousCameraPosition); - vec3 previousPosition = mat3(gbufferPreviousModelView) * fragposition + gbufferPreviousModelView[3].xyz; - previousPosition = toClipSpace3Prev(previousPosition); - vec2 velocity = previousPosition.xy - closestToCamera.xy; - previousPosition.xy = texcoord + velocity; - - //reject history if off-screen and early exit - if (previousPosition.x < 0.0 || previousPosition.y < 0.0 || previousPosition.x > 1.0 || previousPosition.y > 1.0) - return smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).xyz; - - #ifdef TAA_UPSCALING - vec3 albedoCurrent0 = smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).xyz; - // Interpolating neighboorhood clampling boundaries between pixels - vec3 cMax = texture2D(colortex0, adjTC).rgb; - vec3 cMin = texture2D(colortex6, adjTC).rgb; - #else - vec3 albedoCurrent0 = texture2D(colortex3, adjTC).rgb; - vec3 albedoCurrent1 = texture2D(colortex3, adjTC + vec2(texelSize.x,texelSize.y)).rgb; - vec3 albedoCurrent2 = texture2D(colortex3, adjTC + vec2(texelSize.x,-texelSize.y)).rgb; - vec3 albedoCurrent3 = texture2D(colortex3, adjTC + vec2(-texelSize.x,-texelSize.y)).rgb; - vec3 albedoCurrent4 = texture2D(colortex3, adjTC + vec2(-texelSize.x,texelSize.y)).rgb; - vec3 albedoCurrent5 = texture2D(colortex3, adjTC + vec2(0.0,texelSize.y)).rgb; - vec3 albedoCurrent6 = texture2D(colortex3, adjTC + vec2(0.0,-texelSize.y)).rgb; - vec3 albedoCurrent7 = texture2D(colortex3, adjTC + vec2(-texelSize.x,0.0)).rgb; - vec3 albedoCurrent8 = texture2D(colortex3, adjTC + vec2(texelSize.x,0.0)).rgb; - //Assuming the history color is a blend of the 3x3 neighborhood, we clamp the history to the min and max of each channel in the 3x3 neighborhood - vec3 cMax = max(max(max(albedoCurrent0,albedoCurrent1),albedoCurrent2),max(albedoCurrent3,max(albedoCurrent4,max(albedoCurrent5,max(albedoCurrent6,max(albedoCurrent7,albedoCurrent8)))))); - vec3 cMin = min(min(min(albedoCurrent0,albedoCurrent1),albedoCurrent2),min(albedoCurrent3,min(albedoCurrent4,min(albedoCurrent5,min(albedoCurrent6,min(albedoCurrent7,albedoCurrent8)))))); - albedoCurrent0 = smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).rgb; - #endif - - #ifndef NO_CLIP - vec3 albedoPrev = max(FastCatmulRom(colortex5, previousPosition.xy,vec4(texelSize, 1.0/texelSize), 0.75).xyz, 0.0); - vec3 finalcAcc = clamp(albedoPrev,cMin,cMax); - - //Increases blending factor when far from AABB and in motion, reduces ghosting - float isclamped = distance(albedoPrev,finalcAcc)/luma(albedoPrev) * 0.5; - float movementRejection = (0.12+isclamped)*clamp(length(velocity/texelSize),0.0,1.0); - - float test = 0.05; - if(hand) movementRejection *= 5; - if(istranslucent) test = 0.1; - - //Blend current pixel with clamped history, apply fast tonemap beforehand to reduce flickering - // vec3 supersampled = invTonemap(mix(tonemap(finalcAcc),tonemap(albedoCurrent0),clamp(BLEND_FACTOR + movementRejection, min(luma(motionVector) *255,1.0),1.))); - - vec3 supersampled = invTonemap(mix(tonemap(finalcAcc),tonemap(albedoCurrent0),clamp(BLEND_FACTOR + movementRejection, test,1.))); - #endif - - - #ifdef NO_CLIP - vec3 albedoPrev = texture2D(colortex5, previousPosition.xy).xyz; - vec3 supersampled = mix(albedoPrev,albedoCurrent0,clamp(0.05,0.,1.)); - #endif - - //De-tonemap - return supersampled; -} - - -vec3 decode (vec2 encn){ - vec3 n = vec3(0.0); - encn = encn * 2.0 - 1.0; - n.xy = abs(encn); - n.z = 1.0 - n.x - n.y; - n.xy = n.z <= 0.0 ? (1.0 - n.yx) * sign(encn) : encn; - return clamp(normalize(n.xyz),-1.0,1.0); -} -vec2 decodeVec2(float a){ - const vec2 constant1 = 65535. / vec2( 256., 65536.); - const float constant2 = 256. / 255.; - return fract( a * constant1 ) * constant2 ; -} -vec2 R2_samples(int n){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha * n)*2.-1.0; -} -vec4 TAA_hq_render(){ - #ifdef TAA_UPSCALING - vec2 adjTC = clamp(texcoord*RENDER_SCALE, vec2(0.0),RENDER_SCALE-texelSize*2.); - #else - vec2 adjTC = texcoord; - #endif - - //use velocity from the nearest texel from camera in a 3x3 box in order to improve edge quality in motion - #ifdef CLOSEST_VELOCITY - vec3 closestToCamera = closestToCamera5taps(adjTC,depthtex0); - #endif - - #ifndef CLOSEST_VELOCITY - vec3 closestToCamera = vec3(texcoord,texture2D(depthtex0,adjTC).x); - #endif - - //reproject previous frame - vec3 fragposition = toScreenSpace(closestToCamera); - fragposition = mat3(gbufferModelViewInverse) * fragposition + gbufferModelViewInverse[3].xyz + (cameraPosition - previousCameraPosition); - vec3 previousPosition = mat3(gbufferPreviousModelView) * fragposition + gbufferPreviousModelView[3].xyz; - previousPosition = toClipSpace3Prev(previousPosition); - vec2 velocity = previousPosition.xy - closestToCamera.xy; - previousPosition.xy = texcoord + velocity; - - // //reject history if off-screen and early exit - if (previousPosition.x < 0.0 || previousPosition.y < 0.0 || previousPosition.x > 1.0 || previousPosition.y > 1.0) - return vec4(smoothfilter(colortex3, adjTC + R2_samples(frameCounter)*texelSize*0.5).xyz, 1.0); - - vec3 albedoCurrent0 = smoothfilter(colortex3, adjTC + R2_samples(frameCounter)*texelSize*0.5).xyz; - - float rej = 0.0; - vec4 albedoPrev = texture2D(colortex5, previousPosition.xy); - vec3 supersampled = albedoPrev.rgb * albedoPrev.a + albedoCurrent0; - - if (length(velocity) > 1e-6) return vec4(albedoCurrent0,1.0); - return vec4(supersampled/(albedoPrev.a+1.0), albedoPrev.a+1.0); -} +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// void main() { +/* DRAWBUFFERS:6 */ -/* DRAWBUFFERS:5 */ +vec2 texcoord = (gl_FragCoord.xy*vec2(2.0,4.0))*texelSize; +vec2 gaussDir = vec2(1.0,0.0); +gl_FragData[0].rgb = vec3(0.0); +vec2 tc2 = texcoord*vec2(2.0,1.)/2.; +if (tc2.x < 1.0*resScale.x && tc2.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(tc2/2,gaussDir,0.16,0); - // vec3 motionVector = texture2D(colortex10,texcoord).xyz ; +vec2 tc4 = texcoord*vec2(4.0,1.)/2.-vec2(0.5*resScale.x+4.0*texelSize.x,0.)*2.0; +if (tc4.x > 0.0 && tc4.y > 0.0 && tc4.x < 1.0*resScale.x && tc4.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(tc4/2,gaussDir,0.16,3); - // vec3 viewpos = motionVector; - // vec3 eyepos = mat3(gbufferModelViewInverse) * viewpos; - // vec3 worldPos = eyepos + (cameraPosition + gbufferModelViewInverse[3].xyz); - // vec3 feetPos = worldPos - cameraPosition; +vec2 tc8 = texcoord*vec2(8.0,1.)/2.-vec2(0.75*resScale.x+8.*texelSize.x,0.)*4.0; +if (tc8.x > 0.0 && tc8.y > 0.0 && tc8.x < 1.0*resScale.x && tc8.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(tc8/2,gaussDir,0.035,6); - // vec4 clippos = gbufferProjection * vec4(viewpos,1.0); +vec2 tc16 = texcoord*vec2(8.0,1./2.)-vec2(0.875*resScale.x+12.*texelSize.x,0.)*8.0; +if (tc16.x > 0.0 && tc16.y > 0.0 && tc16.x < 1.0*resScale.x && tc16.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(tc16/2,gaussDir,0.0085,12); - // vec3 ndcPos = projectAndDivide(gbufferProjectionInverse, viewpos); - // vec3 screenPos = ndcPos * 0.5 + 0.5; +vec2 tc32 = texcoord*vec2(16.0,1./2.)-vec2(0.9375*resScale.x+16.*texelSize.x,0.)*16.0; +if (tc32.x > 0.0 && tc32.y > 0.0 && tc32.x < 1.0*resScale.x && tc32.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(tc32/2,gaussDir,0.002,28); - // vec3 movement = ( cameraPosition - previousCameraPosition); +vec2 tc64 = texcoord*vec2(32.0,1./2.)-vec2(0.96875*resScale.x+20.*texelSize.x,0.)*32.0; +if (tc64.x > 0.0 && tc64.y > 0.0 && tc64.x < 1.0*resScale.x && tc64.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(tc64/2,gaussDir,0.0005,60); - - gl_FragData[0].a = 1.0; -#ifndef SPLIT_RENDER - #ifdef SCREENSHOT_MODE - - - vec4 color = TAA_hq_render(); - gl_FragData[0] = color; - - - #else - #ifdef TAA - vec4 data = texture2D(colortex1,texcoord* RENDER_SCALE); // terraom - vec4 dataUnpacked1 = vec4(decodeVec2(data.z),decodeVec2(data.w)); - bool hand = abs(dataUnpacked1.w-0.75) < 0.01; - bool translucentCol = texture2D(colortex13,texcoord * RENDER_SCALE).a > 0.0; // translucents - - - - vec3 color = TAA_hq(hand, translucentCol); - gl_FragData[0].rgb = clamp(fp10Dither(color ,triangularize(R2_dither())),6.11*1e-5,65000.0); - #endif - - #ifndef TAA - vec3 color = clamp(fp10Dither(texture2D(colortex3,texcoord).rgb,triangularize(interleaved_gradientNoise())),0.,65000.); - gl_FragData[0].rgb = color; - #endif - #endif -#endif -#ifdef SPLIT_RENDER - if(texcoord.x > 0.5){ - - vec4 color = TAA_hq_render(); - gl_FragData[0] = color; - - }else{ - vec4 data = texture2D(colortex1,texcoord* RENDER_SCALE); // terraom - vec4 dataUnpacked1 = vec4(decodeVec2(data.z),decodeVec2(data.w)); - bool hand = abs(dataUnpacked1.w-0.75) < 0.01; - bool translucentCol = texture2D(colortex13,texcoord * RENDER_SCALE).a > 0.0; // translucents - - - - vec3 color = TAA_hq(hand, translucentCol); - gl_FragData[0].rgb = clamp(fp10Dither(color ,triangularize(R2_dither())),6.11*1e-5,65000.0); - - } -#endif +gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); } diff --git a/shaders/composite8.vsh b/shaders/composite8.vsh index 3c77d0c..568bb90 100644 --- a/shaders/composite8.vsh +++ b/shaders/composite8.vsh @@ -1,18 +1,21 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable - #include "lib/settings.glsl" - +#include "lib/res_params.glsl" +uniform float viewWidth; +uniform float viewHeight; varying vec2 texcoord; -flat varying float exposureA; -flat varying float tempOffsets; -uniform sampler2D colortex4; -uniform int frameCounter; -#include "/lib/util.glsl" -void main() { +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// - tempOffsets = HaltonSeq2(frameCounter%10000); +void main() { + vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.0))/BLOOM_QUALITY; gl_Position = ftransform(); - texcoord = gl_MultiTexCoord0.xy; - exposureA = texelFetch2D(colortex4,ivec2(10,37),0).r; + //0-0.25 + gl_Position.y = (gl_Position.y*0.5+0.5)*0.25/clampedRes.y*1080.0*2.0-1.0; + //0-0.5 + gl_Position.x = (gl_Position.x*0.5+0.5)*0.5/clampedRes.x*1920.0*2.0-1.0; + texcoord = gl_MultiTexCoord0.xy/clampedRes*vec2(1920.,1080.); } diff --git a/shaders/composite9.fsh b/shaders/composite9.fsh index 937e315..da17b54 100644 --- a/shaders/composite9.fsh +++ b/shaders/composite9.fsh @@ -1,50 +1,62 @@ #version 120 -//downsample 1st pass (half res) for bloom - #include "lib/settings.glsl" -uniform sampler2D colortex5; -// uniform sampler2D colortex8; -uniform vec2 texelSize; -uniform float viewWidth; -uniform float viewHeight; - +//6 Vertical gaussian blurs and vertical downsampling #include "lib/res_params.glsl" -void main() { -/* DRAWBUFFERS:3 */ - - -vec2 resScale = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))/vec2(1920.,1080.); -vec2 quarterResTC = gl_FragCoord.xy*texelSize*2.*resScale/BLOOM_QUALITY; - -// float emissives1 = texture2D(colortex8,quarterResTC).a; -// float emissives2 = emissives1 < 1.0 ? emissives1 : 0.0; - - // 0.5 - gl_FragData[0] = texture2D(colortex5,quarterResTC-1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex5,quarterResTC+1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(-1.0*texelSize.x,1.0*texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(1.0*texelSize.x,-1.0*texelSize.y))/4.*0.5; - - //0.25 - gl_FragData[0] += texture2D(colortex5,quarterResTC-2.0*vec2(texelSize.x,0.0))/2.*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(0.0,texelSize.y))/2.*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(0,-texelSize.y))/2*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(-texelSize.x,0.0))/2*0.125; - - //0.125 - gl_FragData[0] += texture2D(colortex5,quarterResTC-2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(-2.0*texelSize.x,2.0*texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(2.0*texelSize.x,-2.0*texelSize.y))/4.*0.125; - - //0.125 - gl_FragData[0] += texture2D(colortex5,quarterResTC)*0.125; - - - gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); - if (quarterResTC.x > 1.0 - 3.5*texelSize.x || quarterResTC.y > 1.0 -3.5*texelSize.y || quarterResTC.x < 3.5*texelSize.x || quarterResTC.y < 3.5*texelSize.y) gl_FragData[0].rgb = vec3(0.0); - - +uniform sampler2D colortex6; +uniform vec2 texelSize; +varying vec2 texcoord; +uniform float viewWidth; +uniform float viewHeight; +vec2 resScale = vec2(1920.,1080.)/max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))*BLOOM_QUALITY; +vec3 gauss1D(vec2 coord,vec2 dir,float alpha,int maxIT){ + vec4 tot = vec4(0.); + float maxTC = 0.25*resScale.y; + float minTC = 0.; + for (int i = -maxIT;i minTC && spCoord.y < maxTC); + } + return tot.rgb/max(1.0,tot.a); +} + +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// + +void main() { +/* DRAWBUFFERS:6 */ +vec2 texcoord = (gl_FragCoord.xy*vec2(2.0,4.0))*texelSize; + +vec2 gaussDir = vec2(0.0,1.0); +gl_FragData[0].rgb = vec3(0.0); +vec2 tc2 = texcoord*vec2(2.0,1.); +if (tc2.x < 1.0*resScale.x && tc2.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord/vec2(2.0,4.0),gaussDir,0.16,0); + +vec2 tc4 = texcoord*vec2(4.0,2.)-vec2(0.5*resScale.x+4.0*texelSize.x,0.)*4.0; +if (tc4.x > 0.0 && tc4.y > 0.0 && tc4.x < 1.0*resScale.x && tc4.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord/vec2(2.0,2.0),gaussDir,0.16,3); + +vec2 tc8 = texcoord*vec2(8.0,4.)-vec2(0.75*resScale.x+8.*texelSize.x,0.)*8.0; +if (tc8.x > 0.0 && tc8.y > 0.0 && tc8.x < 1.0*resScale.x && tc8.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,2.0)/vec2(2.0,2.0),gaussDir,0.035,6); + +vec2 tc16 = texcoord*vec2(16.0,8.)-vec2(0.875*resScale.x+12.*texelSize.x,0.)*16.0; +if (tc16.x > 0.0 && tc16.y > 0.0 && tc16.x < 1.0*resScale.x && tc16.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,4.0)/vec2(2.0,2.0),gaussDir,0.0085,12); + +vec2 tc32 = texcoord*vec2(32.0,16.)-vec2(0.9375*resScale.x+16.*texelSize.x,0.)*32.0; +if (tc32.x > 0.0 && tc32.y > 0.0 && tc32.x < 1.0*resScale.x && tc32.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,8.0)/vec2(2.0,2.0),gaussDir,0.002,30); + +vec2 tc64 = texcoord*vec2(64.0,32.)-vec2(0.96875*resScale.x+20.*texelSize.x,0.)*64.0; +if (tc64.x > 0.0 && tc64.y > 0.0 && tc64.x < 1.0*resScale.x && tc64.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,16.0)/vec2(2.0,2.0),gaussDir,0.0005,60); + +gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); } diff --git a/shaders/composite9.vsh b/shaders/composite9.vsh index 97113b9..82dc7ae 100644 --- a/shaders/composite9.vsh +++ b/shaders/composite9.vsh @@ -1,8 +1,10 @@ #version 120 + #include "lib/settings.glsl" #include "lib/res_params.glsl" uniform float viewWidth; uniform float viewHeight; +varying vec2 texcoord; //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -10,9 +12,12 @@ uniform float viewHeight; //////////////////////////////VOID MAIN////////////////////////////// void main() { - //Improves performances and makes sure bloom radius stays the same at high resolution (>1080p) - vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); + vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.0))/BLOOM_QUALITY; gl_Position = ftransform(); - //*0.51 to avoid errors when sampling outside since clearing is disabled - gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.51*BLOOM_QUALITY/clampedRes*vec2(1920.0,1080.)*2.0-1.0; + //0-0.25 + gl_Position.y = (gl_Position.y*0.5+0.5)*0.25/clampedRes.y*1080.0*2.0-1.0; + //0-0.5 + gl_Position.x = (gl_Position.x*0.5+0.5)*0.5/clampedRes.x*1920.0*2.0-1.0; + texcoord = gl_MultiTexCoord0.xy/clampedRes*vec2(1920.,1080.); + } diff --git a/shaders/deferred.fsh b/shaders/deferred.fsh index 4b00706..95f7d50 100644 --- a/shaders/deferred.fsh +++ b/shaders/deferred.fsh @@ -36,6 +36,7 @@ uniform float rainStrength; uniform float eyeAltitude; uniform float nightVision; uniform vec3 sunVec; +flat varying vec3 WsunVec; uniform vec2 texelSize; uniform float frameTimeCounter; uniform mat4 gbufferProjection; @@ -74,10 +75,39 @@ float R2_dither(){ float blueNoise(){ return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); } +float interleaved_gradientNoise(){ + vec2 coord = gl_FragCoord.xy; + float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y + 1.0/1.6180339887 * frameCounter)); + return noise; +} vec4 lightCol = vec4(lightSourceColor, float(sunElevation > 1e-5)*2-1.); + +float luma(vec3 color) { + return dot(color,vec3(0.299, 0.587, 0.114)); +} #include "lib/volumetricFog.glsl" + const float[17] Slightmap = float[17](14.0,17.,19.0,22.0,24.0,28.0,31.0,40.0,60.0,79.0,93.0,110.0,132.0,160.0,197.0,249.0,249.0); +uniform sampler2D depthtex1;//depth +// #define ffstep(x,y) clamp((y - x) * 1e35,0.0,1.0) +// #define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) +// #define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) +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; +} +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.); + void main() { /* DRAWBUFFERS:4 */ gl_FragData[0] = vec4(0.0); @@ -154,7 +184,7 @@ if (gl_FragCoord.x > 18. && gl_FragCoord.y > 1. && gl_FragCoord.x < 18+257){ sky *= vec3(0.0, 0.18, 0.35); #endif - sky = mix(sky, vec3(0.5,0.5,0.5)*avgSky * 4000., clamp(1 - viewVector.y,0.0,1.0) * rainStrength ); + // sky = mix(sky, vec3(0.5,0.5,0.5)*avgSky * 4000., clamp(1 - viewVector.y,0.0,1.0) * rainStrength ); // sky *= max(abs(viewVector.y+0.05),0.25); gl_FragData[0] = vec4(sky/4000.*Sky_Brightness,1.0); } @@ -163,23 +193,24 @@ if (gl_FragCoord.x > 18. && gl_FragCoord.y > 1. && gl_FragCoord.x < 18+257){ if (gl_FragCoord.x > 18.+257. && gl_FragCoord.y > 1. && gl_FragCoord.x < 18+257+257.){ vec2 p = clamp(floor(gl_FragCoord.xy-vec2(18.+257,1.))/256.+tempOffsets/256.,0.0,1.0); vec3 viewVector = cartToSphere(p); - vec4 clouds = renderClouds(mat3(gbufferModelView)*viewVector*1024.,vec3(0.), blueNoise(),sunColorCloud,moonColor,ambientUp,blueNoise()); - mat2x3 vL = getVolumetricRays(fract(frameCounter/1.6180339887),mat3(gbufferModelView)*viewVector*1024.); - float absorbance = dot(vL[1],vec3(0.22,0.71,0.07)); + + vec4 clouds = renderClouds(mat3(gbufferModelView)*viewVector*1024.,vec2(blueNoise(),R2_dither()), sunColorCloud, moonColor, ambientUp*5.0); + vec4 VL_Fog = getVolumetricRays(mat3(gbufferModelView)*viewVector*1024., fract(frameCounter/1.6180339887), ambientUp); + + vec3 skytex = texelFetch2D(colortex4,ivec2(gl_FragCoord.xy)-ivec2(257,0),0).rgb/150.; - - if(viewVector.y < -0.025) skytex = skytex * clamp( exp(viewVector.y - 1.0),0.,1.) ; + if(viewVector.y < -0.025) skytex = skytex * clamp( exp(viewVector.y) - 1.0,0.25,1.0) ; - skytex = skytex*clouds.a + clouds.rgb; + skytex = skytex*clouds.a + clouds.rgb/5.0; + skytex = skytex*VL_Fog.a + VL_Fog.rgb*20; - // gl_FragData[0] = vec4(skytex,1.0); - gl_FragData[0] = vec4(skytex*absorbance+vL[0].rgb,1.0); + gl_FragData[0] = vec4(skytex,1.0); } //Temporally accumulate sky and light values vec3 temp = texelFetch2D(colortex4,ivec2(gl_FragCoord.xy),0).rgb; vec3 curr = gl_FragData[0].rgb*150.; -gl_FragData[0].rgb = clamp(mix(temp,curr,0.06),0.0,65000.); +gl_FragData[0].rgb = clamp(mix(temp,curr,0.07),0.0,65000.); //Exposure values if (gl_FragCoord.x > 10. && gl_FragCoord.x < 11. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) diff --git a/shaders/deferred.vsh b/shaders/deferred.vsh index a36b3ee..3dedc0d 100644 --- a/shaders/deferred.vsh +++ b/shaders/deferred.vsh @@ -32,6 +32,7 @@ uniform sampler2D colortex6; uniform sampler2D depthtex0; +flat varying vec3 WsunVec; uniform mat4 gbufferModelViewInverse; uniform vec3 sunPosition; uniform vec2 texelSize; @@ -246,9 +247,4 @@ void main() { exposure = Manual_exposure_value; rodExposure = clamp(log(Manual_exposure_value*2.0+1.0)-0.1,0.0,2.0); #endif - float modWT = (worldTime%24000)*1.0; - - float fogAmount0 = 1/3000.+FOG_TOD_MULTIPLIER*(1/100.*(clamp(modWT-11000.,0.,2000.0)/2000.+(1.0-clamp(modWT,0.,3000.0)/3000.))*(clamp(modWT-11000.,0.,2000.0)/2000.+(1.0-clamp(modWT,0.,3000.0)/3000.)) + 1/120.*clamp(modWT-13000.,0.,1000.0)/1000.*(1.0-clamp(modWT-23000.,0.,1000.0)/1000.)); - VFAmount = CLOUDY_FOG_AMOUNT*(fogAmount0*fogAmount0+FOG_RAIN_MULTIPLIER*1.0/20000.*rainStrength); - fogAmount = BASE_FOG_AMOUNT*(fogAmount0+max(FOG_RAIN_MULTIPLIER*1/10.*rainStrength , FOG_TOD_MULTIPLIER*1/50.*clamp(modWT-13000.,0.,1000.0)/1000.*(1.0-clamp(modWT-23000.,0.,1000.0)/1000.))); -} +} \ No newline at end of file diff --git a/shaders/deferred1.fsh b/shaders/deferred1.fsh index 306a476..4636f1e 100644 --- a/shaders/deferred1.fsh +++ b/shaders/deferred1.fsh @@ -4,6 +4,9 @@ //Computes volumetric clouds at variable resolution (default 1/4 res) +uniform float far; +uniform float near; +flat varying vec4 lightCol; flat varying vec3 sunColor; flat varying vec3 moonColor; flat varying vec3 avgAmbient; @@ -13,6 +16,7 @@ uniform sampler2D depthtex0; // uniform sampler2D colortex4; uniform sampler2D noisetex; +flat varying vec3 WsunVec; uniform vec3 sunVec; uniform vec2 texelSize; uniform float frameTimeCounter; @@ -74,26 +78,26 @@ vec3 normVec (vec3 vec){ //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// + void main() { /* DRAWBUFFERS:0 */ -float phi = 2 * 3.14159265359; -float noise = fract(fract(frameCounter * (1.0 / phi)) + interleaved_gradientNoise() ) ; + +#ifdef VOLUMETRIC_CLOUDS + // vec2 halfResTC = vec2(floor(gl_FragCoord.xy)/CLOUDS_QUALITY/RENDER_SCALE+0.5+(vec2(tempOffsets)*(texelSize/4))*CLOUDS_QUALITY*RENDER_SCALE*0.5); + + vec2 halfResTC = vec2(floor(gl_FragCoord.xy)/CLOUDS_QUALITY/RENDER_SCALE+0.5+offsets[framemod8]*CLOUDS_QUALITY*RENDER_SCALE*0.5); + + float z = texture2D(depthtex0,halfResTC*texelSize).x; + + vec3 fragpos = toScreenSpace(vec3(halfResTC*texelSize,1)); - #ifdef VOLUMETRIC_CLOUDS - vec2 halfResTC = vec2(floor(gl_FragCoord.xy)/CLOUDS_QUALITY/RENDER_SCALE+0.5+(vec2(tempOffsets)*(texelSize/4))*CLOUDS_QUALITY*RENDER_SCALE*0.5); - - vec3 fragpos = toScreenSpace(vec3(halfResTC*texelSize,1.0)); - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos; - vec3 np3 = normVec(p3); - - - vec4 currentClouds = renderClouds(fragpos,vec3(0.), R2_dither(),sunColor/150.,moonColor/150.,avgAmbient/150.,blueNoise2()); - gl_FragData[0] = currentClouds ; - - - #else - gl_FragData[0] = vec4(0.0,0.0,0.0,1.0); - #endif + vec4 currentClouds = renderClouds(fragpos,vec2(R2_dither(),blueNoise2()), lightCol.rgb/80., moonColor/150., (avgAmbient*2.0)* 8./150./3.); + + gl_FragData[0] = currentClouds; + +#else + gl_FragData[0] = vec4(0.0,0.0,0.0,1.0); +#endif } diff --git a/shaders/deferred1.vsh b/shaders/deferred1.vsh index ef88f75..a6c6771 100644 --- a/shaders/deferred1.vsh +++ b/shaders/deferred1.vsh @@ -5,15 +5,20 @@ flat varying vec3 sunColor; flat varying vec3 moonColor; +flat varying vec4 lightCol; flat varying vec3 avgAmbient; flat varying float tempOffsets; +flat varying vec3 WsunVec; flat varying vec3 ambientUp; flat varying vec3 ambientLeft; flat varying vec3 ambientRight; flat varying vec3 ambientB; flat varying vec3 ambientF; flat varying vec3 ambientDown; +uniform mat4 gbufferModelViewInverse; +uniform vec3 sunPosition; +uniform float sunElevation; uniform sampler2D colortex4; uniform int frameCounter; @@ -35,6 +40,12 @@ void main() { sunColor = texelFetch2D(colortex4,ivec2(12,37),0).rgb; moonColor = texelFetch2D(colortex4,ivec2(13,37),0).rgb; // avgAmbient = texelFetch2D(colortex4,ivec2(11,37),0).rgb; + + vec3 sc = texelFetch2D(colortex4,ivec2(6,37),0).rgb; + lightCol.a = float(sunElevation > 1e-5)*2-1.; + lightCol.rgb = sc; + + WsunVec = lightCol.a*normalize(mat3(gbufferModelViewInverse) *sunPosition); // ambientUp = texelFetch2D(colortex4,ivec2(0,37),0).rgb; // ambientDown = texelFetch2D(colortex4,ivec2(1,37),0).rgb; diff --git a/shaders/entity.properties b/shaders/entity.properties index c57aaa6..fb27360 100644 --- a/shaders/entity.properties +++ b/shaders/entity.properties @@ -3,11 +3,11 @@ ### all the different strengths of subsurface scattering and what entities to put them on. #medium sss (same as strong sss for blocks) -entity.1100 = slime giant ender_dragon ghast +entity.1100 = slime giant ender_dragon ghast #weak sss (same as weak sss for blocks) -entity.1200 = frog sheep chicken snow_golem polar_bear zombie_horse armor_stand arrow squid bat cat cod cow donkey fox horse mooshroom mule ocelot parrot pig piglin polar_bear pufferfish rabbit salmon strider tropical_fish turtle villager wandering_trader bee cave_spider dolphin enderman llama panda spider wolf zombified_piglin blaze creeper drowned elder_gaurdian endermite evoker guardian hoglin husk magma_cube phantom piglin_brute pillager ravager silverfish stray vex vindicator witch zoglin zombie zombie_villager wither player trader_llama +entity.1200 = player frog sheep chicken snow_golem polar_bear zombie_horse armor_stand arrow squid bat cat cod cow donkey fox horse mooshroom mule ocelot parrot pig piglin polar_bear pufferfish rabbit salmon strider tropical_fish turtle villager wandering_trader bee cave_spider dolphin enderman llama panda spider wolf zombified_piglin blaze creeper drowned elder_gaurdian endermite evoker guardian hoglin husk magma_cube phantom piglin_brute pillager ravager silverfish stray vex vindicator witch zoglin zombie zombie_villager wither trader_llama # entity.5000 = minecraft:lightning_bolt -entity.9001 = minecraft:boat -layer.translucent=slime +# entity.9001 = minecraft:boat +# layer.translucent=slime diff --git a/shaders/final.fsh b/shaders/final.fsh index bbbdfa7..296a4a7 100644 --- a/shaders/final.fsh +++ b/shaders/final.fsh @@ -7,7 +7,7 @@ varying vec2 texcoord; uniform sampler2D colortex7; -uniform sampler2D noisetex; +// uniform sampler2D noisetex; uniform vec2 texelSize; uniform float viewWidth; uniform float viewHeight; @@ -94,6 +94,6 @@ void main() { float lum = luma(col); vec3 diff = col-lum; col = col + diff*(-lum*CROSSTALK + SATURATION); - + gl_FragColor.rgb = clamp(int8Dither(col,texcoord),0.0,1.0); } diff --git a/shaders/gbuffers_all_particles.fsh b/shaders/gbuffers_all_particles.fsh index 4612ee5..4fad8fc 100644 --- a/shaders/gbuffers_all_particles.fsh +++ b/shaders/gbuffers_all_particles.fsh @@ -2,15 +2,21 @@ varying vec4 lmtexcoord; varying vec4 color; +flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) +flat varying vec3 avgAmbient; + +uniform vec3 sunVec; +flat varying vec3 WsunVec; + uniform sampler2D texture; uniform sampler2DShadow shadow; uniform sampler2D gaux1; uniform sampler2D noisetex; -uniform vec3 sunVec; -flat varying vec3 WsunVec; uniform float frameTimeCounter; uniform ivec2 eyeBrightnessSmooth; +uniform float far; +uniform float near; uniform vec2 texelSize; uniform float rainStrength; uniform mat4 gbufferProjectionInverse; @@ -19,12 +25,16 @@ uniform mat4 gbufferModelView; uniform mat4 shadowModelView; uniform mat4 shadowProjection; uniform vec3 cameraPosition; + + #include "lib/settings.glsl" #include "lib/Shadow_Params.glsl" #include "/lib/res_params.glsl" #include "lib/sky_gradient.glsl" #include "lib/volumetricClouds.glsl" +#include "lib/diffuse_lighting.glsl" + //faster and actually more precise than pow 2.2 vec3 toLinear(vec3 sRGB){ return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); @@ -72,23 +82,11 @@ float shadow2D_bicubic(sampler2DShadow tex, vec3 sc) g1(fuv.y) * (g0x * shadow2D(tex, vec3(p2,sc.z)).x + g1x * shadow2D(tex, vec3(p3,sc.z)).x); } -float luma(vec3 color) { - return dot(color,vec3(0.299, 0.587, 0.114)); -} + vec3 normVec (vec3 vec){ return vec*inversesqrt(dot(vec,vec)); } -float GetCloudShadow(vec3 eyePlayerPos){ - vec3 worldPos = (eyePlayerPos + cameraPosition) - Cloud_Height; - vec3 cloudPos = worldPos*Cloud_Size + WsunVec/abs(WsunVec.y) * ((3250 - 3250*0.35) - worldPos.y*Cloud_Size) ; - float shadow = getCloudDensity(cloudPos, 1); - // float shadow = (getCloudDensity(cloudPos, 1) + HighAltitudeClouds(cloudPos)) / 2.0; - - shadow = clamp(exp(-shadow*15),0.0,1.0); - - return shadow ; -} //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -104,50 +102,43 @@ void main() { #endif #ifndef WEATHER - gl_FragData[1].a = 0.0; // for bloomy rain gl_FragData[0] = TEXTURE; - vec2 tempOffset = offsets[framemod8]; - float avgBlockLum = luma(texture2DLod(texture, lmtexcoord.xy,128).rgb*color.rgb); - gl_FragData[0].rgb = clamp((gl_FragData[0].rgb)*pow(avgBlockLum,-0.33)*0.85,0.0,1.0); - vec3 albedo = toLinear(gl_FragData[0].rgb); + vec3 Albedo = toLinear(gl_FragData[0].rgb); + vec2 tempOffset = offsets[framemod8]; vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize/RENDER_SCALE,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); vec3 p3 = mat3(gbufferModelViewInverse) * fragpos; vec3 np3 = normVec(p3); - vec3 DirectLightCol = texelFetch2D(gaux1,ivec2(6,37),0).rgb / 127.0; - DirectLightCol *= GetCloudShadow(p3); - vec3 AmbientLight = texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb * 8.0/150.0/3.0; + float Shadows = 0.0; + vec3 p3_shadow = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; + vec3 projectedShadowPosition = mat3(shadowModelView) * p3_shadow + shadowModelView[3].xyz; + projectedShadowPosition = diagonal3(shadowProjection) * projectedShadowPosition + shadowProjection[3].xyz; - //compute shadows only if not backface - float diffuseSun = 0.712; - if (diffuseSun > 0.001) { - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - vec3 projectedShadowPosition = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; - projectedShadowPosition = diagonal3(shadowProjection) * projectedShadowPosition + shadowProjection[3].xyz; + //apply distortion + float distortFactor = calcDistort(projectedShadowPosition.xy); + projectedShadowPosition.xy *= distortFactor; + //do shadows only if on shadow map + if (abs(projectedShadowPosition.x) < 1.0-1.5/shadowMapResolution && abs(projectedShadowPosition.y) < 1.0-1.5/shadowMapResolution){ - //apply distortion - float distortFactor = calcDistort(projectedShadowPosition.xy); - projectedShadowPosition.xy *= distortFactor; - //do shadows only if on shadow map - if (abs(projectedShadowPosition.x) < 1.0-1.5/shadowMapResolution && abs(projectedShadowPosition.y) < 1.0-1.5/shadowMapResolution){ + float diffthresh = 0.0002; + projectedShadowPosition = projectedShadowPosition * vec3(0.5,0.5,0.5/6.0) + vec3(0.5,0.5,0.5); - float diffthresh = 0.0002; - - projectedShadowPosition = projectedShadowPosition * vec3(0.5,0.5,0.5/6.0) + vec3(0.5,0.5,0.5); - - float shading = shadow2D_bicubic(shadow,vec3(projectedShadowPosition + vec3(0.0,0.0,-diffthresh*1.2))); - DirectLightCol *= shading; - } + Shadows += shadow2D_bicubic(shadow,vec3(projectedShadowPosition + vec3(0.0,0.0,-diffthresh*1.2))); + } + #ifdef CLOUDS_SHADOWS + Shadows *= GetCloudShadow(p3); + #endif - float phase = phaseg(clamp(dot(np3, WsunVec),0.0,1.0), 0.7) + 0.05 ; float lightleakfix = clamp(eyeBrightnessSmooth.y/240.0,0.0,1.0); - vec3 DirectLight = DirectLightCol * phase * lightleakfix; - - gl_FragData[0].rgb = (AmbientLight + DirectLight) * albedo; + float phase = phaseg(clamp(dot(np3, WsunVec),0.0,1.0), 0.7) + 1.0 ; + vec3 Direct_lighting = DoDirectLighting(lightCol.rgb/80., Shadows, 1.0, 0.0) * phase * lightleakfix; + vec3 Indirect_lighting = DoAmbientLighting(avgAmbient, vec3(TORCH_R,TORCH_G,TORCH_B), lmtexcoord.zw, 5.0); + + gl_FragData[0].rgb = (Direct_lighting + Indirect_lighting) * Albedo; #endif } \ No newline at end of file diff --git a/shaders/gbuffers_all_particles.vsh b/shaders/gbuffers_all_particles.vsh index 5b964e5..76e0d65 100644 --- a/shaders/gbuffers_all_particles.vsh +++ b/shaders/gbuffers_all_particles.vsh @@ -21,7 +21,9 @@ varying vec4 normalMat; #endif flat varying vec3 WsunVec; -flat varying vec4 lightCol; +flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) +flat varying vec3 avgAmbient; + uniform mat4 gbufferModelViewInverse; uniform vec3 sunPosition; uniform float sunElevation; @@ -53,6 +55,7 @@ void main() { gl_Position = ftransform(); color = gl_Color; + avgAmbient = texelFetch2D(colortex4,ivec2(0,37),0).rgb; vec3 sc = texelFetch2D(colortex4,ivec2(6,37),0).rgb; lightCol.a = float(sunElevation > 1e-5)*2-1.; lightCol.rgb = sc; @@ -61,11 +64,13 @@ void main() { FlatNormals = normalize(gl_NormalMatrix *gl_Normal); + #ifdef MC_NORMAL_MAP tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); #endif normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),1.0); + #ifdef TAA_UPSCALING gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; #endif diff --git a/shaders/gbuffers_all_solid.fsh b/shaders/gbuffers_all_solid.fsh index 008c48d..5c39cc1 100644 --- a/shaders/gbuffers_all_solid.fsh +++ b/shaders/gbuffers_all_solid.fsh @@ -5,6 +5,7 @@ +flat varying int NameTags; #ifndef USE_LUMINANCE_AS_HEIGHTMAP #ifndef MC_NORMAL_MAP @@ -41,14 +42,18 @@ varying vec4 NoSeasonCol; varying vec4 seasonColor; uniform float far; varying vec4 normalMat; + + #ifdef MC_NORMAL_MAP varying vec4 tangent; uniform float wetness; uniform sampler2D normals; -uniform sampler2D specular; varying vec3 FlatNormals; #endif +// #ifdef SPECULARTEX +uniform sampler2D specular; +// #endif #ifdef POM vec2 dcdx = dFdx(vtexcoord.st*vtexcoordam.pq)*exp2(Texture_MipMap_Bias); vec2 dcdy = dFdy(vtexcoord.st*vtexcoordam.pq)*exp2(Texture_MipMap_Bias); @@ -67,22 +72,26 @@ uniform vec3 cameraPosition; uniform float rainStrength; uniform sampler2D noisetex;//depth uniform sampler2D depthtex0; -in vec3 test_motionVectors; + +in vec3 velocity; flat varying float blockID; - -flat varying vec4 TESTMASK; +flat varying int EMISSIVE; // float interleaved_gradientNoise(){ // return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+frameTimeCounter*51.9521); // } +// 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; +// } 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; + vec2 coord = gl_FragCoord.xy; float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)); return noise; } - float blueNoise(){ return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); } @@ -133,11 +142,6 @@ vec4 encode (vec3 n, vec2 lightmaps){ #ifdef MC_NORMAL_MAP - // vec3 applyBump(mat3 tbnMatrix, vec3 bump){ - // float bumpmult = 1.0; - // bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); - // return normalize(bump*tbnMatrix); - // } vec3 applyBump(mat3 tbnMatrix, vec3 bump, float puddle_values){ float bumpmult = clamp(puddle_values,0.0,1.0); bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); @@ -235,7 +239,7 @@ float densityAtPosSNOW(in vec3 pos){ //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// -/* RENDERTARGETS: 1,7,8,13,15 */ +/* RENDERTARGETS: 1,7,8,15 */ void main() { @@ -243,6 +247,7 @@ void main() { float noise = fract(fract(frameCounter * (1.0 / phi)) + interleaved_gradientNoise() ) ; vec3 normal = normalMat.xyz; + vec3 normal2 = normalMat.xyz; #ifdef MC_NORMAL_MAP vec3 tangent2 = normalize(cross(tangent.rgb,normal)*tangent.w); @@ -250,6 +255,7 @@ void main() { tangent.y, tangent2.y, normal.y, tangent.z, tangent2.z, normal.z); #endif + vec2 tempOffset=offsets[framemod8]; vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize/RENDER_SCALE,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); @@ -293,19 +299,24 @@ void main() { if (dist < MAX_OCCLUSION_DISTANCE) { float depthmap = readNormal(vtexcoord.st).a; + float used_POM_DEPTH = 1.0; if ( viewVector.z < 0.0 && depthmap < 0.9999 && depthmap > 0.00001) { - // vec3 interval = viewVector.xyz /-viewVector.z/MAX_OCCLUSION_POINTS*POM_DEPTH; - vec3 interval = (viewVector.xyz /-viewVector.z/MAX_OCCLUSION_POINTS * POM_DEPTH) * clamp(1.0-pow(depthmap,2),0.1,1.0) ; - + #ifdef Adaptive_Step_length + vec3 interval = (viewVector.xyz /-viewVector.z/MAX_OCCLUSION_POINTS * POM_DEPTH) * clamp(1.0-pow(depthmap,2),0.1,1.0) ; + used_POM_DEPTH = 1.0; + #else + vec3 interval = viewVector.xyz /-viewVector.z/MAX_OCCLUSION_POINTS*POM_DEPTH; + #endif vec3 coord = vec3(vtexcoord.st, 1.0); - coord += interval; + + coord += interval * used_POM_DEPTH; float sumVec = 0.5; for (int loopCount = 0; (loopCount < MAX_OCCLUSION_POINTS) && (1.0 - POM_DEPTH + POM_DEPTH * readNormal(coord.st).a ) < coord.p && coord.p >= 0.0; ++loopCount) { - coord = coord+interval; - sumVec += 1; + coord = coord+interval * used_POM_DEPTH; + sumVec += 1.0 * used_POM_DEPTH; } if (coord.t < mincoord) { @@ -330,6 +341,10 @@ void main() { vec4 Albedo = texture2DGradARB(texture, adjustedTexCoord.xy,dcdx,dcdy) * color; + #ifdef ENTITIES + if(NameTags == 1) Albedo = texture2D(texture, lmtexcoord.xy, Texture_MipMap_Bias) * color; + #endif + #ifdef AEROCHROME_MODE vec3 aerochrome_color = mix(vec3(1.0, 0.0, 0.0), vec3(0.715, 0.303, 0.631), AEROCHROME_PINKNESS); float gray = dot(Albedo.rgb, vec3(0.2, 01.0, 0.07)); @@ -354,6 +369,10 @@ void main() { Albedo.rgb = mix(Albedo.rgb, vec3(0.01, 0.08, 0.15), 0.5); } #endif + + #ifdef WhiteWorld + Albedo.rgb = vec3(1.0); + #endif #ifdef DISABLE_ALPHA_MIPMAPS Albedo.a = texture2DGradARB(texture, adjustedTexCoord.xy,vec2(0.),vec2(0.0)).a; @@ -379,6 +398,10 @@ void main() { NormalTex.z = clamp(sqrt(1.0 - dot(NormalTex.xy, NormalTex.xy)),0.0,1.0); normal = applyBump(tbnMatrix,NormalTex, mix(1.0,Puddle_shape,rainfall)); + + #ifdef ENTITIES + if(NameTags == 1) normal = vec3(1); + #endif #endif //////////////////////////////// @@ -393,20 +416,28 @@ void main() { vec4 data1 = clamp(encode(viewToWorld(normal), lmtexcoord.zw),0.,1.0); gl_FragData[0] = vec4(encodeVec2(Albedo.x,data1.x),encodeVec2(Albedo.y,data1.y),encodeVec2(Albedo.z,data1.z),encodeVec2(data1.w,Albedo.w)); - gl_FragData[1].a = 0.0; - #else + #else + float bias = Texture_MipMap_Bias - blueNoise()*0.5; //////////////////////////////// //////////////////////////////// NORMAL //////////////////////////////// #ifdef MC_NORMAL_MAP - vec4 NormalTex = texture2D(normals, lmtexcoord.xy, Texture_MipMap_Bias).rgba; + vec4 NormalTex = texture2D(normals, lmtexcoord.xy, bias).rgba; NormalTex.xy = NormalTex.xy*2.0-1.0; NormalTex.z = clamp(sqrt(1.0 - dot(NormalTex.xy, NormalTex.xy)),0.0,1.0) ; normal = applyBump(tbnMatrix, NormalTex.xyz, mix(1.0,1.0-Puddle_shape,rainfall) ); + + // #ifdef ENTITIES + // if(NameTags == 1 || NameTags == 2) normal = normal2; + // #endif + #ifdef ENTITIES + if(NameTags == 1) normal = vec3(1); + #endif + #endif @@ -414,19 +445,28 @@ void main() { //////////////////////////////// SPECULAR //////////////////////////////// - vec4 SpecularTex = texture2D(specular, lmtexcoord.xy, Texture_MipMap_Bias).rgba; + vec4 SpecularTex = texture2D(specular, lmtexcoord.xy, bias); SpecularTex.r = max(SpecularTex.r, Puddle_shape); SpecularTex.g = max(SpecularTex.g, Puddle_shape*0.04); + + #ifdef ENTITIES + if(NameTags == 1) SpecularTex = vec4(0.0); + #endif + gl_FragData[2] = SpecularTex; + if(EMISSIVE > 0) gl_FragData[2].a = 0.9; + //////////////////////////////// //////////////////////////////// ALBEDO //////////////////////////////// + + vec4 Albedo = texture2D(texture, lmtexcoord.xy, bias) * color; - vec4 Albedo = texture2D(texture, lmtexcoord.xy, Texture_MipMap_Bias) * color; - + // pain in my ass + #ifdef AEROCHROME_MODE vec3 aerochrome_color = mix(vec3(1.0, 0.0, 0.0), vec3(0.715, 0.303, 0.631), AEROCHROME_PINKNESS); float gray = dot(Albedo.rgb, vec3(0.2, 01.0, 0.07)); @@ -473,6 +513,7 @@ void main() { else Albedo.a = 0.0; #endif + #ifdef HAND if (Albedo.a > 0.1) Albedo.a = 0.75; else Albedo.a = 0.0; @@ -482,18 +523,18 @@ void main() { //////////////////////////////// FINALIZE //////////////////////////////// - // #ifndef ENTITIES - // if(TESTMASK.r==255) Albedo.rgb = vec3(0); - // #endif - - vec4 data1 = clamp(blueNoise()/255.0 + encode(viewToWorld(normal), lmtexcoord.zw),0.0,1.0); - gl_FragData[0] = vec4(encodeVec2(Albedo.x,data1.x), encodeVec2(Albedo.y,data1.y), encodeVec2(Albedo.z,data1.z), encodeVec2(data1.w,Albedo.w)); + vec4 data1 = clamp( encode(viewToWorld(normal), (blueNoise()*lmtexcoord.zw/30.0) + lmtexcoord.zw), 0.0, 1.0); + gl_FragData[0] = vec4(encodeVec2(Albedo.x,data1.x), encodeVec2(Albedo.y,data1.y), encodeVec2(Albedo.z,data1.z), encodeVec2(data1.w,Albedo.w)); + + gl_FragData[1].a = 0.0; - #ifdef WORLD - gl_FragData[1].a = 0.0; - #endif - #endif - gl_FragData[4] = vec4(FlatNormals* 0.5 + 0.5,VanillaAO); + gl_FragData[5].x = 0; + + #ifdef ENTITIES + gl_FragData[5].xyz = velocity *0.5+0.5; + #endif + + gl_FragData[3] = vec4(FlatNormals * 0.5 + 0.5,VanillaAO); } \ No newline at end of file diff --git a/shaders/gbuffers_all_solid.vsh b/shaders/gbuffers_all_solid.vsh index 92ed9f7..092f5a6 100644 --- a/shaders/gbuffers_all_solid.vsh +++ b/shaders/gbuffers_all_solid.vsh @@ -2,6 +2,13 @@ #include "lib/settings.glsl" #include "/lib/res_params.glsl" +/* +!! DO NOT REMOVE !! +This code is from Chocapic13' shaders +Read the terms of modification and sharing before changing something below please ! +!! DO NOT REMOVE !! +*/ + #ifndef USE_LUMINANCE_AS_HEIGHTMAP #ifndef MC_NORMAL_MAP @@ -13,23 +20,18 @@ #define MC_NORMAL_MAP #endif -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ -uniform int worldDay; -varying vec4 lmtexcoord; -varying vec4 color; -varying float VanillaAO; -varying vec4 NoSeasonCol; -varying vec4 normalMat; -#ifdef POM -varying vec4 vtexcoordam; // .st for add, .pq for mul -varying vec4 vtexcoord; -#endif +varying vec4 color; +varying vec4 NoSeasonCol; +varying float VanillaAO; + +varying vec4 lmtexcoord; +varying vec4 normalMat; + +#ifdef POM + varying vec4 vtexcoordam; // .st for add, .pq for mul + varying vec4 vtexcoord; +#endif #ifdef MC_NORMAL_MAP varying vec4 tangent; @@ -37,9 +39,6 @@ varying vec4 vtexcoord; varying vec3 FlatNormals; #endif -out vec3 test_motionVectors; -in vec3 at_velocity; - uniform float frameTimeCounter; const float PI48 = 150.796447372*WAVY_SPEED; float pi2wt = PI48*frameTimeCounter; @@ -47,12 +46,15 @@ float pi2wt = PI48*frameTimeCounter; attribute vec4 mc_Entity; uniform int blockEntityId; uniform int entityId; +flat varying int EMISSIVE; flat varying float blockID; -flat varying vec4 TESTMASK; flat varying int lightningBolt; +flat varying int NameTags; +in vec3 at_velocity; +out vec3 velocity; uniform mat4 gbufferModelView; uniform mat4 gbufferModelViewInverse; @@ -126,8 +128,8 @@ vec3 blackbody2(float Temp) // return dot(color,vec3(0.21, 0.72, 0.07)); // } - #define SEASONS_VSH - #include "/lib/climate_settings.glsl" +#define SEASONS_VSH +#include "/lib/climate_settings.glsl" //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -136,17 +138,31 @@ vec3 blackbody2(float Temp) //////////////////////////////VOID MAIN////////////////////////////// void main() { + + gl_Position = ftransform(); + + NameTags = 0; + + velocity = at_velocity; + + // emission and shit... + EMISSIVE = 0; + #ifndef LabPBR_Emissives + if(mc_Entity.x == 10005) EMISSIVE = 1; + #endif + + #ifdef SPIDEREYES + // gl_Position.xy = gl_Position.xy * 0.9 + 0.9 * gl_Position.w - gl_Position.w; + if(gl_Color.a < 1.0 ) gl_Position = vec4(10,10,10,1); + EMISSIVE = 1; + #endif + + lmtexcoord.xy = (gl_MultiTexCoord0).xy; FlatNormals = normalize(gl_NormalMatrix * gl_Normal); - TESTMASK = vec4(normalize(gl_NormalMatrix * gl_Normal), 1.0); - - TESTMASK.r = blockEntityId == 222 ? 255 : TESTMASK.r; - + blockID = mc_Entity.x; - #ifdef ENTITIES - test_motionVectors = at_velocity; - #endif #ifdef POM vec2 midcoord = (gl_TextureMatrix[0] * mc_midTexCoord).st; @@ -156,15 +172,17 @@ void main() { vtexcoord.xy = sign(texcoordminusmid)*0.5+0.5; #endif - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; + vec2 lmcoord = gl_MultiTexCoord1.xy / 255.0; // is this even correct? lol + lmtexcoord.zw = lmcoord; + vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; color = gl_Color; + VanillaAO = 1.0 - clamp(color.a,0,1); if (color.a < 0.3) color.a = 1.0; // fix vanilla ao on some custom block models. - bool istopv = gl_MultiTexCoord0.t < mc_midTexCoord.t; #ifdef MC_NORMAL_MAP tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); @@ -180,15 +198,20 @@ void main() { normalMat.a = entityId == 1200 ? 0.65 : normalMat.a; #endif #endif + // normalMat.a = 0.45; - normalMat.a = 0.45; - gl_Position = ftransform(); + + + + // try and single out nametag text and then discard nametag background + if( dot(gl_Color.rgb, vec3(0.35)) < 1.0) NameTags = 1; + + if(gl_Color.a >= 0.24 && gl_Color.a <= 0.25 ) gl_Position = vec4(10,10,10,1); #endif - #ifdef WORLD normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),mc_Entity.x == 10004 || mc_Entity.x == 10003 ? 0.5 : mc_Entity.x == 10001 ? 0.6 : 1.0); @@ -200,20 +223,22 @@ void main() { normalMat.a = (mc_Entity.x == 10007 || mc_Entity.x == 10008) ? 0.55 : normalMat.a; // 0.55 abnormal block strong sss #endif - normalMat.a = mc_Entity.x == 10005 ? 0.8 : normalMat.a; + // normalMat.a = mc_Entity.x == 10005 ? 0.8 : normalMat.a; #ifdef WAVY_PLANTS + bool istopv = gl_MultiTexCoord0.t < mc_midTexCoord.t; + if ((mc_Entity.x == 10001 && istopv) && abs(position.z) < 64.0) { - vec3 worldpos = mat3(gbufferModelViewInverse) * position + gbufferModelViewInverse[3].xyz + cameraPosition; - worldpos.xyz += calcMovePlants(worldpos.xyz)*lmtexcoord.w - cameraPosition; - position = mat3(gbufferModelView) * worldpos + gbufferModelView[3].xyz; + vec3 worldpos = mat3(gbufferModelViewInverse) * position + gbufferModelViewInverse[3].xyz + cameraPosition; + worldpos.xyz += calcMovePlants(worldpos.xyz)*lmtexcoord.w - cameraPosition; + position = mat3(gbufferModelView) * worldpos + gbufferModelView[3].xyz; } if (mc_Entity.x == 10003 && abs(position.z) < 64.0) { - vec3 worldpos = mat3(gbufferModelViewInverse) * position + gbufferModelViewInverse[3].xyz + cameraPosition; - worldpos.xyz += calcMoveLeaves(worldpos.xyz, 0.0040, 0.0064, 0.0043, 0.0035, 0.0037, 0.0041, vec3(1.0,0.2,1.0), vec3(0.5,0.1,0.5))*lmtexcoord.w - cameraPosition; - position = mat3(gbufferModelView) * worldpos + gbufferModelView[3].xyz; + vec3 worldpos = mat3(gbufferModelViewInverse) * position + gbufferModelViewInverse[3].xyz + cameraPosition; + worldpos.xyz += calcMoveLeaves(worldpos.xyz, 0.0040, 0.0064, 0.0043, 0.0035, 0.0037, 0.0041, vec3(1.0,0.2,1.0), vec3(0.5,0.1,0.5))*lmtexcoord.w - cameraPosition; + position = mat3(gbufferModelView) * worldpos + gbufferModelView[3].xyz; } #endif @@ -223,33 +248,17 @@ void main() { } gl_Position = toClipSpace3(position); - - - - - #ifdef SEPARATE_AO - - // #if indirect_effect == 1 || indirect_effect == 0 - // lmtexcoord.zw *= sqrt(color.a); - // #endif - - #else - color.rgb *= color.a; - #endif - - // if (mc_Entity.x == 10099 ) seasonColor.rgb = (gl_Color.rgb * blackbody2(sin(frameTimeCounter)*12000 + 14000)) * (1.0 - floor(luma(gl_Color.rgb)+(1.0/255.))); - #endif - // seasonColor = color; NoSeasonCol.rgb = gl_Color.rgb; + #ifdef Seasons #ifndef BLOCKENTITIES #ifndef ENTITIES YearCycleColor(color.rgb, gl_Color.rgb); #endif #endif - #endif + #endif #ifdef TAA_UPSCALING gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; diff --git a/shaders/gbuffers_all_translucent.fsh b/shaders/gbuffers_all_translucent.fsh index 4d31cc3..acf49e3 100644 --- a/shaders/gbuffers_all_translucent.fsh +++ b/shaders/gbuffers_all_translucent.fsh @@ -9,7 +9,6 @@ uniform sampler2D normals; varying vec3 tangent; varying vec4 tangent_other; varying vec3 viewVector; -varying float dist; #include "lib/settings.glsl" #include "/lib/res_params.glsl" @@ -18,11 +17,13 @@ varying float dist; uniform sampler2D texture; uniform sampler2D noisetex; uniform sampler2DShadow shadow; -uniform sampler2D gaux2; -uniform sampler2D gaux1; +// uniform sampler2D gaux2; +// uniform sampler2D gaux1; + +// uniform sampler2D colortex4; +uniform sampler2D colortex5; uniform sampler2D depthtex1; -uniform vec4 lightCol; uniform float nightVision; uniform vec3 sunVec; @@ -50,6 +51,8 @@ uniform int frameCounter; uniform int isEyeInWater; +flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) +flat varying vec3 avgAmbient; @@ -62,6 +65,9 @@ uniform int isEyeInWater; #include "lib/stars.glsl" #include "lib/volumetricClouds.glsl" +#include "lib/diffuse_lighting.glsl" + + const vec2[8] offsets = vec2[8](vec2(1./8.,-3./8.), vec2(-1.,3.)/8., vec2(5.0,1.)/8., @@ -141,7 +147,7 @@ vec3 rayTrace(vec3 dir,vec3 position,float dither, float fresnel, bool inwater){ for (int i = 0; i <= int(quality); i++) { #ifdef USE_QUARTER_RES_DEPTH // decode depth buffer - float sp = sqrt(texelFetch2D(gaux1,ivec2(spos.xy/texelSize/4),0).w/65000.0); + float sp = sqrt(texelFetch2D(colortex4,ivec2(spos.xy/texelSize/4),0).w/65000.0); sp = invLinZ(sp); if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ)) return vec3(spos.xy/RENDER_SCALE,sp); @@ -181,14 +187,15 @@ float cdist(vec2 coord) { return max(abs(coord.s-0.5),abs(coord.t-0.5))*2.0; } - #define PW_DEPTH 0.0 //[0.5 1.0 1.5 2.0 2.5 3.0] - #define PW_POINTS 1 //[2 4 6 8 16 32] + #define PW_DEPTH 1.0 //[0.5 1.0 1.5 2.0 2.5 3.0] + #define PW_POINTS 2 //[2 4 6 8 16 32] #define bayer4(a) (bayer2( .5*(a))*.25+bayer2(a)) #define bayer8(a) (bayer4( .5*(a))*.25+bayer2(a)) #define bayer16(a) (bayer8( .5*(a))*.25+bayer2(a)) #define bayer32(a) (bayer16(.5*(a))*.25+bayer2(a)) #define bayer64(a) (bayer32(.5*(a))*.25+bayer2(a)) #define bayer128(a) fract(bayer64(.5*(a))*.25+bayer2(a)) + vec3 getParallaxDisplacement(vec3 posxz, float iswater,float bumpmult,vec3 viewVec) { float waveZ = mix(20.0,0.25,iswater); float waveM = mix(0.0,4.0,iswater); @@ -316,19 +323,45 @@ vec4 encode (vec3 n, vec2 lightmaps){ float square(float x){ return x*x; } -float g(float NdotL, float roughness){ - float alpha = square(max(roughness, 0.02)); - return 2.0 * NdotL / (NdotL + sqrt(square(alpha) + (1.0 - square(alpha)) * square(NdotL))); -} + float gSimple(float dp, float roughness){ float k = roughness + 1; k *= k/8.0; return dp / (dp * (1.0-k) + k); } +vec3 GGX2_2(vec3 n, vec3 v, vec3 l, float r, vec3 F0) { -vec3 GGX2(vec3 n, vec3 v, vec3 l, float r, vec3 F0,float fresnel) { + float alpha = square(r) + 1e-4; // when roughness is zero it fucks up + + vec3 h = normalize(l + v) ; + + float dotNH = clamp(dot(h,n),0.,1.); + float dotVH = clamp(dot(h,v),0.,1.); + + float D = alpha / (2.2 * square( (dotNH * alpha - 1.0) * square(dotNH) + 1.0) ); + + vec3 F = F0 + (1. - F0) * pow(clamp(1.0 - dotVH,0.0,1.0),5.0); + + return F * D; +} +// float SunGGX(vec3 n, vec3 v, vec3 l, float Roughness, float F0){ + +// vec3 h = normalize(l + v) ; + +// float dotNH = clamp(dot(h,n),0.,1.); +// float dotVH = clamp(dot(h,v),0.,1.); + +// float alpha =max(square(Roughness),1e-4) ; + +// float WallFresnel = F0 + (1. - F0) * pow(clamp(1.0 - dotVH,0.0,1.0),5.0); +// float Sun = square( dotNH - pow(alpha,1.5) - 1.0); + +// float Final = ((alpha / (10.0 * Sun + 1e-4)) * WallFresnel); + +// return Final ; +// } +float SunGGX(vec3 n, vec3 v, vec3 l, float roughness,float F0, float fresnel){ - float roughness = r; float alpha = square(roughness) + 1e-4; // when roughness is zero it fucks up @@ -343,11 +376,39 @@ vec3 GGX2(vec3 n, vec3 v, vec3 l, float r, vec3 F0,float fresnel) { float D = alpha / (0.0541592653589793*square(square(dotNH) * (alpha - 1.0) + 1.0)); float G = gSimple(dotNV, roughness) * gSimple(dotNL, roughness); - vec3 F = F0 + (1. - F0) * exp2((-5.55473*dotVH-6.98316)*dotVH); + float F = F0 + (1. - F0) * exp2((-5.55473*dotVH-6.98316)*dotVH); return dotNL * F * (G * D / (4 * dotNV * dotNL + 1e-7)); } +vec3 GGX (vec3 n, vec3 v, vec3 l, float r, vec3 F0) { + r = pow(r,2.5); +// r*=r; + + vec3 h = l + v; + float hn = inversesqrt(dot(h, h)); + + float dotLH = clamp(dot(h,l)*hn,0.,1.); + float dotNH = clamp(dot(h,n)*hn,0.,1.) ; + float dotNL = clamp(dot(n,l),0.,1.); + float dotNHsq = dotNH*dotNH; + + float denom = dotNHsq * r - dotNHsq + 1.; + float D = r / (3.141592653589793 * denom * denom); + vec3 F = F0 + (1. - F0) * exp2((-5.55473*dotLH-6.98316)*dotLH); + float k2 = .25 * r; + + return dotNL * D * F / (dotLH*dotLH*(1.0-k2)+k2); +} + + +vec3 pixelCoord (vec3 Coordinates, int Resolution){ + return floor(Coordinates / Resolution) * Resolution; +} +#define PHYSICSMOD_FRAGMENT +#include "/lib/oceans.glsl" + + //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -360,32 +421,30 @@ void main() { float iswater = normalMat.w; vec3 fragC = gl_FragCoord.xyz*vec3(texelSize,1.0); vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize/RENDER_SCALE,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); - gl_FragData[0] = texture2D(texture, lmtexcoord.xy,-5)*color; - // float avgBlockLum = luma(texture2DLod(texture, lmtexcoord.xy,128).rgb*color.rgb); - // gl_FragData[0].rgb = clamp((gl_FragData[0].rgb)*pow(avgBlockLum,-0.33)*0.85,0.0,1.0); - - vec3 albedo = toLinear(gl_FragData[0].rgb); + gl_FragData[0] = texture2D(texture, lmtexcoord.xy,Texture_MipMap_Bias)*color; + float alphalabede = gl_FragData[0].a; + vec3 Albedo = toLinear(gl_FragData[0].rgb); +//pain + #ifdef HAND + iswater = 0.1; + #endif #ifndef Vanilla_like_water - if (iswater > 0.4) { - albedo = vec3(1.0); - gl_FragData[0] = vec4(0.42,0.6,0.7,0.7); - } if (iswater > 0.9) { - gl_FragData[0] = vec4(vec3(0.0),1./255.); + Albedo = vec3(0.0); + gl_FragData[0] = vec4(vec3(0.0),1.0/255.0); } #endif #ifdef Vanilla_like_water if (iswater > 0.5) { - gl_FragData[0].a = luma(albedo.rgb); - albedo = color.rgb; + gl_FragData[0].a = luma(Albedo.rgb); + Albedo = color.rgb; } #endif - gl_FragData[4] = vec4(albedo, gl_FragData[0].a); - + gl_FragData[4] = vec4(Albedo, gl_FragData[0].a); vec3 normal = normalMat.xyz; @@ -393,47 +452,73 @@ void main() { mat3 tbnMatrix = mat3(tangent.x, binormal.x, normal.x, tangent.y, binormal.y, normal.y, tangent.z, binormal.z, normal.z); + + vec3 WaterNormals; + vec3 TranslucentNormals; + if (iswater > 0.4){ - float bumpmult = 1.; - vec3 posxz = p3+cameraPosition; - posxz.xz-=posxz.y; - vec3 bump; + + if(physics_iterationsNormal < 1.0){ + float bumpmult = 1.; + + vec3 bump; + + vec3 posxz = p3+cameraPosition; + + posxz.xz -= posxz.y; - posxz.xyz = getParallaxDisplacement(posxz,iswater,bumpmult,normalize(tbnMatrix*fragpos)); + posxz.xyz = getParallaxDisplacement(posxz,iswater,bumpmult,normalize(tbnMatrix*fragpos)) ; - bump = normalize(getWaveHeight(posxz.xz,iswater)); - bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); - normal = normalize(bump * tbnMatrix); - }else { + + bump = normalize(getWaveHeight(posxz.xz,iswater)); + WaterNormals = bump; // tangent space normals for refraction + + bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); + normal = normalize(bump * tbnMatrix); + + + }else{ + vec3 PhysicsMod_normal = physics_waveNormal(physics_localPosition.xz, physics_localWaviness, physics_gameTime); + + normal = normalize(worldToView(PhysicsMod_normal) + mix(normal, vec3(0.0), clamp(physics_localWaviness,0.0,1.0))); + + vec3 worldSpaceNormal = normal; + + vec3 bitangent = normalize(cross(tangent, worldSpaceNormal)); + mat3 tbn_new = mat3(tangent, binormal, worldSpaceNormal); + vec3 tangentSpaceNormal = (worldSpaceNormal * tbn_new); + + WaterNormals = tangentSpaceNormal ; + } + + }else{ vec3 normalTex = texture2D(normals, lmtexcoord.xy, Texture_MipMap_Bias).rgb; normalTex.xy = normalTex.xy*2.0-1.0; normalTex.z = clamp(sqrt(1.0 - dot(normalTex.xy, normalTex.xy)),0.0,1.0); - normal = applyBump(tbnMatrix,normalTex); - } + TranslucentNormals = normalTex; + + normal = applyBump(tbnMatrix,normalTex); + + } + + TranslucentNormals += WaterNormals; vec4 data0 = vec4(1); - vec4 data1 = clamp( encode(viewToWorld(normal), lmtexcoord.zw),0.0,1.0); + vec4 data1 = clamp( encode(TranslucentNormals, lmtexcoord.zw),0.0,1.0); gl_FragData[3] = vec4(encodeVec2(data0.x,data1.x), encodeVec2(data0.y,data1.y), encodeVec2(data0.z,data1.z), encodeVec2(data1.w,data0.w)); gl_FragData[5] = vec4(encodeVec2(lmtexcoord.a,lmtexcoord.a), encodeVec2(lmtexcoord.a,lmtexcoord.a), encodeVec2(lmtexcoord.a,lmtexcoord.a), encodeVec2(lmtexcoord.a,lmtexcoord.a)); - float NdotL = lightSign*dot(normal,sunVec); - float NdotU = dot(upVec,normal); - float diffuseSun = clamp(NdotL,0.0f,1.0f); - diffuseSun = clamp((-15 + diffuseSun*255.0) / 240.0 ,0.0,1.0); - - vec3 direct = texelFetch2D(gaux1,ivec2(6,37),0).rgb/127.0; - - #ifdef ambientLight_only - direct = vec3(0); - #endif + float NdotL = clamp(lightSign*dot(normal,sunVec) ,0.0,1.0); + NdotL = clamp((-15 + NdotL*255.0) / 240.0 ,0.0,1.0); - float shading = 1.0; + + float Shadows = 1.0; float cloudShadow = 1.0; //compute shadows only if not backface - if (diffuseSun > 0.001) { + if (NdotL > 0.001) { vec3 p3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; vec3 projectedShadowPosition = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; projectedShadowPosition = diagonal3(shadowProjection) * projectedShadowPosition + shadowProjection[3].xyz; @@ -444,134 +529,127 @@ void main() { //do shadows only if on shadow map if (abs(projectedShadowPosition.x) < 1.0-1.5/shadowMapResolution && abs(projectedShadowPosition.y) < 1.0-1.5/shadowMapResolution){ const float threshMul = max(2048.0/shadowMapResolution*shadowDistance/128.0,0.95); - float distortThresh = (sqrt(1.0-diffuseSun*diffuseSun)/diffuseSun+0.7)/distortFactor; + float distortThresh = (sqrt(1.0-NdotL*NdotL)/NdotL+0.7)/distortFactor; float diffthresh = distortThresh/6000.0*threshMul; projectedShadowPosition = projectedShadowPosition * vec3(0.5,0.5,0.5/6.0) + vec3(0.5,0.5,0.5); - shading = 0.0; + Shadows = 0.0; float noise = blueNoise(); float rdMul = 4.0/shadowMapResolution; + for(int i = 0; i < 9; i++){ vec2 offsetS = tapLocation(i,9, 1.618,noise,0.0); float weight = 1.0+(i+noise)*rdMul/9.0*shadowMapResolution; - shading += shadow2D(shadow,vec3(projectedShadowPosition + vec3(rdMul*offsetS,-diffthresh*weight))).x/9.0; - } - direct *= shading; + Shadows += shadow2D(shadow,vec3(projectedShadowPosition + vec3(rdMul*offsetS,-diffthresh*weight))).x/9.0; + } } - #ifdef VOLUMETRIC_CLOUDS #ifdef CLOUDS_SHADOWS - vec3 campos = (p3 + cameraPosition)-319 ; - // get cloud position - vec3 cloudPos = campos*Cloud_Size + WsunVec/abs(WsunVec.y) * (2250 - campos.y*Cloud_Size); - // get the cloud density and apply it - cloudShadow = getCloudDensity(cloudPos, 1); - // cloudShadow = exp(-cloudShadow*sqrt(cloudDensity)*25); - - cloudShadow = clamp(exp(-cloudShadow*10),0,1); - - // make these turn to zero when occluded by the cloud shadow - direct *= cloudShadow; - #endif + Shadows *= GetCloudShadow(p3); #endif } - vec3 ambientLight = (texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb * 2.0) * 8./150./3.; + // vec3 ambientLight = (texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb * 2.0) * 8./150./3.; - direct *= (iswater > 0.9 ? 0.2: 1.0)*diffuseSun*lmtexcoord.w; + // direct *= (iswater > 0.9 ? 0.2: 1.0)*NdotL*lmtexcoord.w; - vec3 directLight = direct; + // vec3 directLight = direct; + vec3 WS_normal = viewToWorld(normal); + vec3 ambientCoefs = WS_normal/dot(abs(WS_normal),vec3(1.)); + float skylight = clamp(abs(ambientCoefs.y+1),0.35,2.0) ; - vec3 color = vec3(0); + vec3 Indirect_lighting = DoAmbientLighting(avgAmbient, vec3(TORCH_R,TORCH_G,TORCH_B), lmtexcoord.zw, skylight); + vec3 Direct_lighting = DoDirectLighting(lightCol.rgb/80.0, Shadows, NdotL, 0.0); - - color += ambientLight ; - color += directLight; + vec3 FinalColor = (Direct_lighting + Indirect_lighting) * Albedo; + + // if (iswater > 0.9) FinalColor = Albedo; #ifdef Glass_Tint float alphashit = min(pow(gl_FragData[0].a,2.0),1.0); - color *= alphashit; + FinalColor *= alphashit; #endif - color *= albedo; - vec2 specularstuff = texture2D(specular, lmtexcoord.xy, Texture_MipMap_Bias).rg; - specularstuff = iswater > 0.0 && specularstuff.r > 0.0 && specularstuff.g < 0.9 ? specularstuff : vec2(1.0,0.02); - - if (iswater > 0.0){ - - float roughness = pow(1.0-specularstuff.r,2.0); - float f0 = 0; + vec2 SpecularTex = texture2D(specular, lmtexcoord.xy, Texture_MipMap_Bias).rg; + SpecularTex = iswater > 0.0 && SpecularTex.r > 0.0 && SpecularTex.g < 0.9 ? SpecularTex : vec2(1.0,0.02); + + if (iswater > 0.0 && (SpecularTex.g > 0.0 || SpecularTex.r > 0.0)){ + vec3 Reflections_Final = vec3(0.0); + float roughness = max(pow(1.0-SpecularTex.r,2.0),0.1); + float f0 = SpecularTex.g; float F0 = f0; vec3 reflectedVector = reflect(normalize(fragpos), normal); float normalDotEye = dot(normal, normalize(fragpos)); float fresnel = pow(clamp(1.0 + normalDotEye,0.0,1.0), 5.0); + // float unchangedfresnel = fresnel; // snells window looking thing if(isEyeInWater == 1 && iswater > 0.99) fresnel = clamp(pow(1.66 + normalDotEye,25),0.02,1.0); - fresnel = mix(F0, 1.0, fresnel); + if(isEyeInWater == 1 && physics_iterationsNormal > 0.0) fresnel = clamp( 1.0 - (pow( normalDotEye * 1.66 ,25)),0.02,1.0); + + // fresnel = mix(F0, 1.0, fresnel); + fresnel = F0 + (1.0 - F0) * fresnel; float indoors = clamp((lmtexcoord.w-0.6)*5.0, 0.0,1.0); vec3 wrefl = mat3(gbufferModelViewInverse)*reflectedVector; - vec3 sky_c = skyCloudsFromTex(wrefl,gaux1).rgb / 150. * 5. ; - sky_c.rgb *= indoors; + // SSR, Sky, and Sun reflections + vec4 Reflections = vec4(0.0); + vec3 SkyReflection = skyCloudsFromTex(wrefl,colortex4).rgb / 150. * 5.; + vec3 SunReflection = Direct_lighting * GGX(normal, -normalize(fragpos), lightSign*sunVec, roughness, f0); + // vec3 SunReflection = Direct_lighting * SunGGX(normal, -normalize(fragpos), lightSign*sunVec, roughness, f0, fresnel); - float visibilityFactor = clamp(exp2((pow(roughness,3.0) / F0) * -4),0,1); - - sky_c = mix(sky_c,color,(1.0-indoors)) ; - - vec4 reflection = vec4(0.); - #ifdef SCREENSPACE_REFLECTIONS - vec3 rtPos = rayTrace(reflectedVector,fragpos.xyz, interleaved_gradientNoise(), fresnel, isEyeInWater == 1); - if (rtPos.z <1.){ - vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rtPos) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; - previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; - previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; - if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) { - reflection.a = 1.0; - reflection.rgb = texture2D(gaux2,previousPosition.xy).rgb; + if(iswater > 0.0){ + #ifdef SCREENSPACE_REFLECTIONS + vec3 rtPos = rayTrace(reflectedVector,fragpos.xyz, interleaved_gradientNoise(), fresnel, isEyeInWater == 1); + if (rtPos.z < 1.){ + vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rtPos) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; + previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; + previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; + if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) { + + Reflections.a = 1.0; + Reflections.rgb = texture2D(colortex5,previousPosition.xy).rgb; + } } - } - #endif + #endif + } + float visibilityFactor = clamp(exp2((pow(roughness,3.0) / f0) * -4),0,1); - if(isEyeInWater == 1 ) sky_c.rgb = color.rgb*lmtexcoord.w; + Reflections_Final = mix(SkyReflection*indoors, Reflections.rgb, Reflections.a); + Reflections_Final = mix(FinalColor, Reflections_Final, fresnel * visibilityFactor); + Reflections_Final += SunReflection; - reflection.rgb = mix(sky_c.rgb, reflection.rgb, reflection.a); - vec3 sunSpec = shading*directLight * GGX2(normal, -normalize(fragpos), lightSign*sunVec, roughness, vec3(f0), fresnel) ; - - sunSpec *= max(cloudShadow-0.5,0.0); - - vec3 reflected = reflection.rgb*fresnel + sunSpec ; - - // reflected = vec3(0); + gl_FragData[0].rgb = Reflections_Final; + //correct alpha channel with fresnel float alpha0 = gl_FragData[0].a; - // //correct alpha channel with fresnel gl_FragData[0].a = -gl_FragData[0].a*fresnel+gl_FragData[0].a+fresnel; - gl_FragData[0].rgb = clamp(color/gl_FragData[0].a*alpha0*(1.0-fresnel)*0.1+reflected/gl_FragData[0].a*0.1,0.0,65100.0); - - if (gl_FragData[0].r > 65000.) gl_FragData[0].rgba = vec4(0.); - #ifdef BorderFog - float fog = 1.0 - clamp( exp2(-pow(length(fragpos / far),10.)*3.0) ,0.0,1.0); - gl_FragData[0].a = mix(gl_FragData[0].a, 0.0, fog); - #endif + // //suffering + // #ifdef SPIDEREYES + // gl_FragData[0].rgb = Albedo.rgb * 10; + // #endif - } - else - gl_FragData[0].rgb = color*.1; + } else { + gl_FragData[0].rgb = FinalColor; + } + + #ifndef HAND + gl_FragData[1] = vec4(Albedo,iswater); + #endif +// #endif - gl_FragData[1] = vec4(albedo,iswater); } } diff --git a/shaders/gbuffers_all_translucent.vsh b/shaders/gbuffers_all_translucent.vsh index 31eb0da..1a5d791 100644 --- a/shaders/gbuffers_all_translucent.vsh +++ b/shaders/gbuffers_all_translucent.vsh @@ -16,7 +16,6 @@ varying vec4 color; varying vec4 normalMat; varying vec3 binormal; varying vec3 tangent; -varying float dist; uniform mat4 gbufferModelViewInverse; varying vec3 viewVector; @@ -26,6 +25,7 @@ attribute vec4 at_tangent; attribute vec4 mc_Entity; uniform sampler2D colortex4; + uniform vec3 sunPosition; flat varying vec3 WsunVec; uniform float sunElevation; @@ -33,7 +33,7 @@ uniform float sunElevation; varying vec4 tangent_other; flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) - +flat varying vec3 avgAmbient; uniform vec2 texelSize; @@ -51,6 +51,17 @@ uniform int framemod8; vec4 toClipSpace3(vec3 viewSpacePosition) { return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); } + + + + + + + + +#define PHYSICSMOD_VERTEX +#include "/lib/oceans.glsl" + //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -58,25 +69,42 @@ vec4 toClipSpace3(vec3 viewSpacePosition) { //////////////////////////////VOID MAIN////////////////////////////// void main() { + + vec4 Swtich_gl_vertex = gl_Vertex; + + if(physics_iterationsNormal > 0.0){ + // basic texture to determine how shallow/far away from the shore the water is + physics_localWaviness = texelFetch(physics_waviness, ivec2(gl_Vertex.xz) - physics_textureOffset, 0).r; + // transform gl_Vertex (since it is the raw mesh, i.e. not transformed yet) + vec4 finalPosition = vec4(gl_Vertex.x, gl_Vertex.y + physics_waveHeight(gl_Vertex.xz, PHYSICS_ITERATIONS_OFFSET, physics_localWaviness, physics_gameTime), gl_Vertex.z, gl_Vertex.w); + // pass this to the fragment shader to fetch the texture there for per fragment normals + physics_localPosition = finalPosition.xyz; + + Swtich_gl_vertex.xyz = finalPosition.xyz ; + } + lmtexcoord.xy = (gl_MultiTexCoord0).xy; vec2 lmcoord = gl_MultiTexCoord1.xy/255.; lmtexcoord.zw = lmcoord; - vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; - gl_Position = toClipSpace3(position); + vec3 position = mat3(gl_ModelViewMatrix) * vec3(Swtich_gl_vertex) + gl_ModelViewMatrix[3].xyz; + gl_Position = toClipSpace3(position); color = gl_Color; float mat = 0.0; + if(mc_Entity.x == 8.0 || mc_Entity.x == 9.0) { mat = 1.0; gl_Position.z -= 1e-4; } - - if (mc_Entity.x == 10002) mat = 0.01; + if (mc_Entity.x == 10002) mat = 0.2; if (mc_Entity.x == 72) mat = 0.5; - - // if (mc_Entity.x == 8) mat = 0.1; + + #ifdef ENTITIES + mat = 0.2; + #endif + normalMat = vec4(normalize( gl_NormalMatrix*gl_Normal),mat); @@ -91,9 +119,7 @@ void main() { tangent.y, binormal.y, normalMat.y, tangent.z, binormal.z, normalMat.z); - dist = length(gl_ModelViewMatrix * gl_Vertex); - - viewVector = ( gl_ModelViewMatrix * gl_Vertex).xyz; + viewVector = ( gl_ModelViewMatrix * Swtich_gl_vertex).xyz; viewVector = normalize(tbnMatrix * viewVector); @@ -112,4 +138,6 @@ void main() { lightCol.rgb = sc; WsunVec = lightCol.a*normalize(mat3(gbufferModelViewInverse) *sunPosition); + + avgAmbient = texelFetch2D(colortex4,ivec2(0,37),0).rgb; } diff --git a/shaders/gbuffers_beaconbeam.fsh b/shaders/gbuffers_beaconbeam.fsh index dcf4e65..21b42aa 100644 --- a/shaders/gbuffers_beaconbeam.fsh +++ b/shaders/gbuffers_beaconbeam.fsh @@ -1,35 +1,8 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#include "lib/settings.glsl" +// #define ENTITIES +// #define BLOCKENTITIES +// #define WORLD +#define SPIDEREYES -varying vec4 lmtexcoord; -varying vec4 color; - -uniform sampler2D texture; -uniform sampler2D gaux1; - -//faster and actually more precise than pow 2.2 -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -/* DRAWBUFFERS:2 */ -void main() { - - vec4 Albedo = texture2D(texture, lmtexcoord.xy)*color; - Albedo.a = 1.0; - - float exposure = texelFetch2D(gaux1,ivec2(10,37),0).r; - Albedo.rgb *= 25.0 ; - Albedo.rgb *= clamp(0.5-exposure,0.05,1.0); - - - gl_FragData[0] = Albedo; - -} \ No newline at end of file +#include "gbuffers_all_solid.fsh" \ No newline at end of file diff --git a/shaders/gbuffers_beaconbeam.vsh b/shaders/gbuffers_beaconbeam.vsh index ad085e1..188ebaa 100644 --- a/shaders/gbuffers_beaconbeam.vsh +++ b/shaders/gbuffers_beaconbeam.vsh @@ -1,57 +1,8 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#include "/lib/res_params.glsl" -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ +// #define ENTITIES +// #define BLOCKENTITIES +// #define WORLD +#define SPIDEREYES -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -#ifdef MC_NORMAL_MAP -varying vec4 tangent; -attribute vec4 at_tangent; -#endif - -uniform vec2 texelSize; -uniform int framemod8; - 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.); -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - - gl_Position = ftransform(); - color = gl_Color; - - - #ifdef MC_NORMAL_MAP - tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); - #endif - - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),1.0); - #ifdef TAA_UPSCALING - gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; - #endif - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif -} +#include "gbuffers_all_solid.vsh" \ No newline at end of file diff --git a/shaders/gbuffers_entities.vsh b/shaders/gbuffers_entities.vsh index f4f07a4..1600354 100644 --- a/shaders/gbuffers_entities.vsh +++ b/shaders/gbuffers_entities.vsh @@ -1,6 +1,6 @@ #version 120 -// #define WORLD +#define WORLD #define ENTITIES #include "gbuffers_all_solid.vsh" \ No newline at end of file diff --git a/shaders/gbuffers_hand.fsh b/shaders/gbuffers_hand.fsh index 21ac244..f7c09bc 100644 --- a/shaders/gbuffers_hand.fsh +++ b/shaders/gbuffers_hand.fsh @@ -1,4 +1,5 @@ #version 120 +#define WORLD #define HAND #include "gbuffers_all_solid.fsh" \ No newline at end of file diff --git a/shaders/gbuffers_hand_water.fsh b/shaders/gbuffers_hand_water.fsh index 9208bed..ddf178d 100644 --- a/shaders/gbuffers_hand_water.fsh +++ b/shaders/gbuffers_hand_water.fsh @@ -1,4 +1,5 @@ #version 120 +#define HAND // #define WORLD #include "gbuffers_all_translucent.fsh" \ No newline at end of file diff --git a/shaders/gbuffers_hand_water.vsh b/shaders/gbuffers_hand_water.vsh index 5228fab..05dca80 100644 --- a/shaders/gbuffers_hand_water.vsh +++ b/shaders/gbuffers_hand_water.vsh @@ -1,4 +1,5 @@ #version 120 +#define HAND // #define WORLD #include "gbuffers_all_translucent.vsh" \ No newline at end of file diff --git a/shaders/gbuffers_skytextured.fsh b/shaders/gbuffers_skytextured.fsh index 2852cff..21db346 100644 --- a/shaders/gbuffers_skytextured.fsh +++ b/shaders/gbuffers_skytextured.fsh @@ -1,24 +1,7 @@ #version 120 -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ +/* RENDERTARGETS:0 */ -/* RENDERTARGETS:12 */ - -varying vec4 color; -varying vec2 texcoord; -//faster and actually more precise than pow 2.2 -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} - -uniform sampler2D texture; void main() { - - gl_FragData[0] = texture2D(texture,texcoord.xy)*color; - gl_FragData[0].rgb = gl_FragData[0].rgb*gl_FragData[0].a; + discard; } diff --git a/shaders/gbuffers_skytextured.vsh b/shaders/gbuffers_skytextured.vsh index 4722357..0a2f94b 100644 --- a/shaders/gbuffers_skytextured.vsh +++ b/shaders/gbuffers_skytextured.vsh @@ -1,38 +1,5 @@ #version 120 -#include "/lib/res_params.glsl" -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 color; -varying vec2 texcoord; - -uniform vec2 texelSize; -uniform int framemod8; - 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.); void main() { - texcoord = (gl_TextureMatrix[0] * gl_MultiTexCoord0).st; - - - - color = gl_Color; - gl_Position = ftransform(); - #ifdef TAA_UPSCALING - gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; - #endif - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif } diff --git a/shaders/gbuffers_spidereyes.fsh b/shaders/gbuffers_spidereyes.fsh index aa3de8b..21b42aa 100644 --- a/shaders/gbuffers_spidereyes.fsh +++ b/shaders/gbuffers_spidereyes.fsh @@ -1,32 +1,8 @@ #version 120 -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ +// #define ENTITIES +// #define BLOCKENTITIES +// #define WORLD +#define SPIDEREYES - -varying vec4 color; -varying vec2 texcoord; - -uniform sampler2D texture; -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - vec4 albedo = texture2D(texture, texcoord); - - albedo *= color; - albedo.rgb = toLinear(albedo.rgb)*0.33; -/* DRAWBUFFERS:2 */ - gl_FragData[0] = albedo; - -} +#include "gbuffers_all_solid.fsh" \ No newline at end of file diff --git a/shaders/gbuffers_spidereyes.vsh b/shaders/gbuffers_spidereyes.vsh index cfe2b7d..188ebaa 100644 --- a/shaders/gbuffers_spidereyes.vsh +++ b/shaders/gbuffers_spidereyes.vsh @@ -1,37 +1,8 @@ #version 120 -#include "/lib/res_params.glsl" -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ -varying vec4 color; -varying vec2 texcoord; +// #define ENTITIES +// #define BLOCKENTITIES +// #define WORLD +#define SPIDEREYES -uniform vec2 texelSize; -uniform int framemod8; - 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.); -void main() { - - - texcoord = (gl_MultiTexCoord0).xy; - color = gl_Color; - - gl_Position = ftransform(); - #ifdef TAA_UPSCALING - gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; - #endif - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif - -} +#include "gbuffers_all_solid.vsh" \ No newline at end of file diff --git a/shaders/lang/en_us.lang b/shaders/lang/en_us.lang index 21dfa02..7a0cfcb 100644 --- a/shaders/lang/en_us.lang +++ b/shaders/lang/en_us.lang @@ -1,9 +1,9 @@ option.indirect_effect = Indirect Lighting value.indirect_effect.0 = Vanilla AO value.indirect_effect.1 = SSAO -value.indirect_effect.2 = RTAO -value.indirect_effect.3 = SSGI -value.indirect_effect.4 = SSDO +value.indirect_effect.2 = GTAO +value.indirect_effect.3 = RTAO +value.indirect_effect.4 = SSGI option.ambient_colortype = Coloring Type value.ambient_colortype.0 = Temperature diff --git a/shaders/lib/PhotonGTAO.glsl b/shaders/lib/PhotonGTAO.glsl new file mode 100644 index 0000000..8e6227c --- /dev/null +++ b/shaders/lib/PhotonGTAO.glsl @@ -0,0 +1,186 @@ + +// Common constants + +const float eps = 1e-6; +const float e = exp(1.0); +const float tau = 2.0 * pi; +const float half_pi = 0.5 * pi; +const float rcp_pi = 1.0 / pi; +const float degree = tau / 360.0; // Size of one degree in radians, useful because radians() is not a constant expression on all platforms +const float golden_ratio = 0.5 + 0.5 * sqrt(5.0); +const float golden_angle = tau / golden_ratio / golden_ratio; +const float hand_depth = 0.56; + +#if defined TAA && defined TAAU +const float taau_render_scale = TAAU_RENDER_SCALE; +#else +const float taau_render_scale = 1.0; +#endif + +// Helper functions + +#define rcp(x) (1.0 / (x)) +#define clamp01(x) clamp(x, 0.0, 1.0) // free on operation output +#define max0(x) max(x, 0.0) +#define min1(x) min(x, 1.0) + +float sqr(float x) { return x * x; } +vec2 sqr(vec2 v) { return v * v; } +vec3 sqr(vec3 v) { return v * v; } +vec4 sqr(vec4 v) { return v * v; } + +float cube(float x) { return x * x * x; } + +float max_of(vec2 v) { return max(v.x, v.y); } +float max_of(vec3 v) { return max(v.x, max(v.y, v.z)); } +float max_of(vec4 v) { return max(v.x, max(v.y, max(v.z, v.w))); } +float min_of(vec2 v) { return min(v.x, v.y); } +float min_of(vec3 v) { return min(v.x, min(v.y, v.z)); } +float min_of(vec4 v) { return min(v.x, min(v.y, min(v.z, v.w))); } + +float length_squared(vec2 v) { return dot(v, v); } +float length_squared(vec3 v) { return dot(v, v); } + +vec2 normalize_safe(vec2 v) { return v == vec2(0.0) ? v : normalize(v); } +vec3 normalize_safe(vec3 v) { return v == vec3(0.0) ? v : normalize(v); } + +float rcp_length(vec2 v) { return inversesqrt(dot(v, v)); } +float rcp_length(vec3 v) { return inversesqrt(dot(v, v)); } + +float fast_acos(float x) { + const float C0 = 1.57018; + const float C1 = -0.201877; + const float C2 = 0.0464619; + + float res = (C2 * abs(x) + C1) * abs(x) + C0; // p(x) + res *= sqrt(1.0 - abs(x)); + + return x >= 0 ? res : pi - res; // Undo range reduction +} +vec2 fast_acos(vec2 v) { return vec2(fast_acos(v.x), fast_acos(v.y)); } + +uniform vec2 view_res; +uniform vec2 view_pixel_size; + +float linear_step(float edge0, float edge1, float x) { + return clamp01((x - edge0) / (edge1 - edge0)); +} + +vec2 linear_step(vec2 edge0, vec2 edge1, vec2 x) { + return clamp01((x - edge0) / (edge1 - edge0)); +} + +vec4 project(mat4 m, vec3 pos) { + return vec4(m[0].x, m[1].y, m[2].zw) * pos.xyzz + m[3]; +} +vec3 project_and_divide(mat4 m, vec3 pos) { + vec4 homogenous = project(m, pos); + return homogenous.xyz / homogenous.w; +} + +vec3 screen_to_view_space(vec3 screen_pos, bool handle_jitter) { + vec3 ndc_pos = 2.0 * screen_pos - 1.0; + + return project_and_divide(gbufferProjectionInverse, ndc_pos); +} + +vec3 view_to_screen_space(vec3 view_pos, bool handle_jitter) { + vec3 ndc_pos = project_and_divide(gbufferProjection, view_pos); + + + return ndc_pos * 0.5 + 0.5; +} + + +// --------------------- +// ambient occlusion +// --------------------- + +#define GTAO_SLICES 2 +#define GTAO_HORIZON_STEPS 3 +#define GTAO_RADIUS 2.0 +#define GTAO_FALLOFF_START 0.75 + +float integrate_arc(vec2 h, float n, float cos_n) { + vec2 tmp = cos_n + 2.0 * h * sin(n) - cos(2.0 * h - n); + return 0.25 * (tmp.x + tmp.y); +} + +float calculate_maximum_horizon_angle( + vec3 view_slice_dir, + vec3 viewer_dir, + vec3 screen_pos, + vec3 view_pos, + float dither +) { + const float step_size = GTAO_RADIUS * rcp(float(GTAO_HORIZON_STEPS)); + + float max_cos_theta = -1.0; + + vec2 ray_step = (view_to_screen_space(view_pos + view_slice_dir * step_size, true) - screen_pos).xy; + vec2 ray_pos = screen_pos.xy + ray_step * (dither + max_of(view_pixel_size) * rcp_length(ray_step)); + + + for (int i = 0; i < GTAO_HORIZON_STEPS; ++i, ray_pos += ray_step) { + float depth = texelFetch(depthtex1, ivec2(clamp(ray_pos,0.0,1.0) * view_res * taau_render_scale - 0.5), 0).x; + + if (depth == 1.0 || depth < hand_depth || depth == screen_pos.z) continue; + + vec3 offset = screen_to_view_space(vec3(ray_pos, depth), true) - view_pos; + + float len_sq = length_squared(offset); + float norm = inversesqrt(len_sq); + + float distance_falloff = linear_step(GTAO_FALLOFF_START * GTAO_RADIUS, GTAO_RADIUS, len_sq * norm); + + float cos_theta = dot(viewer_dir, offset) * norm; + cos_theta = mix(cos_theta, -1.0, distance_falloff); + + max_cos_theta = max(cos_theta, max_cos_theta); + } + + return fast_acos(clamp(max_cos_theta, -1.0, 1.0)); +} + +float ambient_occlusion(vec3 screen_pos, vec3 view_pos, vec3 view_normal, vec2 dither , inout vec3 debug) { + float ao = 0.0; + vec3 bent_normal = vec3(0.0); + + // Construct local working space + vec3 viewer_dir = normalize(-view_pos); + vec3 viewer_right = normalize(cross(vec3(0.0, 1.0, 0.0), viewer_dir)); + vec3 viewer_up = cross(viewer_dir, viewer_right); + mat3 local_to_view = mat3(viewer_right, viewer_up, viewer_dir); + + for (int i = 0; i < GTAO_SLICES; ++i) { + float slice_angle = (i + dither.x) * (pi / float(GTAO_SLICES)); + + vec3 slice_dir = vec3(cos(slice_angle), sin(slice_angle), 0.0); + vec3 view_slice_dir = local_to_view * slice_dir; + + vec3 ortho_dir = slice_dir - dot(slice_dir, viewer_dir) * viewer_dir; + vec3 axis = cross(slice_dir, viewer_dir); + + vec3 projected_normal = view_normal - axis * dot(view_normal, axis); + + float len_sq = dot(projected_normal, projected_normal); + float norm = inversesqrt(len_sq); + + float sgn_gamma = sign(dot(ortho_dir, projected_normal)); + float cos_gamma = clamp01(dot(projected_normal, viewer_dir) * norm); + float gamma = sgn_gamma * fast_acos(cos_gamma); + + vec2 max_horizon_angles; + max_horizon_angles.x = calculate_maximum_horizon_angle(-view_slice_dir, viewer_dir, screen_pos, view_pos, dither.y); + max_horizon_angles.y = calculate_maximum_horizon_angle( view_slice_dir, viewer_dir, screen_pos, view_pos, dither.y); + + max_horizon_angles = gamma + clamp(vec2(-1.0, 1.0) * max_horizon_angles - gamma, -half_pi, half_pi); + + vec3 max_horizon_angles2 = mat3(gbufferModelViewInverse) * projected_normal; + + ao += integrate_arc(max_horizon_angles, gamma, cos_gamma) * len_sq * norm * max_horizon_angles.y; + } + + ao *= rcp(float(GTAO_SLICES)); + return ao; +} diff --git a/shaders/lib/climate_settings.glsl b/shaders/lib/climate_settings.glsl index a8ee8dd..7045ed4 100644 --- a/shaders/lib/climate_settings.glsl +++ b/shaders/lib/climate_settings.glsl @@ -3,8 +3,10 @@ uniform float Day; +uniform float worldDay; // it's so symmetrical~ + float day0 = clamp(clamp(Day, 0.0,1.0)*clamp(2-Day, 0.0,1.0),0.0,1.0); float day1 = clamp(clamp(Day-1, 0.0,1.0)*clamp(3-Day, 0.0,1.0),0.0,1.0); float day2 = clamp(clamp(Day-2, 0.0,1.0)*clamp(4-Day, 0.0,1.0),0.0,1.0); @@ -23,23 +25,36 @@ float day7 = clamp(clamp(Day-7, 0.0,1.0)*clamp(9-Day, 0.0,1.0),0.0,1.0); /////////////////////////////////////////////////////////////////////////////// VERTEX SHADER #ifdef Seasons #ifdef SEASONS_VSH + varying vec4 seasonColor; + void YearCycleColor ( inout vec3 FinalColor, vec3 glcolor ){ // colors for things that arent leaves and using the tint index. - vec3 SummerCol = vec3(Summer_R, Summer_G, Summer_B) * glcolor; - vec3 AutumnCol = vec3(Fall_R, Fall_G, Fall_B) * glcolor; + vec3 SummerCol = vec3(Summer_R, Summer_G, Summer_B); + vec3 AutumnCol = vec3(Fall_R, Fall_G, Fall_B); vec3 WinterCol = vec3(Winter_R, Winter_G, Winter_B) ; - vec3 SpringCol = vec3(Spring_R, Spring_G, Spring_B) * glcolor; + vec3 SpringCol = vec3(Spring_R, Spring_G, Spring_B); + + // decide if you want to replace biome colors or tint them. + SummerCol *= glcolor; + AutumnCol *= glcolor; + WinterCol *= glcolor; + SpringCol *= glcolor; // do leaf colors different because thats cool and i like it if(mc_Entity.x == 10003){ - SummerCol = vec3(Summer_Leaf_R, Summer_Leaf_G, Summer_Leaf_B) * glcolor; - AutumnCol = vec3(Fall_Leaf_R, Fall_Leaf_G, Fall_Leaf_B) * glcolor; - WinterCol = vec3(Winter_Leaf_R, Winter_Leaf_G, Winter_Leaf_B) ; - SpringCol = vec3(Spring_Leaf_R, Spring_Leaf_G, Spring_Leaf_B)* glcolor; + SummerCol = vec3(Summer_Leaf_R, Summer_Leaf_G, Summer_Leaf_B); + AutumnCol = vec3(Fall_Leaf_R, Fall_Leaf_G, Fall_Leaf_B); + WinterCol = vec3(Winter_Leaf_R, Winter_Leaf_G, Winter_Leaf_B); + SpringCol = vec3(Spring_Leaf_R, Spring_Leaf_G, Spring_Leaf_B); + + SummerCol *= glcolor; + AutumnCol *= glcolor; + WinterCol *= glcolor; + SpringCol *= glcolor; } // length of each season in minecraft days @@ -64,7 +79,7 @@ float day7 = clamp(clamp(Day-7, 0.0,1.0)*clamp(9-Day, 0.0,1.0),0.0,1.0); bool IsTintIndex = floor(dot(glcolor,vec3(0.5))) < 1.0; // multiply final color by the final lerped color, because it contains all the other colors. - if (IsTintIndex && mc_Entity.x != 200) FinalColor = SpringToSummer; + FinalColor = SpringToSummer; } #endif #endif @@ -107,7 +122,7 @@ float day7 = clamp(clamp(Day-7, 0.0,1.0)*clamp(9-Day, 0.0,1.0),0.0,1.0); #ifdef Daily_Weather Coverage += day0 * 0.3 + day1 * 0.8 + day2 * 0.2 + day3 * 0.0 + day4 * 0.8 + day5 * 0.5 + day6 * -0.5 + day7 * 0.6; #else - Coverage += cloudCoverage; + Coverage += mix(Cumulus_coverage, Rain_coverage, rainStrength); // Coverage = mix(Coverage, Rain_coverage, rainStrength); #endif @@ -138,7 +153,7 @@ float day7 = clamp(clamp(Day-7, 0.0,1.0)*clamp(9-Day, 0.0,1.0),0.0,1.0); Thickness = CirrusThickness; } #else - Coverage = 0.5; + Coverage = 0.7; Thickness = 0.05; #endif @@ -187,7 +202,7 @@ float day7 = clamp(clamp(Day-7, 0.0,1.0)*clamp(9-Day, 0.0,1.0),0.0,1.0); BiomeColors.b = isSwamps*0.35 + isJungles*0.8; // insure the biome colors are locked to the fog shape and lighting, but not its orignal color. - BiomeColors *= dot(FinalFogColor,vec3(0.5)); + BiomeColors *= dot(FinalFogColor,vec3(0.33)); // these range 0.0-1.0. they will never overlap. float Inbiome = isJungles+isSwamps; @@ -204,8 +219,8 @@ float day7 = clamp(clamp(Day-7, 0.0,1.0)*clamp(9-Day, 0.0,1.0),0.0,1.0); float Inbiome = isJungles+isSwamps; vec2 BiomeFogDensity; // x = uniform || y = cloudy - BiomeFogDensity.x = isSwamps*5 + isJungles*5; - BiomeFogDensity.y = isSwamps*50 + isJungles*2; + BiomeFogDensity.x = isSwamps*1 + isJungles*5; + BiomeFogDensity.y = isSwamps*5 + isJungles*2; UniformDensity = mix(UniformDensity, vec4(BiomeFogDensity.x), Inbiome); CloudyDensity = mix(CloudyDensity, vec4(BiomeFogDensity.y), Inbiome); @@ -229,8 +244,9 @@ float day7 = clamp(clamp(Day-7, 0.0,1.0)*clamp(9-Day, 0.0,1.0),0.0,1.0); float Night = clamp((Time-13000)/2000,0,1) * clamp((23000-Time)/2000,0,1) ; // set densities. morn, noon, even, night - vec4 UniformDensity = vec4(0.0, 0.0, 0.0, 0.0); - vec4 CloudyDensity = vec4(0.0, 0.0, 0.0, 0.0); + vec4 UniformDensity = TOD_Fog_mult * vec4(Morning_Uniform_Fog, Noon_Uniform_Fog, Evening_Uniform_Fog, Night_Uniform_Fog); + vec4 CloudyDensity = TOD_Fog_mult * vec4(Morning_Cloudy_Fog, Noon_Cloudy_Fog, Evening_Cloudy_Fog, Night_Cloudy_Fog); + #ifdef Daily_Weather DailyWeather_FogDensity(UniformDensity, CloudyDensity); // let daily weather influence fog densities. diff --git a/shaders/lib/diffuse_lighting.glsl b/shaders/lib/diffuse_lighting.glsl new file mode 100644 index 0000000..b4166aa --- /dev/null +++ b/shaders/lib/diffuse_lighting.glsl @@ -0,0 +1,61 @@ +// in this here file im doing all the lighting for sunlight, ambient light, torches, for solids and translucents. + +//// OVERWORLD //// + +vec3 DoAmbientLighting (vec3 SkyColor, vec3 TorchColor, vec2 Lightmap, float skyLightDir){ + // Lightmap.x = 0.0; + // Lightmap.y = 1.0; + + SkyColor = SkyColor * 2.0 * ambient_brightness; + + + vec3 TorchLight = TorchColor * pow(1.0-pow(1.0-clamp(Lightmap.x,0.0,1.0) ,0.1),2); + TorchLight = exp(TorchLight * 30) - 1.0; + + + // vec3 SkyLight = max((SkyColor * 8./150./3.) * pow(Lightmap.y,3.0) , vec3(0.2,0.4,1.0) * (MIN_LIGHT_AMOUNT*0.01)) ; + vec3 SkyLight = max((SkyColor * 8./150./3.) * pow(Lightmap.y,3.0),0.0) ; + + + return SkyLight * skyLightDir + TorchLight; +} + +vec3 DoDirectLighting(vec3 SunColor, float Shadow, float NdotL, float SubsurfaceScattering){ + + // vec3 SunLight = max(NdotL * Shadow, SubsurfaceScattering) * SunColor; + vec3 SunLight = NdotL * Shadow * SunColor; + + return SunLight; +} + + +//// NETHER //// +vec3 DoAmbientLighting_Nether(vec3 FogColor, vec3 TorchColor, float Lightmap, vec3 Normal, vec3 np3, vec3 WorldPos){ + + vec3 TorchLight = TorchColor * clamp(pow(Lightmap,3.0),0.0,1.0); + + + + vec3 LavaGlow = vec3(TORCH_R,TORCH_G,TORCH_B); + LavaGlow *= pow(clamp(1.0-max(Normal.y,0.0) + dot(Normal,np3),0.0,1.0),3.0); + LavaGlow *= clamp(exp2(-max((WorldPos.y - 50.0) / 5,0.0)),0.0,1.0); + LavaGlow *= pow(Lightmap,0.2); + + vec3 AmbientLight = vec3(0.1) + FogColor*clamp(1.1 + dot(Normal,np3),0.0,1.0); + + return AmbientLight + TorchLight + LavaGlow; +} +//// END //// +vec3 DoAmbientLighting_End(vec3 FogColor, vec3 TorchColor, float Lightmap, vec3 Normal, vec3 np3){ + + // vec3 TorchLight = TorchColor * clamp(pow(Lightmap,3.0),0.0,1.0); + vec3 TorchLight = TorchColor * pow(1.0-pow(1.0-clamp(Lightmap,0.0,1.0) ,0.1),2); + TorchLight = exp(TorchLight * 30) - 1.0; + + + FogColor = (FogColor / pow(0.00001 + dot(FogColor,vec3(0.3333)),1.0) ) * 0.1; + // vec3 AmbientLight = sqrt( clamp(1.25 + dot(Normal,np3),0.0,1.0)) * (vec3(0.5,0.75,1.0) * 0.05); + vec3 AmbientLight = sqrt( clamp(1.25 + dot(Normal,np3),0.0,1.0)*0.5) * FogColor; + + return TorchLight + AmbientLight; +} \ No newline at end of file diff --git a/shaders/lib/end_fog.glsl b/shaders/lib/end_fog.glsl new file mode 100644 index 0000000..4a4a193 --- /dev/null +++ b/shaders/lib/end_fog.glsl @@ -0,0 +1,346 @@ +vec3 srgbToLinear2(vec3 srgb){ + return mix( + srgb / 12.92, + pow(.947867 * srgb + .0521327, vec3(2.4) ), + step( .04045, srgb ) + ); +} +vec3 blackbody2(float Temp) +{ + float t = pow(Temp, -1.5); + float lt = log(Temp); + + vec3 col = vec3(0.0); + col.x = 220000.0 * t + 0.58039215686; + col.y = 0.39231372549 * lt - 2.44549019608; + col.y = Temp > 6500. ? 138039.215686 * t + 0.72156862745 : col.y; + col.z = 0.76078431372 * lt - 5.68078431373; + col = clamp(col,0.0,1.0); + col = Temp < 1000. ? col * Temp * 0.001 : col; + + return srgbToLinear2(col); +} + + +// Integer Hash - II +// - Inigo Quilez, Integer Hash - II, 2017 +// https://www.shadertoy.com/view/XlXcW4 +uvec3 iqint2(uvec3 x) +{ + const uint k = 1103515245u; + + x = ((x>>8U)^x.yzx)*k; + x = ((x>>8U)^x.yzx)*k; + x = ((x>>8U)^x.yzx)*k; + + return x; +} + +uvec3 hash(vec2 s) +{ + + uvec4 u = uvec4(s, uint(s.x) ^ uint(s.y), uint(s.x) + uint(s.y)); // Play with different values for 3rd and 4th params. Some hashes are okay with constants, most aren't. + + return iqint2(u.xyz); +} +vec3 hash31(float p) +{ + vec3 p3 = fract(vec3(p) * vec3(.1031, .1030, .0973)); + p3 += dot(p3, p3.yzx+33.33); + return fract((p3.xxy+p3.yzz)*p3.zyx); +} + +// uniform float ifEndBoss; +// uniform float isSneaking; + +// uniform float EndSequence1; +// uniform float EndSequence2; + + +// position related stuff +// vec2 SEED = vec2(sin(frameTimeCounter*5) + 1); +// uvec3 HASH = hash(SEED); +// vec3 RandomPosition = clamp(vec3(HASH) * (1.0/float(0xffffffffu)), 0.0, 1.0); +vec3 RandomPosition = hash31(1); + + +// vec3 ManualLightPos = vec3(109.25, 128.73, 1189.4) ; +// vec3 ManualLightPos = vec3(307.96, 141.00, 1107.05) - vec3(sin(frameTimeCounter), 0, -cos(frameTimeCounter))*25; +// ManualLightPos -= vec3(sin(frameTimeCounter), 0, -cos(frameTimeCounter))*100; + +vec3 ManualLightPos = vec3(ORB_X, ORB_Y, ORB_Z); + +///////////////// POSITION +///////////////// POSITION +///////////////// POSITION +vec3 LightSourcePosition(vec3 WorldPos, vec3 CameraPos){ + + vec3 Origin = WorldPos ; + vec3 RandomPosition2 = hash31(Origin.y); + // make the swirl only happen within a radius + float SwirlBounds = clamp(sqrt(length(vec3(Origin.x,Origin.y-100,Origin.z)) / 150.0 - 1.0) ,0.0,1.0); + + if( SwirlBounds < 1.0) { + Origin.y -= 200; + } else { + Origin = WorldPos - cameraPosition - ManualLightPos ; + // Origin -= RandomPosition * 100; + } + + #ifdef THE_ORB + Origin = WorldPos - ManualLightPos; + #endif + + return Origin; +} + +///////////////// COLOR +///////////////// COLOR +///////////////// COLOR +vec3 LightSourceColor(float SwirlBounds){ + + vec3 Color = vec3(0.0); + + if( SwirlBounds < 1.0) { + + //////// STAGE 1 + Color = vec3(0.5, 0.5, 1.0); + + //////// STAGE 2 + + // Color = mix(Color, vec3(1.0,0.3,0.3), pow(EndSequence1,3.0)); + + // //////// STAGE 3 + // // yes rico, kaboom + // Color = mix(Color, vec3(1.0,0.0,1.0) * (1.0-EndSequence2), EndSequence2); + + } else { + + // Color = vec3(0.6, 0.8 ,1.0); + Color = vec3(ORB_R, ORB_G, ORB_B) * ORB_ColMult; + + // float Timing = dot(RandomPosition, vec3(1.0/3.0)); + + // float Flash = max(sin(frameTimeCounter*10) * Timing,0.0); + // Color *= blackbody2(RandomPosition.y*4000 + 1000); + // Color *= Flash; + + } + + #ifdef THE_ORB + Color = vec3(ORB_R, ORB_G, ORB_B) * ORB_ColMult; + #endif + + return Color; +} + +///////////////// SHAPE +///////////////// SHAPE +///////////////// SHAPE +vec3 LightSourceShape(vec3 WorldPos){ + + vec3 Shapes = vec3(0.0); + vec3 Origin = WorldPos ; + + // make the swirl only happen within a radius + float SwirlBounds = clamp(sqrt(length(Origin) / 200.0 - 1.0) ,0.0,1.0); + + if( SwirlBounds < 1.0) { + + // vec3 Origin = WorldPos; + Origin.y -= 200; + + vec3 Origin2 = Origin; + Origin2.y += 100 ; + Origin2.y *= 0.8; + + float Center = length(Origin); + float AltCenter = length(Origin2); + + //////// STAGE 1 + // when the ender dragon is alive, restrict the fog in this shape + // the max of a sphere is another smaller sphere. this creates a hollow sphere. + Shapes.r = max(1.0 - AltCenter / 75.0, max(AltCenter / 150.0 - 1.0, 0.0)); + + float radius = 200.0; + float thickness = 50.0 * radius; + Shapes.r = (thickness - clamp(pow(sqrt(pow(Origin2.x,2) + pow(Origin2.z,2)) - radius,2) + pow(Origin2.y*0.75,2.0) - radius,0,thickness)) / thickness ; + + Shapes.r = max(Shapes.r, max(1.0 - AltCenter / 75.0, 0.0)); + + radius = 50.0; + thickness = 5.0 * radius; + Shapes.b = (thickness - clamp(pow(sqrt(pow(Origin2.x,2) + pow(Origin2.y,2)) - radius,2) + pow(Origin2.z*0.75,2.0) - radius,0,thickness)) / thickness ; + } + + return Shapes; +} + + +float densityAtPosFog(in vec3 pos){ + pos /= 18.; + pos.xz *= 0.5; + + vec3 p = floor(pos); + vec3 f = fract(pos); + + f = (f*f) * (3.-2.*f); + vec2 uv = p.xz + f.xz + p.y * vec2(0.0,193.0); + vec2 coord = uv / 512.0; + vec2 xy = texture2D(noisetex, coord).yx; + return mix(xy.r,xy.g, f.y); +} + +float cloudVol(in vec3 pos, int LOD){ + + + // THE OOOOOOOOOOOOOOOOOOOOOORB + vec3 Shapes = LightSourceShape(pos); + + vec3 samplePos = pos*vec3(1.0,1./32.,1.0); + vec3 samplePos2 = pos*vec3(1.0,1./48.,1.0); + + // #ifndef THE_ORB + // ender dragon battle area swirling effect. + // if(EndSequence2 < 1.0){ + float radiance = 2.39996 + samplePos.y + frameTimeCounter/10; + mat2 rotationMatrix = mat2(vec2(cos(radiance), -sin(radiance)), vec2(sin(radiance), cos(radiance))); + + // make the swirl only happen within a radius + float SwirlBounds = clamp(sqrt(length(vec3(pos.x,pos.y-100,pos.z)) / 200.0 - 1.0) ,0.0,1.0); + + samplePos.xz = mix(samplePos.xz * rotationMatrix, samplePos.xz, SwirlBounds); + samplePos2.xz = mix(samplePos2.xz * rotationMatrix, samplePos2.xz, SwirlBounds); + // } + // #endif + + samplePos2.y -= frameTimeCounter/15; + + float finalfog = 0; + + finalfog += max(0.6-densityAtPosFog(samplePos * 16.0) * 2,0.0); + // finalfog = exp(finalfog*5)-1; + + float smallnoise = max(densityAtPosFog(samplePos2 * (160. - finalfog*3))-0.1,0.0); + finalfog -= ((1-smallnoise) - max(0.15 - abs(smallnoise * 2.0 - 0.55) * 0.5,0.0)*1.5) * 0.3; + + // make the eye of the swirl have no fog, so you can actually see. + finalfog = max(finalfog - Shapes.r, 0.0); + + // dragon death sequence + // finalfog = Shapes.b; + + + return finalfog; +} + + +mat2x3 getVolumetricRays(float dither,vec3 fragpos,float dither2) { + int SAMPLES = 16; + //project pixel position into projected shadowmap space + vec3 wpos = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; + vec3 fragposition = mat3(shadowModelView) * wpos + shadowModelView[3].xyz; + fragposition = diagonal3(shadowProjection) * fragposition + shadowProjection[3].xyz; + + + //project view origin into projected shadowmap space + vec3 start = vec3(0.0); + + //rayvector into projected shadow map space + //we can use a projected vector because its orthographic projection + //however we still have to send it to curved shadow map space every step + vec3 dV = (fragposition-start); + vec3 dVWorld = (wpos-gbufferModelViewInverse[3].xyz); + + float maxLength = min(length(dVWorld),32.0 * 12.0)/length(dVWorld); + dV *= maxLength; + dVWorld *= maxLength; + + //apply dither + vec3 progress = start.xyz; + vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; + vec3 vL = vec3(0.); + float dL = length(dVWorld); + + vec3 absorbance = vec3(1.0); + float expFactor = 11.0; + + vec3 fogColor = (gl_Fog.color.rgb / pow(dot(gl_Fog.color.rgb,vec3(0.3333)),1.1) ) ; + + + for (int i=0;i -near) ? (-near -position.z) / dir.z : far*sqrt(3.); - vec3 direction = normalize(toClipSpace3(position+dir*rayLength)-clipPosition); //convert to clip space - direction.xy = normalize(direction.xy); - - //get at which length the ray intersects with the edge of the screen - vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; - float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z); - - - vec3 stepv = direction * mult / quality*vec3(RENDER_SCALE,1.0); - vec3 spos = clipPosition*vec3(RENDER_SCALE,1.0) + stepv*dither; - - float minZ = clipPosition.z+stepv.z; - float maxZ = spos.z+stepv.z; - spos.xy += TAA_Offset*texelSize*0.5/RENDER_SCALE; - - float dist = 1.0 + clamp(position.z*position.z/50.0,0,2); // shrink sample size as distance increases - for (int i = 0; i <= int(quality); i++) { - - float sp = texelFetch2D(depthtex1,ivec2(spos.xy/texelSize),0).r; - if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ)) return vec3(spos.xy/RENDER_SCALE,sp); - - spos += stepv; - //small bias - minZ = maxZ-(0.0001/dist)/ld(spos.z); - maxZ += stepv.z; - } - - return vec3(1.1); -} -// vec3 rayTrace_GI(vec3 dir,vec3 position,float dither, float quality){ - -// vec3 clipPosition = toClipSpace3(position); -// float rayLength = ((position.z + dir.z * far*sqrt(3.)) > -near) ? -// (-near -position.z) / dir.z : far*sqrt(3.); -// vec3 direction = normalize(toClipSpace3(position+dir*rayLength)-clipPosition); //convert to clip space -// direction.xy = normalize(direction.xy); - -// //get at which length the ray intersects with the edge of the screen -// vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; -// float mult = maxLengths.y; - -// vec3 stepv = direction * mult / quality*vec3(RENDER_SCALE,1.0) * dither; -// vec3 spos = clipPosition*vec3(RENDER_SCALE,1.0) ; - -// spos.xy += TAA_Offset*texelSize*0.5/RENDER_SCALE; - -// float biasdist = clamp(position.z*position.z/50.0,1,2); // shrink sample size as distance increases - -// for(int i = 0; i < int(quality); i++){ -// spos += stepv; -// float sp = sqrt(texelFetch2D(colortex4,ivec2(spos.xy/texelSize/4),0).w/65000.0); -// float currZ = linZ(spos.z); - -// if( sp < currZ) { -// float dist = abs(sp-currZ)/currZ; -// if (abs(dist) < biasdist*0.05) return vec3(spos.xy, invLinZ(sp))/vec3(RENDER_SCALE,1.0); -// } -// spos += stepv; -// } -// return vec3(1.1); -// } void frisvad(in vec3 n, out vec3 f, out vec3 r){ if(n.z < -0.9) { @@ -153,28 +68,44 @@ vec2 R2_samples_spec(int n){ return fract(alpha * n); } -vec3 sampleGGXVNDF(vec3 V_, float roughness, float U1, float U2){ - // stretch view - vec3 V = normalize(vec3(roughness * V_.x, roughness * V_.y, V_.z)); - // orthonormal basis - vec3 T1 = (V.z < 0.9999) ? normalize(cross(V, vec3(0,0,1))) : vec3(1,0,0); - vec3 T2 = cross(T1, V); - // sample point with polar coordinates (r, phi) - float a = 1.0 / (1.0 + V.z); - float r = sqrt(U1*0.25); - float phi = (U2 -near) ? (-near -position.z) / dir.z : far*sqrt(3.); + vec3 direction = normalize(toClipSpace3(position+dir*rayLength)-clipPosition); //convert to clip space + direction.xy = normalize(direction.xy); + + //get at which length the ray intersects with the edge of the screen + vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; + float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z); + + + vec3 stepv = direction * mult / quality*vec3(RENDER_SCALE,1.0); + vec3 spos = clipPosition*vec3(RENDER_SCALE,1.0) + stepv*dither; + + float minZ = clipPosition.z+stepv.z; + float maxZ = spos.z+stepv.z; + spos.xy += TAA_Offset*texelSize*0.5/RENDER_SCALE; + + float dist = 1.0 + clamp(position.z*position.z/50.0,0,2); // shrink sample size as distance increases + for (int i = 0; i <= int(quality); i++) { + + float sp = texelFetch2D(depthtex1,ivec2(spos.xy/texelSize),0).r; + + + if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ)) return vec3(spos.xy/RENDER_SCALE,sp); + + spos += stepv; + //small bias + minZ = maxZ-(0.0001/dist)/ld(spos.z); + maxZ += stepv.z; + } + + return vec3(1.1); } +vec3 rayTraceSpeculars(vec3 dir,vec3 position,float dither, float quality, bool hand, inout float reflectLength){ - -vec3 rayTraceSpeculars(vec3 dir,vec3 position,float dither, float quality, bool hand){ vec3 clipPosition = toClipSpace3(position); float rayLength = ((position.z + dir.z * far*sqrt(3.)) > -near) ? (-near -position.z) / dir.z : far*sqrt(3.); @@ -197,11 +128,10 @@ vec3 rayTraceSpeculars(vec3 dir,vec3 position,float dither, float quality, bool float dist = 1.0 + clamp(position.z*position.z/50.0,0,2); // shrink sample size as distance increases for (int i = 0; i <= int(quality); i++) { - // decode depth buffer vec2 testthing = hand ? spos.xy*texelSize : spos.xy/texelSize/4.0; // fix for ssr on hand - float sp = sqrt(texelFetch2D(gaux1,ivec2(testthing),0).w/65000.0); + float sp = sqrt((texelFetch2D(colortex4,ivec2(testthing),0).a+0.1)/65000.0); sp = invLinZ(sp); - + if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ) ) return vec3(spos.xy/RENDER_SCALE,sp); spos += stepv; @@ -209,58 +139,94 @@ vec3 rayTraceSpeculars(vec3 dir,vec3 position,float dither, float quality, bool float biasamount = 0.0002 / dist; if(hand) biasamount = 0.01; minZ = maxZ-biasamount / ld(spos.z); - maxZ += stepv.z; + + reflectLength += 1.0 / quality; // for shit } + + return vec3(1.1); } - -vec3 mix_vec3(vec3 X, vec3 Y, float A){ - return X * (1.0 - A) + Y * A; -} -float mix_float(float X, float Y, float A){ - return X * (1.0 - A) + Y * A; +vec3 sampleGGXVNDF(vec3 V_, float roughness, float U1, float U2){ + // stretch view + vec3 V = normalize(vec3(roughness * V_.x, roughness * V_.y, V_.z)); + // orthonormal basis + vec3 T1 = (V.z < 0.9999) ? normalize(cross(V, vec3(0,0,1))) : vec3(1,0,0); + vec3 T2 = cross(T1, V); + // sample point with polar coordinates (r, phi) + float a = 1.0 / (1.0 + V.z); + float r = sqrt(U1*0.25); + float phi = (U2 0.01; + float hasReflections2 = max(1.0 - roughness*1.75,0.0); + + + // // if (!hasReflections) Outdoors = 0.0; + // SunReflection = directlighting * SunGGX(normal, -np3, sunPos, roughness, f0.y) / 5.0; + SunReflection = directlighting * GGX(normal, -np3, sunPos, roughness, f0.yyy); +// + if (hasReflections) { // Skip sky reflection and SSR if its just not very visible anyway + #ifdef Sky_reflection + SkyReflection = skyCloudsFromTex(L, colortex4).rgb / 150. * 5.; + #endif + + #ifdef Screen_Space_Reflections + // #ifdef SCREENSHOT_MODE + // float rayQuality = reflection_quality; + // #else + float rayQuality = mix_float(reflection_quality,4,luma(rayContrib)); // Scale quality with ray contribution + // #endif + // float rayQuality = reflection_quality; + + vec3 rtPos = rayTraceSpeculars( mat3(gbufferModelView) * L,fragpos.xyz, noise.b, reflection_quality, hand, reflectLength); + + float LOD = clamp(reflectLength * 6.0, 0.0,6.0) ; + if(hand || isEntities) LOD = 6.0; + + if (rtPos.z < 1.) { // Reproject on previous frame + vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rtPos) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; + previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; + previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; + if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) { + Reflections.a = 1.0; + Reflections.rgb = texture2DLod(colortex5,previousPosition.xy,LOD).rgb; + } + } + #endif + } + + // check if the f0 is within the metal ranges, then tint by albedo if it's true. + vec3 Metals = f0.y > 229.5/255.0 ? clamp(albedo + fresnel,0.0,1.0) : vec3(1.0); + + SunReflection *= Metals; + + #ifdef Sky_reflection + SkyReflection *= Metals; + #endif + #ifdef Screen_Space_Reflections + Reflections.rgb *= Metals; + #endif + + // background reflections + SkyReflection = mix_vec3(Output, SkyReflection, Outdoors); + + // composite background and SSR. + Reflections.rgb = mix_vec3(SkyReflection, Reflections.rgb, Reflections.a); + + // put reflections onto the scene + #ifdef Rough_reflections + Output = hand ? mix_vec3(Output, Reflections.rgb, VisibilityFactor) : mix_vec3(Output, Reflections.rgb, luma(rayContrib)); + #else + Output = mix_vec3(Output, Reflections.rgb, VisibilityFactor); + #endif + + Output += SunReflection; +} + +void MaterialReflections_N( + inout vec3 Output, + float roughness, + vec3 f0, + vec3 albedo, + vec3 normal, + vec3 np3, + vec3 fragpos, + vec3 noise, + bool hand +){ + vec3 Reflections_Final = Output; + float reflectLength = 0.0; + + roughness = unpackRoughness(roughness); + f0 = f0.y == 0.0 ? vec3(0.02) : f0; + + // roughness = 0.0; + // f0 = vec3(0.9); + + float visibilityFactor = clamp(exp2((pow(roughness,3.0) / f0.y) * -4),0,1); + + mat3 basis = CoordBase(normal); + vec3 normSpaceView = -np3*basis ; + + // roughness stuff + #ifdef Rough_reflections + int seed = (frameCounter%40000); + vec2 ij = fract(R2_samples_spec(seed) + noise.rg) ; + vec3 H = sampleGGXVNDF(normSpaceView, roughness, ij.x, ij.y); + + if(hand) H = normalize(vec3(0.0,0.0,1.0)); + #else + vec3 H = normalize(vec3(0.0,0.0,1.0)); + #endif + + vec3 Ln = reflect(-normSpaceView, H); + vec3 L = basis * Ln; + + // fresnel stuff + float fresnel = pow(clamp(1.0 + dot(-Ln, H),0.0,1.0),5.0); vec3 F = mix(f0, vec3(1.0), fresnel); vec3 rayContrib = F; - // float NdotV = clamp(normalize(dot(np3, L))*10000.,0.,1.); - bool hasReflections = (f0.y * (1.0 - roughness * Roughness_Threshold)) > 0.01; + bool hasReflections = (f0.y * (1.0 - roughness * Roughness_Threshold)) >= 0.0; + if (Roughness_Threshold == 1.0){ hasReflections = true; } - if (Roughness_Threshold == 1.0){ hasReflections = roughness > -1; } - - if (!hasReflections ) Outdoors = 0.0; - - - - // if(hand){ - // LOD_controller = 6; - // // noise.b = 0.5; - // } // SSR, Sky, and Sun reflections vec4 Reflections = vec4(0.0); - // vec3 SkyReflection = skyCloudsFromTex_Spec(L, colortex4,int(LOD_controller)).rgb / 150. * 5.; - vec3 SkyReflection = skyCloudsFromTex(L, colortex4).rgb / 150. * 5.; - - vec3 SunReflection = diffuse * GGX2(normal, -np3, sunPos, roughness, f0) * 8./150./3. * sunCol * Sun_specular_Strength; - - #ifndef Sky_reflection - SkyReflection = Reflections_Final; - #endif - - - - + vec3 FogReflection = vec3(0.0); #ifdef Screen_Space_Reflections if ( hasReflections ) { // Skip SSR if ray contribution is low - - #ifdef SCREENSHOT_MODE - float rayQuality = reflection_quality; - #else - float rayQuality = mix_float(reflection_quality,0.0,dot(rayContrib,vec3(0.33))); // Scale quality with ray contribution - #endif - - vec3 rtPos = rayTraceSpeculars( mat3(gbufferModelView) * L,fragpos.xyz, noise.b, reflection_quality, hand); - - // float test = dot(vec2(-rtPos.x,-rtPos.y), vec2(rtPos.x,rtPos.y)); - // float LOD_controller = clamp((1-pow(test*0.5+1.0,25)) * 10,0.0,6.0) ; - - // LOD_controller = 0; + float rayQuality = reflection_quality; + vec3 rtPos = rayTraceSpeculars( mat3(gbufferModelView) * L,fragpos.xyz, noise.b, reflection_quality, hand, reflectLength); + + float LOD = clamp( reflectLength * 6.0 ,0.0,6.0); if (rtPos.z < 1. ){ // Reproject on previous frame vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rtPos) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; @@ -331,39 +375,137 @@ void MaterialReflections( previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) { Reflections.a = 1.0; - Reflections.rgb = texture2DLod(colortex5,previousPosition.xy,0).rgb; + Reflections.rgb = texture2DLod(colortex5,previousPosition.xy,LOD).rgb; } } } #endif + // check if the f0 is within the metal ranges, then tint by albedo if it's true. vec3 Metals = f0.y > 229.5/255.0 ? clamp(albedo + fresnel,0.0,1.0) : vec3(1.0); - Reflections.rgb *= Metals; - SunReflection *= Metals; - #ifdef Sky_reflection - SkyReflection *= Metals; - #endif - float lumaRayContrib = pow(luma(rayContrib),1.0); - float oneminus_lumaRayContrib = pow(1.0-luma(rayContrib),1.0); - // darken albedos, and stop darkening where the sky gets occluded indoors - Reflections_Final *= mix_float(1.0 - (Reflections.a*lumaRayContrib), oneminus_lumaRayContrib, Outdoors); - - // apply all reflections to the lighting - Reflections_Final += Reflections.rgb * lumaRayContrib; - Reflections_Final += SkyReflection * lumaRayContrib * (1.0-Reflections.a) * Outdoors ; - float visibilityFactor = clamp(exp2((pow(roughness,3.0) / f0.y) * -4),0,1); - + #ifdef Sky_reflection + // reflect nether fog color instead of a sky. + FogReflection = gl_Fog.color.rgb * 0.5 * NetherFog_brightness; + FogReflection *= 1.0 + sqrt(roughness) * 15.0; // brighten rough spots for some highlights that look neat + FogReflection *= Metals; + + FogReflection = mix(Output, FogReflection, pow(fresnel, 0.2)+0.1); // make sure the background contains the fog reflection. + #else + FogReflection = Output; + #endif + + Reflections.rgb = mix(FogReflection, Reflections.rgb, Reflections.a); // make background only where ssr is not. + Reflections_Final = mix(Output, Reflections.rgb, luma(rayContrib)); // apply reflections to final scene color. + #ifdef Rough_reflections Output = hand ? mix_vec3(Output, Reflections_Final, visibilityFactor) : Reflections_Final; #else Output = mix_vec3(Output, Reflections_Final, visibilityFactor); #endif - Output += SunReflection ; - // float aaaa = dot(vec2(-rtPos.x,-rtPos.y), vec2(rtPos.x,rtPos.y)); - // test = pow(test*0.5+1.0,2); - // Output = vec3(0,test,0) ; + // Output = vec3(reflectLength); +} + +void MaterialReflections_E( + inout vec3 Output, + float roughness, + vec3 f0, + vec3 albedo, + vec3 normal, + vec3 np3, + vec3 fragpos, + vec3 noise, + bool hand, + vec3 lightCol, + vec3 lightDir, + bool isEntities +){ + vec3 Reflections_Final = Output; + float reflectLength = 0.0; + + roughness = unpackRoughness(roughness); + f0 = f0.y == 0.0 ? vec3(0.02) : f0; + + // roughness = 0.0; + // f0 = vec3(0.9); + + float visibilityFactor = clamp(exp2((pow(roughness,3.0) / f0.y) * -4),0,1); + + mat3 basis = CoordBase(normal); + vec3 normSpaceView = -np3*basis ; + + // roughness stuff + #ifdef Rough_reflections + int seed = (frameCounter%40000); + vec2 ij = fract(R2_samples_spec(seed) + noise.rg) ; + vec3 H = sampleGGXVNDF(normSpaceView, roughness, ij.x, ij.y); + + if(hand) H = normalize(vec3(0.0,0.0,1.0)); + #else + vec3 H = normalize(vec3(0.0,0.0,1.0)); + #endif + + vec3 Ln = reflect(-normSpaceView, H); + vec3 L = basis * Ln; + + // fresnel stuff + float fresnel = pow(clamp(1.0 + dot(-Ln, H),0.0,1.0),5.0); + vec3 F = mix(f0, vec3(1.0), fresnel); + vec3 rayContrib = F; + + // float NdotV = clamp(normalize(dot(np3, L))*10000.,0.,1.); + bool hasReflections = (f0.y * (1.0 - roughness * Roughness_Threshold)) >= 0.0; + if (Roughness_Threshold == 1.0){ hasReflections = true; } + + + vec3 Ln_2 = reflect(-normSpaceView, normalize(vec3(0.0,0.0,1.0))); + vec3 L_2 = basis * Ln_2; + + vec3 FogReflection = skyCloudsFromTexLOD(L_2, colortex4, sqrt(roughness) * 9.0).rgb / 150.0; + FogReflection = mix(FogReflection, lightCol * 2 * clamp(dot(L_2, lightDir),0,1), roughness); + + + FogReflection *= 1.0 + roughness * 2.0; + vec4 Reflections = vec4(0.0); + + #ifdef Screen_Space_Reflections + if ( hasReflections ) { // Skip SSR if ray contribution is low + + float rayQuality = reflection_quality; + vec3 rtPos = rayTraceSpeculars( mat3(gbufferModelView) * L,fragpos.xyz, noise.b, reflection_quality, hand, reflectLength); + + float LOD = clamp( reflectLength * 6.0 ,0.0,6.0); + + if(hand) LOD = 6.0; + if(isEntities) LOD = 4.0; + + if (rtPos.z < 1. ){ // Reproject on previous frame + vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rtPos) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; + previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; + previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; + if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) { + Reflections.a = 1.0; + Reflections.rgb = texture2DLod(colortex5,previousPosition.xy,LOD).rgb; + } + } + } + #endif + + + // check if the f0 is within the metal ranges, then tint by albedo if it's true. + vec3 Metals = f0.y > 229.5/255.0 ? clamp(albedo + fresnel,0.0,1.0) : vec3(1.0); + Reflections.rgb *= Metals; + FogReflection *= Metals; + + Reflections.rgb = mix(FogReflection, Reflections.rgb, Reflections.a); // make background only where ssr is not. + Reflections_Final = mix(Output, Reflections.rgb, luma(rayContrib)); // apply reflections to final scene color. + + #ifdef Rough_reflections + Output = hand ? mix_vec3(Output, Reflections_Final, visibilityFactor) : Reflections_Final; + #else + Output = mix_vec3(Output, Reflections_Final, visibilityFactor); + #endif } \ No newline at end of file diff --git a/shaders/lib/volumetricClouds.glsl b/shaders/lib/volumetricClouds.glsl index dcfb4c5..068e465 100644 --- a/shaders/lib/volumetricClouds.glsl +++ b/shaders/lib/volumetricClouds.glsl @@ -1,5 +1,3 @@ - - #ifdef HQ_CLOUDS int maxIT_clouds = minRayMarchSteps; int maxIT = maxRayMarchSteps; @@ -19,21 +17,17 @@ uniform float viewHeight; uniform float viewWidth; uniform sampler2D colortex4;//Skybox -// uniform float lightningFlash; #define WEATHERCLOUDS #include "/lib/climate_settings.glsl" +float CumulusHeight = 250; +float MaxCumulusHeight = CumulusHeight + 100; -float maxHeight = 5000.; -float cloud_height = 1500.; - -// quick variables -float rainCloudwetness = rainStrength ; -float rainClouds = rainCloudwetness; - -float cloud_movement1 = frameTimeCounter * cloud_speed * 0.001; +float AltostratusHeight = 2000; +float rainCloudwetness = rainStrength; +float cloud_movement = 0; //3D noise from 2d texture float densityAtPos(in vec3 pos){ @@ -45,47 +39,33 @@ float densityAtPos(in vec3 pos){ vec2 coord = uv / 512.0; //The y channel has an offset to avoid using two textures fetches - vec2 xy = texture2D(noisetex, coord).yx; - return mix(xy.r,xy.g, f.y); } -float cloudshape = 0.0; - float cloudCov(in vec3 pos,vec3 samplePos){ + + float CloudLarge = texture2D(noisetex, (samplePos.xz + cloud_movement) / 5000 ).b; + float CloudSmall = texture2D(noisetex, (samplePos.xz - cloud_movement) / 500 ).r; + + float coverage = abs(pow(CloudLarge,1)*2.0 - 1.2)*0.5 - (1.0-CloudSmall) + 0.3; + + float Topshape = max(pos.y - (MaxCumulusHeight + CumulusHeight)*0.46, 0.0) / 200; + + Topshape += max(exp((pos.y - MaxCumulusHeight) / 10.0 ), 0.0) ; + + float FinalShape = DailyWeather_LowAltitude(coverage) - Topshape; + + // cap the top and bottom for reasons + float capbase = sqrt(max(CumulusHeight*1.05 - pos.y, 0.0)/50) ; + float captop = max(pos.y - MaxCumulusHeight, 0.0); - // float CloudLarge = texture2D(noisetex, samplePos.xz/150000 + cloud_movement1 ).b; - // float CloudSmall = texture2D(noisetex, samplePos.xz/15000 - cloud_movement1 + vec2(1-CloudLarge,-CloudLarge)/5).r; + FinalShape = FinalShape - capbase - captop ; - - // float coverage = CloudSmall-CloudLarge; - - // // float mult = max( abs(pos.y - (maxHeight+cloud_height)*0.4 ) / 5000, 0); - - // float mult = max( abs(pos.y-1750) / 5000, 0); - - - // cloudshape = DailyWeather_LowAltitude(coverage) - mult ; - - // return max(cloudshape,0.0); - - - - - float CloudLarge = texture2D(noisetex, samplePos.xz/150000 + cloud_movement1).b; - float CloudSmall = texture2D(noisetex, samplePos.xz/15000 - cloud_movement1 + vec2(1-CloudLarge,-CloudLarge)/5).r; - - float coverage = (CloudSmall) - pow(CloudLarge*0.5+0.5,1.5); - - float mult = max( abs(pos.y - (maxHeight+cloud_height)*0.4 ) / 5000, 0); - // float mult = max( abs(pos.y-1750) / 5000, 0); - - cloudshape = DailyWeather_LowAltitude(coverage) - mult; - - return max(cloudshape,0.0); + return max(FinalShape,0.0); } + //Erode cloud with 3d Perlin-worley noise, actual cloud value float cloudVol(in vec3 pos,in vec3 samplePos,in float cov, in int LoD){ float noise = 0.0 ; @@ -93,73 +73,48 @@ float cloudVol(in vec3 pos,in vec3 samplePos,in float cov, in int LoD){ float pw = log(fbmPower1); float pw2 = log(fbmPower2); - // samplePos.xyz -= cloud_movement1.xyz*400; - - for (int i = 0; i <= LoD; i++){ - float weight = exp(-i*pw2); - - noise += weight - densityAtPos(samplePos * 8 * exp(i*pw) )*weight ; - totalWeights += weight ; - } - - noise *= clamp(1.0-cloudshape,0.0,1.0); - noise /= totalWeights; - noise = noise*noise; - float cloud = max(cov-noise*noise*fbmAmount,0.0); - - // // noise = (1.0 - densityAtPos(samplePos * 4.)); - // // samplePos = floor(samplePos*)/16; - // noise += ((1.0 - densityAtPos(samplePos * 16.))*0.5+0.5) * (1.0 - densityAtPos(samplePos * 4.)); - // // noise += (1.0 - densityAtPos(samplePos / 160 * 1000.)); - // noise *= clamp(pow(1.0-cloudshape,0.5),0.0,1.0); - - // float cloud = max(cov - noise*noise*noise,0.0) ; + samplePos.xz -= cloud_movement/4; + noise += 1.0-densityAtPos(samplePos * 200.) ; + float smallnoise = densityAtPos(samplePos * 600.); + if (LoD > 0) noise += ((1-smallnoise) - max(0.15 - abs(smallnoise * 2.0 - 0.55) * 0.5,0.0)*1.5) * 0.5; + + noise *= 1.0-cov; + + noise = noise*noise; + float cloud = max(cov - noise*noise*fbmAmount,0.0); + return cloud; } -float getCloudDensity(in vec3 pos, in int LoD){ +float GetCumulusDensity(in vec3 pos, in int LoD){ - - // vec3 samplePos = floor((pos*vec3(1.0,1./48.,1.0)/4 ) /512)*512 ; vec3 samplePos = pos*vec3(1.0,1./48.,1.0)/4; + float coverageSP = cloudCov(pos,samplePos); if (coverageSP > 0.001) { if (LoD < 0) return max(coverageSP - 0.27*fbmAmount,0.0); - return cloudVol(pos,samplePos,coverageSP, LoD); + return cloudVol(pos,samplePos,coverageSP,LoD); } else return 0.0; } -float HighAltitudeClouds(vec3 pos){ - vec2 pos2d = pos.xz/100000.0 ; +float GetAltostratusDensity(vec3 pos){ - float cloudLarge = texture2D(noisetex, pos2d/5. ).b; - float cloudSmall = texture2D(noisetex, pos2d + vec2(-cloudLarge,cloudLarge)/10).b; - - - // #ifdef Dynamic_Sky - // coverage = max(10.3 - Weather_properties.g*10.,0.0); - // // thickness = Weather_properties.g*3 ; - // #endif + float large = texture2D(noisetex, pos.xz/100000. ).b; + float small = texture2D(noisetex, pos.xz/10000. - vec2(-large,1-large)/5).b; - float coverage = 1; - float thickness = 1; - DailyWeather_HighAltitude(coverage, thickness); + float shape = (small + pow((1.0-large),2.0))/2.0; - float cirrusFinal = exp(pow((cloudSmall + cloudLarge),thickness) * -coverage ); - return max(cirrusFinal,0.0); + shape = pow(max(shape + Alto_coverage - 0.5,0.0),2.0); + + return shape; } -//Mie phase function -float phaseg(float x, float g){ - float gg = g * g; - return (gg * -0.25 + 0.25) * pow(-2.0 * (g * x) + (gg + 1.0), -1.5) /3.14; -} + // random magic number bullshit go! vec3 Cloud_lighting( - vec3 Pos, float CloudShape, float SkyShadowing, float SunShadowing, @@ -168,252 +123,229 @@ vec3 Cloud_lighting( vec3 sunContribution, vec3 sunContributionMulti, vec3 moonContribution, - vec3 moonContributionMulti, + float AmbientShadow, int cloudType ){ - // low altitude - float powder = 1.0 - exp(-CloudShape * 400.0); - float ambientShading = exp(-SkyShadowing * 50. + powder)*powder ; - vec3 ambientLighting = SkyColors * ambientShading; - - // if(cloudType == 1) ambientLighting = SkyColors * powder; + float coeeff = -30; + // float powder = 1.0 - exp((CloudShape*CloudShape) * -800); + float powder = 1.0 - exp(CloudShape * coeeff/3); + float lesspowder = powder*0.4+0.6; - vec3 sunLighting = exp(-SunShadowing)*sunContribution + exp(-SunShadowing * 0.2)*sunContributionMulti; - sunLighting *= powder; + vec3 skyLighting = SkyColors * exp(SkyShadowing * AmbientShadow * coeeff/2 ) * lesspowder ; - vec3 moonLighting = ( exp2(-MoonShadowing * 2.0 )*moonContribution + exp(-MoonShadowing * 0.2 )*moonContributionMulti ) * powder; + if(cloudType == 1){ + coeeff = -10; + skyLighting = SkyColors * exp(SkyShadowing * coeeff/15) * lesspowder; + } - return ambientLighting + sunLighting ; + vec3 sunLighting = exp(SunShadowing * coeeff + powder) * sunContribution; + sunLighting += exp(SunShadowing * coeeff/4 + powder*2) * sunContributionMulti; + vec3 moonLighting = exp(MoonShadowing * coeeff / 3) * moonContribution * powder; - - // low altitude - // float powder = max(1.0 - exp2(-CloudShape*100.0),0.0); - // float ambientShading = (powder*0.8+0.2) * exp2(-SkyShadowing * 50.); - // vec3 ambientLighting = SkyColors * 4.0 * ambientShading; - - // if(cloudType == 1) ambientLighting = SkyColors * (1.0-powder/2); - - // vec3 sunLighting = ( exp2(-SunShadowing * 2.0 )*sunContribution + exp(-SunShadowing * 0.2 )*sunContributionMulti ) * powder; - // vec3 moonLighting = ( exp2(-MoonShadowing * 2.0 )*moonContribution + exp(-MoonShadowing * 0.2 )*moonContributionMulti ) * powder; - - // // if(cloudType == 0) sunLighting *= clamp((1.05-CirrusCoverage),0,1); // less sunlight hits low clouds if high clouds have alot of coverage - - // return ambientLighting + sunLighting + moonLighting; + return skyLighting + moonLighting + sunLighting ; } -vec3 pixelCoord (vec3 Coordinates, int Resolution){ - return floor(Coordinates / Resolution) * Resolution; +//Mie phase function +float phaseg(float x, float g){ + float gg = g * g; + return (gg * -0.25 + 0.25) * pow(-2.0 * (g * x) + (gg + 1.0), -1.5) / 3.14; +} + +float CustomPhase(float LightPos, float S_1, float S_2){ + float SCALE = S_2; // remember the epislons 0.001 is fine. + float N = S_1; + float N2 = N / SCALE; + + float R = 1; + float A = pow(1.0 - pow(max(R-LightPos,0.0), N2 ),N); + + return A; } -vec3 startOffset = vec3(0); vec4 renderClouds( - vec3 fragpositi, - vec3 color, - float dither, - vec3 sunColor, - vec3 moonColor, - vec3 avgAmbient, - float dither2 + vec3 FragPosition, + vec2 Dither, + vec3 SunColor, + vec3 MoonColor, + vec3 SkyColor ){ #ifndef VOLUMETRIC_CLOUDS return vec4(0.0,0.0,0.0,1.0); #endif - - float vL = 0.0; float total_extinction = 1.0; - color = vec3(0.0); + vec3 color = vec3(0.0); //project pixel position into projected shadowmap space - vec4 fragposition = gbufferModelViewInverse*vec4(fragpositi,1.0); + vec4 fragpos = normalize(gbufferModelViewInverse*vec4(FragPosition,1.0)); - vec3 worldV = normalize(fragposition.rgb); - float VdotU = worldV.y; + maxIT_clouds = int(clamp( maxIT_clouds / sqrt(exp2(fragpos.y)),0.0, maxIT)); - //project view origin into projected shadowmap space - vec4 start = (gbufferModelViewInverse*vec4(0.0,0.0,0.,1.)); + vec3 dV_view = normalize(fragpos.xyz); + + dV_view.y += 0.05; + + vec3 dV_view2 = dV_view; + float mult2 = length(dV_view2); - // vec3 dV_view = worldV; - - // cloud plane curvature - float curvature = 0.05; - worldV.y += curvature; - vec3 dV_view = worldV; - worldV.y -= curvature; - vec3 dV_view2 = worldV; - - - - maxIT_clouds = int(clamp( maxIT_clouds / sqrt(exp2(VdotU)),0.0, maxIT)); - - worldV = normalize(worldV)*100000. + cameraPosition; //makes max cloud distance not dependant of render distance - dV_view = normalize(dV_view); - - float height = Cloud_Height; - int flipClouds = 1; - // if (worldV.y < cloud_height){ - // flipClouds = -1; - // }; - - if (worldV.y < cloud_height || cameraPosition.y > 390. ) return vec4(0.,0.,0.,1.); //don't trace if no intersection is possible - // if (worldV.y < cloud_height && flipClouds == -1) return vec4(0.,0.,0.,1.); //don't trace if no intersection is possible - //setup ray to start at the start of the cloud plane and end at the end of the cloud plane - dV_view *= max(maxHeight - cloud_height, 0.0)/dV_view.y/(maxIT_clouds); - - // dV_view = floor(dV_view/1000)*1000; - startOffset = dV_view*dither; - - vec3 camPos = ((cameraPosition*flipClouds)-height)*Cloud_Size; - - vec3 progress_view = startOffset + camPos + dV_view*(cloud_height-camPos.y)/dV_view.y; - // progress_view = floor - float shadowStep = 200.; - vec3 dV_Sun = flipClouds * normalize(mat3(gbufferModelViewInverse)*sunVec)*shadowStep; + dV_view *= max(MaxCumulusHeight - CumulusHeight, 0.0)/abs(dV_view.y)/maxIT_clouds; float mult = length(dV_view); - float SdotV = dot(sunVec,normalize(fragpositi)); + // i want the samples to stay at one point in the world, but as the height coordinates go negative everything goes insideout, so this is a work around.... + float startFlip = mix(max(cameraPosition.y - MaxCumulusHeight,0.0), max(CumulusHeight-cameraPosition.y,0), clamp(dV_view.y,0,1)); + // vec3 progress_view = dV_view*Dither.x + cameraPosition + (dV_view/abs(dV_view.y))*startFlip; + vec3 progress_view = dV_view*Dither.x + cameraPosition + (dV_view/abs(dV_view.y))*startFlip; - float spinX = sin(frameTimeCounter *3.14); - float spinZ = sin(1.57 + frameTimeCounter*3.14); - float SdotV_custom = dot(mat3(gbufferModelView) * normalize(vec3(0,0.1,0)),normalize(fragpositi)); - - float phaseLightning = phaseg(SdotV_custom, 0.7); - - // direct light colors and shit for clouds - // multiply everything by ~pi just for good luck :D - // float mieDayMulti = phaseg(SdotV, 0.35)*3.14; - // float mieDay = mix(phaseg(SdotV,0.75), mieDayMulti,0.8)*3.14; - - float mieDayMulti = phaseg(SdotV, 0.35); - float mieDay = (phaseg(SdotV,0.75) + mieDayMulti)*2.0; - - float mieNightMulti = phaseg(-SdotV, 0.35)*3.14; - float mieNight = mix(phaseg(-SdotV,0.9), mieNightMulti,0.5)*3.14; - - vec3 sunContribution = mieDay*sunColor*3.14; - vec3 sunContributionMulti = mieDayMulti*sunColor*3.14; - - vec3 moonContribution = mieNight*moonColor*3.14; - vec3 moonContributionMulti = mieNightMulti*moonColor*3.14; - - float ambientMult = 1.0; - vec3 skyCol0 = (avgAmbient * ambientMult) ; - - vec3 progress_view_high = progress_view + (20000.0-progress_view.y) * dV_view / dV_view.y; - float muEshD_high = 0.0; - float muEshN_high = 0.0; - - float cirrusShadowStep = 7.; - float cirrusDensity = 0.03; - // progress_view = floor(progress_view/512)*512; - float cloud = 0.0; - for(int i=0;i= 0.0){ - float muS = cloud*densityofclouds; - float muE = cloud*densityofclouds; + float SdotV = dot(sunVec,normalize(FragPosition)); - float muEshD = 0.0; - if (sunContribution.g > 1e-5){ + SkyColor *= clamp(abs(dV_Sun.y)/100.,0.75,1.0); + SunColor = SunColor * clamp(dV_Sun.y ,0.0,1.0); + MoonColor *= clamp(-dV_Sun.y,0.0,1.0); + + if(dV_Sun.y/shadowStep < -0.1) dV_Sun = -dV_Sun; + + float mieDay = phaseg(SdotV, 0.75) * 2; + float mieDayMulti = phaseg(SdotV, 0.35) * 2; + + vec3 sunContribution = SunColor * mieDay; + vec3 sunContributionMulti = SunColor * mieDayMulti ; + + float mieNight = (phaseg(-SdotV,0.8) + phaseg(-SdotV, 0.35)*4) * 6.0; + vec3 moonContribution = MoonColor * mieNight; + + #ifdef Cumulus + for(int i=0;i lViewPosM; + // if(IntersecTerrain) break; + + float cumulus = GetCumulusDensity(progress_view, cloudLoD); + + float alteredDensity = Cumulus_density * clamp(exp( (progress_view.y - (MaxCumulusHeight + CumulusHeight)*0.455) / 9.0 ),0.0,1.0); + + if(cumulus > 1e-5){ + float muE = cumulus*alteredDensity; + + float Sunlight = 0.0; + float MoonLight = 0.0; + for (int j=0; j < self_shadow_samples; j++){ - float sample = j+dither2; - #ifdef Cumulus_Clouds - // low altitude clouds shadows - vec3 shadowSamplePos = progress_view + dV_Sun * (sample + sample*2.0); + vec3 shadowSamplePos = progress_view + dV_Sun * (1+j+Dither.y/2)*0.15; + float shadow = GetCumulusDensity(shadowSamplePos, 0) * Cumulus_density; + + Sunlight += shadow; + MoonLight += shadow; - if (shadowSamplePos.y < maxHeight){ - float cloudS = getCloudDensity(vec3(shadowSamplePos), cloudShadowLoD); - muEshD += cloudS*cloudDensity*shadowStep; - } - #endif - - #ifdef High_Altitude_Clouds - // high altitude clouds shadows - vec3 shadowSamplePos_high = progress_view_high + dV_Sun * (sample + sample*2.0); - float highAlt_cloudS = HighAltitudeClouds(shadowSamplePos_high); - muEshD_high += highAlt_cloudS*cirrusDensity*cirrusShadowStep; - #endif } - } - float muEshN = 0.0; - if (moonContribution.g > 1e-5){ - for (int j=0; j= 0.0){ - float muS = cirrus*cirrusDensity; - float muE = cirrus*cirrusDensity; - - float muEshA_high = cirrus*cirrusDensity; - - vec3 S = Cloud_lighting(progress_view, muE, muEshA_high, muEshD_high, muEshN_high, skyCol0 * max(abs(dV_Sun.y)/150.0,0.5) , sunContribution, sunContributionMulti, moonContribution, moonContributionMulti, 1); - - vec3 Sint = (S - S * exp(-mult*muE)) / muE; - color += max(muS*Sint*total_extinction,0.0); - total_extinction *= max(exp(-muE*mult),0); + } + progress_view += dV_view; } #endif - - vec3 normView = normalize(dV_view2)*flipClouds; + + + #ifdef Altostratus + if (max(AltostratusHeight-cameraPosition.y,0.0)/max(normalize(dV_view).y,0.0) / 100000.0 < AltostratusHeight) { + + vec3 progress_view_high = dV_view2 + cameraPosition + dV_view2/dV_view2.y * max(AltostratusHeight-cameraPosition.y,0.0); + float altostratus = GetAltostratusDensity(progress_view_high) * Alto_density; + + float Sunlight = 0.0; + float MoonLight = 0.0; + + if(altostratus > 1e-5){ + for (int j = 0; j < 2; j++){ + vec3 shadowSamplePos_high = progress_view_high + dV_Sun * float(j+Dither.y); + float shadow = GetAltostratusDensity(shadowSamplePos_high) * Alto_density; + Sunlight += shadow; + } + vec3 S = Cloud_lighting(altostratus, altostratus, Sunlight, MoonLight, SkyColor, sunContribution, sunContributionMulti, moonContribution, 1, 1); + + vec3 Sint = (S - S * exp(-20*altostratus)) / altostratus; + color += max(altostratus*Sint*total_extinction,0.0); + total_extinction *= max(exp(-20*altostratus),0.0); + } + } + #endif + + vec3 normView = normalize(dV_view); // Assume fog color = sky gradient at long distance - vec3 fogColor = skyFromTex(normView, colortex4)/150.; - float dist = (cloud_height - (cameraPosition.y))/normalize(dV_view2).y; - float fog = exp(-dist/15000.0*(1.0+rainCloudwetness*8.)); + vec3 fogColor = skyFromTex(normView, colortex4)/150. * 5.0; + float dist = max(cameraPosition.y+CumulusHeight,CumulusHeight)/abs(normView.y); + float fog = exp(dist / -5000.0 * (1.0+rainCloudwetness*8.)); + + // if(IntersecTerrain) fog = 1.0; + return mix(vec4(fogColor,0.0), vec4(color,total_extinction), fog); // return vec4(color,total_extinction); } + +float GetCloudShadow(vec3 eyePlayerPos){ + vec3 playerPos = eyePlayerPos + cameraPosition; + playerPos.y += 0.05; + float shadow; + + // assume a flat layer of cloud, and stretch the sampled density along the sunvector, starting from some vertical layer in the cloud. + #ifdef Cumulus + vec3 lowShadowStart = playerPos + WsunVec/abs(WsunVec.y) * max((MaxCumulusHeight + CumulusHeight)*0.44 - playerPos.y,0.0) ; + shadow += GetCumulusDensity(lowShadowStart,1)*cloudDensity; + #endif + + #ifdef Altostratus + vec3 highShadowStart = playerPos + WsunVec/abs(WsunVec.y) * max(AltostratusHeight - playerPos.y,0.0); + shadow += GetAltostratusDensity(highShadowStart) * Alto_density; + #endif + + shadow = clamp(exp(-shadow*10.0),0.0,1.0); + + return shadow; +} +float GetCloudShadow_VLFOG(vec3 WorldPos){ + + float shadow; + + // assume a flat layer of cloud, and stretch the sampled density along the sunvector, starting from some vertical layer in the cloud. + #ifdef Cumulus + vec3 lowShadowStart = WorldPos + WsunVec/abs(WsunVec.y) * max((MaxCumulusHeight + CumulusHeight)*0.435 - WorldPos.y,0.0) ; + shadow += GetCumulusDensity(lowShadowStart,0)*cloudDensity; + #endif + + #ifdef Altostratus + vec3 highShadowStart = WorldPos + WsunVec/abs(WsunVec.y) * max(AltostratusHeight - WorldPos.y,0.0); + shadow += GetAltostratusDensity(highShadowStart) * Alto_density; + #endif + + shadow = clamp(exp(-shadow*15.0),0.0,1.0); + + // do not allow it to exist above the lowest cloud plane + shadow *= clamp(((MaxCumulusHeight + CumulusHeight)*0.435 - WorldPos.y)/100,0.0,1.0) ; + + return shadow; +} \ No newline at end of file diff --git a/shaders/lib/volumetricFog.glsl b/shaders/lib/volumetricFog.glsl index 4b6573d..d7b37a1 100644 --- a/shaders/lib/volumetricFog.glsl +++ b/shaders/lib/volumetricFog.glsl @@ -1,35 +1,19 @@ - -float luma(vec3 color) { - return dot(color,vec3(0.299, 0.587, 0.114)); -} - float phaseRayleigh(float cosTheta) { const vec2 mul_add = vec2(0.1, 0.28) /acos(-1.0); return cosTheta * mul_add.x + mul_add.y; // optimized version from [Elek09], divided by 4 pi for energy conservation } - -// #define TIMEOFDAYFOG -// #include "/lib/climate_settings.glsl" - // uniform int worldTime; - - // void TimeOfDayFog( inout float Uniform, inout float Cloudy) { - - // float Time = (worldTime%24000)*1.0; - - // // set schedules for fog to appear at specific ranges of time in the day. - // float Morning = clamp((Time-22000)/2000,0,1) + clamp((2000-Time)/2000,0,1); - // float Noon = clamp(Time/2000,0,1) * clamp((12000-Time)/2000,0,1); - // float Evening = clamp((Time-10000)/2000,0,1) * clamp((14000-Time)/2000,0,1) ; - // float Night = clamp((Time-12000)/2000,0,1) * clamp((23000-Time)/2000,0,1) ; - - // vec4 UniformDensity = vec4(0, 55, 0, 0); - // vec4 CloudyDensity = vec4(0, 0, 0, 0); - - - // Uniform *= Morning*UniformDensity.r + Noon*UniformDensity.g + Evening*UniformDensity.b + Night*UniformDensity.a; - // Cloudy *= Morning*CloudyDensity.r + Noon*CloudyDensity.g + Evening*CloudyDensity.b + Night*CloudyDensity.a; - // } +float densityAtPosFog(in vec3 pos){ + pos /= 18.; + pos.xz *= 0.5; + vec3 p = floor(pos); + vec3 f = fract(pos); + f = (f*f) * (3.-2.*f); + vec2 uv = p.xz + f.xz + p.y * vec2(0.0,193.0); + vec2 coord = uv / 512.0; + vec2 xy = texture2D(noisetex, coord).yx; + return mix(xy.r,xy.g, f.y); +} float cloudVol(in vec3 pos){ @@ -37,24 +21,28 @@ float cloudVol(in vec3 pos){ vec3 samplePos2 = pos*vec3(1.0,1./48.,1.0); - float mult = exp2( -max((pos.y - SEA_LEVEL) / 35.,0.0)); + float mult = exp( -max((pos.y - SEA_LEVEL) / 35.,0.0)); - float fog_shape = 1-densityAtPos(samplePos * 24.0); - float fog_eroded = densityAtPos( samplePos2 * 150.0); + float fog_shape = 1.0 - densityAtPosFog(samplePos * 24.0); + float fog_eroded = 1.0 - densityAtPosFog( samplePos2 * 200.0); + + // float CloudyFog = max( (fog_shape*2.0 - fog_eroded*0.5) - 1.2, max(fog_shape-0.8,0.0)) * mult; + + float CloudyFog = max((fog_shape*1.2 - fog_eroded*0.2) - 0.75,0.0) ; - float CloudyFog = max( (fog_shape*2.0 - fog_eroded*0.5) - 1.4, 0.0) * mult; float UniformFog = exp2( -max((pos.y - SEA_LEVEL) / 25.,0.0)); - float RainFog = max(fog_shape*10. - 7.,0.5) * exp2( -max((pos.y - SEA_LEVEL) / 25.,0.0)) * 5. * rainStrength; + float RainFog = max(fog_shape*10. - 7.,0.5) * exp2( -max((pos.y - SEA_LEVEL) / 25.,0.0)) * 5. * rainStrength * RainFog_amount; TimeOfDayFog(UniformFog, CloudyFog); - return RainFog + CloudyFog + UniformFog; + return CloudyFog + UniformFog + RainFog; } -mat2x3 getVolumetricRays( +vec4 getVolumetricRays( + vec3 fragpos, float dither, - vec3 fragpos + vec3 AmbientColor ){ //project pixel position into projected shadowmap space vec3 wpos = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; @@ -76,7 +64,6 @@ mat2x3 getVolumetricRays( //apply dither vec3 progress = start.xyz; - vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; vec3 vL = vec3(0.); @@ -88,23 +75,23 @@ mat2x3 getVolumetricRays( float rayL = phaseRayleigh(SdotV); // Makes fog more white idk how to simulate it correctly - vec3 sunColor = lightCol.rgb / 5.0; - vec3 skyCol0 = (ambientUp / 5.0 * 5.); // * max(abs(WsunVec.y)/150.0,0.); + vec3 sunColor = lightCol.rgb / 80.0; + vec3 skyCol0 = AmbientColor / 150. * 5.; // * max(abs(WsunVec.y)/150.0,0.); vec3 rC = vec3(fog_coefficientRayleighR*1e-6, fog_coefficientRayleighG*1e-5, fog_coefficientRayleighB*1e-5); vec3 mC = vec3(fog_coefficientMieR*1e-6, fog_coefficientMieG*1e-6, fog_coefficientMieB*1e-6); float mu = 1.0; float muS = mu; - vec3 absorbance = vec3(1.0); + float absorbance = 1.0; float expFactor = 11.0; vec3 WsunVec = mat3(gbufferModelViewInverse) * sunVec * lightCol.a; - float cloudShadow = 1.0; + vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; - for (int i=0;i 6500. ? 138039.215686 * t + 0.72156862745 : col.y; + col.z = 0.76078431372 * lt - 5.68078431373; + col = clamp(col,0.0,1.0); + col = Temp < 1000. ? col * Temp * 0.001 : col; - - -// float getPuddleCoverage(vec3 samplePos){ -// float puddle = texture2D(noisetex, samplePos.xz/25000).b ; - -// return max(puddle,0.0); -// } + return srgbToLinear2(col); +} +float densityAtPosSNOW(in vec3 pos){ + pos /= 18.; + pos.xz *= 0.5; + vec3 p = floor(pos); + vec3 f = fract(pos); + f = (f*f) * (3.-2.*f); + vec2 uv = p.xz + f.xz + p.y * vec2(0.0,193.0); + vec2 coord = uv / 512.0; + vec2 xy = texture2D(noisetex, coord).yx; + return mix(xy.r,xy.g, f.y); +} //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -222,17 +235,15 @@ const vec2[8] offsets = vec2[8](vec2(1./8.,-3./8.), //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// -/* RENDERTARGETS: 1,7,8,13 */ +/* RENDERTARGETS: 1,7,8,15,10 */ void main() { - #ifdef BLOCK_ENT - gl_FragData[3] = TESTMASK; - #endif float phi = 2 * 3.14159265359; float noise = fract(fract(frameCounter * (1.0 / phi)) + interleaved_gradientNoise() ) ; vec3 normal = normalMat.xyz; + vec3 normal2 = normalMat.xyz; #ifdef MC_NORMAL_MAP vec3 tangent2 = normalize(cross(tangent.rgb,normal)*tangent.w); @@ -240,30 +251,15 @@ void main() { tangent.y, tangent2.y, normal.y, tangent.z, tangent2.z, normal.z); #endif + vec2 tempOffset=offsets[framemod8]; vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize/RENDER_SCALE,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); - - - vec3 worldpos = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition; - float lightmap = clamp( (lmtexcoord.w-0.66) * 5.0,0.,1.); - float rainfall = 0. ; - float Puddle_shape = 0.; - float puddle_shiny = 1.; - float puddle_normal = 0.; - - #ifndef ENTITIES - #ifdef WORLD - #ifdef Puddles - rainfall = rainStrength ; - Puddle_shape = 1.0 - max(texture2D(noisetex, worldpos.xz * (0.015 * Puddle_Size)).b - (1.0-lightmap) ,0.0); - puddle_shiny = clamp( pow(1.0-Puddle_shape,2.0)*2,0.5,1.) ; - puddle_normal = clamp( pow(Puddle_shape,5.0) * 50. ,0.,1.) ; - #endif - #endif - #endif + + float lightmap = clamp( (lmtexcoord.w-0.8) * 10.0,0.,1.); + #ifdef POM // vec2 tempOffset=offsets[framemod8]; @@ -277,13 +273,26 @@ void main() { #ifdef WORLD if (dist < MAX_OCCLUSION_DISTANCE) { - if ( viewVector.z < 0.0 && readNormal(vtexcoord.st).a < 0.9999 && readNormal(vtexcoord.st).a > 0.00001) { + float depthmap = readNormal(vtexcoord.st).a; + float used_POM_DEPTH = 1.0; - vec3 interval = viewVector.xyz /-viewVector.z/MAX_OCCLUSION_POINTS*POM_DEPTH; - vec3 coord = vec3(vtexcoord.st, 1.0); - coord += noise*interval; - float sumVec = noise; - for (int loopCount = 0; (loopCount < MAX_OCCLUSION_POINTS) && (1.0 - POM_DEPTH + POM_DEPTH*readNormal(coord.st).a < coord.p) && coord.p >= 0.0; ++loopCount) { coord = coord+interval; sumVec += 1.0; } + if ( viewVector.z < 0.0 && depthmap < 0.9999 && depthmap > 0.00001) { + + #ifdef Adaptive_Step_length + vec3 interval = (viewVector.xyz /-viewVector.z/MAX_OCCLUSION_POINTS * POM_DEPTH) * clamp(1.0-pow(depthmap,2),0.1,1.0) ; + used_POM_DEPTH = 1.0; + #else + vec3 interval = viewVector.xyz /-viewVector.z/MAX_OCCLUSION_POINTS*POM_DEPTH; + #endif + vec3 coord = vec3(vtexcoord.st, 1.0); + + coord += interval * used_POM_DEPTH; + + float sumVec = 0.5; + for (int loopCount = 0; (loopCount < MAX_OCCLUSION_POINTS) && (1.0 - POM_DEPTH + POM_DEPTH * readNormal(coord.st).a ) < coord.p && coord.p >= 0.0; ++loopCount) { + coord = coord+interval * used_POM_DEPTH; + sumVec += 1.0 * used_POM_DEPTH; + } if (coord.t < mincoord) { if (readTexture(vec2(coord.s,mincoord)).a == 0.0) { @@ -301,93 +310,104 @@ void main() { } #endif - // color - vec4 data0 = texture2DGradARB(texture, adjustedTexCoord.xy,dcdx,dcdy); + //////////////////////////////// + //////////////////////////////// ALBEDO + //////////////////////////////// - #ifdef DISABLE_ALPHA_MIPMAPS - data0.a = texture2DGradARB(texture, adjustedTexCoord.xy,vec2(0.),vec2(0.0)).a; - #endif - - data0.rgb *= color.rgb; - float avgBlockLum = luma(texture2DLod(texture, lmtexcoord.xy,128).rgb*color.rgb); - data0.rgb = clamp(data0.rgb*pow(avgBlockLum,-0.33)*0.85,0.0,1.0); + vec4 Albedo = texture2DGradARB(texture, adjustedTexCoord.xy,dcdx,dcdy) * color; + + #ifdef ENTITIES + if(NameTags == 1) Albedo = texture2D(texture, lmtexcoord.xy, Texture_MipMap_Bias) * color; + #endif + #ifdef WORLD + if (Albedo.a > 0.1) Albedo.a = normalMat.a; + else Albedo.a = 0.0; + #endif - #ifdef WORLD - if (data0.a > 0.1) data0.a = normalMat.a; - else data0.a = 0.0; - #endif + #ifdef HAND + if (Albedo.a > 0.1) Albedo.a = 0.75; + else Albedo.a = 0.0; + #endif - #ifdef HAND - if (data0.a > 0.1) data0.a = 0.75; - else data0.a = 0.0; - #endif + //////////////////////////////// + //////////////////////////////// NORMAL + //////////////////////////////// - // normal - #ifdef MC_NORMAL_MAP - vec3 normalTex = texture2DGradARB(normals, adjustedTexCoord.xy, dcdx,dcdy).rgb; - normalTex.xy = normalTex.xy*2.0-1.0; - normalTex.z = clamp(sqrt(1.0 - dot(normalTex.xy, normalTex.xy)),0.0,1.0); - normal = applyBump(tbnMatrix,normalTex, mix(1.0,puddle_normal,rainfall)); - #endif + #ifdef MC_NORMAL_MAP + vec3 NormalTex = texture2DGradARB(normals, adjustedTexCoord.xy, dcdx,dcdy).rgb; + NormalTex.xy = NormalTex.xy*2.0-1.0; + NormalTex.z = clamp(sqrt(1.0 - dot(NormalTex.xy, NormalTex.xy)),0.0,1.0); - // specular - gl_FragData[2] = texture2DGradARB(specular, adjustedTexCoord.xy,dcdx,dcdy); + normal = applyBump(tbnMatrix,NormalTex, 1.0); + #endif - // finalize - vec4 data1 = clamp(encode(viewToWorld(normal), lmtexcoord.zw),0.,1.0); - gl_FragData[0] = vec4(encodeVec2(data0.x,data1.x),encodeVec2(data0.y,data1.y),encodeVec2(data0.z,data1.z),encodeVec2(data1.w,data0.w)); - - gl_FragData[1].a = 0.0; + //////////////////////////////// + //////////////////////////////// SPECULAR + //////////////////////////////// + + gl_FragData[2] = texture2DGradARB(specular, adjustedTexCoord.xy,dcdx,dcdy); + + //////////////////////////////// + //////////////////////////////// FINALIZE + //////////////////////////////// + + vec4 data1 = clamp(encode(viewToWorld(normal), lmtexcoord.zw),0.,1.0); + gl_FragData[0] = vec4(encodeVec2(Albedo.x,data1.x),encodeVec2(Albedo.y,data1.y),encodeVec2(Albedo.z,data1.z),encodeVec2(data1.w,Albedo.w)); + + gl_FragData[1].a = 0.0; #else - // specular - vec4 specular = texture2D(specular, lmtexcoord.xy, Texture_MipMap_Bias).rgba; - vec4 specular_modded = vec4( max(specular.r,puddle_shiny), max(specular.g, puddle_shiny*0.1),specular.ba); - gl_FragData[2].rgba = mix(specular, specular_modded, rainfall); - float porosity = specular.z >= 64.5/255.0 ? 0.0 : (specular.z*255.0/64.0)*0.65; - #ifndef Porosity - porosity = 0.4; - #endif - // normal - #ifdef MC_NORMAL_MAP - vec4 normalTex = texture2D(normals, lmtexcoord.xy, Texture_MipMap_Bias).rgba; - normalTex.xy = normalTex.xy*2.0-1.0; - normalTex.z = clamp(sqrt(1.0 - dot(normalTex.xy, normalTex.xy)),0.0,1.0) ; - normal = applyBump(tbnMatrix, normalTex.xyz, mix(1.0,puddle_normal, rainfall) ); - #endif + //////////////////////////////// + //////////////////////////////// NORMAL + //////////////////////////////// - // color - vec4 data0 = texture2D(texture, lmtexcoord.xy, Texture_MipMap_Bias) ; + #ifdef MC_NORMAL_MAP + vec4 NormalTex = texture2D(normals, lmtexcoord.xy, Texture_MipMap_Bias).rgba; + NormalTex.xy = NormalTex.xy*2.0-1.0; + NormalTex.z = clamp(sqrt(1.0 - dot(NormalTex.xy, NormalTex.xy)),0.0,1.0) ; - data0.rgb *= mix(color.rgb, vec3(0.0), max((puddle_shiny*porosity)*0.5,0) * rainfall ); + normal = applyBump(tbnMatrix, NormalTex.xyz, 1.0); + #endif + //////////////////////////////// + //////////////////////////////// SPECULAR + //////////////////////////////// - float avgBlockLum = luma(texture2DLod(texture, lmtexcoord.xy,128).rgb*color.rgb); - data0.rgb = clamp(data0.rgb*pow(avgBlockLum,-0.33)*0.85,0.0,1.0); + vec4 SpecularTex = texture2D(specular, lmtexcoord.xy, Texture_MipMap_Bias); + gl_FragData[2] = SpecularTex; + + //////////////////////////////// + //////////////////////////////// ALBEDO + //////////////////////////////// - #ifndef ENTITIES - if(TESTMASK.r==255) data0.rgb = vec3(0); - #endif - - #ifdef DISABLE_ALPHA_MIPMAPS - data0.a = texture2DLod(texture,lmtexcoord.xy,0).a; - #endif - #ifdef WORLD - if (data0.a > 0.1) data0.a = normalMat.a; - else data0.a = 0.0; - - #endif - #ifdef HAND - if (data0.a > 0.1) data0.a = 0.75; - else data0.a = 0.0; - #endif - - // finalize - vec4 data1 = clamp(blueNoise()/255.0 + encode(viewToWorld(normal), lmtexcoord.zw),0.0,1.0); - gl_FragData[0] = vec4(encodeVec2(data0.x,data1.x), encodeVec2(data0.y,data1.y), encodeVec2(data0.z,data1.z), encodeVec2(data1.w,data0.w)); + vec4 Albedo = texture2D(texture, lmtexcoord.xy, Texture_MipMap_Bias) * color; + + + #ifdef WhiteWorld + Albedo.rgb = vec3(1.0); + #endif + + #ifdef WORLD + if (Albedo.a > 0.1) Albedo.a = normalMat.a; + else Albedo.a = 0.0; + #endif + + #ifdef HAND + if (Albedo.a > 0.1) Albedo.a = 0.75; + else Albedo.a = 0.0; + #endif + + //////////////////////////////// + //////////////////////////////// FINALIZE + //////////////////////////////// + + + vec4 data1 = clamp( encode(viewToWorld(normal), blueNoise()*lmtexcoord.zw/50.0+lmtexcoord.zw ),0.0,1.0); + + gl_FragData[0] = vec4(encodeVec2(Albedo.x,data1.x), encodeVec2(Albedo.y,data1.y), encodeVec2(Albedo.z,data1.z), encodeVec2(data1.w,Albedo.w)); #ifdef WORLD gl_FragData[1].a = 0.0; @@ -395,17 +415,12 @@ void main() { #endif + gl_FragData[3] = vec4(FlatNormals* 0.5 + 0.5,VanillaAO); + + + gl_FragData[4].x = 0; - #ifdef ENTITIES - #ifdef WORLD - gl_FragData[3].xyz = test_motionVectors; + gl_FragData[4].x = 1; #endif - #endif - // float z = texture2D(depthtex0,texcoord).x; - // vec3 fragpos = toScreenSpace(vec3(texcoord,z)); - // gl_FragData[0].rgb *= vec3(1- clamp( pow( length(fragpos)/far, 1), 0, 1)) ; - - - } \ No newline at end of file diff --git a/shaders/programs/all_solid.vsh b/shaders/programs/all_solid.vsh new file mode 100644 index 0000000..d0a9289 --- /dev/null +++ b/shaders/programs/all_solid.vsh @@ -0,0 +1,140 @@ +#extension GL_EXT_gpu_shader4 : enable +#include "/lib/settings.glsl" +#include "/lib/res_params.glsl" + +/* +!! DO NOT REMOVE !! +This code is from Chocapic13' shaders +Read the terms of modification and sharing before changing something below please ! +!! DO NOT REMOVE !! +*/ + + +#ifndef USE_LUMINANCE_AS_HEIGHTMAP +#ifndef MC_NORMAL_MAP + #undef POM +#endif +#endif + +#ifdef POM + #define MC_NORMAL_MAP +#endif + + +varying vec4 color; +varying float VanillaAO; + +varying vec4 lmtexcoord; +varying vec4 normalMat; + +#ifdef POM + varying vec4 vtexcoordam; // .st for add, .pq for mul + varying vec4 vtexcoord; +#endif + +#ifdef MC_NORMAL_MAP + varying vec4 tangent; + attribute vec4 at_tangent; + varying vec3 FlatNormals; +#endif + + +attribute vec4 mc_Entity; +uniform int blockEntityId; +uniform int entityId; + +flat varying float blockID; + +flat varying int NameTags; + +attribute vec4 mc_midTexCoord; + +uniform vec2 texelSize; +uniform int framemod8; + +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.); + +#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) +#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) + +vec4 toClipSpace3(vec3 viewSpacePosition) { + return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); +} + +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// + +void main() { + gl_Position = ftransform(); + lmtexcoord.xy = (gl_MultiTexCoord0).xy; + + FlatNormals = normalize(gl_NormalMatrix * gl_Normal); + + NameTags = 0; + blockID = mc_Entity.x; + + #ifdef POM + vec2 midcoord = (gl_TextureMatrix[0] * mc_midTexCoord).st; + vec2 texcoordminusmid = lmtexcoord.xy-midcoord; + vtexcoordam.pq = abs(texcoordminusmid)*2; + vtexcoordam.st = min(lmtexcoord.xy,midcoord-texcoordminusmid); + vtexcoord.xy = sign(texcoordminusmid)*0.5+0.5; + #endif + + vec2 lmcoord = gl_MultiTexCoord1.xy/255.; + lmtexcoord.zw = lmcoord; + vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; + + color = gl_Color; + + VanillaAO = 1.0 - clamp(color.a,0,1); + if (color.a < 0.3) color.a = 1.0; // fix vanilla ao on some custom block models. + + + #ifdef MC_NORMAL_MAP + tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); + #endif + + normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal), 1.0); + +#ifdef ENTITIES + // try and single out nametag text and then discard nametag background + if( dot(gl_Color.rgb, vec3(0.35)) < 1.0) NameTags = 1; + + if(gl_Color.a >= 0.24 && gl_Color.a <= 0.25 ) gl_Position = vec4(10,10,10,1); +#endif + + + +#ifdef WORLD + + normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),mc_Entity.x == 10004 || mc_Entity.x == 10003 ? 0.5 : mc_Entity.x == 10001 ? 0.6 : 1.0); + + normalMat.a = mc_Entity.x == 10005 ? 0.8 : normalMat.a; + + if (mc_Entity.x == 100 ){ + color.rgb = normalize(color.rgb)*sqrt(3.0); + normalMat.a = 0.9; + } + + gl_Position = toClipSpace3(position); + +#endif + + #ifdef TAA_UPSCALING + gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; + #endif + #ifdef TAA + gl_Position.xy += offsets[framemod8] * gl_Position.w * texelSize; + #endif +} diff --git a/shaders/programs/all_translucent.fsh b/shaders/programs/all_translucent.fsh new file mode 100644 index 0000000..dbd7368 --- /dev/null +++ b/shaders/programs/all_translucent.fsh @@ -0,0 +1,576 @@ +// #version 120 +#extension GL_EXT_gpu_shader4 : enable + +varying vec4 lmtexcoord; +varying vec4 color; +varying vec4 normalMat; +varying vec3 binormal; +uniform sampler2D normals; +varying vec3 tangent; +varying vec4 tangent_other; +varying vec3 viewVector; + +#include "/lib/settings.glsl" +#include "/lib/res_params.glsl" + + +uniform sampler2D texture; +uniform sampler2D noisetex; +uniform sampler2DShadow shadow; +// uniform sampler2D gaux2; +uniform sampler2D gaux1; +uniform sampler2D depthtex1; +uniform sampler2D colortex5; + +uniform float nightVision; + +uniform vec3 sunVec; +uniform float frameTimeCounter; +uniform float lightSign; +uniform float near; +uniform float far; +uniform float moonIntensity; +uniform float sunIntensity; +uniform vec3 sunColor; +uniform vec3 nsunColor; +uniform vec3 upVec; +uniform float sunElevation; +uniform float fogAmount; +uniform vec2 texelSize; +uniform float rainStrength; +uniform float skyIntensityNight; +uniform float skyIntensity; +flat varying vec3 WsunVec; +uniform mat4 gbufferPreviousModelView; +uniform vec3 previousCameraPosition; +uniform int framemod8; +uniform sampler2D specular; +uniform int frameCounter; +uniform int isEyeInWater; + + +flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) +flat varying vec3 avgAmbient; + +#include "/lib/color_transforms.glsl" +#include "/lib/projections.glsl" +#include "/lib/sky_gradient.glsl" +#include "/lib/waterBump.glsl" + +#include "/lib/diffuse_lighting.glsl" + + + 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 interleaved_gradientNoise(float temporal){ + vec2 coord = gl_FragCoord.xy; + float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+temporal); + return noise; +} +vec3 srgbToLinear2(vec3 srgb){ + return mix( + srgb / 12.92, + pow(.947867 * srgb + .0521327, vec3(2.4) ), + step( .04045, srgb ) + ); +} +vec3 blackbody2(float Temp) +{ + float t = pow(Temp, -1.5); + float lt = log(Temp); + + vec3 col = vec3(0.0); + col.x = 220000.0 * t + 0.58039215686; + col.y = 0.39231372549 * lt - 2.44549019608; + col.y = Temp > 6500. ? 138039.215686 * t + 0.72156862745 : col.y; + col.z = 0.76078431372 * lt - 5.68078431373; + col = clamp(col,0.0,1.0); + col = Temp < 1000. ? col * Temp * 0.001 : col; + + return srgbToLinear2(col); +} + +float blueNoise(){ + return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); +} +float invLinZ (float lindepth){ + return -((2.0*near/lindepth)-far-near)/(far-near); +} +float ld(float dist) { + return (2.0 * near) / (far + near - dist * (far - near)); +} +vec3 nvec3(vec4 pos){ + return pos.xyz/pos.w; +} + +vec4 nvec4(vec3 pos){ + return vec4(pos.xyz, 1.0); +} +vec3 rayTrace(vec3 dir,vec3 position,float dither, float fresnel, bool inwater){ + + float quality = mix(15,SSR_STEPS,fresnel); + vec3 clipPosition = toClipSpace3(position); + float rayLength = ((position.z + dir.z * far*sqrt(3.)) > -near) ? + (-near -position.z) / dir.z : far*sqrt(3.); + vec3 direction = normalize(toClipSpace3(position+dir*rayLength)-clipPosition); //convert to clip space + direction.xy = normalize(direction.xy); + + //get at which length the ray intersects with the edge of the screen + vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; + float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z); + + + vec3 stepv = direction * mult / quality*vec3(RENDER_SCALE,1.0); + + + vec3 spos = clipPosition*vec3(RENDER_SCALE,1.0) + stepv*dither; + float minZ = clipPosition.z; + float maxZ = spos.z+stepv.z*0.5; + + spos.xy += offsets[framemod8]*texelSize*0.5/RENDER_SCALE; + + float dist = 1.0 + clamp(position.z*position.z/50.0,0,2); // shrink sample size as distance increases + for (int i = 0; i <= int(quality); i++) { + // decode depth buffer + float sp = texelFetch2D(depthtex1,ivec2(spos.xy/texelSize),0).x; + + + if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ) ) return vec3(spos.xy/RENDER_SCALE,sp); + + spos += stepv; + + //small bias + float biasamount = 0.0002 / dist; + + minZ = maxZ-biasamount / ld(spos.z); + + maxZ += stepv.z; + } + + return vec3(1.1); +} + + +float facos(float sx){ + float x = clamp(abs( sx ),0.,1.); + float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); + return sx > 0. ? a : pi - a; +} + + + + + float bayer2(vec2 a){ + a = floor(a); + return fract(dot(a,vec2(0.5,a.y*0.75))); +} + +float cdist(vec2 coord) { + return max(abs(coord.s-0.5),abs(coord.t-0.5))*2.0; +} + + #define PW_DEPTH 1.0 //[0.5 1.0 1.5 2.0 2.5 3.0] + #define PW_POINTS 1 //[2 4 6 8 16 32] + #define bayer4(a) (bayer2( .5*(a))*.25+bayer2(a)) +#define bayer8(a) (bayer4( .5*(a))*.25+bayer2(a)) +#define bayer16(a) (bayer8( .5*(a))*.25+bayer2(a)) +#define bayer32(a) (bayer16(.5*(a))*.25+bayer2(a)) +#define bayer64(a) (bayer32(.5*(a))*.25+bayer2(a)) +#define bayer128(a) fract(bayer64(.5*(a))*.25+bayer2(a)) +vec3 getParallaxDisplacement(vec3 posxz, float iswater,float bumpmult,vec3 viewVec) { + float waveZ = mix(20.0,0.25,iswater); + float waveM = mix(0.0,4.0,iswater); + + vec3 parallaxPos = posxz; + vec2 vec = viewVector.xy * (1.0 / float(PW_POINTS)) * 22.0 * PW_DEPTH; + float waterHeight = getWaterHeightmap(posxz.xz, waveM, waveZ, iswater) ; + + parallaxPos.xz += waterHeight * vec; + + return parallaxPos; + +} +vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter,float distort) +{ + float alpha = (sampleNumber+jitter)/nb; + float angle = jitter*6.28 + alpha * nbRot * 6.28; + + float sin_v, cos_v; + + sin_v = sin(angle); + cos_v = cos(angle); + + return vec2(cos_v, sin_v)*sqrt(alpha); +} +//Low discrepancy 2D sequence, integration error is as low as sobol but easier to compute : http://extremelearning.com.au/unreasonable-effectiveness-of-quasirandom-sequences/ +vec2 R2_samples(int n){ + vec2 alpha = vec2(0.75487765, 0.56984026); + return fract(alpha * n); +} +vec4 hash44(vec4 p4) +{ + p4 = fract(p4 * vec4(.1031, .1030, .0973, .1099)); + p4 += dot(p4, p4.wzxy+33.33); + return fract((p4.xxyz+p4.yzzw)*p4.zywx); +} +vec3 TangentToWorld(vec3 N, vec3 H) +{ + vec3 UpVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0); + vec3 T = normalize(cross(UpVector, N)); + vec3 B = cross(N, T); + + return vec3((T * H.x) + (B * H.y) + (N * H.z)); +} +float GGX (vec3 n, vec3 v, vec3 l, float r, float F0) { + r*=r;r*=r; + + vec3 h = l + v; + float hn = inversesqrt(dot(h, h)); + + float dotLH = clamp(dot(h,l)*hn,0.,1.); + float dotNH = clamp(dot(h,n)*hn,0.,1.); + float dotNL = clamp(dot(n,l),0.,1.); + float dotNHsq = dotNH*dotNH; + + float denom = dotNHsq * r - dotNHsq + 1.; + float D = r / (3.141592653589793 * denom * denom); + float F = F0 + (1. - F0) * exp2((-5.55473*dotLH-6.98316)*dotLH); + float k2 = .25 * r; + + return dotNL * D * F / (dotLH*dotLH*(1.0-k2)+k2); +} + + vec3 applyBump(mat3 tbnMatrix, vec3 bump){ + float bumpmult = 1.0; + bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); + return normalize(bump*tbnMatrix); + } + +#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) +float triangularize(float dither) +{ + float center = dither*2.0-1.0; + dither = center*inversesqrt(abs(center)); + return clamp(dither-fsign(center),0.0,1.0); +} +vec3 fp10Dither(vec3 color,float dither){ + const vec3 mantissaBits = vec3(6.,6.,5.); + vec3 exponent = floor(log2(color)); + return color + dither*exp2(-mantissaBits)*exp2(exponent); +} +float R2_dither(){ + vec2 alpha = vec2(0.75487765, 0.56984026); + return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y + 1.0/1.6180339887 * frameCounter) ; +} +float interleaved_gradientNoise(){ + vec2 coord = gl_FragCoord.xy + (frameCounter%40000); + // vec2 coord = gl_FragCoord.xy + frameTimeCounter; + // vec2 coord = gl_FragCoord.xy; + float noise = fract( 52.9829189 * fract( (coord.x * 0.06711056) + (coord.y * 0.00583715)) ); + return noise ; +} +//encoding by jodie +float encodeVec2(vec2 a){ + const vec2 constant1 = vec2( 1., 256.) / 65535.; + vec2 temp = floor( a * 255. ); + return temp.x*constant1.x+temp.y*constant1.y; +} +float encodeVec2(float x,float y){ + return encodeVec2(vec2(x,y)); +} +vec3 viewToWorld(vec3 viewPosition) { + vec4 pos; + pos.xyz = viewPosition; + pos.w = 0.0; + pos = gbufferModelViewInverse * pos; + return pos.xyz; +} +vec3 worldToView(vec3 worldPos) { + vec4 pos = vec4(worldPos, 0.0); + pos = gbufferModelView * pos; + return pos.xyz; +} +vec4 encode (vec3 n, vec2 lightmaps){ + n.xy = n.xy / dot(abs(n), vec3(1.0)); + n.xy = n.z <= 0.0 ? (1.0 - abs(n.yx)) * sign(n.xy) : n.xy; + vec2 encn = clamp(n.xy * 0.5 + 0.5,-1.0,1.0); + + return vec4(encn,vec2(lightmaps.x,lightmaps.y)); +} + + + + +float square(float x){ + return x*x; +} + +float gSimple(float dp, float roughness){ + float k = roughness + 1; + k *= k/8.0; + return dp / (dp * (1.0-k) + k); +} +vec3 GGX2_2(vec3 n, vec3 v, vec3 l, float r, vec3 F0) { + + float alpha = square(r) + 1e-4; // when roughness is zero it fucks up + + vec3 h = normalize(l + v) ; + + float dotNH = clamp(dot(h,n),0.,1.); + float dotVH = clamp(dot(h,v),0.,1.); + + float D = alpha / (2.2 * square( (dotNH * alpha - 1.0) * square(dotNH) + 1.0) ); + + vec3 F = F0 + (1. - F0) * pow(clamp(1.0 - dotVH,0.0,1.0),5.0); + + return F * D; +} +// float SunGGX(vec3 n, vec3 v, vec3 l, float Roughness, float F0){ + +// vec3 h = normalize(l + v) ; + +// float dotNH = clamp(dot(h,n),0.,1.); +// float dotVH = clamp(dot(h,v),0.,1.); + +// float alpha =max(square(Roughness),1e-4) ; + +// float WallFresnel = F0 + (1. - F0) * pow(clamp(1.0 - dotVH,0.0,1.0),5.0); +// float Sun = square( dotNH - pow(alpha,1.5) - 1.0); + +// float Final = ((alpha / (10.0 * Sun + 1e-4)) * WallFresnel); + +// return Final ; +// } +float SunGGX(vec3 n, vec3 v, vec3 l, float roughness,float F0, float fresnel){ + + + float alpha = square(roughness) + 1e-4; // when roughness is zero it fucks up + + vec3 h = normalize(l + v) * mix(1.000, 1.0025, pow(fresnel,2) ); + + float dotLH = clamp(dot(h,l),0.,1.); + float dotNH = clamp(dot(h,n),0.,1.); + float dotNL = clamp(dot(n,l),0.,1.); + float dotNV = clamp(dot(n,v),0.,1.); + float dotVH = clamp(dot(h,v),0.,1.); + + + float D = alpha / (0.0541592653589793*square(square(dotNH) * (alpha - 1.0) + 1.0)); + float G = gSimple(dotNV, roughness) * gSimple(dotNL, roughness); + float F = F0 + (1. - F0) * exp2((-5.55473*dotVH-6.98316)*dotVH); + + return dotNL * F * (G * D / (4 * dotNV * dotNL + 1e-7)); +} + + +vec3 normVec (vec3 vec){ + return vec*inversesqrt(dot(vec,vec)); +} +float getWaterHeightmap_dimension(vec2 posxz, float waveM, float waveZ, float iswater) { // water waves + vec2 movement = vec2(frameTimeCounter*0.01); + vec2 pos = posxz ; + float caustic = 1.0; + float weightSum = 0.0; + + float radiance = 2.39996; + mat2 rotationMatrix = mat2(vec2(cos(radiance), -sin(radiance)), vec2(sin(radiance), cos(radiance))); + + for (int i = 0; i < 3; i++){ + pos = rotationMatrix * pos ; + + float Waves = texture2D(noisetex, pos / 64.0 + movement).b; + + + caustic += exp2(pow(Waves,3.0) * -5.0); + weightSum += exp2(-(3.0-caustic)); + } + return ((3.0-caustic) * weightSum / (30.0 * 3.0)); +} + +vec3 getWaveHeightmap_dimension(vec2 posxz, float iswater){ + + vec2 coord = posxz; + + float deltaPos = 0.25; + + float waveZ = mix(20.0,0.25,iswater); + float waveM = mix(0.0,4.0,iswater); + + float h0 = getWaterHeightmap_dimension(coord, waveM, waveZ, iswater); + float h1 = getWaterHeightmap_dimension(coord + vec2(deltaPos,0.0), waveM, waveZ, iswater); + float h3 = getWaterHeightmap_dimension(coord + vec2(0.0,deltaPos), waveM, waveZ, iswater); + + + float xDelta = ((h1-h0))/deltaPos*2.; + float yDelta = ((h3-h0))/deltaPos*2.; + + vec3 wave = normalize(vec3(xDelta,yDelta,1.0-pow(abs(xDelta+yDelta),2.0))); + + return wave; +} + +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +/* RENDERTARGETS:2,7,1,11,13,14 */ +void main() { + if (gl_FragCoord.x * texelSize.x < RENDER_SCALE.x && gl_FragCoord.y * texelSize.y < RENDER_SCALE.y ) { + + gl_FragData[0] = texture2D(texture, lmtexcoord.xy,Texture_MipMap_Bias)*color; + vec3 Albedo = toLinear(gl_FragData[0].rgb); + + float iswater = normalMat.w; + + #ifdef HAND + iswater = 0.1; + #endif + #ifndef Vanilla_like_water + if (iswater > 0.9) { + Albedo = vec3(0.0); + gl_FragData[0] = vec4(vec3(0.0),1.0/255.0); + } + #endif + #ifdef Vanilla_like_water + if (iswater > 0.5) { + gl_FragData[0].a = luma(Albedo.rgb); + Albedo = color.rgb; + } + #endif + + + + gl_FragData[4] = vec4(Albedo, gl_FragData[0].a); + + + vec2 tempOffset=offsets[framemod8]; + vec3 fragC = gl_FragCoord.xyz*vec3(texelSize,1.0); + vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize/RENDER_SCALE,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); + vec3 p3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; + vec3 np3 = normVec(p3); + + + vec3 normal = normalMat.xyz; + vec3 WaterNormals; + vec3 TranslucentNormals; + + mat3 tbnMatrix = mat3(tangent.x, binormal.x, normal.x, + tangent.y, binormal.y, normal.y, + tangent.z, binormal.z, normal.z); + + + + + if (iswater > 0.4){ + float bumpmult = 1.; + vec3 posxz = p3+cameraPosition; + posxz.xz-=posxz.y; + + vec3 bump; + + posxz.xyz = getParallaxDisplacement(posxz,iswater,bumpmult,normalize(tbnMatrix*fragpos)); + + bump = normalize(getWaveHeightmap_dimension(posxz.xz,iswater)); + WaterNormals = bump; // tangent space normals for refraction + + bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); + normal = normalize(bump * tbnMatrix); + + + }else{ + vec3 normalTex = texture2D(normals, lmtexcoord.xy, Texture_MipMap_Bias).rgb; + + normalTex.xy = normalTex.xy*2.0-1.0; + normalTex.z = clamp(sqrt(1.0 - dot(normalTex.xy, normalTex.xy)),0.0,1.0); + + TranslucentNormals = normalTex; + + normal = applyBump(tbnMatrix,normalTex); + } + + TranslucentNormals += WaterNormals; + + vec4 data0 = vec4(1); + vec4 data1 = clamp( encode(TranslucentNormals, lmtexcoord.zw),0.0,1.0); + gl_FragData[3] = vec4(encodeVec2(data0.x,data1.x), encodeVec2(data0.y,data1.y), encodeVec2(data0.z,data1.z), encodeVec2(data1.w,data0.w)); + gl_FragData[5] = vec4(encodeVec2(lmtexcoord.a,lmtexcoord.a), encodeVec2(lmtexcoord.a,lmtexcoord.a), encodeVec2(lmtexcoord.a,lmtexcoord.a), encodeVec2(lmtexcoord.a,lmtexcoord.a)); + + + vec3 Indirect_lighting = DoAmbientLighting_Nether(gl_Fog.color.rgb, vec3(TORCH_R,TORCH_G,TORCH_B), lmtexcoord.z, viewToWorld(normal), np3, p3 + cameraPosition); + vec3 FinalColor = Indirect_lighting * Albedo; + + #ifdef Glass_Tint + float alphashit = min(pow(gl_FragData[0].a,2.0),1.0); + FinalColor *= alphashit; + #endif + + vec2 SpecularTex = texture2D(specular, lmtexcoord.xy, Texture_MipMap_Bias).rg; + SpecularTex = iswater > 0.0 && SpecularTex.r > 0.0 && SpecularTex.g < 0.9 ? SpecularTex : vec2(1.0,0.02); + + if (iswater > 0.0 || (SpecularTex.g > 0.0 || SpecularTex.r > 0.0)){ + vec3 Reflections_Final = vec3(0.0); + float roughness = pow(1.0-SpecularTex.r,2.0); + float f0 = SpecularTex.g; + float F0 = f0; + + float visibilityFactor = clamp(exp2((pow(roughness,3.0) / f0) * -4),0,1); + + vec3 reflectedVector = reflect(normalize(fragpos), normal); + float normalDotEye = dot(normal, normalize(fragpos)); + float fresnel = pow(clamp(1.0 + normalDotEye,0.0,1.0), 5.0); + + // snells window looking thing + if(isEyeInWater == 1 && iswater > 0.99) fresnel = clamp(pow(1.66 + normalDotEye,25),0.02,1.0); + + fresnel = F0 + (1.0 - F0) * fresnel; + + vec4 Reflections = vec4(0.0); + if(iswater > 0){ + #ifdef SCREENSPACE_REFLECTIONS + vec3 rtPos = rayTrace(reflectedVector,fragpos.xyz, interleaved_gradientNoise(), fresnel, isEyeInWater == 1); + if (rtPos.z < 1.){ + vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rtPos) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; + previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; + previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; + if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) { + Reflections.a = 1.0; + Reflections.rgb = texture2D(colortex5,previousPosition.xy).rgb; + } + } + #endif + } + + + Reflections_Final = mix(FinalColor, Reflections.rgb, Reflections.a * fresnel * visibilityFactor); + + + float F2 = pow(clamp(1.0 + normalDotEye,0.0,1.0),pow(1.0-roughness,2.0) * 1.5 + 0.5); + F2 = mix(f0, 1.0, F2); + + Reflections_Final += mix( gl_Fog.color.rgb * 0.25, vec3(0.0), Reflections.a * visibilityFactor) ; + + gl_FragData[0].rgb = Reflections_Final; + + //correct alpha channel with fresnel + float alpha0 = gl_FragData[0].a; + gl_FragData[0].a = -gl_FragData[0].a*fresnel+gl_FragData[0].a+fresnel; + + if (gl_FragData[0].r > 65000.) gl_FragData[0].rgba = vec4(0.); + + + } else { + gl_FragData[0].rgb = FinalColor; + } + + #ifndef HAND + gl_FragData[1] = vec4(Albedo,iswater); + #endif + } +} diff --git a/shaders/world-1/gbuffers_all_translucent.vsh b/shaders/programs/all_translucent.vsh similarity index 86% rename from shaders/world-1/gbuffers_all_translucent.vsh rename to shaders/programs/all_translucent.vsh index 13986e0..2ea0fdb 100644 --- a/shaders/world-1/gbuffers_all_translucent.vsh +++ b/shaders/programs/all_translucent.vsh @@ -1,6 +1,6 @@ // #version 120 #extension GL_EXT_gpu_shader4 : enable - +#include "/lib/settings.glsl" #include "/lib/res_params.glsl" @@ -16,22 +16,24 @@ varying vec4 color; varying vec4 normalMat; varying vec3 binormal; varying vec3 tangent; -varying float dist; uniform mat4 gbufferModelViewInverse; varying vec3 viewVector; + +flat varying int glass; + attribute vec4 at_tangent; attribute vec4 mc_Entity; uniform sampler2D colortex4; + uniform vec3 sunPosition; flat varying vec3 WsunVec; uniform float sunElevation; varying vec4 tangent_other; -#define SHADOW_MAP_BIAS 0.8 flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) - +flat varying vec3 avgAmbient; uniform vec2 texelSize; @@ -49,6 +51,15 @@ uniform int framemod8; vec4 toClipSpace3(vec3 viewSpacePosition) { return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); } + + + + + + + + + //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -56,23 +67,27 @@ vec4 toClipSpace3(vec3 viewSpacePosition) { //////////////////////////////VOID MAIN////////////////////////////// void main() { + + vec4 Swtich_gl_vertex = gl_Vertex; + lmtexcoord.xy = (gl_MultiTexCoord0).xy; vec2 lmcoord = gl_MultiTexCoord1.xy/255.; lmtexcoord.zw = lmcoord; - vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; - gl_Position = toClipSpace3(position); + vec3 position = mat3(gl_ModelViewMatrix) * vec3(Swtich_gl_vertex) + gl_ModelViewMatrix[3].xyz; + gl_Position = toClipSpace3(position); color = gl_Color; float mat = 0.0; + if(mc_Entity.x == 8.0 || mc_Entity.x == 9.0) { mat = 1.0; gl_Position.z -= 1e-4; } - - if (mc_Entity.x == 10002) mat = 0.01; + if (mc_Entity.x == 10002) mat = 0.2; if (mc_Entity.x == 72) mat = 0.5; + // if (mc_Entity.x == 8) mat = 0.1; normalMat = vec4(normalize( gl_NormalMatrix*gl_Normal),mat); @@ -88,14 +103,12 @@ void main() { tangent.y, binormal.y, normalMat.y, tangent.z, binormal.z, normalMat.z); - dist = length(gl_ModelViewMatrix * gl_Vertex); - - viewVector = ( gl_ModelViewMatrix * gl_Vertex).xyz; + viewVector = ( gl_ModelViewMatrix * Swtich_gl_vertex).xyz; viewVector = normalize(tbnMatrix * viewVector); - #ifdef TAA_UPSCALING + #ifdef TAA_UPSCALING gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; #endif #ifdef TAA @@ -109,4 +122,6 @@ void main() { lightCol.rgb = sc; WsunVec = lightCol.a*normalize(mat3(gbufferModelViewInverse) *sunPosition); + + avgAmbient = texelFetch2D(colortex4,ivec2(0,37),0).rgb; } diff --git a/shaders/shaders.properties b/shaders/shaders.properties index 0b6b8dc..2650327 100644 --- a/shaders/shaders.properties +++ b/shaders/shaders.properties @@ -8,7 +8,7 @@ clouds=off stars=true vignette=false dynamicHandLight=true -program.composite7.enabled=TAA_UPSCALING +program.composite4.enabled=TAA_UPSCALING #Get the correct alpha value : S_A*(1-DST_A)+DST_A blend.gbuffers_terrain = off @@ -38,19 +38,15 @@ alphaTest.gbuffers_skytextured=false alphaTest.gbuffers_hand=true -# profile.potato = shadowMapResolution=512 !Sub_surface_scattering !Variable_Penumbra_Shadows shadowDistance=32 VPS_Search_Samples=8 SHADOW_FILTER_SAMPLE_COUNT=8 !SCREENSPACE_CONTACT_SHADOWS !SSAO ambientOcclusionLevel=0.50 TAA_UPSCALING RENDER_SCALE_X=0.5 RENDER_SCALE_Y=0.5 SHARPENING= 1.0 !VOLUMETRIC_CLOUDS rain_clouds=1.0 cloudCoverage=0.36 cloud_LevelOfDetail=-1 cloud_ShadowLevelOfDetail=-1 CLOUDS_QUALITY=0.2 minRayMarchSteps=20 maxRayMarchSteps=20 !High_Altitude_Clouds reflection_quality=10 Roughness_Strength=0 !Screen_Space_Reflections !Sky_reflection -# profile.lower = shadowMapResolution=512 Sub_surface_scattering !Variable_Penumbra_Shadows shadowDistance=32 VPS_Search_Samples=8 SHADOW_FILTER_SAMPLE_COUNT=8 SCREENSPACE_CONTACT_SHADOWS !SSAO ambientOcclusionLevel=0.50 TAA_UPSCALING RENDER_SCALE_X=0.5 RENDER_SCALE_Y=0.5 SHARPENING= 1.0 !VOLUMETRIC_CLOUDS rain_clouds=1.0 cloudCoverage=0.36 cloud_LevelOfDetail=-1 cloud_ShadowLevelOfDetail=-1 CLOUDS_QUALITY=0.2 minRayMarchSteps=20 maxRayMarchSteps=20 !High_Altitude_Clouds reflection_quality=10 Roughness_Strength=0 !Screen_Space_Reflections !Sky_reflection -# profile.low = shadowMapResolution=512 Sub_surface_scattering Variable_Penumbra_Shadows shadowDistance=32 VPS_Search_Samples=8 SHADOW_FILTER_SAMPLE_COUNT=8 SCREENSPACE_CONTACT_SHADOWS !SSAO ambientOcclusionLevel=0.50 TAA_UPSCALING RENDER_SCALE_X=0.7 RENDER_SCALE_Y=0.7 SHARPENING= 0.5 VOLUMETRIC_CLOUDS rain_clouds=1.0 cloudCoverage=0.36 cloud_LevelOfDetail=0 cloud_ShadowLevelOfDetail=0 CLOUDS_QUALITY=0.35 minRayMarchSteps=20 maxRayMarchSteps=20 High_Altitude_Clouds reflection_quality=10 Roughness_Strength=1 !Screen_Space_Reflections !Sky_reflection -# profile.medium = shadowMapResolution=1024 Sub_surface_scattering Variable_Penumbra_Shadows shadowDistance=48 VPS_Search_Samples=15 SHADOW_FILTER_SAMPLE_COUNT=15 SCREENSPACE_CONTACT_SHADOWS SSAO ambientOcclusionLevel=0.15 TAA_UPSCALING RENDER_SCALE_X=0.7 RENDER_SCALE_Y=0.7 SHARPENING= 0.5 VOLUMETRIC_CLOUDS rain_clouds=1.0 cloudCoverage=0.36 cloud_LevelOfDetail=1 cloud_ShadowLevelOfDetail=0 CLOUDS_QUALITY=0.5 minRayMarchSteps=20 maxRayMarchSteps=30 High_Altitude_Clouds reflection_quality=16 Roughness_Strength=2 Screen_Space_Reflections Sky_reflection -# profile.high = shadowMapResolution=2048 Sub_surface_scattering Variable_Penumbra_Shadows shadowDistance=69. VPS_Search_Samples=15 SHADOW_FILTER_SAMPLE_COUNT=15 SCREENSPACE_CONTACT_SHADOWS SSAO ambientOcclusionLevel=0.15 !TAA_UPSCALING RENDER_SCALE_X=0.7 RENDER_SCALE_Y=0.7 SHARPENING= 0.35 VOLUMETRIC_CLOUDS rain_clouds=1.0 cloudCoverage=0.36 cloud_LevelOfDetail=1 cloud_ShadowLevelOfDetail=0 CLOUDS_QUALITY=0.5 minRayMarchSteps=20 maxRayMarchSteps=30 High_Altitude_Clouds reflection_quality=35 Roughness_Strength=3 Screen_Space_Reflections Sky_reflection -# profile.ultra = shadowMapResolution=4096 Sub_surface_scattering Variable_Penumbra_Shadows shadowDistance=80 VPS_Search_Samples=15 SHADOW_FILTER_SAMPLE_COUNT=25 SCREENSPACE_CONTACT_SHADOWS SSAO ambientOcclusionLevel=0.15 !TAA_UPSCALING RENDER_SCALE_X=0.7 RENDER_SCALE_Y=0.7 SHARPENING= 0.2 VOLUMETRIC_CLOUDS rain_clouds=1.0 cloudCoverage=0.36 cloud_LevelOfDetail=2 cloud_ShadowLevelOfDetail=2 CLOUDS_QUALITY=0.5 minRayMarchSteps=20 maxRayMarchSteps=50 High_Altitude_Clouds reflection_quality=35 Roughness_Strength=3 Screen_Space_Reflections Sky_reflection +sliders = Cumulus_coverage Cumulus_density Alto_coverage Alto_density ORB_ColMult ORB_X ORB_Y ORB_Z ORB_R ORB_G ORB_B TOD_Fog_mult Morning_Uniform_Fog Noon_Uniform_Fog Evening_Uniform_Fog Night_Uniform_Fog Morning_Cloudy_Fog Noon_Cloudy_Fog Evening_Cloudy_Fog Night_Cloudy_Fog NetherFog_brightness WeatherDay Summer_Leaf_R Summer_Leaf_G Summer_Leaf_B Fall_Leaf_R Fall_Leaf_G Fall_Leaf_B Winter_Leaf_R Winter_Leaf_G Winter_Leaf_B Spring_Leaf_R Spring_Leaf_G Spring_Leaf_B Summer_R Summer_G Summer_B Fall_R Fall_G Fall_B Winter_R Winter_G Winter_B Spring_R Spring_G Spring_B Season_Length CaveFogFallOff CaveFogColor_R CaveFogColor_G CaveFogColor_B indirect_effect GI_Strength Cloud_Height Dynamic_sky_day ambient_brightness AmbientLight_R AmbientLight_G AmbientLight_B cloud_speed Rain_coverage override_R override_G override_B override_Cloudy_Fog_Density override_cloudyfog_fade override_fog override_Uniform_Fog_Density override_uniformfog_fade override_Bloomy_Fog override_Sun_Strength Moon_temp Haze_amount UniformFog_amount CloudyFog_amount TimeOfDayFog_multiplier RainFog_amount CaveFog_amount uniformfog_fade cloudyfog_fade cloudray_amount Swamp_cloudyfog_height Jungle_cloudyfog_fade Swamp_uniformfog_height Jungle_uniformfog_fade noise_mode Distant_shadow_quality ambient_temp Sun_temp Puddle_Size Cloud_Size LabSSS_Curve Emissive_Curve Emissive_Brightness AO_Strength Swamp_Sun_Strength Jungle_Sun_Strength Swamp_Bloomy_Fog Jungle_Bloomy_Fog Swamp_Mie Jungle_Mie Swamp_cloudyfog_Density Jungle_Cloudy_Fog_Density Swamp_UniformFog_Density Jungle_Uniform_Fog_Density Swamp_Bloomy_Fog Jungle_Bloomy_Fog Swamp_Mie Jungle_Mie Swamp_R Swamp_G Swamp_B Jungle_R Jungle_G Jungle_B Jungle_fog_strength Swamp_fog_strength Lush_fog_strength Snells_Window_Width self_shadow_samples Shadow_brightness Cloud_top_cutoff Cloud_base_cutoff Cloud_fade_amount BLOOMY_FOG FOG_RAIN_MULTIPLIER FOG_TOD_MULTIPLIER CLOUDY_FOG_AMOUNT BASE_FOG_AMOUNT WAVY_SPEED WAVY_STRENGTH ANTI_GHOSTING BLOOM_STRENGTH shadowDistance shadowDistanceRenderMul FinalR FinalG FinalB Ambient_Mult Sky_Brightness fog_coefficientMieR fog_coefficientMieG fog_coefficientMieB sun_illuminance sunColorG sunColorB sunColorR sky_mieg sky_coefficientMieB sky_coefficientMieG sky_coefficientMieR sky_coefficientRayleighB sky_coefficientRayleighG sky_coefficientRayleighR CLOUDS_QUALITY EXPOSURE_MULTIPLIER MIN_LIGHT_AMOUNT TORCH_R TORCH_G TORCH_B TORCH_AMOUNT shadowMapResolution sunPathRotation SKY_BRIGHTNESS_DAY SKY_BRIGHTNESS_NIGHT BLEND_FACTOR FLICKER_REDUCTION MOTION_REJECTION VL_SAMPLES Exposure_Speed POM_MAP_RES POM_DEPTH MAX_ITERATIONS MAX_DIST SSR_STEPS ambientOcclusionLevel SEA_LEVEL ATMOSPHERIC_DENSITY CLOUDS_SHADOWS_STRENGTH moon_illuminance moonColorR moonColorG moonColorB fog_mieg1 fog_mieg2 fog_coefficientRayleighR fog_coefficientRayleighG SATURATION Manual_exposure_value focal aperture MANUAL_FOCUS SHADOW_FILTER_SAMPLE_COUNT Max_Filter_Depth VPS_Search_Samples Min_Shadow_Filter_Radius Max_Shadow_Filter_Radius SSAO_SAMPLES Water_Top_Layer fog_coefficientRayleighB SHARPENING rayMarchSampleCount Dirt_Mie_Phase Dirt_Amount Dirt_Scatter_R Dirt_Scatter_G Dirt_Scatter_B Dirt_Absorb_R Dirt_Absorb_G Dirt_Absorb_B Water_Absorb_R Water_Absorb_G Water_Absorb_B Purkinje_strength Purkinje_strength Purkinje_R Purkinje_G Purkinje_B Texture_MipMap_Bias DoF_Adaptation_Speed Purkinje_Multiplier CROSSTALK RENDER_SCALE_X RENDER_SCALE_Y VL_RENDER_RESOLUTION BLOOM_QUALITY VL_RENDER_RESOLUTION RAY_COUNT STEPS STEP_LENGTH cloud_LevelOfDetail cloud_ShadowLevelOfDetail cloud_LevelOfDetailLQ cloud_ShadowLevelOfDetailLQ minRayMarchSteps maxRayMarchSteps minRayMarchStepsLQ maxRayMarchStepsLQ cloudDensity cloudCoverage fbmAmount fbmPower1 fbmPower2 cloudMieG cloudMieG2 cloudMie2Multiplier Strong_SSS_strength Medium_SSS_strength Weak_SSS_strength Shadow_brightness Roughness_Threshold Sun_specular_Strength reflection_quality Roughness_Strength SSS_mode DOF_QUALITY DOF_ANAMORPHIC_RATIO AEROCHROME_PINKNESS -sliders = WeatherDay Summer_Leaf_R Summer_Leaf_G Summer_Leaf_B Fall_Leaf_R Fall_Leaf_G Fall_Leaf_B Winter_Leaf_R Winter_Leaf_G Winter_Leaf_B Spring_Leaf_R Spring_Leaf_G Spring_Leaf_B Summer_R Summer_G Summer_B Fall_R Fall_G Fall_B Winter_R Winter_G Winter_B Spring_R Spring_G Spring_B Season_Length CaveFogFallOff CaveFogColor_R CaveFogColor_G CaveFogColor_B indirect_effect GI_Strength Cloud_Height Dynamic_sky_day ambient_brightness AmbientLight_R AmbientLight_G AmbientLight_B cloud_speed Rain_coverage override_R override_G override_B override_Cloudy_Fog_Density override_cloudyfog_fade override_fog override_Uniform_Fog_Density override_uniformfog_fade override_Bloomy_Fog override_Sun_Strength Moon_temp Haze_amount UniformFog_amount CloudyFog_amount TimeOfDayFog_multiplier RainFog_amount CaveFog_amount uniformfog_fade cloudyfog_fade cloudray_amount Swamp_cloudyfog_height Jungle_cloudyfog_fade Swamp_uniformfog_height Jungle_uniformfog_fade noise_mode Distant_shadow_quality ambient_temp Sun_temp Puddle_Size Cloud_Size LabSSS_Curve Emissive_Curve Emissive_Brightness AO_Strength Swamp_Sun_Strength Jungle_Sun_Strength Swamp_Bloomy_Fog Jungle_Bloomy_Fog Swamp_Mie Jungle_Mie Swamp_cloudyfog_Density Jungle_Cloudy_Fog_Density Swamp_UniformFog_Density Jungle_Uniform_Fog_Density Swamp_Bloomy_Fog Jungle_Bloomy_Fog Swamp_Mie Jungle_Mie Swamp_R Swamp_G Swamp_B Jungle_R Jungle_G Jungle_B Jungle_fog_strength Swamp_fog_strength Lush_fog_strength Snells_Window_Width self_shadow_samples Shadow_brightness Cloud_top_cutoff Cloud_base_cutoff Cloud_fade_amount BLOOMY_FOG FOG_RAIN_MULTIPLIER FOG_TOD_MULTIPLIER CLOUDY_FOG_AMOUNT BASE_FOG_AMOUNT WAVY_SPEED WAVY_STRENGTH ANTI_GHOSTING BLOOM_STRENGTH shadowDistance shadowDistanceRenderMul FinalR FinalG FinalB Ambient_Mult Sky_Brightness fog_coefficientMieR fog_coefficientMieG fog_coefficientMieB sun_illuminance sunColorG sunColorB sunColorR sky_mieg sky_coefficientMieB sky_coefficientMieG sky_coefficientMieR sky_coefficientRayleighB sky_coefficientRayleighG sky_coefficientRayleighR CLOUDS_QUALITY EXPOSURE_MULTIPLIER MIN_LIGHT_AMOUNT TORCH_R TORCH_G TORCH_B TORCH_AMOUNT shadowMapResolution sunPathRotation SKY_BRIGHTNESS_DAY SKY_BRIGHTNESS_NIGHT BLEND_FACTOR FLICKER_REDUCTION MOTION_REJECTION VL_SAMPLES Exposure_Speed POM_MAP_RES POM_DEPTH MAX_ITERATIONS MAX_DIST SSR_STEPS ambientOcclusionLevel SEA_LEVEL ATMOSPHERIC_DENSITY CLOUDS_SHADOWS_STRENGTH moon_illuminance moonColorR moonColorG moonColorB fog_mieg1 fog_mieg2 fog_coefficientRayleighR fog_coefficientRayleighG SATURATION Manual_exposure_value focal aperture MANUAL_FOCUS SHADOW_FILTER_SAMPLE_COUNT Max_Filter_Depth VPS_Search_Samples Min_Shadow_Filter_Radius Max_Shadow_Filter_Radius SSAO_SAMPLES Water_Top_Layer fog_coefficientRayleighB SHARPENING rayMarchSampleCount Dirt_Mie_Phase Dirt_Amount Dirt_Scatter_R Dirt_Scatter_G Dirt_Scatter_B Dirt_Absorb_R Dirt_Absorb_G Dirt_Absorb_B Water_Absorb_R Water_Absorb_G Water_Absorb_B Purkinje_strength Purkinje_strength Purkinje_R Purkinje_G Purkinje_B Texture_MipMap_Bias DoF_Adaptation_Speed Purkinje_Multiplier CROSSTALK RENDER_SCALE_X RENDER_SCALE_Y VL_RENDER_RESOLUTION BLOOM_QUALITY VL_RENDER_RESOLUTION RAY_COUNT STEPS STEP_LENGTH cloud_LevelOfDetail cloud_ShadowLevelOfDetail cloud_LevelOfDetailLQ cloud_ShadowLevelOfDetailLQ minRayMarchSteps maxRayMarchSteps minRayMarchStepsLQ maxRayMarchStepsLQ cloudDensity cloudCoverage fbmAmount fbmPower1 fbmPower2 cloudMieG cloudMieG2 cloudMie2Multiplier Strong_SSS_strength Medium_SSS_strength Weak_SSS_strength Shadow_brightness Roughness_Threshold Sun_specular_Strength reflection_quality Roughness_Strength SSS_mode DOF_QUALITY DOF_ANAMORPHIC_RATIO AEROCHROME_PINKNESS -# screen=[Atmospherics] [TAA_OPTIONS] [Lighting] [Camera] [Shading] [Wavy_stuff] [Water_and_transparencies] [Xonk_settings] +screen.columns=2 +screen = [Direct_Light] [World] [Ambient_light] [Fog] [Post_Processing] [Clouds] [Misc_Settings] [Climate] - -screen.columns=1 -screen = [Direct_Light] [Ambient_light] [World] [Atmospherics] [Post_Processing] [Climate] [Misc_Settings] +# screen = [Direct_Light] [World] +# [Ambient_light] [Fog] +# [Post_Processing] [Clouds] +# [Misc_Settings] [Climate] ######## LIGHTING ### DIRECT LIGHT @@ -68,7 +64,7 @@ screen = [Direct_Light] [Ambient_light] [World] [Atmospherics] [Post_Processing] ### AMBIENT LIGHT screen.Ambient_light.columns=1 - screen.Ambient_light = [Torch] [Ambient] [ambientlight_colors] indirect_effect HQ_SSGI AO_Strength GI_Strength + screen.Ambient_light = [Torch] [Ambient] [ambientlight_colors] indirect_effect HQ_SSGI AO_Strength GI_Strength AO_in_sunlight screen.ambientlight_colors.columns=1 screen.ambientlight_colors = ambient_brightness ambient_colortype ambient_temp AmbientLight_R AmbientLight_G AmbientLight_B @@ -91,13 +87,22 @@ screen = [Direct_Light] [Ambient_light] [World] [Atmospherics] [Post_Processing] screen.Waving_Stuff = WAVY_STRENGTH WAVY_SPEED WAVY_PLANTS ## POM screen.POM.columns=1 - screen.POM = POM MAX_ITERATIONS POM_DEPTH MAX_DIST Horrible_slope_normals + screen.POM = POM MAX_ITERATIONS POM_DEPTH MAX_DIST Adaptive_Step_length Horrible_slope_normals ######## CLIMATE screen.Climate.columns=1 - screen.Climate = [Seasons] [Weather] [Biome_Fog] + screen.Climate = [Weather] [Biome_Fog] [Seasons] + + ## DAILY WEATHER + screen.Weather.columns=1 + screen.Weather = Daily_Weather WeatherDay + + ## BIOME SPECIFICS + screen.Biome_Fog.columns=1 + screen.Biome_Fog = Biome_specific_environment + ## SEASONS screen.Seasons.columns=1 @@ -115,27 +120,11 @@ screen = [Direct_Light] [Ambient_light] [World] [Atmospherics] [Post_Processing] screen.Spring_colors.columns=1 screen.Spring_colors = Spring_R Spring_G Spring_B Spring_Leaf_R Spring_Leaf_G Spring_Leaf_B - ## DAILY WEATHER - screen.Weather.columns=1 - screen.Weather = Daily_Weather WeatherDay - ## BIOME SPECIFICS - screen.Biome_Fog.columns=1 - screen.Biome_Fog = Biome_specific_environment Jungle_fog_strength [Jungle_Settings] Swamp_fog_strength [Swamp_Settings] override_fog [Override_Settings] - - screen.Jungle_Settings.columns=1 - screen.Jungle_Settings = Jungle_R Jungle_G Jungle_B Jungle_Cloudy_Fog_Density Jungle_cloudyfog_fade Jungle_Uniform_Fog_Density Jungle_uniformfog_fade Jungle_Bloomy_Fog Jungle_Sun_Strength - - screen.Swamp_Settings.columns=1 - screen.Swamp_Settings = Swamp_R Swamp_G Swamp_B Swamp_cloudyfog_Density Swamp_cloudyfog_height Swamp_UniformFog_Density Swamp_uniformfog_height Swamp_Bloomy_Fog Swamp_Sun_Strength - - screen.Override_Settings.columns=1 - screen.Override_Settings = override_R override_G override_B override_Cloudy_Fog_Density override_cloudyfog_fade override_Uniform_Fog_Density override_uniformfog_fade override_Bloomy_Fog override_Sun_Strength - - ######## ATMOSPHERICS screen.Atmospherics.columns=1 - screen.Atmospherics = [Sky] [Fog] [Biome_Fog] [Clouds] High_Altitude_Clouds Cumulus_Clouds Allow_Vanilla_sky CLOUDS_SHADOWS VL_CLOUDS_SHADOWS + screen.Atmospherics = [Sky] [Fog] [Biome_Fog] [Clouds] Altostratus Cumulus_Clouds Allow_Vanilla_sky + ### SKY screen.Sky.columns=1 screen.Sky = [Sky_coefficients] [Sun_and_Moon_Colors] sunPathRotation @@ -145,17 +134,22 @@ screen = [Direct_Light] [Ambient_light] [World] [Atmospherics] [Post_Processing] ### CLOUDS screen.Clouds.columns=2 - screen.Clouds = VOLUMETRIC_CLOUDS Dynamic_Sky cloud_LevelOfDetail cloud_ShadowLevelOfDetail CLOUDS_QUALITY cloudDensity cloudCoverage Rain_coverage cloud_speed fbmAmount fbmPower1 fbmPower2 Cloud_top_cutoff Cloud_base_cutoff Shadow_brightness self_shadow_samples + # screen.Clouds = VOLUMETRIC_CLOUDS Altostratus cloud_LevelOfDetail cloud_ShadowLevelOfDetail CLOUDS_QUALITY cloudDensity cloudCoverage Rain_coverage cloud_speed fbmAmount fbmPower1 fbmPower2 Cloud_top_cutoff Cloud_base_cutoff Shadow_brightness self_shadow_samples CLOUDS_SHADOWS VL_CLOUDS_SHADOWS + screen.Clouds = VOLUMETRIC_CLOUDS CLOUDS_QUALITY Cumulus Altostratus Cumulus_coverage Alto_coverage Cumulus_density Alto_density CLOUDS_SHADOWS ### FOG screen.Fog.columns=1 - screen.Fog = [Biome_Fog] [cave_fog] [Fog_Densities] VL_RENDER_RESOLUTION VL_SAMPLES BLOOMY_FOG VL_Clouds_Shadows fog_selfShadowing + screen.Fog = VL_RENDER_RESOLUTION VL_SAMPLES BLOOMY_FOG Haze_amount RainFog_amount [TOD_fog] [Biome_Fog] [Cave_Fog] BorderFog - screen.Fog_Densities.columns=1 - screen.Fog_Densities = Haze_amount UniformFog_amount CloudyFog_amount TimeOfDayFog_multiplier RainFog_amount CaveFog_amount uniformfog_fade cloudyfog_fade + screen.TOD_fog.columns=2 + screen.TOD_fog = TOD_Fog_mult Morning_Uniform_Fog Morning_Cloudy_Fog Noon_Uniform_Fog Noon_Cloudy_Fog Evening_Uniform_Fog Evening_Cloudy_Fog Night_Uniform_Fog Night_Cloudy_Fog + + screen.Cave_Fog.columns=1 + screen.Cave_Fog = Cave_fog CaveFog_amount CaveFogFallOff CaveFogColor_R CaveFogColor_G CaveFogColor_B screen.Fog_Color.columns=1 screen.Fog_Color = fog_mieg1 fog_mieg2 fog_coefficientRayleighR fog_coefficientRayleighG fog_coefficientRayleighB fog_coefficientMieR fog_coefficientMieG fog_coefficientMieB + ### WATER screen.Water.columns=1 screen.Water = Refraction Vanilla_like_water Dirt_Amount Dirt_Mie_Phase rayMarchSampleCount SCREENSPACE_REFLECTIONS SSR_STEPS USE_QUARTER_RES_DEPTH SUN_MICROFACET_SPECULAR Water_Top_Layer lightMapDepthEstimation [Water_fog_color] @@ -184,7 +178,10 @@ screen = [Direct_Light] [Ambient_light] [World] [Atmospherics] [Post_Processing] ######## MISC SETTINGS screen.Misc_Settings.columns=1 - screen.Misc_Settings =end_shadows WhiteWorld ambientLight_only Cloud_Size Cloud_Height BorderFog Texture_MipMap_Bias Glass_Tint display_LUT DISABLE_ALPHA_MIPMAPS + screen.Misc_Settings = [the_orb] WhiteWorld ambientLight_only Glass_Tint display_LUT DISABLE_ALPHA_MIPMAPS + + screen.the_orb.columns = 1 + screen.the_orb = THE_ORB ORB_X ORB_Y ORB_Z ORB_ColMult ORB_R ORB_G ORB_B screen.LabPBR.columns = 1 screen.LabPBR = [Reflections] [Subsurface_Scattering] [Emissives] [POM] [Porosity] @@ -199,7 +196,6 @@ screen = [Direct_Light] [Ambient_light] [World] [Atmospherics] [Post_Processing] screen.Sun_and_Moon_Colors = sunColorR sunColorG sunColorB moonColorR moonColorG moonColorB colortype Sun_temp Moon_temp screen.Advanced = Dirt_Scatter_R Dirt_Scatter_G Dirt_Scatter_B Dirt_Absorb_R Dirt_Absorb_G Dirt_Absorb_B Water_Absorb_R Water_Absorb_G Water_Absorb_B - screen.cave_fog = Cave_fog CaveFogFallOff CaveFogColor_R CaveFogColor_G CaveFogColor_B ######## moonphase based weather @@ -260,11 +256,19 @@ uniform.float.isCrimsonForest = smooth(12, if(in(biome,53), 1,0), 5, 5) uniform.float.isSoulValley = smooth(13, if(in(biome,54), 1,0), 5, 5) uniform.float.isBasaltDelta = smooth(14, if(in(biome,55), 1,0), 5, 5) + + +# uniform.float.ifEndBoss = smooth(if(bossBattle == 2, 1, 0 ), 1, 1) + +# uniform.float.EndSequence1 = smooth(if(hideGUI == 1, 1.0, 0.0), 30, 0) + +# uniform.float.EndSequence2 = smooth(if(EndSequence1 > 0.95, 1.0, 0.0), 1.25, 0) + # uniform.float.Winter = smooth(14, if( worldDay > 0 && worldDay < 10), 5, 5) # thank you sixthsurge! -uniform.float.lightningFlash = smooth(if(equals(skyColor.r, skyColor.g, 0.01) && skyColor.r > 0.3, 1.0, 0.0), 0, 0.5) +# uniform.float.lightningFlash = smooth(if(equals(skyColor.r, skyColor.g, 0.01) && skyColor.r > 0.3, 1.0, 0.0), 0, 0.5) texture.noise=texture/noises.png texture.composite.colortex6=texture/blueNoise.png @@ -327,3 +331,11 @@ variable.float.shSunZ = (shadowModelView.0.2 * wSunX + shadowModelView.1.2 * wSu uniform.vec3.shadowLightVec = vec3(lightSign*shSunX, lightSign*shSunY, lightSign*shSunZ) uniform.float.shadowMaxProj = 150.0/abs(sunPosY) + + + + + +# photon shit +uniform.vec2.view_res = vec2(viewWidth, viewHeight) +uniform.vec2.view_pixel_size = vec2(1.0 / viewWidth, 1.0 / viewHeight) \ No newline at end of file diff --git a/shaders/shadow.fsh b/shaders/shadow.fsh index 9eb9359..b398e50 100644 --- a/shaders/shadow.fsh +++ b/shaders/shadow.fsh @@ -20,9 +20,11 @@ float R2_dither(){ } void main() { gl_FragData[0] = texture2D(tex,texcoord.xy); + #ifdef SHADOW_DISABLE_ALPHA_MIPMAPS gl_FragData[0].a = texture2DLod(tex,texcoord.xy,0).a; #endif + #ifdef Stochastic_Transparent_Shadows gl_FragData[0].a = float(gl_FragData[0].a >= R2_dither()); #endif diff --git a/shaders/world-1/block.properties b/shaders/world-1/block.properties deleted file mode 100644 index 73045f4..0000000 --- a/shaders/world-1/block.properties +++ /dev/null @@ -1,20 +0,0 @@ -#if MC_VERSION >= 11300 -block.10001= minecraft:acacia_sapling minecraft:birch_sapling minecraft:dark_oak_sapling minecraft:jungle_sapling minecraft:oak_sapling minecraft:spruce_sapling minecraft:grass minecraft:dead_bush minecraft:fern minecraft:dandelion minecraft:poppy minecraft:blue_orchid minecraft:allium minecraft:azure_bluet minecraft:orange_tulip minecraft:pink_tulip minecraft:red_tulip minecraft:white_tulip minecraft:oxeye_daisy minecraft:brown_mushroom minecraft:red_mushroom minecraft:wheat minecraft:nether_wart minecraft:carrot minecraft:potato minecraft:beetroot_seeds -block.10003 = minecraft:acacia_leaves minecraft:birch_leaves minecraft:dark_oak_leaves minecraft:jungle_leaves minecraft:oak_leaves minecraft:spruce_leaves minecraft:vine -block.10004 = minecraft:cobweb minecraft:sugar_cane minecraft:pumpkin_seeds minecraft:lily_pad minecraft:lilac minecraft:sunflower minecraft:tall_grass minecraft:rose_bush minecraft:peony minecraft:large_fern -block.10002= minecraft:black_stained_glass minecraft:black_stained_glass_pane minecraft:blue_stained_glass minecraft:blue_stained_glass_pane minecraft:brown_stained_glass minecraft:brown_stained_glass_pane minecraft:cyan_stained_glass minecraft:cyan_stained_glass_pane minecraft:gray_stained_glass minecraft:gray_stained_glass_pane minecraft:green_stained_glass minecraft:green_stained_glass_pane minecraft:light_blue_stained_glass minecraft:light_blue_stained_glass_pane minecraft:light_gray_stained_glass minecraft:light_gray_stained_glass_pane minecraft:lime_stained_glass minecraft:lime_stained_glass_pane minecraft:magenta_stained_glass minecraft:magenta_stained_glass_pane minecraft:orange_stained_glass minecraft:orange_stained_glass_pane minecraft:pink_stained_glass minecraft:pink_stained_glass_pane minecraft:purple_stained_glass minecraft:purple_stained_glass_pane minecraft:red_stained_glass minecraft:red_stained_glass_pane minecraft:white_stained_glass minecraft:white_stained_glass_pane minecraft:yellow_stained_glass minecraft:yellow_stained_glass_pane minecraft:glass_pane minecraft:glass -block.8 = minecraft:water minecraft:flowing_water -block.79 = minecraft:ice -block.10005 = minecraft:glowstone minecraft:torch minecraft:wall_torch minecraft:lava minecraft:fire minecraft:redstone_torch minecraft:redstone_wall_torch minecraft:jack_o_lantern minecraft:magma_block minecraft:redstone_lamp:lit=true minecraft:lantern minecraft:campfire:lit=true minecraft:shroomlight minecraft:nether_portal minecraft:soul_torch minecraft:soul_wall_torch minecraft:soul_fire minecraft:end_rod minecraft:sea_lantern minecraft:soul_lantern minecraft:end_gateway minecraft:soul_campfire:lit=true minecraft:lava minecraft:fire -#else -#wavy plants, translucent, bottom vertices not moving -block.10001= 6 31 32 37 38 39 40 59 115 141 142 207 -#wavy plants (blocks) -block.10003 = 18 106 161 -#translucent -block.10004 = 30 83 104 105 111 175 176 177 -#reflective surfaces (not including water and ice) -block.10002=95 160 -#endif - -layer.translucent=minecraft:glass_pane minecraft:glass diff --git a/shaders/world-1/composite15.fsh b/shaders/world-1/composite15.fsh index 74136a6..298ca9a 100644 --- a/shaders/world-1/composite15.fsh +++ b/shaders/world-1/composite15.fsh @@ -1,28 +1,8 @@ #version 120 //Vignetting, applies bloom, applies exposure and tonemaps the final image #extension GL_EXT_gpu_shader4 : enable -#define Fake_purkinje -#define BLOOMY_FOG 2.0 //[0.0 0.25 0.5 0.75 1.0 1.25 1.5 1.75 2.0 3.0 4.0 6.0 10.0 15.0 20.0] -#define BLOOM_STRENGTH 4.0 //[0.0 0.25 0.5 0.75 1.0 1.25 1.5 1.75 2.0 3.0 4.0] -#define TONEMAP ToneMap_Hejl2015 // Tonemapping operator [Tonemap_Uchimura HableTonemap reinhard Tonemap_Lottes ACESFilm ToneMap_Hejl2015] -//#define USE_ACES_COLORSPACE_APPROXIMATION // Do the tonemap in another colorspace -#define Purkinje_strength 1.0 // Simulates how the eye is unable to see colors at low light intensities. 0 = No purkinje effect at low exposures [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define Purkinje_R 0.4 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define Purkinje_G 0.7 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define Purkinje_B 1.0 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define Purkinje_Multiplier 5.0 // How much the purkinje effect increases brightness [0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.05 1.1 1.15 1.2 1.25 1.3 1.35 1.4 1.45 1.5 1.55 1.6 1.65 1.7 1.75 1.8 1.85 1.9 1.95 2.0 2.05 2.1 2.15 2.2 2.25 2.3 2.35 2.4 2.45 2.5 2.55 2.6 2.65 2.7 2.75 2.8 2.85 2.9 2.95 3.0 3.05 3.1 3.15 3.2 3.25 3.3 3.35 3.4 3.45 3.5 3.55 3.6 3.65 3.7 3.75 3.8 3.85 3.9 3.95 4.0 4.05 4.1 4.15 4.2 4.25 4.3 4.35 4.4 4.45 4.5 4.55 4.6 4.65 4.7 4.75 4.8 4.85 4.9 4.95 5.0 5.05 5.1 5.15 5.2 5.25 5.3 5.35 5.4 5.45 5.5 5.55 5.6 5.65 5.7 5.75 5.8 5.85 5.9 5.95 6.0 6.05 6.1 6.15 6.2 6.25 6.3 6.35 6.4 6.45 6.5 6.55 6.6 6.65 6.7 6.75 6.8 6.85 6.9 6.95 7.0 7.05 7.1 7.15 7.2 7.25 7.3 7.35 7.4 7.45 7.5 7.55 7.6 7.65 7.7 7.75 7.8 7.85 7.9 7.95 8.0 8.05 8.1 8.15 8.2 8.25 8.3 8.35 8.4 8.45 8.5 8.55 8.6 8.65 8.7 8.75 8.8 8.85 8.9 8.95 9.0 9.05 9.1 9.15 9.2 9.25 9.3 9.35 9.4 9.45 9.5 9.55 9.6 9.65 9.7 9.75 9.8 9.85 9.9 9.95 ] - - -//#define DOF //enable depth of field (blur on non-focused objects) -//#define HQ_DOF //Slow! Forces circular bokeh! Uses 4 times more samples with noise in order to remove sampling artifacts at great blur sizes. -//#define HEXAGONAL_BOKEH //disabled : circular blur shape - enabled : hexagonal blur shape -#define AUTOFOCUS -//#define FAR_BLUR_ONLY // Removes DoF on objects closer to the camera than the focus point -//lens properties -#define focal 2.4 // Centimeters [0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.05 1.1 1.15 1.2 1.25 1.3 1.35 1.4 1.45 1.5 1.55 1.6 1.65 1.7 1.75 1.8 1.85 1.9 1.95 2.0 2.05 2.1 2.15 2.2 2.25 2.3 2.35 2.4 2.45 2.5 2.55 2.6 2.65 2.7 2.75 2.8 2.85 2.9 2.95 3.0 3.05 3.1 3.15 3.2 3.25 3.3 3.35 3.4 3.45 3.5 3.55 3.6 3.65 3.7 3.75 3.8 3.85 3.9 3.95 4.0 4.05 4.1 4.15 4.2 4.25 4.3 4.35 4.4 4.45 4.5 4.55 4.6 4.65 4.7 4.75 4.8 4.85 4.9 4.95 5.0 5.05 5.1 5.15 5.2 5.25 5.3 5.35 5.4 5.45 5.5 5.55 5.6 5.65 5.7 5.75 5.8 5.85 5.9 5.95 6.0 6.05 6.1 6.15 6.2 6.25 6.3 6.35 6.4 6.45 6.5 6.55 6.6 6.65 6.7 6.75 6.8 6.85 6.9 6.95 7.0 7.05 7.1 7.15 7.2 7.25 7.3 7.35 7.4 7.45 7.5 7.55 7.6 7.65 7.7 7.75 7.8 7.85 7.9 7.95 8.0 8.05 8.1 8.15 8.2 8.25 8.3 8.35 8.4 8.45 8.5 8.55 8.6 8.65 8.7 8.75 8.8 8.85 8.9 8.95 9.0 9.05 9.1 9.15 9.2 9.25 9.3 9.35 9.4 9.45 9.5 9.55 9.6 9.65 9.7 9.75 9.8 9.85 9.9 9.95 ] -#define aperture 0.8 // Centimeters [0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.05 1.1 1.15 1.2 1.25 1.3 1.35 1.4 1.45 1.5 1.55 1.6 1.65 1.7 1.75 1.8 1.85 1.9 1.95 2.0 2.05 2.1 2.15 2.2 2.25 2.3 2.35 2.4 2.45 2.5 2.55 2.6 2.65 2.7 2.75 2.8 2.85 2.9 2.95 3.0 3.05 3.1 3.15 3.2 3.25 3.3 3.35 3.4 3.45 3.5 3.55 3.6 3.65 3.7 3.75 3.8 3.85 3.9 3.95 4.0 4.05 4.1 4.15 4.2 4.25 4.3 4.35 4.4 4.45 4.5 4.55 4.6 4.65 4.7 4.75 4.8 4.85 4.9 4.95 5.0 5.05 5.1 5.15 5.2 5.25 5.3 5.35 5.4 5.45 5.5 5.55 5.6 5.65 5.7 5.75 5.8 5.85 5.9 5.95 6.0 6.05 6.1 6.15 6.2 6.25 6.3 6.35 6.4 6.45 6.5 6.55 6.6 6.65 6.7 6.75 6.8 6.85 6.9 6.95 7.0 7.05 7.1 7.15 7.2 7.25 7.3 7.35 7.4 7.45 7.5 7.55 7.6 7.65 7.7 7.75 7.8 7.85 7.9 7.95 8.0 8.05 8.1 8.15 8.2 8.25 8.3 8.35 8.4 8.45 8.5 8.55 8.6 8.65 8.7 8.75 8.8 8.85 8.9 8.95 9.0 9.05 9.1 9.15 9.2 9.25 9.3 9.35 9.4 9.45 9.5 9.55 9.6 9.65 9.7 9.75 9.8 9.85 9.9 9.95 ] -#define MANUAL_FOCUS 48.0 // If autofocus is turned off, sets the focus point (meters) [0.06948345122280154 0.07243975703425146 0.07552184450877376 0.07873506526686186 0.0820849986238988 0.08557746127787037 0.08921851740926011 0.09301448921066349 0.09697196786440505 0.10109782498721881 0.10539922456186433 0.10988363537639657 0.11455884399268773 0.11943296826671962 0.12451447144412296 0.129812176855438 0.1353352832366127 0.1410933807013415 0.1470964673929768 0.15335496684492847 0.1598797460796939 0.16668213447794653 0.17377394345044514 0.18116748694692214 0.18887560283756183 0.19691167520419406 0.20528965757990927 0.21402409717744744 0.22313016014842982 0.2326236579172927 0.2425210746356487 0.25283959580474646 0.26359713811572677 0.27481238055948964 0.2865047968601901 0.29869468928867837 0.3114032239145977 0.32465246735834974 0.3384654251067422 0.3528660814588489 0.36787944117144233 0.3835315728763107 0.39984965434484737 0.4168620196785084 0.4345982085070782 0.453089017280169 0.4723665527410147 0.49246428767540973 0.513417119032592 0.5352614285189903 0.5580351457700471 0.5817778142098083 0.6065306597126334 0.6323366621862497 0.6592406302004438 0.6872892787909722 0.7165313105737893 0.7470175003104326 0.7788007830714049 0.8119363461506349 0.8464817248906141 0.8824969025845955 0.9200444146293233 0.9591894571091382 1.0 1.0425469051899914 1.086904049521229 1.1331484530668263 1.1813604128656459 1.2316236423470497 1.2840254166877414 1.338656724353094 1.3956124250860895 1.4549914146182013 1.5168967963882134 1.5814360605671443 1.6487212707001282 1.7188692582893286 1.7920018256557555 1.8682459574322223 1.9477340410546757 2.030604096634748 2.117000016612675 2.2070718156067044 2.300975890892825 2.398875293967098 2.5009400136621287 2.6073472713092674 2.718281828459045 2.833936307694169 2.9545115270921065 3.080216848918031 3.211270543153561 3.347900166492527 3.4903429574618414 3.638846248353525 3.7936678946831774 3.955076722920577 4.123352997269821 4.298788906309526 4.4816890703380645 4.672371070304759 4.871165999245474 5.0784190371800815 5.29449005047003 5.51975421667673 5.754602676005731 5.999443210467818 6.254700951936329 6.5208191203301125 6.798259793203881 7.087504708082256 7.38905609893065 7.703437568215379 8.031194996067258 8.372897488127265 8.72913836372013 9.10053618607165 9.487735836358526 9.891409633455755 10.312258501325767 10.751013186076355 11.208435524800691 11.685319768402522 12.182493960703473 12.700821376227164 13.241202019156521 13.804574186067095 14.391916095149892 15.00424758475255 15.642631884188171 16.30817745988666 17.00203994009402 17.725424121461643 18.479586061009854 19.265835257097933 20.085536923187668 20.940114358348602 21.831051418620845 22.75989509352673 23.728258192205157 24.737822143832553 25.790339917193062 26.88763906446752 28.03162489452614 29.22428378123494 30.46768661252054 31.763992386181833 33.11545195869231 34.52441195350251 35.99331883562839 37.524723159600995 39.12128399815321 40.78577355933337 42.52108200006278 44.3302224444953 46.21633621589248 48.182698291098816 50.23272298708815 52.36996988945491 54.598150033144236 56.92113234615337 59.34295036739207 61.867809250367884 64.50009306485578 67.24437240923179 70.10541234668786 73.08818067910767 76.19785657297057 79.43983955226133 82.81975887399955 86.3434833026695 90.01713130052181 93.84708165144015 97.83998453682129 102.00277308269969 106.34267539816554 110.86722712598126 115.58428452718766 120.50203812241894 125.62902691361414 130.9741532108186 136.54669808981876 142.35633750745257 148.4131591025766 154.72767971186107 161.3108636308289 168.17414165184545 175.32943091211476 182.78915558614753 190.56626845863 198.67427341514983 ] +#include "/lib/settings.glsl" #ifdef DOF //hexagon pattern @@ -379,15 +359,10 @@ uniform float aspectRatio; uniform float far; -uniform float screenBrightness; -uniform float isWastes; -uniform float isWarpedForest; -uniform float isCrimsonForest; -uniform float isSoulValley; -uniform float isBasaltDelta; +#include "/lib/color_transforms.glsl" +#include "/lib/color_dither.glsl" + -#include "lib/color_transforms.glsl" -#include "lib/color_dither.glsl" float cdist(vec2 coord) { return max(abs(coord.s-0.5),abs(coord.t-0.5))*2.0; @@ -440,7 +415,7 @@ void main() { #ifdef AUTOFOCUS float focus = ld(texture2D(depthtex0, vec2(0.5)).r)*far; #else - float focus = MANUAL_FOCUS*screenBrightness; + float focus = MANUAL_FOCUS; #endif float pcoc = min(abs(aperture * (focal/100.0 * (z - focus)) / (z * (focus - focal/100.0))),texelSize.x*15.0); #ifdef FAR_BLUR_ONLY @@ -478,18 +453,14 @@ void main() { #endif vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); - float BiomeParams = isWastes + isWarpedForest*10 + isCrimsonForest*10 + isSoulValley*5 + isBasaltDelta*0 ; - - vec3 bloom = texture2D(colortex3,texcoord/clampedRes*vec2(1920.,1080.)*0.5).rgb/2./7.0; - float lightScat = clamp(4 * 0.05 * pow(exposure.a ,0.2) ,0.0,1.0)*vignette; - + float lightScat = clamp(BLOOM_STRENGTH * 0.05 * pow(exposure.a ,0.2) ,0.0,1.0)*vignette; float VL_abs = texture2D(colortex7,texcoord).r; + VL_abs = clamp((1.0-VL_abs*1.05)*BLOOMY_FOG*0.5,0.0,1.0)*clamp(1.0-pow(cdist(texcoord.xy),15.0),0.0,1.0); - VL_abs = clamp((1.0-VL_abs*1.05)*0.5,0.0,1.0)*clamp(1.0-pow(cdist(texcoord.xy),15.0),0.0,1.0); - col = (mix(col,bloom,VL_abs)+bloom*lightScat)*exposure.rgb; + col = ( mix(col, bloom, VL_abs) + bloom*lightScat) * exposure.rgb; /* //Purkinje Effect float lum = dot(col,vec3(0.15,0.3,0.55)); diff --git a/shaders/world-1/composite15.vsh b/shaders/world-1/composite15.vsh index 5099bbb..634d9d3 100644 --- a/shaders/world-1/composite15.vsh +++ b/shaders/world-1/composite15.vsh @@ -1,9 +1,7 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable -#define FinalR 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] -#define FinalG 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] -#define FinalB 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] +#include "/lib/settings.glsl" varying vec2 texcoord; flat varying vec4 exposure; diff --git a/shaders/world-1/composite2.fsh b/shaders/world-1/composite2.fsh index e9506b3..8c8c4d9 100644 --- a/shaders/world-1/composite2.fsh +++ b/shaders/world-1/composite2.fsh @@ -1,70 +1,33 @@ #version 120 -//Render sky, volumetric clouds, direct lighting #extension GL_EXT_gpu_shader4 : enable -#define SCREENSPACE_CONTACT_SHADOWS //Raymarch towards the sun in screen-space, in order to cast shadows outside of the shadow map or at the contact of objects. Can get really expensive at high resolutions. -#define SHADOW_FILTER_SAMPLE_COUNT 9 // Number of samples used to filter the actual shadows [1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 ] -#define CAVE_LIGHT_LEAK_FIX // Hackish way to remove sunlight incorrectly leaking into the caves. Can inacurrately remove shadows in some places -#define CLOUDS_SHADOWS -#define CLOUDS_SHADOWS_STRENGTH 1.0 //[0.1 0.125 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.9 1.0] -#define CLOUDS_QUALITY 0.5 //[0.1 0.125 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.9 1.0] -#define SSAO //It is also recommended to reduce the ambientOcclusionLevel value with this enabled -#define SSAO_SAMPLES 7 //[4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32] -#define TORCH_R 1.0 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define TORCH_G 0.75 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define TORCH_B 0.5 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define indirect_effect 1 // Choose what effect is applied to indirect light. [0 1 2 3] -#define AO_Strength 0.8 // strength of shadowed areas [0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 ] +#include "/lib/settings.glsl" +#include "/lib/diffuse_lighting.glsl" -#define GI_Strength 1.0 // strength of bounced light areas [1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 ] - -// #define HQ_SSGI - -//////////// misc settings - -// #define WhiteWorld // THIS IS A DEBUG VIEW. uses to see AO easier. used to see fake GI better (green light) -// #define LabPBR_Emissives -#define Emissive_Brightness 10.0 // [1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 15. 20. 25. 30. 35. 40. 45. 50. 100.] -#define Emissive_Curve 2.0 // yes i blatantly copied kappa here. [1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 ] - -#define n_MIN_LIGHT_AMOUNT 1.0 //[0.0 0.5 1.0 1.5 2.0 3.0 4.0 5.0] - -const bool shadowHardwareFiltering = true; varying vec2 texcoord; -uniform float nightVision; -flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) -flat varying vec3 ambientUp; -flat varying vec3 ambientLeft; -flat varying vec3 ambientRight; -flat varying vec3 ambientB; -flat varying vec3 ambientF; -flat varying vec3 ambientDown; flat varying vec3 avgAmbient; -flat varying vec3 WsunVec; + flat varying vec2 TAA_Offset; flat varying float tempOffsets; +const bool colortex5MipmapEnabled = true; + uniform sampler2D colortex0;//clouds uniform sampler2D colortex1;//albedo(rgb),material(alpha) RGBA16 -uniform sampler2D colortex3; uniform sampler2D colortex4;//Skybox -uniform sampler2D colortex5; -uniform sampler2D colortex6;//Skybox +uniform sampler2D colortex3; uniform sampler2D colortex7; +uniform sampler2D colortex5; +uniform sampler2D colortex2; uniform sampler2D colortex8; +uniform sampler2D colortex15; +uniform sampler2D colortex6;//Skybox uniform sampler2D depthtex1;//depth uniform sampler2D depthtex0;//depth uniform sampler2D noisetex;//depth - -uniform float isWastes; -uniform float isWarpedForest; -uniform float isCrimsonForest; -uniform float isSoulValley; -uniform float isBasaltDelta; - uniform int heldBlockLightValue; uniform int frameCounter; uniform int isEyeInWater; @@ -77,45 +40,52 @@ uniform float rainStrength; uniform mat4 gbufferProjection; uniform mat4 gbufferProjectionInverse; uniform mat4 gbufferModelViewInverse; -uniform mat4 gbufferPreviousModelView; -uniform mat4 gbufferPreviousProjection; -uniform vec3 previousCameraPosition; uniform mat4 shadowModelView; uniform mat4 shadowProjection; uniform mat4 gbufferModelView; +uniform mat4 gbufferPreviousModelView; +uniform mat4 gbufferPreviousProjection; +uniform vec3 previousCameraPosition; + uniform vec2 texelSize; uniform float viewWidth; uniform float viewHeight; uniform float aspectRatio; uniform vec3 cameraPosition; -// uniform int framemod8; uniform vec3 sunVec; uniform ivec2 eyeBrightnessSmooth; + #define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) #define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) + 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; } -#include "lib/waterOptions.glsl" -#include "lib/color_transforms.glsl" -#include "lib/sky_gradient.glsl" -#include "lib/stars.glsl" -#include "lib/volumetricClouds.glsl" -#include "lib/waterBump.glsl" + + +#include "/lib/color_transforms.glsl" +#include "/lib/waterBump.glsl" +#include "/lib/sky_gradient.glsl" + + float ld(float dist) { return (2.0 * near) / (far + near - dist * (far - near)); } -vec3 ld(vec3 dist) { - return (2.0 * near) / (far + near - dist * (far - near)); -} -#include "lib/specular.glsl" +vec2 RENDER_SCALE = vec2(1.0); + +#include "/lib/specular.glsl" +#include "/lib/nether_fog.glsl" + + + + vec3 normVec (vec3 vec){ return vec*inversesqrt(dot(vec,vec)); @@ -144,20 +114,12 @@ vec3 fp10Dither(vec3 color,float dither){ return color + dither*exp2(-mantissaBits)*exp2(exponent); } -vec2 R2_samples(int n){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha * n); -} + + float facos(float sx){ float x = clamp(abs( sx ),0.,1.); return sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); } -vec3 worldToView(vec3 worldPos) { - vec4 pos = vec4(worldPos, 0.0); - pos = gbufferModelView * pos; - return pos.xyz; -} - vec3 decode (vec2 encn){ vec3 n = vec3(0.0); encn = encn * 2.0 - 1.0; @@ -171,6 +133,24 @@ vec2 decodeVec2(float a){ const float constant2 = 256. / 255.; return fract( a * constant1 ) * constant2 ; } +// float linZ(float depth) { +// return (2.0 * near) / (far + near - depth * (far - near)); +// // l = (2*n)/(f+n-d(f-n)) +// // f+n-d(f-n) = 2n/l +// // -d(f-n) = ((2n/l)-f-n) +// // d = -((2n/l)-f-n)/(f-n) + +// } +// float invLinZ (float lindepth){ +// return -((2.0*near/lindepth)-far-near)/(far-near); +// } + +// vec3 toClipSpace3(vec3 viewSpacePosition) { +// return projMAD(gbufferProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; +// } + + + vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter,float distort) { @@ -185,12 +165,17 @@ vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter,float distort return vec2(cos_v, sin_v)*sqrt(alpha); } + + + +vec3 BilateralFiltering(sampler2D tex, sampler2D depth,vec2 coord,float frDepth,float maxZ){ + vec4 sampled = vec4(texelFetch2D(tex,ivec2(coord),0).rgb,1.0); + + return vec3(sampled.x,sampled.yz/sampled.w); +} float blueNoise(){ return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); } -vec4 blueNoise(vec2 coord){ - return texelFetch2D(colortex6, ivec2(coord )%512 , 0); -} float R2_dither(){ vec2 alpha = vec2(0.75487765, 0.56984026); return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y); @@ -215,123 +200,116 @@ vec2 tapLocation(int sampleNumber, float spinAngle,int nb, float nbRot,float r0) return vec2(cos_v, sin_v)*ssR; } -void ssAO(inout vec3 lighting,vec3 fragpos,float mulfov, vec2 noise, vec3 normal, float lightmap){ + +float ssao(vec3 fragpos, float dither,vec3 normal) +{ + float mulfov = 1.0; ivec2 pos = ivec2(gl_FragCoord.xy); - const float tan70 = tan(70.*3.14/240.); + const float tan70 = tan(70.*3.14/180.); float mulfov2 = gbufferProjection[1][1]/tan70; - float maxR2 = fragpos.z*fragpos.z*mulfov2*2.*1.412/50.0; + const float PI = 3.14159265; + const float samplingRadius = 0.712; + float angle_thresh = 0.05; - float rd = mulfov2 * 0.04 ; + + + float rd = mulfov2*0.05; //pre-rotate direction - float n = 0.0; + float n = 0.; float occlusion = 0.0; - vec2 acc = -(TAA_Offset*(texelSize/2)) ; + vec2 acc = -vec2(TAA_Offset)*texelSize*0.5; + float mult = (dot(normal,normalize(fragpos))+1.0)*0.5+0.5; - int seed = (frameCounter%40000)*2 + frameCounter; - vec2 ij = fract(R2_samples(seed) + noise.rg ); - vec2 v = ij; - - for (int j = 0; j < 7 ;j++) { - vec2 sp = tapLocation(j,v.x,7,1.682,v.y); - vec2 sampleOffset = sp*rd ; - ivec2 offset = ivec2(gl_FragCoord.xy + sampleOffset*vec2(viewWidth,viewHeight*aspectRatio)); - - if (offset.x >= 0 && offset.y >= 0 && offset.x < viewWidth && offset.y < viewHeight ) { - vec3 t0 = toScreenSpace(vec3(offset*texelSize+acc+0.5*texelSize,texelFetch2D(depthtex1,offset,0).x)); - vec3 vec = t0.xyz - fragpos; - float dsquared = dot(vec,vec); + vec2 v = fract(vec2(dither,interleaved_gradientNoise()) + (frameCounter%10000) * vec2(0.75487765, 0.56984026)); + for (int j = 0; j < 7+2 ;j++) { + vec2 sp = tapLocation(j,v.x,7+2,2.,v.y); + vec2 sampleOffset = sp*rd; + ivec2 offset = ivec2(gl_FragCoord.xy + sampleOffset*vec2(viewWidth,viewHeight)); + if (offset.x >= 0 && offset.y >= 0 && offset.x < viewWidth && offset.y < viewHeight ) { + vec3 t0 = toScreenSpace(vec3(offset*texelSize+acc+0.5*texelSize,texelFetch2D(depthtex1,offset,0).x)); + vec3 vec = t0.xyz - fragpos; + float dsquared = dot(vec,vec); if (dsquared > 1e-5){ - if (dsquared < maxR2){ - float NdotV = clamp(dot(vec*inversesqrt(dsquared), normalize(normal) ),0.,1.); - occlusion += NdotV * clamp(1.0-dsquared/maxR2,0.0,1.0); + if (dsquared < fragpos.z*fragpos.z*0.05*0.05*mulfov2*2.*1.412){ + float NdotV = clamp(dot(vec*inversesqrt(dsquared), normalize(normal)),0.,1.); + occlusion += NdotV; } - n += 1.0 ; + n += 1.0; } + } } - } - occlusion *= mix(2.25,0.0,clamp(pow(lightmap,2),0,1)); - occlusion = max(1.0 - occlusion/n, 0.0); - lighting = lighting * occlusion; + + + + + return clamp(1.0-occlusion/n*2.0,0.,1.0); } - - -vec3 cosineHemisphereSample(vec2 Xi, float roughness) -{ - float r = sqrt(Xi.x); - float theta = 2.0 * 3.14159265359 * Xi.y; - - float x = r * cos(theta); - float y = r * sin(theta); - - return vec3(x, y, sqrt(clamp(1.0 - Xi.x,0.,1.))); +vec3 viewToWorld(vec3 viewPosition) { + vec4 pos; + pos.xyz = viewPosition; + pos.w = 0.0; + pos = gbufferModelViewInverse * pos; + return pos.xyz; } -vec3 TangentToWorld(vec3 N, vec3 H, float roughness) -{ - vec3 UpVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0); - vec3 T = normalize(cross(UpVector, N)); - vec3 B = cross(N, T); - - return vec3((T * H.x) + (B * H.y) + (N * H.z)); +vec3 worldToView(vec3 worldPos) { + vec4 pos = vec4(worldPos, 0.0); + pos = gbufferModelView * pos; + return pos.xyz; } +void waterVolumetrics(inout vec3 inColor, vec3 rayStart, vec3 rayEnd, float estEndDepth, float estSunDepth, float rayLength, float dither, vec3 waterCoefs, vec3 scatterCoef, vec3 ambient){ + inColor *= exp(-rayLength * waterCoefs); //No need to take the integrated value + int spCount = rayMarchSampleCount; + vec3 start = toShadowSpaceProjected(rayStart); + vec3 end = toShadowSpaceProjected(rayEnd); + vec3 dV = (end-start); + //limit ray length at 32 blocks for performance and reducing integration error + //you can't see above this anyway + float maxZ = min(rayLength,12.0)/(1e-8+rayLength); + dV *= maxZ; + vec3 dVWorld = -mat3(gbufferModelViewInverse) * (rayEnd - rayStart) * maxZ; + rayLength *= maxZ; + float dY = normalize(mat3(gbufferModelViewInverse) * rayEnd).y * rayLength; + estEndDepth *= maxZ; + estSunDepth *= maxZ; + vec3 absorbance = vec3(1.0); + vec3 vL = vec3(0.0); -vec3 RT(vec3 dir, vec3 position, float noise, float stepsizes){ - float stepSize = stepsizes; - int maxSteps = 12; - vec3 clipPosition = toClipSpace3(position); - float rayLength = ((position.z + dir.z * sqrt(3.0)*far) > -sqrt(3.0)*near) ? - (-sqrt(3.0)*near -position.z) / dir.z : sqrt(3.0)*far; - vec3 end = toClipSpace3(position+dir*rayLength) ; - vec3 direction = end-clipPosition ; //convert to clip space - float len = max(abs(direction.x)/texelSize.x,abs(direction.y)/texelSize.y)/stepSize; - //get at which length the ray intersects with the edge of the screen - vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; - - float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z)*2000.0; - vec3 stepv = direction/len; + float expFactor = 11.0; + vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; + for (int i=0;i 1.0) occlude += skyLightDir; - } - lighting *= occlude/nrays; +void LabEmission( + inout vec3 Lighting, + vec3 Albedo, + float Emission +){ + // if( Emission < 255.0/255.0 ) Lighting = mix(Lighting, Albedo * Emissive_Brightness, pow(Emission, Emissive_Curve)); // old method.... idk why + if( Emission < 255.0/255.0 ) Lighting += (Albedo * Emissive_Brightness) * pow(Emission, Emissive_Curve); } void main() { @@ -339,97 +317,109 @@ void main() { vec3 waterEpsilon = vec3(Water_Absorb_R, Water_Absorb_G, Water_Absorb_B); vec3 dirtEpsilon = vec3(Dirt_Absorb_R, Dirt_Absorb_G, Dirt_Absorb_B); vec3 totEpsilon = dirtEpsilon*dirtAmount + waterEpsilon; - vec3 scatterCoef = dirtAmount * vec3(Dirt_Scatter_R, Dirt_Scatter_G, Dirt_Scatter_B) / pi; + vec3 scatterCoef = dirtAmount * vec3(Dirt_Scatter_R, Dirt_Scatter_G, Dirt_Scatter_B) / 3.14; + + float z0 = texture2D(depthtex0,texcoord).x; float z = texture2D(depthtex1,texcoord).x; + vec2 tempOffset=TAA_Offset; + float noise = blueNoise(); vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(tempOffset)*texelSize*0.5,z)); vec3 p3 = mat3(gbufferModelViewInverse) * fragpos; vec3 np3 = normVec(p3); - + + + vec4 trpData = texture2D(colortex7,texcoord); + bool iswater = trpData.a > 0.99; vec4 SpecularTex = texture2D(colortex8,texcoord); - // for a thing - vec3 wpos = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - vec3 dVWorld = (wpos-gbufferModelViewInverse[3].xyz); - float dL = length(dVWorld); - vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; - progressW = gbufferModelViewInverse[3].xyz+cameraPosition + dVWorld; - - p3 += gbufferModelViewInverse[3].xyz; - - bool iswater = texture2D(colortex7,texcoord).a > 0.99; - - vec4 data = texture2D(colortex1,texcoord); + vec4 data = texture2D(colortex1,texcoord); // terraom vec4 dataUnpacked0 = vec4(decodeVec2(data.x),decodeVec2(data.y)); vec4 dataUnpacked1 = vec4(decodeVec2(data.z),decodeVec2(data.w)); + + float Translucent_Programs = texture2D(colortex2,texcoord).a; // the shader for all translucent progams. + // Normal // + vec3 normal = decode(dataUnpacked0.yw) ; + + vec4 normalAndAO = texture2D(colortex15,texcoord); + vec3 FlatNormals = normalAndAO.rgb * 2.0 - 1.0; + float vanilla_AO = 1.0 - exp2(-5 * pow(1-normalAndAO.a,3)) ; + vec3 albedo = toLinear(vec3(dataUnpacked0.xz,dataUnpacked1.x)); - vec3 normal = mat3(gbufferModelViewInverse) * worldToView(decode(dataUnpacked0.yw)); vec2 lightmap = dataUnpacked1.yz; bool translucent = abs(dataUnpacked1.w-0.5) <0.01; bool hand = abs(dataUnpacked1.w-0.75) <0.01; - bool blocklights = abs(dataUnpacked1.w-0.8) <0.01; - vec3 lightSource = normalize(vec3(0.0, -1.0,0.0)); - vec3 viewspace_sunvec = mat3(gbufferModelView) * lightSource; + if (z >=1.0) { + vec3 color = clamp(gl_Fog.color.rgb*pow(luma(gl_Fog.color.rgb),-0.75)*0.65,0.0,1.0)*0.02; - vec3 WsunVec = normalize(mat3(gbufferModelViewInverse) * viewspace_sunvec); - float LightDir = max(dot(normal, WsunVec),0.0); + gl_FragData[0].rgb = clamp(fp10Dither(color*8./3. * (1.0-rainStrength*0.4),triangularize(noise)),0.0,65000.); + + } else { + + p3 += gbufferModelViewInverse[3].xyz + cameraPosition; + + // do all ambient lighting stuff + vec3 Indirect_lighting = DoAmbientLighting_Nether(gl_Fog.color.rgb, vec3(TORCH_R,TORCH_G,TORCH_B), lightmap.x, normal, np3, p3 ); + + + vec3 LightColor = LightSourceColor(); + + float SdotV = dot(normalize(viewspace_sunvec), normalize(fragpos)); + float OrbMie = max(exp((p3.y - 60) / -30.),0); + + // 0.5 added because lightsources are always high radius. + float NdotL = clamp( dot(normal,normalize(WsunVec)) + 0.25,0.0,1.0); + + vec3 LightSource = LightColor * NdotL * OrbMie ; + + // LightSource *= rayTraceShadow(worldToView(normalize(-LightPos)), fragpos, interleaved_gradientNoise()); + // LightSource *= GetCloudShadow(p3, WsunVec, blueNoise()); - vec3 ambientCoefs = normal/dot(abs(normal),vec3(1.)); + // finalize + gl_FragData[0].rgb = (Indirect_lighting) * albedo; + // gl_FragData[0].rgb = LightSource * albedo; - #ifdef WhiteWorld - albedo = vec3(1.0); - #endif + #ifdef Specular_Reflections + MaterialReflections_N(gl_FragData[0].rgb, SpecularTex.r, SpecularTex.ggg, albedo, normal, np3, fragpos, vec3(blueNoise(gl_FragCoord.xy).rg,noise), hand); + #endif -////// ----- indirect ----- ////// - - vec3 custom_lightmap = texture2D(colortex4, (vec2(lightmap.x, pow(lightmap.y,2))*15.0+0.5+vec2(0.0,19.))*texelSize).rgb*8./150./3.; // y = torch + if(!hand) gl_FragData[0].rgb *= ssao(fragpos,noise,FlatNormals) * vanilla_AO; - // vec3 ambientLight = vec3(1.0) / 30; - vec3 ambientLight = ((ambientUp + ambientDown + ambientRight + ambientLeft + ambientB + ambientF) ) * (abs(ambientCoefs.y * 0.5) + 0.5) ; + #ifdef LabPBR_Emissives + LabEmission(gl_FragData[0].rgb, albedo, SpecularTex.a); + #endif + } + + // ////// border Fog + // if(Translucent_Programs > 0.0){ + // vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); + // float fogdistfade = 1.0 - clamp( exp(-pow(length(fragpos / far),2.)*5.0) ,0.0,1.0); + + // gl_FragData[0].rgb = mix(gl_FragData[0].rgb, gl_Fog.color.rgb*0.5*NetherFog_brightness, fogdistfade) ; + // } - vec3 Lightsources = custom_lightmap.y * vec3(TORCH_R,TORCH_G,TORCH_B) * 0.5; - if(hand) Lightsources *= 0.15; - if(blocklights) Lightsources *= 0.3; - if(custom_lightmap.y > 10.) Lightsources *= 0.3; + ////// Water Fog + if ((isEyeInWater == 0 && iswater) || (isEyeInWater == 1 && !iswater)){ + vec3 fragpos0 = toScreenSpace(vec3(texcoord-vec2(tempOffset)*texelSize*0.5,z0)); + float Vdiff = distance(fragpos,fragpos0); - //apply a curve for the torch light so it doesnt mix with lab emissive colors too much - #ifdef LabPBR_Emissives - if(blocklights && (SpecularTex.a > 0.0 && SpecularTex.a < 1.0)) Lightsources = mix(vec3(0.0), Lightsources, SpecularTex.a); - #endif + if(isEyeInWater == 1) Vdiff = (length(fragpos)); - ambientLight += Lightsources; + float VdotU = np3.y; + float estimatedDepth = Vdiff; //assuming water plane + float estimatedSunDepth = estimatedDepth; //assuming water plane - #if indirect_effect == 1 - if (!hand) ssAO(ambientLight, fragpos, 1.0, blueNoise(gl_FragCoord.xy).rg, worldToView(decode(dataUnpacked0.yw)), lightmap.x) ; - #endif - // #if indirect_effect == 2 - // if (!hand ) rtAO(ambientLight, normal, blueNoise(gl_FragCoord.xy).rg, fragpos); - // #endif - // #if indirect_effect == 3 - // if (!hand) rtGI(ambientLight, normal, blueNoise(gl_FragCoord.xy).rg, fragpos, 1, albedo); - // #endif + vec3 ambientColVol = vec3(1.0,0.25,0.5) * 0.33 ; + waterVolumetrics(gl_FragData[0].rgb, fragpos0, fragpos, estimatedDepth , estimatedSunDepth, Vdiff, noise, totEpsilon, scatterCoef, ambientColVol); + } - vec3 Indirect_lighting = ambientLight; - -////// ----- finalize ----- ////// - - gl_FragData[0].rgb = Indirect_lighting * albedo ; - - #ifdef LabPBR_Emissives - gl_FragData[0].rgb = SpecularTex.a < 255.0/255.0 ? mix(gl_FragData[0].rgb, albedo * Emissive_Brightness*0.5 , SpecularTex.a): gl_FragData[0].rgb; - #endif - - // do this after water and stuff is done because yea - #ifdef Specular_Reflections - MaterialReflections(gl_FragData[0].rgb, SpecularTex.r, SpecularTex.ggg, albedo, WsunVec, vec3(0), 0.0 , lightmap.y, normal, np3, fragpos, vec3(blueNoise(gl_FragCoord.xy).rg,blueNoise()), hand); - #endif /* DRAWBUFFERS:3 */ } diff --git a/shaders/world-1/composite2.vsh b/shaders/world-1/composite2.vsh index b1cf351..6d29816 100644 --- a/shaders/world-1/composite2.vsh +++ b/shaders/world-1/composite2.vsh @@ -1,17 +1,12 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable -#define TAA + +#include "/lib/settings.glsl" + varying vec2 texcoord; -flat varying vec3 WsunVec; -flat varying vec3 ambientUp; -flat varying vec3 ambientLeft; -flat varying vec3 ambientRight; -flat varying vec3 ambientB; -flat varying vec3 ambientF; -flat varying vec3 ambientDown; flat varying vec3 avgAmbient; -flat varying vec4 lightCol; + flat varying float tempOffsets; flat varying vec2 TAA_Offset; flat varying vec3 zMults; @@ -43,26 +38,14 @@ void main() { texcoord = gl_MultiTexCoord0.xy; tempOffsets = HaltonSeq2(frameCounter%10000); + TAA_Offset = offsets[frameCounter%8]; + #ifndef TAA - TAA_Offset = vec2(0.0); + TAA_Offset = vec2(0.0); #endif - vec3 sc = texelFetch2D(colortex4,ivec2(6,37),0).rgb; - ambientUp = texelFetch2D(colortex4,ivec2(0,37),0).rgb; - ambientDown = texelFetch2D(colortex4,ivec2(1,37),0).rgb; - ambientLeft = texelFetch2D(colortex4,ivec2(2,37),0).rgb; - ambientRight = texelFetch2D(colortex4,ivec2(3,37),0).rgb; - ambientB = texelFetch2D(colortex4,ivec2(4,37),0).rgb; - ambientF = texelFetch2D(colortex4,ivec2(5,37),0).rgb; - avgAmbient = texelFetch2D(colortex4,ivec2(11,37),0).rgb; - - lightCol.a = float(sunElevation > 1e-5)*2-1.; - lightCol.rgb = sc; - - WsunVec = lightCol.a*normalize(mat3(gbufferModelViewInverse) *sunPosition); + avgAmbient = texelFetch2D(colortex4,ivec2(0,37),0).rgb; zMults = vec3((far * near)*2.0,far+near,far-near); - - } diff --git a/shaders/world-1/composite3.fsh b/shaders/world-1/composite3.fsh new file mode 100644 index 0000000..f3fae99 --- /dev/null +++ b/shaders/world-1/composite3.fsh @@ -0,0 +1,79 @@ +#version 120 +//Volumetric fog rendering +#extension GL_EXT_gpu_shader4 : enable + +#include "/lib/settings.glsl" + +flat varying vec4 lightCol; +flat varying vec3 ambientUp; +flat varying vec3 ambientLeft; +flat varying vec3 ambientRight; +flat varying vec3 ambientB; +flat varying vec3 ambientF; +flat varying vec3 ambientDown; +flat varying float tempOffsets; +flat varying float fogAmount; +flat varying float VFAmount; +uniform sampler2D noisetex; +uniform sampler2D depthtex0; + + +uniform sampler2D colortex2; +uniform sampler2D colortex3; +// uniform sampler2D colortex4; + +uniform vec3 sunVec; +uniform float far; +uniform int frameCounter; +uniform float rainStrength; +uniform float sunElevation; +uniform ivec2 eyeBrightnessSmooth; +uniform float frameTimeCounter; +uniform int isEyeInWater; +uniform vec2 texelSize; + + +#include "/lib/color_transforms.glsl" +#include "/lib/color_dither.glsl" +#include "/lib/projections.glsl" +#include "/lib/nether_fog.glsl" + + +#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) + +float interleaved_gradientNoise(){ + return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+tempOffsets); +} +float blueNoise(){ + return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); +} + +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// + +varying vec2 texcoord; + +void main() { +/* DRAWBUFFERS:0 */ + + // if (isEyeInWater == 0){ + // vec2 tc = floor(gl_FragCoord.xy)*2.0*texelSize+0.5*texelSize; + // float z = texture2D(depthtex0,tc).x; + // vec3 fragpos = toScreenSpace(vec3(tc,z)); + + // vec3 fragpos_ALT = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); + + // float noise = blueNoise(); + // mat2x3 vl = getVolumetricRays(noise,fragpos, interleaved_gradientNoise()); + + // float absorbance = dot(vl[1],vec3(0.22,0.71,0.07)); + + // gl_FragData[0] = clamp(vec4(vl[0],absorbance),0.000001,65000.); + + // } else { + // gl_FragData[0] = vec4(0.0); + // } +} diff --git a/shaders/world1/lib/composite3.vsh b/shaders/world-1/composite3.vsh similarity index 69% rename from shaders/world1/lib/composite3.vsh rename to shaders/world-1/composite3.vsh index 05cecb7..91f9f96 100644 --- a/shaders/world1/lib/composite3.vsh +++ b/shaders/world-1/composite3.vsh @@ -1,10 +1,12 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable -varying vec2 texcoord; -flat varying vec3 zMults; -uniform float far; -uniform float near; +flat varying float tempOffsets; + +uniform int frameCounter; + +#include "/lib/util.glsl" + //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -12,8 +14,9 @@ uniform float near; //////////////////////////////VOID MAIN////////////////////////////// void main() { - zMults = vec3(1.0/(far * near),far+near,far-near); gl_Position = ftransform(); - texcoord = gl_MultiTexCoord0.xy; + tempOffsets = HaltonSeq2(frameCounter%10000); + + gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.51*2.0-1.0; } diff --git a/shaders/world-1/composite5.fsh b/shaders/world-1/composite5.fsh deleted file mode 100644 index 5444e90..0000000 --- a/shaders/world-1/composite5.fsh +++ /dev/null @@ -1,271 +0,0 @@ -#version 120 -//Volumetric fog rendering -#extension GL_EXT_gpu_shader4 : enable - -#define VL_SAMPLES 8 //[4 6 8 10 12 14 16 20 24 30 40 50] -#define Ambient_Mult 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0 5.0 6.0 10.0] -#define SEA_LEVEL 70 //[0 10 20 30 40 50 60 70 80 90 100 110 120 130 150 170 190] //The volumetric light uses an altitude-based fog density, this is where fog density is the highest, adjust this value according to your world. -#define ATMOSPHERIC_DENSITY 1.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 4.0 5.0 7.5 10.0 12.5 15.0 20.] -#define fog_mieg1 0.40 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0] -#define fog_mieg2 0.10 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0] -#define fog_coefficientRayleighR 5.8 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientRayleighG 1.35 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientRayleighB 3.31 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] - -#define fog_coefficientMieR 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientMieG 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientMieB 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] - -#define Underwater_Fog_Density 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0] - -flat varying vec4 lightCol; -flat varying vec3 ambientUp; -flat varying vec3 ambientLeft; -flat varying vec3 ambientRight; -flat varying vec3 ambientB; -flat varying vec3 ambientF; -flat varying vec3 ambientDown; -flat varying float tempOffsets; -flat varying float fogAmount; -flat varying float VFAmount; -uniform sampler2D noisetex; -uniform sampler2D depthtex0; - - -uniform sampler2D colortex2; -uniform sampler2D colortex3; -uniform sampler2D colortex4; - -uniform vec3 sunVec; -uniform float far; -uniform int frameCounter; -uniform float rainStrength; -uniform float sunElevation; -uniform ivec2 eyeBrightnessSmooth; -uniform float frameTimeCounter; -uniform int isEyeInWater; -uniform vec2 texelSize; - - -uniform float isWastes; -uniform float isWarpedForest; -uniform float isCrimsonForest; -uniform float isSoulValley; -uniform float isBasaltDelta; - - -#include "lib/waterOptions.glsl" -#include "lib/color_transforms.glsl" -#include "lib/color_dither.glsl" -#include "lib/projections.glsl" -#include "lib/sky_gradient.glsl" -#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) - -float interleaved_gradientNoise(){ - return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+tempOffsets); -} - - -float phaseg(float x, float g){ - float gg = g * g; - return (gg * -0.25 + 0.25) * pow(-2.0 * (g * x) + (gg + 1.0), -1.5) /3.14; -} -float phaseRayleigh(float cosTheta) { - const vec2 mul_add = vec2(0.1, 0.28) /acos(-1.0); - return cosTheta * mul_add.x + mul_add.y; // optimized version from [Elek09], divided by 4 pi for energy conservation -} - -float densityAtPos(in vec3 pos) -{ - - pos /= 18.; - pos.xz *= 0.5; - - - vec3 p = floor(pos); - vec3 f = fract(pos); - - f = (f*f) * (3.-2.*f); - - vec2 uv = p.xz + f.xz + p.y * vec2(0.0,193.0); - - vec2 coord = uv / 512.0; - - vec2 xy = texture2D(noisetex, coord).yx; - - return mix(xy.r,xy.g, f.y); -} -// float cloudVol(in vec3 pos){ - -// vec3 samplePos = pos*vec3(1.0,1./32.,1.0)*5.0+frameTimeCounter*vec3(0.5,0.,0.5)*1.; -// float noise = densityAtPos(samplePos*12.); -// float unifCov = exp2(-max(pos.y-SEA_LEVEL,0.0)/50.); - -// float cloud = pow(clamp(1.0-noise-0.76,0.0,1.0),2.)+0.005; - -// return cloud; -// } - -float cloudVol(in vec3 pos){ - - // float[4] BiomeParams = float[4]( - // /*[0] Cloudy amount */ isWastes*5 + isWarpedForest*0 + isCrimsonForest*0 + isSoulValley + isBasaltDelta*2 - // /*[1] uniform amount*/ ,isWastes*0 + isWarpedForest*0.005 + isCrimsonForest*0.005 + isSoulValley*0.5 + isBasaltDelta*0 - // /*[2] uniform height*/ ,isWastes*3 + isWarpedForest*100 + isCrimsonForest*100 + isSoulValley*2 + isBasaltDelta - // /*[3] cloudy height*/ ,isWastes*20 + isWarpedForest + isCrimsonForest + isSoulValley*100 + isBasaltDelta*100 - // ); - - // cloudy fog shapes - vec3 samplePos = pos*vec3(1.0,1./48.,1.0); - - samplePos.x += frameTimeCounter*2.0; - float cloudy_fog_erosion = densityAtPos(samplePos * 200.0); - - samplePos += cloudy_fog_erosion; - - samplePos.y -= frameTimeCounter*0.2; - float main_cloudy_fog = densityAtPos(samplePos * 50.0); - - float final = main_cloudy_fog/100.0; - return final; -} - -mat2x3 getVolumetricRays(float dither,vec3 fragpos) { - - //project pixel position into projected shadowmap space - vec3 wpos = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - vec3 fragposition = mat3(shadowModelView) * wpos + shadowModelView[3].xyz; - fragposition = diagonal3(shadowProjection) * fragposition + shadowProjection[3].xyz; - - - - //project view origin into projected shadowmap space - vec3 start = toShadowSpaceProjected(vec3(0.)); - - - //rayvector into projected shadow map space - //we can use a projected vector because its orthographic projection - //however we still have to send it to curved shadow map space every step - vec3 dV = (fragposition-start); - vec3 dVWorld = (wpos-gbufferModelViewInverse[3].xyz); - - float maxLength = min(length(dVWorld),far)/length(dVWorld); - dV *= maxLength; - dVWorld *= maxLength; - - //apply dither - vec3 progress = start.xyz; - vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; - vec3 vL = vec3(0.); - - float SdotV = dot(sunVec,normalize(fragpos))*lightCol.a; - float dL = length(dVWorld); - //Mie phase + somewhat simulates multiple scattering (Horizon zero down cloud approx) - float mie = max(phaseg(SdotV,fog_mieg1),1.0/13.0); - float rayL = phaseRayleigh(SdotV); - // wpos.y = clamp(wpos.y,0.0,1.0); - - vec3 ambientCoefs = dVWorld/dot(abs(dVWorld),vec3(1.)); - - vec3 ambientLight = ambientUp; - ambientLight += ambientDown; - ambientLight += ambientRight; - ambientLight += ambientLeft; - ambientLight += ambientB; - ambientLight += ambientF; - - vec3 skyCol0 = ambientLight*8.*2./150./3.*Ambient_Mult*3.1415; - - float mu = 1.0; - float muS = 1.05; - vec3 absorbance = vec3(1.0); - float expFactor = 11.0; - - vec3 fogColor = clamp(gl_Fog.color.rgb*pow(luma(gl_Fog.color.rgb),-0.75)*0.65,0.0,1.0)*0.05; - - // float testcolor = clamp(exp2(-max(progressW.y-25,0.0)/5) ,0,1); - // fogColor = mix(fogColor, vec3(0,1,0), testcolor); - - for (int i=0;i 0.99; vec2 refractedCoord = texcoord; - vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); - vec3 fragpos2 = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z2)); - // vec3 np3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition; - - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos; - vec3 np3 = normVec(p3); - if (iswater){ - float norm = getWaterHeightmap(np3.xz*1.71, 4.0, 0.25, 1.0); - float displ = norm/(length(fragpos)/far)/35.; - refractedCoord += displ; + vec2 data = texture2D(colortex11,texcoord).xy; // translucents + vec4 dataUnpacked0 = vec4(decodeVec2(data.x),decodeVec2(data.y)); - if (texture2D(colortex7,refractedCoord).a < 0.99) - refractedCoord = texcoord; + vec3 normals = mat3(gbufferModelViewInverse) * worldToView(decode(dataUnpacked0.yw) ); - } + // vec4 vl = BilateralUpscale(colortex0,depthtex0,gl_FragCoord.xy,frDepth); + + #ifdef Refraction + refractedCoord += normals.xy * glassdepth; + + float refractedalpha = texture2D(colortex13,refractedCoord).a; + if(refractedalpha <= 0.0) refractedCoord = texcoord; // remove refracted coords on solids + #endif - vec3 color = texture2D(colortex3,refractedCoord).rgb; - if (frDepth > 2.5/far || transparencies.a < 0.99) // Discount fix for transparencies through hand - color = color*(1.0-transparencies.a)+transparencies.rgb*10.; + + if (Translucent_Programs.a > 0.0){ + #ifdef Glass_Tint + vec3 GlassAlbedo = texture2D(colortex13,texcoord).rgb * 5.0; + color = color*GlassAlbedo.rgb + color * clamp(pow(1.0-luma(GlassAlbedo.rgb),10.),0.0,1.0); + #endif - float dirtAmount = Dirt_Amount; - vec3 waterEpsilon = vec3(Water_Absorb_R, Water_Absorb_G, Water_Absorb_B); - vec3 dirtEpsilon = vec3(Dirt_Absorb_R, Dirt_Absorb_G, Dirt_Absorb_B); - vec3 totEpsilon = dirtEpsilon*dirtAmount + waterEpsilon; + color = color*(1.0-Translucent_Programs.a) + Translucent_Programs.rgb; + } - color *= vl.a; - - - // vec3 fogColor = clamp(gl_Fog.color.rgb*pow(luma(gl_Fog.color.rgb),-0.75)*0.65,0.0,1.0)*0.05; - - //cave fog if (isEyeInWater == 0){ - vec3 fogColor = clamp(gl_Fog.color.rgb,0.0,1.0) * 8. * (1.0-vl.a); + vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); + float fogdistfade = 1.0 - clamp( exp(-pow(length(fragpos / far),2.)*5.0) ,0.0,1.0); + bloomyfogmult = 1.0 - fogdistfade*0.5 ; - float fogdistfade = clamp(length(fragpos)/far, 0.0, 1.0); - - float fogfade = clamp(exp((1.0 - np3.y)*4 - 8),0.0,1.0); - - // float fog = 1.0 - clamp( exp2(-pow(length(fragpos / far),10.)*4.0) ,0.0,1.0); - - float fog = clamp( pow(length(fragpos / far),0.5) ,0.0,1.0); - - color.rgb = mix(color.rgb, fogColor * fogfade , fog ) ; - vl.a *= 1.0 - fogdistfade; + color.rgb = mix(color.rgb, gl_Fog.color.rgb*0.5*NetherFog_brightness, fogdistfade) ; } + + // color *= vl.a; + // color += vl.rgb; + // bloomyfogmult *= pow(vl.a,0.1); + + + // underwater fog if (isEyeInWater == 1){ - // color.rgb *= exp(-length(fragpos)/2*totEpsilon); - // vl.a *= (dot(exp(-length(fragpos)/1.2*totEpsilon),vec3(0.2,0.7,0.1)))*0.5+0.5; - - float fogfade = clamp(exp(-length(fragpos) /12 ) ,0.0,1.0); - float fogcolfade = clamp(exp(np3.y*1.5 - 1.5),0.0,1.0); - color.rgb *= fogfade; - color.rgb = color.rgb * (1.0 + vec3(0.0,0.1,0.2) * 12 * (1.0 - fogfade)) + (vec3(0.0,0.1,0.2) * 0.5 * (1.0 - fogfade))*fogcolfade; - - vl.a *= fogfade*0.75 +0.25; + vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); + float fogfade = clamp(exp(-length(fragpos) /5. ) ,0.0,1.0); + bloomyfogmult *= fogfade*0.70+0.3 ; } /// lava. if (isEyeInWater == 2){ @@ -185,21 +176,21 @@ void main() { } /// powdered snow if (isEyeInWater == 3){ + vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); color.rgb = mix(color.rgb,vec3(10,15,20),clamp(length(fragpos)*0.5,0.,1.)); - vl.a = 0.0; + bloomyfogmult = 0.0; } // blidnesss - color.rgb *= mix(1.0, clamp(1.5-pow(length(fragpos2)*(blindness*0.2),2.0),0.0,1.0), blindness); + if (blindness > 0.0){ + vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); + color.rgb *= mix(1.0,clamp( exp(pow(length(fragpos)*(blindness*0.2),2) * -5),0.,1.) , blindness); + } // darkness effect - color.rgb *= mix(1.0, (1.0-darknessLightFactor*2.0) * clamp(1.0-pow(length(fragpos2)*(darknessFactor*0.07),2.0),0.0,1.0), darknessFactor); + if(darknessFactor > 0.0){ + vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z2)); + color.rgb *= mix(1.0, (1.0-darknessLightFactor*2.0) * clamp(1.0-pow(length(fragpos)*(darknessFactor*0.07),2.0),0.0,1.0), darknessFactor); + } - - // float BiomeParams = isWastes + isWarpedForest + isCrimsonForest + isSoulValley + isBasaltDelta ; - - gl_FragData[0] = vec4(vl.a, 0.0, 0.0, 0.0); + gl_FragData[0].r = bloomyfogmult; gl_FragData[1].rgb = clamp(color,6.11*1e-5,65000.0); - - #ifdef display_LUT - gl_FragData[1].rgb = texture2D(colortex4,texcoord*0.45).rgb * 0.000035; - #endif } diff --git a/shaders/world-1/composite8.fsh b/shaders/world-1/composite8.fsh index dd85629..4348131 100644 --- a/shaders/world-1/composite8.fsh +++ b/shaders/world-1/composite8.fsh @@ -1,20 +1,8 @@ #version 120 //Temporal Anti-Aliasing + Dynamic exposure calculations (vertex shader) - #extension GL_EXT_gpu_shader4 : enable -#define TAA //if disabled you should increase most samples counts as I rely on TAA to filter noise - -//#define FAST_TAA //disables bicubic resampling and closest velocity, improves fps especially at high resolutions - -//TAA OPTIONS -//#define NO_CLIP //Removes all anti-ghosting techniques used and creates a sharp image (good for still screenshots) -#define BLEND_FACTOR 0.05 //[0.01 0.02 0.03 0.04 0.05 0.06 0.08 0.1 0.12 0.14 0.16] higher values = more flickering but sharper image, lower values = less flickering but the image will be blurrier -#define MOTION_REJECTION 0.5 //[0.0 0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4 0.5] //Higher values=sharper image in motion at the cost of flickering -#define ANTI_GHOSTING 1.0 //[0.0 0.25 0.5 0.75 1.0] High values reduce ghosting but may create flickering -#define FLICKER_REDUCTION 0.75 //[0.0 0.25 0.5 0.75 1.0] High values reduce flickering but may reduce sharpness -#define CLOSEST_VELOCITY //improves edge quality in motion at the cost of performance - +#include "/lib/settings.glsl" const int noiseTextureResolution = 32; @@ -48,12 +36,18 @@ uniform sampler2D depthtex0; uniform vec2 texelSize; uniform float frameTimeCounter; +uniform int framemod8; uniform float viewHeight; uniform float viewWidth; uniform vec3 previousCameraPosition; uniform mat4 gbufferPreviousModelView; + + + + #define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) -#include "lib/projections.glsl" + +#include "/lib/projections.glsl" float luma(vec3 color) { @@ -231,15 +225,54 @@ vec3 clip_aabb(vec3 q,vec3 aabb_min, vec3 aabb_max) vec3 toClipSpace3Prev(vec3 viewSpacePosition) { return projMAD(gbufferPreviousProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; } +vec3 tonemap(vec3 col){ + return col/(1+luma(col)); +} +vec3 invTonemap(vec3 col){ + return col/(1-luma(col)); +} +vec3 closestToCamera5taps(vec2 texcoord, sampler2D depth) +{ + vec2 du = vec2(texelSize.x*2., 0.0); + vec2 dv = vec2(0.0, texelSize.y*2.); + + vec3 dtl = vec3(texcoord,0.) + vec3(-texelSize, texture2D(depth, texcoord - dv - du).x); + vec3 dtr = vec3(texcoord,0.) + vec3( texelSize.x, -texelSize.y, texture2D(depth, texcoord - dv + du).x); + vec3 dmc = vec3(texcoord,0.) + vec3( 0.0, 0.0, texture2D(depth, texcoord).x); + vec3 dbl = vec3(texcoord,0.) + vec3(-texelSize.x, texelSize.y, texture2D(depth, texcoord + dv - du).x); + vec3 dbr = vec3(texcoord,0.) + vec3( texelSize.x, texelSize.y, texture2D(depth, texcoord + dv + du).x); + + vec3 dmin = dmc; + dmin = dmin.z > dtr.z? dtr : dmin; + dmin = dmin.z > dtl.z? dtl : dmin; + dmin = dmin.z > dbl.z? dbl : dmin; + dmin = dmin.z > dbr.z? dbr : dmin; + #ifdef TAA_UPSCALING + dmin.xy = dmin.xy/RENDER_SCALE; + #endif + return dmin; +} +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.); vec3 TAA_hq(){ + + vec2 adjTC = texcoord; + + //use velocity from the nearest texel from camera in a 3x3 box in order to improve edge quality in motion #ifdef CLOSEST_VELOCITY - vec3 closestToCamera = closestToCamera3x3(); + vec3 closestToCamera = closestToCamera5taps(adjTC, depthtex0); #endif #ifndef CLOSEST_VELOCITY - vec3 closestToCamera = vec3(texcoord,texture2D(depthtex0,texcoord).x); + vec3 closestToCamera = vec3(texcoord,texture2D(depthtex1,adjTC).x); #endif //reproject previous frame @@ -250,50 +283,53 @@ vec3 TAA_hq(){ vec2 velocity = previousPosition.xy - closestToCamera.xy; previousPosition.xy = texcoord + velocity; - //to reduce error propagation caused by interpolation during history resampling, we will introduce back some aliasing in motion - vec2 d = 0.5-abs(fract(previousPosition.xy*vec2(viewWidth,viewHeight)-texcoord*vec2(viewWidth,viewHeight))-0.5); - float mixFactor = dot(d,d); - float rej = mixFactor*MOTION_REJECTION; //reject history if off-screen and early exit - if (previousPosition.x < 0.0 || previousPosition.y < 0.0 || previousPosition.x > 1.0 || previousPosition.y > 1.0) return texture2D(colortex3, texcoord).rgb; + if (previousPosition.x < 0.0 || previousPosition.y < 0.0 || previousPosition.x > 1.0 || previousPosition.y > 1.0) + return smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).xyz; - //Samples current frame 3x3 neighboorhood - vec3 albedoCurrent0 = texture2D(colortex3, texcoord).rgb; - vec3 albedoCurrent1 = texture2D(colortex3, texcoord + vec2(texelSize.x,texelSize.y)).rgb; - vec3 albedoCurrent2 = texture2D(colortex3, texcoord + vec2(texelSize.x,-texelSize.y)).rgb; - vec3 albedoCurrent3 = texture2D(colortex3, texcoord + vec2(-texelSize.x,-texelSize.y)).rgb; - vec3 albedoCurrent4 = texture2D(colortex3, texcoord + vec2(-texelSize.x,texelSize.y)).rgb; - vec3 albedoCurrent5 = texture2D(colortex3, texcoord + vec2(0.0,texelSize.y)).rgb; - vec3 albedoCurrent6 = texture2D(colortex3, texcoord + vec2(0.0,-texelSize.y)).rgb; - vec3 albedoCurrent7 = texture2D(colortex3, texcoord + vec2(-texelSize.x,0.0)).rgb; - vec3 albedoCurrent8 = texture2D(colortex3, texcoord + vec2(texelSize.x,0.0)).rgb; - - #ifndef NO_CLIP + #ifdef TAA_UPSCALING + vec3 albedoCurrent0 = smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).xyz; + // Interpolating neighboorhood clampling boundaries between pixels + vec3 cMax = texture2D(colortex0, adjTC).rgb; + vec3 cMin = texture2D(colortex6, adjTC).rgb; + #else + vec3 albedoCurrent0 = texture2D(colortex3, adjTC).rgb; + vec3 albedoCurrent1 = texture2D(colortex3, adjTC + vec2(texelSize.x,texelSize.y)).rgb; + vec3 albedoCurrent2 = texture2D(colortex3, adjTC + vec2(texelSize.x,-texelSize.y)).rgb; + vec3 albedoCurrent3 = texture2D(colortex3, adjTC + vec2(-texelSize.x,-texelSize.y)).rgb; + vec3 albedoCurrent4 = texture2D(colortex3, adjTC + vec2(-texelSize.x,texelSize.y)).rgb; + vec3 albedoCurrent5 = texture2D(colortex3, adjTC + vec2(0.0,texelSize.y)).rgb; + vec3 albedoCurrent6 = texture2D(colortex3, adjTC + vec2(0.0,-texelSize.y)).rgb; + vec3 albedoCurrent7 = texture2D(colortex3, adjTC + vec2(-texelSize.x,0.0)).rgb; + vec3 albedoCurrent8 = texture2D(colortex3, adjTC + vec2(texelSize.x,0.0)).rgb; //Assuming the history color is a blend of the 3x3 neighborhood, we clamp the history to the min and max of each channel in the 3x3 neighborhood vec3 cMax = max(max(max(albedoCurrent0,albedoCurrent1),albedoCurrent2),max(albedoCurrent3,max(albedoCurrent4,max(albedoCurrent5,max(albedoCurrent6,max(albedoCurrent7,albedoCurrent8)))))); vec3 cMin = min(min(min(albedoCurrent0,albedoCurrent1),albedoCurrent2),min(albedoCurrent3,min(albedoCurrent4,min(albedoCurrent5,min(albedoCurrent6,min(albedoCurrent7,albedoCurrent8)))))); + albedoCurrent0 = smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).rgb; + #endif - - vec3 albedoPrev = FastCatmulRom(colortex5, previousPosition.xy,vec4(texelSize, 1.0/texelSize), 0.82).xyz; + #ifndef NO_CLIP + vec3 albedoPrev = max(FastCatmulRom(colortex5, previousPosition.xy,vec4(texelSize, 1.0/texelSize), 0.75).xyz, 0.0); vec3 finalcAcc = clamp(albedoPrev,cMin,cMax); + //Increases blending factor when far from AABB and in motion, reduces ghosting + float isclamped = distance(albedoPrev,finalcAcc)/luma(albedoPrev) * 0.5; + float movementRejection = (0.12+isclamped)*clamp(length(velocity/texelSize),0.0,1.0); + + float test = 0.05; + // if(hand) movementRejection *= 5; + // if(istranslucent) test = 0.1; - - //increases blending factor if history is far away from aabb, reduces ghosting at the cost of some flickering - float isclamped = distance(albedoPrev,finalcAcc)/luma(albedoPrev); - - //reduces blending factor if current texel is far from history, reduces flickering - float lumDiff2 = distance(albedoPrev,albedoCurrent0)/luma(albedoPrev); - lumDiff2 = 1.0-clamp(lumDiff2*lumDiff2,0.,1.)*FLICKER_REDUCTION; - - //Blend current pixel with clamped history - vec3 supersampled = mix(finalcAcc,albedoCurrent0,clamp(BLEND_FACTOR*lumDiff2+rej+isclamped*ANTI_GHOSTING+0.01,0.,1.)); + //Blend current pixel with clamped history, apply fast tonemap beforehand to reduce flickering + // vec3 supersampled = invTonemap(mix(tonemap(finalcAcc),tonemap(albedoCurrent0),clamp(BLEND_FACTOR + movementRejection, min(luma(motionVector) *255,1.0),1.))); + + vec3 supersampled = invTonemap(mix(tonemap(finalcAcc),tonemap(albedoCurrent0),clamp(BLEND_FACTOR + movementRejection, test,1.))); #endif #ifdef NO_CLIP - vec3 albedoPrev = texture2D(colortex5, previousPosition.xy).xyz; - vec3 supersampled = mix(albedoPrev,albedoCurrent0,clamp(0.05,0.,1.)); + vec3 albedoPrev = texture2D(colortex5, previousPosition.xy).xyz; + vec3 supersampled = mix(albedoPrev,albedoCurrent0,clamp(0.05,0.,1.)); #endif //De-tonemap @@ -303,14 +339,16 @@ vec3 TAA_hq(){ void main() { /* DRAWBUFFERS:5 */ -gl_FragData[0].a = 1.0; + gl_FragData[0].a = 1.0; + #ifdef TAA - vec3 color = TAA_hq(); - gl_FragData[0].rgb = clamp(fp10Dither(color,triangularize(interleaved_gradientNoise())),6.11*1e-5,65000.0); + vec3 color = TAA_hq(); + gl_FragData[0].rgb = clamp(fp10Dither(color,triangularize(interleaved_gradientNoise())),6.11*1e-5,65000.0); #endif + #ifndef TAA - vec3 color = clamp(fp10Dither(texture2D(colortex3,texcoord).rgb,triangularize(interleaved_gradientNoise())),0.,65000.); - gl_FragData[0].rgb = color; + vec3 color = clamp(fp10Dither(texture2D(colortex3,texcoord).rgb,triangularize(interleaved_gradientNoise())),0.,65000.); + gl_FragData[0].rgb = color; #endif diff --git a/shaders/world-1/composite8.vsh b/shaders/world-1/composite8.vsh index 24ef8ce..372c136 100644 --- a/shaders/world-1/composite8.vsh +++ b/shaders/world-1/composite8.vsh @@ -7,7 +7,10 @@ flat varying float exposureA; flat varying float tempOffsets; uniform sampler2D colortex4; uniform int frameCounter; + + #include "/lib/util.glsl" + void main() { tempOffsets = HaltonSeq2(frameCounter%10000); diff --git a/shaders/world-1/composite9.fsh b/shaders/world-1/composite9.fsh index 517bfe5..a4b6244 100644 --- a/shaders/world-1/composite9.fsh +++ b/shaders/world-1/composite9.fsh @@ -2,7 +2,6 @@ //downsample 1st pass (half res) for bloom uniform sampler2D colortex5; -uniform sampler2D colortex8; uniform vec2 texelSize; uniform float viewWidth; uniform float viewHeight; @@ -18,9 +17,6 @@ void main() { vec2 resScale = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))/vec2(1920.,1080.); vec2 quarterResTC = gl_FragCoord.xy*2.*resScale*texelSize; -float emissives = texture2D(colortex8,quarterResTC).a; -if(emissives == 1.0) emissives = 0.0; -emissives *= 5; //0.5 gl_FragData[0] = texture2D(colortex5,quarterResTC-1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; gl_FragData[0] += texture2D(colortex5,quarterResTC+1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; @@ -43,10 +39,6 @@ emissives *= 5; gl_FragData[0] += texture2D(colortex5,quarterResTC)*0.125; gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); - - // gl_FragData[0].rgb += gl_FragData[0].rgb*emissives; - - if (quarterResTC.x > 1.0 - 3.5*texelSize.x || quarterResTC.y > 1.0 -3.5*texelSize.y || quarterResTC.x < 3.5*texelSize.x || quarterResTC.y < 3.5*texelSize.y) gl_FragData[0].rgb = vec3(0.0); diff --git a/shaders/world-1/deferred.fsh b/shaders/world-1/deferred.fsh index 5745d9d..2b3c2e5 100644 --- a/shaders/world-1/deferred.fsh +++ b/shaders/world-1/deferred.fsh @@ -2,14 +2,7 @@ #extension GL_EXT_gpu_shader4 : enable -//Prepares sky textures (2 * 256 * 256), computes light values and custom lightmaps -#define Ambient_Mult 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0 5.0 6.0 10.0] -#define Sky_Brightness 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0 5.0 6.0 10.0] -#define MIN_LIGHT_AMOUNT 1.0 //[0.0 0.5 1.0 1.5 2.0 3.0 4.0 5.0] -#define TORCH_AMOUNT 1.0 //[0.0 0.5 0.75 1. 1.2 1.4 1.6 1.8 2.0] -#define TORCH_R 1.0 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define TORCH_G 0.75 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define TORCH_B 0.5 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] +#include "/lib/settings.glsl" flat varying vec3 ambientUp; @@ -53,8 +46,12 @@ uniform float sunElevation; uniform vec3 cameraPosition; uniform float far; uniform ivec2 eyeBrightnessSmooth; + + #include "/lib/util.glsl" #include "/lib/ROBOBO_sky.glsl" + + vec3 toShadowSpaceProjected(vec3 p3){ p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; p3 = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; @@ -75,62 +72,8 @@ const float[17] Slightmap = float[17](14.0,17.,19.0,22.0,24.0,28.0,31.0,40.0,60. void main() { /* DRAWBUFFERS:4 */ + gl_FragData[0] = vec4(0.0); -float minLight = MIN_LIGHT_AMOUNT * 0.007/ (exposure + rodExposure/(rodExposure+1.0)*exposure*1.); -vec3 minLight_col = MIN_LIGHT_AMOUNT * 0.007/ (exposure + rodExposure/(rodExposure+1.0)*exposure*1.) * vec3(0.8,0.9,1.0); -//Lightmap for forward shading (contains average integrated sky color across all faces + torch + min ambient) -vec3 avgAmbient = (ambientUp + ambientLeft + ambientRight + ambientB + ambientF + ambientDown)/6.; -if (gl_FragCoord.x < 17. && gl_FragCoord.y < 17.){ - float torchLut = clamp(16.0-gl_FragCoord.x,0.5,15.5); - torchLut = torchLut+0.712; - float torch_lightmap = max(1.0/torchLut/torchLut - 1/17.212/17.212,0.0); - torch_lightmap = pow(torch_lightmap*2.5,1.5)*TORCH_AMOUNT*10.; - float sky_lightmap = (Slightmap[int(gl_FragCoord.y)]-14.0)/235.; - sky_lightmap = pow(sky_lightmap,1.4); - vec3 ambient = avgAmbient*sky_lightmap+torch_lightmap*vec3(TORCH_R,TORCH_G,TORCH_B)*TORCH_AMOUNT; - - gl_FragData[0] = vec4(ambient*Ambient_Mult,1.0); -} - -//Lightmap for deferred shading (contains only torch + min ambient) -if (gl_FragCoord.x < 17. && gl_FragCoord.y > 19. && gl_FragCoord.y < 19.+17. ){ - float torchLut = clamp(16.0-gl_FragCoord.x,0.5,15.5); - torchLut = torchLut+0.712; - float torch_lightmap = max(1.0/torchLut/torchLut - 1/17.212/17.212,0.0); - float ambient = pow(torch_lightmap*2.5,1.5)*TORCH_AMOUNT*10.; - float sky_lightmap = (Slightmap[int(gl_FragCoord.y-19.0)]-14.0)/235./150.; - - gl_FragData[0] = vec4(sky_lightmap,ambient,minLight,1.0)*Ambient_Mult; -} - -//Save light values -if (gl_FragCoord.x < 1. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientUp,1.0); -if (gl_FragCoord.x > 1. && gl_FragCoord.x < 2. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientDown,1.0); -if (gl_FragCoord.x > 2. && gl_FragCoord.x < 3. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientLeft,1.0); -if (gl_FragCoord.x > 3. && gl_FragCoord.x < 4. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientRight,1.0); -if (gl_FragCoord.x > 4. && gl_FragCoord.x < 5. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientB,1.0); -if (gl_FragCoord.x > 5. && gl_FragCoord.x < 6. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientF,1.0); -if (gl_FragCoord.x > 6. && gl_FragCoord.x < 7. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(lightSourceColor,1.0); -if (gl_FragCoord.x > 7. && gl_FragCoord.x < 8. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(avgAmbient,1.0); - -//Sky gradient (no clouds) -const float pi = 3.141592653589793238462643383279502884197169; -if (gl_FragCoord.x > 18. && gl_FragCoord.y > 1. && gl_FragCoord.x < 18+257){ - gl_FragData[0] = vec4(vec3(1.0,0.4,0.12)*100.,1.0); -} - -//Temporally accumulate sky and light values -vec3 temp = texelFetch2D(colortex4,ivec2(gl_FragCoord.xy),0).rgb; -vec3 curr = gl_FragData[0].rgb*150.; -gl_FragData[0].rgb = clamp(mix(temp,curr,0.06),0.0,65000.); //Exposure values if (gl_FragCoord.x > 10. && gl_FragCoord.x < 11. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) diff --git a/shaders/world-1/deferred.vsh b/shaders/world-1/deferred.vsh index 2c5b20a..4fa6840 100644 --- a/shaders/world-1/deferred.vsh +++ b/shaders/world-1/deferred.vsh @@ -1,14 +1,8 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable -#define EXPOSURE_MULTIPLIER 1.0 //[0.25 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.1 1.2 1.3 1.4 1.5 2.0 3.0 4.0] -#define AUTO_EXPOSURE //Highly recommended to keep it on unless you want to take screenshots -#define Manual_exposure_value 1.0 // [0.000553 0.000581 0.000611 0.000642 0.000675 0.000710 0.000746 0.000784 0.000825 0.000867 0.000911 0.000958 0.001007 0.001059 0.001113 0.001170 0.001230 0.001294 0.001360 0.001430 0.001503 0.001580 0.001661 0.001746 0.001836 0.001930 0.002029 0.002133 0.002242 0.002357 0.002478 0.002605 0.002739 0.002879 0.003027 0.003182 0.003345 0.003517 0.003697 0.003887 0.004086 0.004296 0.004516 0.004748 0.004991 0.005247 0.005516 0.005799 0.006096 0.006409 0.006737 0.007083 0.007446 0.007828 0.008229 0.008651 0.009095 0.009561 0.010051 0.010567 0.011108 0.011678 0.012277 0.012906 0.013568 0.014264 0.014995 0.015764 0.016572 0.017422 0.018315 0.019254 0.020241 0.021279 0.022370 0.023517 0.024723 0.025991 0.027323 0.028724 0.030197 0.031745 0.033373 0.035084 0.036883 0.038774 0.040762 0.042852 0.045049 0.047358 0.049787 0.052339 0.055023 0.057844 0.060810 0.063927 0.067205 0.070651 0.074273 0.078081 0.082084 0.086293 0.090717 0.095369 0.100258 0.105399 0.110803 0.116484 0.122456 0.128734 0.135335 0.142274 0.149568 0.157237 0.165298 0.173773 0.182683 0.192049 0.201896 0.212247 0.223130 0.234570 0.246596 0.259240 0.272531 0.286504 0.301194 0.316636 0.332871 0.349937 0.367879 0.386741 0.406569 0.427414 0.449328 0.472366 0.496585 0.522045 0.548811 0.576949 0.606530 0.637628 0.670320 0.704688 0.740818 0.778800 0.818730 0.860707 0.904837 0.951229 1.0 1.051271 1.105170 1.161834 1.221402 1.284025 1.349858 1.419067 1.491824 1.568312 1.648721 1.733253 1.822118 1.915540 2.013752 2.117000 2.225540 2.339646 2.459603 2.585709 2.718281 2.857651 3.004166 3.158192 3.320116 3.490342 3.669296 3.857425 4.055199 4.263114 4.481689 4.711470 4.953032 5.206979 5.473947 5.754602 6.049647 6.359819 6.685894 7.028687 7.389056 7.767901 8.166169 8.584858 9.025013 9.487735 9.974182 10.48556 11.02317 11.58834 12.18249 ] -#define Exposure_Speed 1.0 //[0.25 0.5 0.75 1.0 1.25 1.5 1.75 2.0 2.25 2.5 2.75 3.0 4.0 5.0] -#define CLOUDS_SHADOWS -#define BASE_FOG_AMOUNT 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0 10.0 20.0 30.0 50.0 100.0 150.0 200.0] Base fog amount amount (does not change the "cloudy" fog) -#define CLOUDY_FOG_AMOUNT 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0] -#define FOG_TOD_MULTIPLIER 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0] //Influence of time of day on fog amount -#define FOG_RAIN_MULTIPLIER 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0] //Influence of rain on fog amount + +#include "/lib/settings.glsl" + flat varying vec3 ambientUp; flat varying vec3 ambientLeft; flat varying vec3 ambientRight; @@ -47,9 +41,11 @@ vec3 sunVec = vec3(0.0,1.0,0.0); -#include "lib/sky_gradient.glsl" +#include "/lib/sky_gradient.glsl" #include "/lib/util.glsl" #include "/lib/ROBOBO_sky.glsl" + + vec3 rodSample(vec2 Xi) { float r = sqrt(1.0f - Xi.x*Xi.y); @@ -100,107 +96,101 @@ void main() { gl_Position.xy = gl_Position.xy*vec2(18.+258*2,258.)*texelSize; gl_Position.xy = gl_Position.xy*2.-1.0; - tempOffsets = R2_samples(frameCounter%10000); +// tempOffsets = R2_samples(frameCounter%10000); - ambientUp = vec3(0.0); - ambientDown = vec3(0.0); - ambientLeft = vec3(0.0); - ambientRight = vec3(0.0); - ambientB = vec3(0.0); - ambientF = vec3(0.0); - avgSky = vec3(0.0); +// ambientUp = vec3(0.0); +// ambientDown = vec3(0.0); +// ambientLeft = vec3(0.0); +// ambientRight = vec3(0.0); +// ambientB = vec3(0.0); +// ambientF = vec3(0.0); +// avgSky = vec3(0.0); - //Fake bounced sunlight - vec3 bouncedSun = clamp(gl_Fog.color.rgb*pow(luma(gl_Fog.color.rgb),-0.75)*0.65,0.0,1.0)/4000.*0.08; - ambientUp += bouncedSun*clamp(-sunVec.y+5.,0.,6.0); - ambientLeft += bouncedSun*clamp(sunVec.x+5.,0.0,6.); - ambientRight += bouncedSun*clamp(-sunVec.x+5.,0.0,6.); - ambientB += bouncedSun*clamp(-sunVec.z+5.,0.0,6.); - ambientF += bouncedSun*clamp(sunVec.z+5.,0.0,6.); - ambientDown += bouncedSun*clamp(sunVec.y+5.,0.0,6.); +// //Fake bounced sunlight +// vec3 bouncedSun = clamp(gl_Fog.color.rgb*pow(luma(gl_Fog.color.rgb),-0.75)*0.65,0.0,1.0)/4000.*0.08; +// ambientUp += bouncedSun*clamp(-sunVec.y+5.,0.,6.0); +// ambientLeft += bouncedSun*clamp(sunVec.x+5.,0.0,6.); +// ambientRight += bouncedSun*clamp(-sunVec.x+5.,0.0,6.); +// ambientB += bouncedSun*clamp(-sunVec.z+5.,0.0,6.); +// ambientF += bouncedSun*clamp(sunVec.z+5.,0.0,6.); +// ambientDown += bouncedSun*clamp(sunVec.y+5.,0.0,6.); - float avgLuma = 0.0; - float m2 = 0.0; - int n=100; - vec2 clampedRes = max(1.0/texelSize,vec2(1920.0,1080.)); - float avgExp = 0.0; - vec2 resScale = vec2(1920.,1080.)/clampedRes; - float v[25]; - float temp; - // 5x5 Median filter by morgan mcguire - // We take the median value of the most blurred bloom buffer - #define s2(a, b) temp = a; a = min(a, b); b = max(temp, b); - #define t2(a, b) s2(v[a], v[b]); - #define t24(a, b, c, d, e, f, g, h) t2(a, b); t2(c, d); t2(e, f); t2(g, h); - #define t25(a, b, c, d, e, f, g, h, i, j) t24(a, b, c, d, e, f, g, h); t2(i, j); - for (int i = 0; i < 5; i++){ - for (int j = 0; j < 5; j++){ - vec2 tc = 0.5 + vec2(i-2,j-2)/2.0 * 0.35; - v[i+j*5] = luma(texture2D(colortex6,tc/128. * resScale+vec2(0.484375*resScale.x+10.5*texelSize.x,.0)).rgb); - } - } - t25(0, 1, 3, 4, 2, 4, 2, 3, 6, 7); - t25(5, 7, 5, 6, 9, 7, 1, 7, 1, 4); - t25(12, 13, 11, 13, 11, 12, 15, 16, 14, 16); - t25(14, 15, 18, 19, 17, 19, 17, 18, 21, 22); - t25(20, 22, 20, 21, 23, 24, 2, 5, 3, 6); - t25(0, 6, 0, 3, 4, 7, 1, 7, 1, 4); - t25(11, 14, 8, 14, 8, 11, 12, 15, 9, 15); - t25(9, 12, 13, 16, 10, 16, 10, 13, 20, 23); - t25(17, 23, 17, 20, 21, 24, 18, 24, 18, 21); - t25(19, 22, 8, 17, 9, 18, 0, 18, 0, 9); - t25(10, 19, 1, 19, 1, 10, 11, 20, 2, 20); - t25(2, 11, 12, 21, 3, 21, 3, 12, 13, 22); - t25(4, 22, 4, 13, 14, 23, 5, 23, 5, 14); - t25(15, 24, 6, 24, 6, 15, 7, 16, 7, 19); - t25(3, 11, 5, 17, 11, 17, 9, 17, 4, 10); - t25(6, 12, 7, 14, 4, 6, 4, 7, 12, 14); - t25(10, 14, 6, 7, 10, 12, 6, 10, 6, 17); - t25(12, 17, 7, 17, 7, 10, 12, 18, 7, 12); - t24(10, 18, 12, 20, 10, 20, 10, 12); - avgExp = v[12]; // Median value +// float avgLuma = 0.0; +// float m2 = 0.0; +// int n=100; +// vec2 clampedRes = max(1.0/texelSize,vec2(1920.0,1080.)); +// float avgExp = 0.0; +// vec2 resScale = vec2(1920.,1080.)/clampedRes; +// float v[25]; +// float temp; +// // 5x5 Median filter by morgan mcguire +// // We take the median value of the most blurred bloom buffer +// #define s2(a, b) temp = a; a = min(a, b); b = max(temp, b); +// #define t2(a, b) s2(v[a], v[b]); +// #define t24(a, b, c, d, e, f, g, h) t2(a, b); t2(c, d); t2(e, f); t2(g, h); +// #define t25(a, b, c, d, e, f, g, h, i, j) t24(a, b, c, d, e, f, g, h); t2(i, j); +// for (int i = 0; i < 5; i++){ +// for (int j = 0; j < 5; j++){ +// vec2 tc = 0.5 + vec2(i-2,j-2)/2.0 * 0.35; +// v[i+j*5] = luma(texture2D(colortex6,tc/128. * resScale+vec2(0.484375*resScale.x+10.5*texelSize.x,.0)).rgb); +// } +// } +// t25(0, 1, 3, 4, 2, 4, 2, 3, 6, 7); +// t25(5, 7, 5, 6, 9, 7, 1, 7, 1, 4); +// t25(12, 13, 11, 13, 11, 12, 15, 16, 14, 16); +// t25(14, 15, 18, 19, 17, 19, 17, 18, 21, 22); +// t25(20, 22, 20, 21, 23, 24, 2, 5, 3, 6); +// t25(0, 6, 0, 3, 4, 7, 1, 7, 1, 4); +// t25(11, 14, 8, 14, 8, 11, 12, 15, 9, 15); +// t25(9, 12, 13, 16, 10, 16, 10, 13, 20, 23); +// t25(17, 23, 17, 20, 21, 24, 18, 24, 18, 21); +// t25(19, 22, 8, 17, 9, 18, 0, 18, 0, 9); +// t25(10, 19, 1, 19, 1, 10, 11, 20, 2, 20); +// t25(2, 11, 12, 21, 3, 21, 3, 12, 13, 22); +// t25(4, 22, 4, 13, 14, 23, 5, 23, 5, 14); +// t25(15, 24, 6, 24, 6, 15, 7, 16, 7, 19); +// t25(3, 11, 5, 17, 11, 17, 9, 17, 4, 10); +// t25(6, 12, 7, 14, 4, 6, 4, 7, 12, 14); +// t25(10, 14, 6, 7, 10, 12, 6, 10, 6, 17); +// t25(12, 17, 7, 17, 7, 10, 12, 18, 7, 12); +// t24(10, 18, 12, 20, 10, 20, 10, 12); +// avgExp = v[12]; // Median value - avgBrightness = clamp(mix(avgExp,texelFetch2D(colortex4,ivec2(10,37),0).g,0.95),0.00003051757,65000.0); +// avgBrightness = clamp(mix(avgExp,texelFetch2D(colortex4,ivec2(10,37),0).g,0.95),0.00003051757,65000.0); - float currentExposure = texelFetch2D(colortex4,ivec2(10,37),0).b; - float L = max(avgBrightness,1e-8); - float keyVal = 1.03-2.0/(log(L+1.0)/log(10.0)+2.0); - float targetExposure = 1.0*keyVal/L; +// float currentExposure = texelFetch2D(colortex4,ivec2(10,37),0).b; +// float L = max(avgBrightness,1e-8); +// float keyVal = 1.03-2.0/(log(L+1.0)/log(10.0)+2.0); +// float targetExposure = 1.0*keyVal/L; - float targetrodExposure = clamp(log(targetExposure*2.0+1.0)-0.1,0.0,2.0); - float currentrodExposure = texelFetch2D(colortex4,ivec2(14,37),0).r; +// float targetrodExposure = clamp(log(targetExposure*2.0+1.0)-0.1,0.0,2.0); +// float currentrodExposure = texelFetch2D(colortex4,ivec2(14,37),0).r; - targetExposure = clamp(targetExposure,2.0,3.0); - float rad = sqrt(currentExposure); - float rtarget = sqrt(targetExposure); - float dir = sign(rtarget-rad); - float dist = abs(rtarget-rad); - float maxApertureChange = 0.0032*frameTime/0.016666*(Exposure_Speed*2) * exp2(max(rad,rtarget)*0.5); +// targetExposure = clamp(targetExposure,2.0,3.0); +// float rad = sqrt(currentExposure); +// float rtarget = sqrt(targetExposure); +// float dir = sign(rtarget-rad); +// float dist = abs(rtarget-rad); +// float maxApertureChange = 0.0032*frameTime/0.016666*Exposure_Speed * exp2(max(rad,rtarget)*0.5); - maxApertureChange *= 1.0+nightVision*4.; - rad = rad+dir*min(dist,maxApertureChange); +// maxApertureChange *= 1.0+nightVision*4.; +// rad = rad+dir*min(dist,maxApertureChange); - exposureF = rad*rad; - exposure=exposureF*EXPOSURE_MULTIPLIER; +// exposureF = rad*rad; +// exposure=exposureF*EXPOSURE_MULTIPLIER; - dir = sign(targetrodExposure-currentrodExposure); - dist = abs(targetrodExposure-currentrodExposure); - maxApertureChange = 0.0032*frameTime/0.016666*(Exposure_Speed*2) * exp2(max(rad,rtarget)*0.5); +// dir = sign(targetrodExposure-currentrodExposure); +// dist = abs(targetrodExposure-currentrodExposure); +// maxApertureChange = 0.0032*frameTime/0.016666*Exposure_Speed * exp2(max(rad,rtarget)*0.5); - rodExposure = currentrodExposure + dir * min(dist,maxApertureChange); +// rodExposure = currentrodExposure + dir * min(dist,maxApertureChange); - #ifndef AUTO_EXPOSURE - exposure = Manual_exposure_value; - rodExposure = clamp(log(Manual_exposure_value*2.0+1.0)-0.1,0.0,2.0); - #endif - float modWT = (worldTime%24000)*1.0; + exposure = 1.0; + rodExposure = clamp(log(1.0*2.0+1.0)-0.1,0.0,2.0); - float fogAmount0 = 1/3000.+FOG_TOD_MULTIPLIER*(1/180.*(clamp(modWT-11000.,0.,2000.0)/2000.+(1.0-clamp(modWT,0.,3000.0)/3000.))*(clamp(modWT-11000.,0.,2000.0)/2000.+(1.0-clamp(modWT,0.,3000.0)/3000.)) + 1/200.*clamp(modWT-13000.,0.,1000.0)/1000.*(1.0-clamp(modWT-23000.,0.,1000.0)/1000.)); - VFAmount = CLOUDY_FOG_AMOUNT*(fogAmount0*fogAmount0+FOG_RAIN_MULTIPLIER*1.8/20000.*rainStrength); - fogAmount = BASE_FOG_AMOUNT*(fogAmount0+max(FOG_RAIN_MULTIPLIER*1/15.*rainStrength , FOG_TOD_MULTIPLIER*1/50.*clamp(modWT-13000.,0.,1000.0)/1000.*(1.0-clamp(modWT-23000.,0.,1000.0)/1000.))); } diff --git a/shaders/world-1/deferred2.fsh b/shaders/world-1/deferred2.fsh new file mode 100644 index 0000000..f59c069 --- /dev/null +++ b/shaders/world-1/deferred2.fsh @@ -0,0 +1,30 @@ +#version 120 +#extension GL_EXT_gpu_shader4 : enable +#include "/lib/settings.glsl" + +uniform sampler2D colortex4; +uniform sampler2D depthtex1; + +uniform float near; +uniform float far; + + +float linZ(float depth) { + return (2.0 * near) / (far + near - depth * (far - near)); +} +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// + +void main() { +/* DRAWBUFFERS:4 */ + vec3 oldTex = texelFetch2D(colortex4, ivec2(gl_FragCoord.xy), 0).xyz; + float newTex = texelFetch2D(depthtex1, ivec2(gl_FragCoord.xy*4), 0).x; + + if (newTex < 1.0) + gl_FragData[0] = vec4(oldTex, linZ(newTex)*linZ(newTex)*65000.0); + else + gl_FragData[0] = vec4(oldTex, 2.0); +} diff --git a/shaders/world-1/deferred2.vsh b/shaders/world-1/deferred2.vsh new file mode 100644 index 0000000..8f06db4 --- /dev/null +++ b/shaders/world-1/deferred2.vsh @@ -0,0 +1,11 @@ +#version 120 +#extension GL_EXT_gpu_shader4 : enable +#include "/lib/settings.glsl" + +uniform vec2 texelSize; +#include "/lib/res_params.glsl" +void main() { + gl_Position = ftransform(); + vec2 scaleRatio = max(vec2(0.25), vec2(18.+258*2,258.)*texelSize); + gl_Position.xy = (gl_Position.xy*0.5+0.5)*clamp(scaleRatio+0.01,0.0,1.0)*2.0-1.0; +} diff --git a/shaders/world-1/final.fsh b/shaders/world-1/final.fsh index 2388d11..90041c9 100644 --- a/shaders/world-1/final.fsh +++ b/shaders/world-1/final.fsh @@ -1,11 +1,10 @@ #version 120 //Vignetting, applies bloom, applies exposure and tonemaps the final image #extension GL_EXT_gpu_shader4 : enable -//#define BICUBIC_UPSCALING //Provides a better interpolation when using a render quality different of 1.0, slower -#define CONTRAST_ADAPTATIVE_SHARPENING -#define SHARPENING 0.35 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define SATURATION 0.00 // Negative values desaturates colors, Positive values saturates color, 0 is no change [-1.0 -0.98 -0.96 -0.94 -0.92 -0.9 -0.88 -0.86 -0.84 -0.82 -0.8 -0.78 -0.76 -0.74 -0.72 -0.7 -0.68 -0.66 -0.64 -0.62 -0.6 -0.58 -0.56 -0.54 -0.52 -0.5 -0.48 -0.46 -0.44 -0.42 -0.4 -0.38 -0.36 -0.34 -0.32 -0.3 -0.28 -0.26 -0.24 -0.22 -0.2 -0.18 -0.16 -0.14 -0.12 -0.1 -0.08 -0.06 -0.04 -0.02 0.0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2 0.22 0.24 0.26 0.28 0.3 0.32 0.34 0.36 0.38 0.4 0.42 0.44 0.46 0.48 0.5 0.52 0.54 0.56 0.58 0.6 0.62 0.64 0.66 0.68 0.7 0.72 0.74 0.76 0.78 0.8 0.82 0.84 0.86 0.88 0.9 0.92 0.94 0.96 0.98 1.0 ] -#define CROSSTALK 0.0 // Desaturates bright colors and preserves saturation in darker areas (inverted if negative). Helps avoiding almsost fluorescent colors [-1.0 -0.98 -0.96 -0.94 -0.92 -0.9 -0.88 -0.86 -0.84 -0.82 -0.8 -0.78 -0.76 -0.74 -0.72 -0.7 -0.68 -0.66 -0.64 -0.62 -0.6 -0.58 -0.56 -0.54 -0.52 -0.5 -0.48 -0.46 -0.44 -0.42 -0.4 -0.38 -0.36 -0.34 -0.32 -0.3 -0.28 -0.26 -0.24 -0.22 -0.2 -0.18 -0.16 -0.14 -0.12 -0.1 -0.08 -0.06 -0.04 -0.02 0.0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2 0.22 0.24 0.26 0.28 0.3 0.32 0.34 0.36 0.38 0.4 0.42 0.44 0.46 0.48 0.5 0.52 0.54 0.56 0.58 0.6 0.62 0.64 0.66 0.68 0.7 0.72 0.74 0.76 0.78 0.8 0.82 0.84 0.86 0.88 0.9 0.92 0.94 0.96 0.98 1.0 ] + +#include "/lib/settings.glsl" + + varying vec2 texcoord; uniform sampler2D colortex7; @@ -15,9 +14,11 @@ uniform float viewHeight; uniform float frameTimeCounter; uniform int frameCounter; uniform int isEyeInWater; -#include "lib/color_transforms.glsl" -#include "lib/color_dither.glsl" + +#include "/lib/color_transforms.glsl" +#include "/lib/color_dither.glsl" #include "/lib/res_params.glsl" + vec4 SampleTextureCatmullRom(sampler2D tex, vec2 uv, vec2 texSize ) { // We're going to sample a a 4x4 grid of texels surrounding the target UV coordinate. We'll do this by rounding diff --git a/shaders/world-1/final.vsh b/shaders/world-1/final.vsh index 7aeb51b..88b6076 100644 --- a/shaders/world-1/final.vsh +++ b/shaders/world-1/final.vsh @@ -1,9 +1,7 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable -#define FinalR 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] -#define FinalG 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] -#define FinalB 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] +#include "/lib/settings.glsl" varying vec2 texcoord; flat varying vec4 exposure; diff --git a/shaders/world-1/gbuffers_all_solid.vsh b/shaders/world-1/gbuffers_all_solid.vsh deleted file mode 100644 index 8cc9567..0000000 --- a/shaders/world-1/gbuffers_all_solid.vsh +++ /dev/null @@ -1,213 +0,0 @@ -#extension GL_EXT_gpu_shader4 : enable -#include "/lib/res_params.glsl" -#define WAVY_PLANTS -#define WAVY_STRENGTH 1.0 //[0.1 0.25 0.5 0.75 1.0 1.25 1.5 1.75 2.0] -#define WAVY_SPEED 1.0 //[0.001 0.01 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 1.0 1.25 1.5 2.0 3.0 4.0] -#define SEPARATE_AO -//#define POM -//#define USE_LUMINANCE_AS_HEIGHTMAP //Can generate POM on any texturepack (may look weird in some cases) -// #define RTAO // I recommend turning ambientOcclusionLevel to zero with this on. like ssao, but rt, nicer, noiser, and slower. SSAO will turn OFF when this is ON -#define indirect_effect 1 // Choose what effect is applied to indirect light. [0 1 2 3] - -#define Variable_Penumbra_Shadows //Makes the shadows more blurry the more distant they are to objects (costs fps) -#define mob_SSS - -#ifndef USE_LUMINANCE_AS_HEIGHTMAP -#ifndef MC_NORMAL_MAP -#undef POM -#endif -#endif - -#ifdef POM -#define MC_NORMAL_MAP -#endif - -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -#ifdef POM -varying vec4 vtexcoordam; // .st for add, .pq for mul -varying vec4 vtexcoord; -#endif - -#ifdef MC_NORMAL_MAP - varying vec4 tangent; - attribute vec4 at_tangent; -#endif - -out vec3 test_motionVectors; -in vec3 at_velocity; - -uniform float frameTimeCounter; -const float PI48 = 150.796447372*WAVY_SPEED; -float pi2wt = PI48*frameTimeCounter; -attribute vec4 mc_Entity; -uniform int blockEntityId; -uniform int entityId; -varying vec4 materialMask; -flat varying vec4 TESTMASK; -flat varying int lightningBolt; - -uniform mat4 gbufferModelView; -uniform mat4 gbufferModelViewInverse; -attribute vec4 mc_midTexCoord; -uniform vec3 cameraPosition; -uniform vec2 texelSize; -uniform int framemod8; -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.); -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -vec4 toClipSpace3(vec3 viewSpacePosition) { - return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); -} - -vec2 calcWave(in vec3 pos) { - - float magnitude = abs(sin(dot(vec4(frameTimeCounter, pos),vec4(1.0,0.005,0.005,0.005)))*0.5+0.72)*0.013; - vec2 ret = (sin(pi2wt*vec2(0.0063,0.0015)*4. - pos.xz + pos.y*0.05)+0.1)*magnitude; - - return ret; -} - -vec3 calcMovePlants(in vec3 pos) { - vec2 move1 = calcWave(pos ); - float move1y = -length(move1); - return vec3(move1.x,move1y,move1.y)*5.*WAVY_STRENGTH; -} - -vec3 calcWaveLeaves(in vec3 pos, in float fm, in float mm, in float ma, in float f0, in float f1, in float f2, in float f3, in float f4, in float f5) { - - float magnitude = abs(sin(dot(vec4(frameTimeCounter, pos),vec4(1.0,0.005,0.005,0.005)))*0.5+0.72)*0.013; - vec3 ret = (sin(pi2wt*vec3(0.0063,0.0224,0.0015)*1.5 - pos))*magnitude; - - return ret; -} - -vec3 calcMoveLeaves(in vec3 pos, in float f0, in float f1, in float f2, in float f3, in float f4, in float f5, in vec3 amp1, in vec3 amp2) { - vec3 move1 = calcWaveLeaves(pos , 0.0054, 0.0400, 0.0400, 0.0127, 0.0089, 0.0114, 0.0063, 0.0224, 0.0015) * amp1; - return move1*5.*WAVY_STRENGTH; -} -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - - TESTMASK = vec4(normalize(gl_NormalMatrix * gl_Normal), 1.0); - - TESTMASK.r = blockEntityId == 222 ? 255 : TESTMASK.r; - - - #ifdef ENTITIES - test_motionVectors = at_velocity; - #endif - - #ifdef POM - vec2 midcoord = (gl_TextureMatrix[0] * mc_midTexCoord).st; - vec2 texcoordminusmid = lmtexcoord.xy-midcoord; - vtexcoordam.pq = abs(texcoordminusmid)*2; - vtexcoordam.st = min(lmtexcoord.xy,midcoord-texcoordminusmid); - vtexcoord.xy = sign(texcoordminusmid)*0.5+0.5; - #endif - - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; - color = gl_Color; - bool istopv = gl_MultiTexCoord0.t < mc_midTexCoord.t; - - #ifdef MC_NORMAL_MAP - tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); - #endif - - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal), 1.0); - -#ifdef ENTITIES - - #ifdef mob_SSS - #ifdef Variable_Penumbra_Shadows - normalMat.a = entityId == 1100 ? 1.0 : normalMat.a; - normalMat.a = entityId == 1200 ? 1.0 : normalMat.a; - normalMat.a = entityId == 1400 ? 1.0 : normalMat.a; - #endif - #endif - - - gl_Position = ftransform(); - -#endif - - - -#ifdef WORLD - - - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),mc_Entity.x == 10004 || mc_Entity.x == 10003 ? 0.5 : mc_Entity.x == 10001 ? 0.6 : 1.0); - normalMat.a = (mc_Entity.x == 10006 || mc_Entity == 100061) ? 0.6 : normalMat.a; - normalMat.a = (mc_Entity.x == 10007 || mc_Entity.x == 10008) ? 0.55 : normalMat.a; - - normalMat.a = mc_Entity.x == 10005 ? 0.8 : normalMat.a; - normalMat.a = mc_Entity.x == 99 ? 0.65 : normalMat.a; - - - #ifdef WAVY_PLANTS - if ((mc_Entity.x == 10001 && istopv) && abs(position.z) < 64.0) { - vec3 worldpos = mat3(gbufferModelViewInverse) * position + gbufferModelViewInverse[3].xyz + cameraPosition; - worldpos.xyz += calcMovePlants(worldpos.xyz)*lmtexcoord.w - cameraPosition; - position = mat3(gbufferModelView) * worldpos + gbufferModelView[3].xyz; - } - - if (mc_Entity.x == 10003 && abs(position.z) < 64.0) { - vec3 worldpos = mat3(gbufferModelViewInverse) * position + gbufferModelViewInverse[3].xyz + cameraPosition; - worldpos.xyz += calcMoveLeaves(worldpos.xyz, 0.0040, 0.0064, 0.0043, 0.0035, 0.0037, 0.0041, vec3(1.0,0.2,1.0), vec3(0.5,0.1,0.5))*lmtexcoord.w - cameraPosition; - position = mat3(gbufferModelView) * worldpos + gbufferModelView[3].xyz; - } - #endif - - if (mc_Entity.x == 100 ){ - color.rgb = normalize(color.rgb)*sqrt(3.0); - normalMat.a = 0.9; - } - - gl_Position = toClipSpace3(position); - - if (color.a < 0.3) color.a = 1.0; - - - #ifdef SEPARATE_AO - - #if indirect_effect == 1 || indirect_effect == 0 - lmtexcoord.zw *= sqrt(color.a); - #endif - - #else - color.rgb *= color.a; - #endif - -#endif - - - #ifdef TAA_UPSCALING - gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; - #endif - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w * texelSize; - #endif -} diff --git a/shaders/world-1/gbuffers_all_translucent.fsh b/shaders/world-1/gbuffers_all_translucent.fsh deleted file mode 100644 index d89e204..0000000 --- a/shaders/world-1/gbuffers_all_translucent.fsh +++ /dev/null @@ -1,624 +0,0 @@ -// #version 120 -#extension GL_EXT_gpu_shader4 : enable - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -varying vec3 binormal; -uniform sampler2D normals; -varying vec3 tangent; -varying vec4 tangent_other; -varying vec3 viewVector; -varying float dist; -#include "/lib/res_params.glsl" - -#define CLOUDS_SHADOWS -#define VL_CLOUDS_SHADOWS // Casts shadows from clouds on VL (slow) -#define SCREENSPACE_REFLECTIONS //can be really expensive at high resolutions/render quality, especially on ice -#define SSR_STEPS 30 //[10 15 20 25 30 35 40 50 100 200 400] -#define SUN_MICROFACET_SPECULAR // If enabled will use realistic rough microfacet model, else will just reflect the sun. No performance impact. -#define USE_QUARTER_RES_DEPTH // Uses a quarter resolution depth buffer to raymarch screen space reflections, improves performance but may introduce artifacts -#define saturate(x) clamp(x,0.0,1.0) -#define Dirt_Amount 0.14 //How much dirt there is in water [0.0 0.04 0.08 0.12 0.16 0.2 0.24 0.28 0.32 0.36 0.4 0.44 0.48 0.52 0.56 0.6 0.64 0.68 0.72 0.76 0.8 0.84 0.88 0.92 0.96 1.0 1.04 1.08 1.12 1.16 1.2 1.24 1.28 1.32 1.36 1.4 1.44 1.48 1.52 1.56 1.6 1.64 1.68 1.72 1.76 1.8 1.84 1.88 1.92 1.96 2.0 ] - -#define Dirt_Scatter_R 0.6 //How much dirt diffuses red [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 ] -#define Dirt_Scatter_G 0.6 //How much dirt diffuses green [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 ] -#define Dirt_Scatter_B 0.6 //How much dirt diffuses blue [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 ] - -#define Dirt_Absorb_R 1.65 //How much dirt absorbs red [0.0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2 0.22 0.24 0.26 0.28 0.3 0.32 0.34 0.36 0.38 0.4 0.42 0.44 0.46 0.48 0.5 0.52 0.54 0.56 0.58 0.6 0.62 0.64 0.66 0.68 0.7 0.72 0.74 0.76 0.78 0.8 0.82 0.84 0.86 0.88 0.9 0.92 0.94 0.96 0.98 1.0 1.02 1.04 1.06 1.08 1.1 1.12 1.14 1.16 1.18 1.2 1.22 1.24 1.26 1.28 1.3 1.32 1.34 1.36 1.38 1.4 1.42 1.44 1.46 1.48 1.5 1.52 1.54 1.56 1.58 1.6 1.62 1.64 1.66 1.68 1.7 1.72 1.74 1.76 1.78 1.8 1.82 1.84 1.86 1.88 1.9 1.92 1.94 1.96 1.98 2.0 ] -#define Dirt_Absorb_G 1.85 //How much dirt absorbs green [0.0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2 0.22 0.24 0.26 0.28 0.3 0.32 0.34 0.36 0.38 0.4 0.42 0.44 0.46 0.48 0.5 0.52 0.54 0.56 0.58 0.6 0.62 0.64 0.66 0.68 0.7 0.72 0.74 0.76 0.78 0.8 0.82 0.84 0.86 0.88 0.9 0.92 0.94 0.96 0.98 1.0 1.02 1.04 1.06 1.08 1.1 1.12 1.14 1.16 1.18 1.2 1.22 1.24 1.26 1.28 1.3 1.32 1.34 1.36 1.38 1.4 1.42 1.44 1.46 1.48 1.5 1.52 1.54 1.56 1.58 1.6 1.62 1.64 1.66 1.68 1.7 1.72 1.74 1.76 1.78 1.8 1.82 1.84 1.86 1.88 1.9 1.92 1.94 1.96 1.98 2.0 ] -#define Dirt_Absorb_B 2.05 //How much dirt absorbs blue [0.0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2 0.22 0.24 0.26 0.28 0.3 0.32 0.34 0.36 0.38 0.4 0.42 0.44 0.46 0.48 0.5 0.52 0.54 0.56 0.58 0.6 0.62 0.64 0.66 0.68 0.7 0.72 0.74 0.76 0.78 0.8 0.82 0.84 0.86 0.88 0.9 0.92 0.94 0.96 0.98 1.0 1.02 1.04 1.06 1.08 1.1 1.12 1.14 1.16 1.18 1.2 1.22 1.24 1.26 1.28 1.3 1.32 1.34 1.36 1.38 1.4 1.42 1.44 1.46 1.48 1.5 1.52 1.54 1.56 1.58 1.6 1.62 1.64 1.66 1.68 1.7 1.72 1.74 1.76 1.78 1.8 1.82 1.84 1.86 1.88 1.9 1.92 1.94 1.96 1.98 2.0 ] - -#define Water_Absorb_R 0.2629 //How much water absorbs red [0.0 0.0025 0.005 0.0075 0.01 0.0125 0.015 0.0175 0.02 0.0225 0.025 0.0275 0.03 0.0325 0.035 0.0375 0.04 0.0425 0.045 0.0475 0.05 0.0525 0.055 0.0575 0.06 0.0625 0.065 0.0675 0.07 0.0725 0.075 0.0775 0.08 0.0825 0.085 0.0875 0.09 0.0925 0.095 0.0975 0.1 0.1025 0.105 0.1075 0.11 0.1125 0.115 0.1175 0.12 0.1225 0.125 0.1275 0.13 0.1325 0.135 0.1375 0.14 0.1425 0.145 0.1475 0.15 0.1525 0.155 0.1575 0.16 0.1625 0.165 0.1675 0.17 0.1725 0.175 0.1775 0.18 0.1825 0.185 0.1875 0.19 0.1925 0.195 0.1975 0.2 0.2025 0.205 0.2075 0.21 0.2125 0.215 0.2175 0.22 0.2225 0.225 0.2275 0.23 0.2325 0.235 0.2375 0.24 0.2425 0.245 0.2475 0.25 ] -#define Water_Absorb_G 0.0565 //How much water absorbs green [0.0 0.0025 0.005 0.0075 0.01 0.0125 0.015 0.0175 0.02 0.0225 0.025 0.0275 0.03 0.0325 0.035 0.0375 0.04 0.0425 0.045 0.0475 0.05 0.0525 0.055 0.0575 0.06 0.0625 0.065 0.0675 0.07 0.0725 0.075 0.0775 0.08 0.0825 0.085 0.0875 0.09 0.0925 0.095 0.0975 0.1 0.1025 0.105 0.1075 0.11 0.1125 0.115 0.1175 0.12 0.1225 0.125 0.1275 0.13 0.1325 0.135 0.1375 0.14 0.1425 0.145 0.1475 0.15 0.1525 0.155 0.1575 0.16 0.1625 0.165 0.1675 0.17 0.1725 0.175 0.1775 0.18 0.1825 0.185 0.1875 0.19 0.1925 0.195 0.1975 0.2 0.2025 0.205 0.2075 0.21 0.2125 0.215 0.2175 0.22 0.2225 0.225 0.2275 0.23 0.2325 0.235 0.2375 0.24 0.2425 0.245 0.2475 0.25 ] -#define Water_Absorb_B 0.01011 //How much water absorbs blue [0.0 0.0025 0.005 0.0075 0.01 0.0125 0.015 0.0175 0.02 0.0225 0.025 0.0275 0.03 0.0325 0.035 0.0375 0.04 0.0425 0.045 0.0475 0.05 0.0525 0.055 0.0575 0.06 0.0625 0.065 0.0675 0.07 0.0725 0.075 0.0775 0.08 0.0825 0.085 0.0875 0.09 0.0925 0.095 0.0975 0.1 0.1025 0.105 0.1075 0.11 0.1125 0.115 0.1175 0.12 0.1225 0.125 0.1275 0.13 0.1325 0.135 0.1375 0.14 0.1425 0.145 0.1475 0.15 0.1525 0.155 0.1575 0.16 0.1625 0.165 0.1675 0.17 0.1725 0.175 0.1775 0.18 0.1825 0.185 0.1875 0.19 0.1925 0.195 0.1975 0.2 0.2025 0.205 0.2075 0.21 0.2125 0.215 0.2175 0.22 0.2225 0.225 0.2275 0.23 0.2325 0.235 0.2375 0.24 0.2425 0.245 0.2475 0.25 ] -#define Texture_MipMap_Bias -1.00 // Uses a another mip level for textures. When reduced will increase texture detail but may induce a lot of shimmering. [-5.00 -4.75 -4.50 -4.25 -4.00 -3.75 -3.50 -3.25 -3.00 -2.75 -2.50 -2.25 -2.00 -1.75 -1.50 -1.25 -1.00 -0.75 -0.50 -0.25 0.00 0.25 0.50 0.75 1.00 1.25 1.50 1.75 2.00 2.25 2.50 2.75 3.00 3.25 3.50 3.75 4.00 4.25 4.50 4.75 5.00] - -#define ambient_colortype 0 // Toggle which method you want to change the color of ambient light with. [0 1] -#define ambient_temp 9000 // [1000 2000 3000 4000 5000 6000 7000 8000 9000 10000 15000 50000] - -#define AmbientLight_R 0.91 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define AmbientLight_G 0.86 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define AmbientLight_B 1.0 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] - - - -#define MIN_LIGHT_AMOUNT 1.0 //[0.0 0.5 1.0 1.5 2.0 3.0 4.0 5.0] -//#define Vanilla_like_water // vanilla water texture along with shader water stuff -uniform sampler2D texture; -uniform sampler2D noisetex; -uniform sampler2DShadow shadow; -uniform sampler2D gaux2; -uniform sampler2D gaux1; -uniform sampler2D depthtex1; - -uniform vec4 lightCol; -uniform float nightVision; - -uniform vec3 sunVec; -uniform float frameTimeCounter; -uniform float lightSign; -uniform float near; -uniform float far; -uniform float moonIntensity; -uniform float sunIntensity; -uniform vec3 sunColor; -uniform vec3 nsunColor; -uniform vec3 upVec; -uniform float sunElevation; -uniform float fogAmount; -uniform vec2 texelSize; -uniform float rainStrength; -uniform float skyIntensityNight; -uniform float skyIntensity; -flat varying vec3 WsunVec; -uniform mat4 gbufferPreviousModelView; -uniform vec3 previousCameraPosition; -uniform int framemod8; -uniform sampler2D specular; -uniform int frameCounter; -uniform int isEyeInWater; - - - - - -#include "lib/Shadow_Params.glsl" -#include "lib/color_transforms.glsl" -#include "lib/projections.glsl" -#include "lib/sky_gradient.glsl" -#include "lib/waterBump.glsl" -#include "lib/clouds.glsl" -#include "lib/stars.glsl" -#include "lib/volumetricClouds.glsl" - - 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 interleaved_gradientNoise(float temporal){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+temporal); - return noise; -} -vec3 srgbToLinear2(vec3 srgb){ - return mix( - srgb / 12.92, - pow(.947867 * srgb + .0521327, vec3(2.4) ), - step( .04045, srgb ) - ); -} -vec3 blackbody2(float Temp) -{ - float t = pow(Temp, -1.5); - float lt = log(Temp); - - vec3 col = vec3(0.0); - col.x = 220000.0 * t + 0.58039215686; - col.y = 0.39231372549 * lt - 2.44549019608; - col.y = Temp > 6500. ? 138039.215686 * t + 0.72156862745 : col.y; - col.z = 0.76078431372 * lt - 5.68078431373; - col = clamp(col,0.0,1.0); - col = Temp < 1000. ? col * Temp * 0.001 : col; - - return srgbToLinear2(col); -} - -float blueNoise(){ - return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); -} -float invLinZ (float lindepth){ - return -((2.0*near/lindepth)-far-near)/(far-near); -} -float ld(float dist) { - return (2.0 * near) / (far + near - dist * (far - near)); -} -vec3 nvec3(vec4 pos){ - return pos.xyz/pos.w; -} - -vec4 nvec4(vec3 pos){ - return vec4(pos.xyz, 1.0); -} -vec3 rayTrace(vec3 dir,vec3 position,float dither, float fresnel, bool inwater){ - - float quality = mix(15,SSR_STEPS,fresnel); - vec3 clipPosition = toClipSpace3(position); - float rayLength = ((position.z + dir.z * far*sqrt(3.)) > -near) ? - (-near -position.z) / dir.z : far*sqrt(3.); - vec3 direction = normalize(toClipSpace3(position+dir*rayLength)-clipPosition); //convert to clip space - direction.xy = normalize(direction.xy); - - //get at which length the ray intersects with the edge of the screen - vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; - float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z); - - - vec3 stepv = direction * mult / quality*vec3(RENDER_SCALE,1.0); - - - - - vec3 spos = clipPosition*vec3(RENDER_SCALE,1.0) + stepv*dither; - float minZ = clipPosition.z; - float maxZ = spos.z+stepv.z*0.5; - - spos.xy += offsets[framemod8]*texelSize*0.5/RENDER_SCALE; - - for (int i = 0; i <= int(quality); i++) { - #ifdef USE_QUARTER_RES_DEPTH - // decode depth buffer - float sp = sqrt(texelFetch2D(gaux1,ivec2(spos.xy/texelSize/4),0).w/65000.0); - sp = invLinZ(sp); - if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ)){ - return vec3(spos.xy/RENDER_SCALE,sp); - } - spos += stepv; - #else - float sp = texelFetch2D(depthtex1,ivec2(spos.xy/texelSize),0).r; - if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ)){ - return vec3(spos.xy/RENDER_SCALE,sp); - } - spos += stepv; - #endif - //small bias - minZ = maxZ-0.00004/ld(spos.z); - if(inwater) minZ = maxZ-0.0004/ld(spos.z); - maxZ += stepv.z; - } - - return vec3(1.1); -} - - -float facos(float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : pi - a; -} - - - - - float bayer2(vec2 a){ - a = floor(a); - return fract(dot(a,vec2(0.5,a.y*0.75))); -} - -float cdist(vec2 coord) { - return max(abs(coord.s-0.5),abs(coord.t-0.5))*2.0; -} - - #define PW_DEPTH 1.0 //[0.5 1.0 1.5 2.0 2.5 3.0] - #define PW_POINTS 1 //[2 4 6 8 16 32] - #define bayer4(a) (bayer2( .5*(a))*.25+bayer2(a)) -#define bayer8(a) (bayer4( .5*(a))*.25+bayer2(a)) -#define bayer16(a) (bayer8( .5*(a))*.25+bayer2(a)) -#define bayer32(a) (bayer16(.5*(a))*.25+bayer2(a)) -#define bayer64(a) (bayer32(.5*(a))*.25+bayer2(a)) -#define bayer128(a) fract(bayer64(.5*(a))*.25+bayer2(a)) -vec3 getParallaxDisplacement(vec3 posxz, float iswater,float bumpmult,vec3 viewVec) { - float waveZ = mix(20.0,0.25,iswater); - float waveM = mix(0.0,4.0,iswater); - - vec3 parallaxPos = posxz; - vec2 vec = viewVector.xy * (1.0 / float(PW_POINTS)) * 22.0 * PW_DEPTH; - float waterHeight = getWaterHeightmap(posxz.xz, waveM, waveZ, iswater) ; - - parallaxPos.xz += waterHeight * vec; - - return parallaxPos; - -} -vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter,float distort) -{ - float alpha = (sampleNumber+jitter)/nb; - float angle = jitter*6.28 + alpha * nbRot * 6.28; - - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*sqrt(alpha); -} -//Low discrepancy 2D sequence, integration error is as low as sobol but easier to compute : http://extremelearning.com.au/unreasonable-effectiveness-of-quasirandom-sequences/ -vec2 R2_samples(int n){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha * n); -} -vec4 hash44(vec4 p4) -{ - p4 = fract(p4 * vec4(.1031, .1030, .0973, .1099)); - p4 += dot(p4, p4.wzxy+33.33); - return fract((p4.xxyz+p4.yzzw)*p4.zywx); -} -vec3 TangentToWorld(vec3 N, vec3 H) -{ - vec3 UpVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0); - vec3 T = normalize(cross(UpVector, N)); - vec3 B = cross(N, T); - - return vec3((T * H.x) + (B * H.y) + (N * H.z)); -} -float GGX (vec3 n, vec3 v, vec3 l, float r, float F0) { - r*=r;r*=r; - - vec3 h = l + v; - float hn = inversesqrt(dot(h, h)); - - float dotLH = clamp(dot(h,l)*hn,0.,1.); - float dotNH = clamp(dot(h,n)*hn,0.,1.); - float dotNL = clamp(dot(n,l),0.,1.); - float dotNHsq = dotNH*dotNH; - - float denom = dotNHsq * r - dotNHsq + 1.; - float D = r / (3.141592653589793 * denom * denom); - float F = F0 + (1. - F0) * exp2((-5.55473*dotLH-6.98316)*dotLH); - float k2 = .25 * r; - - return dotNL * D * F / (dotLH*dotLH*(1.0-k2)+k2); -} - - vec3 applyBump(mat3 tbnMatrix, vec3 bump){ - float bumpmult = 1.0; - bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); - return normalize(bump*tbnMatrix); - } - -#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) -float triangularize(float dither) -{ - float center = dither*2.0-1.0; - dither = center*inversesqrt(abs(center)); - return clamp(dither-fsign(center),0.0,1.0); -} -vec3 fp10Dither(vec3 color,float dither){ - const vec3 mantissaBits = vec3(6.,6.,5.); - vec3 exponent = floor(log2(color)); - return color + dither*exp2(-mantissaBits)*exp2(exponent); -} -float R2_dither(){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y + 1.0/1.6180339887 * frameCounter) ; -} -//encoding by jodie -float encodeVec2(vec2 a){ - const vec2 constant1 = vec2( 1., 256.) / 65535.; - vec2 temp = floor( a * 255. ); - return temp.x*constant1.x+temp.y*constant1.y; -} -float encodeVec2(float x,float y){ - return encodeVec2(vec2(x,y)); -} -vec3 viewToWorld(vec3 viewPosition) { - vec4 pos; - pos.xyz = viewPosition; - pos.w = 0.0; - pos = gbufferModelViewInverse * pos; - return pos.xyz; -} -vec3 worldToView(vec3 worldPos) { - vec4 pos = vec4(worldPos, 0.0); - pos = gbufferModelView * pos; - return pos.xyz; -} -vec4 encode (vec3 n, vec2 lightmaps){ - n.xy = n.xy / dot(abs(n), vec3(1.0)); - n.xy = n.z <= 0.0 ? (1.0 - abs(n.yx)) * sign(n.xy) : n.xy; - vec2 encn = clamp(n.xy * 0.5 + 0.5,-1.0,1.0); - - return vec4(encn,vec2(lightmaps.x,lightmaps.y)); -} - - - - -float square(float x){ - return x*x; -} -float g(float NdotL, float roughness){ - float alpha = square(max(roughness, 0.02)); - return 2.0 * NdotL / (NdotL + sqrt(square(alpha) + (1.0 - square(alpha)) * square(NdotL))); -} -float gSimple(float dp, float roughness){ - float k = roughness + 1; - k *= k/8.0; - return dp / (dp * (1.0-k) + k); -} - -vec3 GGX2(vec3 n, vec3 v, vec3 l, float r, vec3 F0) { - - float roughness = r + 1.0/255.0; // when roughness is zero it fucks up - - float alpha = square(roughness); - - - vec3 h = normalize(l + v); - - float dotLH = clamp(dot(h,l),0.,1.); - float dotNH = clamp(dot(h,n),0.,1.); - float dotNL = clamp(dot(n,l),0.,1.); - float dotNV = clamp(dot(n,v),0.,1.); - float dotVH = clamp(dot(h,v),0.,1.); - - - float D = alpha / (3.141592653589793*square(square(dotNH) * (alpha - 1.0) + 1.0)); - float G = gSimple(dotNV, roughness) * gSimple(dotNL, roughness); - vec3 F = F0 + (1. - F0) * exp2((-5.55473*dotVH-6.98316)*dotVH); - - return dotNL * F * (G * D / (4 * dotNV * dotNL + 1e-7)); -} - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -/* RENDERTARGETS:2,7,1,11 */ -void main() { - if (gl_FragCoord.x * texelSize.x < RENDER_SCALE.x && gl_FragCoord.y * texelSize.y < RENDER_SCALE.y ) { - vec2 tempOffset=offsets[framemod8]; - float iswater = normalMat.w; - vec3 fragC = gl_FragCoord.xyz*vec3(texelSize,1.0); - vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize/RENDER_SCALE,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); - gl_FragData[0] = texture2D(texture, lmtexcoord.xy)*color; - float avgBlockLum = luma(texture2DLod(texture, lmtexcoord.xy,128).rgb*color.rgb); - gl_FragData[0].rgb = clamp((gl_FragData[0].rgb)*pow(avgBlockLum,-0.33)*0.85,0.0,1.0); - - vec3 albedo = toLinear(gl_FragData[0].rgb); - - #ifndef Vanilla_like_water - if (iswater > 0.4) { - albedo = vec3(0.42,0.6,0.7); - gl_FragData[0] = vec4(0.42,0.6,0.7,0.7); - } - if (iswater > 0.9) { - gl_FragData[0] = vec4(0.0); - } - #endif - - #ifdef Vanilla_like_water - if (iswater > 0.5) { - gl_FragData[0].a = luma(albedo.rgb); - albedo = color.rgb; - } - #endif - vec2 specularstuff = texture2D(specular, lmtexcoord.xy, Texture_MipMap_Bias).rg; - - vec3 normal = normalMat.xyz; - - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - mat3 tbnMatrix = mat3(tangent.x, binormal.x, normal.x, - tangent.y, binormal.y, normal.y, - tangent.z, binormal.z, normal.z); - if (iswater > 0.4){ - float bumpmult = 1.; - if (iswater > 0.9) - bumpmult = 1.; - float parallaxMult = bumpmult; - vec3 posxz = p3+cameraPosition; - posxz.xz-=posxz.y; - if (iswater < 0.9) - posxz.xz *= 3.0; - vec3 bump; - - - posxz.xyz = getParallaxDisplacement(posxz,iswater,bumpmult,normalize(tbnMatrix*fragpos)); - - bump = normalize(getWaveHeight(posxz.xz,iswater)); - - - - bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); - - normal = normalize(bump * tbnMatrix); - }else { - vec3 normalTex = texture2D(normals, lmtexcoord.xy, Texture_MipMap_Bias).rgb; - - normalTex.xy = normalTex.xy*2.0-1.0; - normalTex.z = clamp(sqrt(1.0 - dot(normalTex.xy, normalTex.xy)),0.0,1.0); - normal = applyBump(tbnMatrix,normalTex); - } - vec4 data0 = vec4(1); - vec4 data1 = clamp( encode(viewToWorld(normal), lmtexcoord.zw),0.0,1.0); - gl_FragData[3] = vec4(encodeVec2(data0.x,data1.x), encodeVec2(data0.y,data1.y), encodeVec2(data0.z,data1.z), encodeVec2(data1.w,data0.w)); - // gl_FragData[3].a = 0.0; - - - float NdotL = lightSign*dot(normal,sunVec); - float NdotU = dot(upVec,normal); - float diffuseSun = clamp(NdotL,0.0f,1.0f); - - vec3 direct = texelFetch2D(gaux1,ivec2(6,37),0).rgb/3.1415; - - float shading = 1.0; - float cloudShadow = 1.0; - //compute shadows only if not backface - if (diffuseSun > 0.001) { - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - vec3 projectedShadowPosition = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; - projectedShadowPosition = diagonal3(shadowProjection) * projectedShadowPosition + shadowProjection[3].xyz; - - //apply distortion - float distortFactor = calcDistort(projectedShadowPosition.xy); - projectedShadowPosition.xy *= distortFactor; - //do shadows only if on shadow map - if (abs(projectedShadowPosition.x) < 1.0-1.5/shadowMapResolution && abs(projectedShadowPosition.y) < 1.0-1.5/shadowMapResolution){ - const float threshMul = max(2048.0/shadowMapResolution*shadowDistance/128.0,0.95); - float distortThresh = (sqrt(1.0-diffuseSun*diffuseSun)/diffuseSun+0.7)/distortFactor; - float diffthresh = distortThresh/6000.0*threshMul; - - projectedShadowPosition = projectedShadowPosition * vec3(0.5,0.5,0.5/6.0) + vec3(0.5,0.5,0.5); - - shading = 0.0; - float noise = blueNoise(); - float rdMul = 4.0/shadowMapResolution; - for(int i = 0; i < 9; i++){ - vec2 offsetS = tapLocation(i,9, 1.618,noise,0.0); - - float weight = 1.0+(i+noise)*rdMul/9.0*shadowMapResolution; - shading += shadow2D(shadow,vec3(projectedShadowPosition + vec3(rdMul*offsetS,-diffthresh*weight))).x/9.0; - } - direct *= shading; - } - - - #ifdef VOLUMETRIC_CLOUDS - #ifdef CLOUDS_SHADOWS - vec3 campos = (p3 + cameraPosition)-319 ; - // get cloud position - vec3 cloudPos = campos*Cloud_Size + WsunVec/abs(WsunVec.y) * (2250 - campos.y*Cloud_Size); - // get the cloud density and apply it - cloudShadow = getCloudDensity(cloudPos, 1); - // cloudShadow = exp(-cloudShadow*sqrt(cloudDensity)*25); - - cloudShadow = clamp(exp(-cloudShadow*10),0,1); - - // make these turn to zero when occluded by the cloud shadow - direct *= cloudShadow; - #endif - #endif - } - - - - - #if ambient_colortype == 0 - vec3 colortype = blackbody2(ambient_temp); - #else - vec3 colortype = vec3(AmbientLight_R,AmbientLight_G,AmbientLight_B) ; - #endif - - vec3 ambientLight = texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb * colortype; - - direct *= (iswater > 0.9 ? 0.2: 1.0)*diffuseSun*lmtexcoord.w; - - - vec3 diffuseLight = (direct*1.5) + (ambientLight*2.5); - vec3 color = diffuseLight * albedo * 8./150./3.0 ; - - - - if (iswater > 0.0){ - - float roughness = iswater > 0.4 ? 0.0 : specularstuff.r > 0.0 ? pow(1.0-specularstuff.r,2.0) : 0.05*(1.0-gl_FragData[0].a ); - float f0 = iswater > 0.4 ? 0.02 : specularstuff.g; - if(f0 > 0.9) f0 = 0.02; - float F0 = f0; - - // float f0 = iswater > 0.1 ? 0.02 : 0.05*(1.0-gl_FragData[0].a); - // float roughness = 0.02; - // float F0 = f0; - - vec3 reflectedVector = reflect(normalize(fragpos), normal); - - - float normalDotEye = dot(normal, normalize(fragpos)); - float fresnel = pow(clamp(1.0 + normalDotEye,0.0,1.0), 5.0); - float fresnel2 = pow(clamp(1.0 + normalDotEye,0.0,1.0), 1.0); - - // gl_FragData[3].a = fresnel2; - - // snells window looking thing - if(isEyeInWater == 1 && iswater > 0.99) fresnel = clamp(pow(1.66 + normalDotEye,25),0.02,1.0); - - fresnel = mix(F0,1.0,fresnel); - - // adjust the amount of sunlight based on f0. max f0 should - color = mix(color, (ambientLight*2.5) * albedo * 8./150./3.0 , mix(1.0-roughness, F0, 0.5)); - - vec3 wrefl = mat3(gbufferModelViewInverse)*reflectedVector; - vec3 sky_c = mix(skyCloudsFromTex(wrefl,gaux1).rgb,texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb*0.5,isEyeInWater); - sky_c.rgb *= lmtexcoord.w*lmtexcoord.w*255*255/240./240./150.*8./3.; - - vec4 reflection = vec4(sky_c.rgb,0.); - #ifdef SCREENSPACE_REFLECTIONS - vec3 rtPos = rayTrace(reflectedVector,fragpos.xyz, blueNoise(), fresnel, isEyeInWater == 0); - if (rtPos.z <1.){ - vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rtPos) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; - previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; - previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; - if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) { - reflection.a = 1.0; - reflection.rgb = texture2D(gaux2,previousPosition.xy).rgb; - } - } - #endif - - - if(isEyeInWater ==1 ) sky_c.rgb = color.rgb*lmtexcoord.y; - - reflection.rgb = mix(sky_c.rgb, reflection.rgb, reflection.a); - - #ifdef SUN_MICROFACET_SPECULAR - vec3 sunSpec = GGX2(normal, -normalize(fragpos), lightSign*sunVec ,roughness, vec3(f0)) * direct; - - // vec3 sunSpec = GGX(normal,-normalize(fragpos), lightSign*sunVec, rainStrength*0.2+roughness+0.05+clamp(-lightSign*0.15,0.0,1.0), f0) * texelFetch2D(gaux1,ivec2(6,37),0).rgb*8./3./150.0/3.1415 * (1.0-rainStrength*0.9); - #else - vec3 sunSpec = drawSun(dot(lightSign * sunVec,reflectedVector), 0.0,texelFetch2D(gaux1,ivec2(6,37),0).rgb,vec3(0.0))*8./3./150.0*fresnel/3.1415 * (1.0-rainStrength*0.9); - #endif - - - // vec3 albedoTint = F0 >= (230.0/255.0) ? clamp(color.rgb + fresnel,0.0,1.0) : vec3(1.0); - // reflection.rgb *= albedoTint; - // sunSpec.rgb *= albedoTint; - sunSpec *= max(cloudShadow-0.5,0.0); - - vec3 reflected = reflection.rgb*fresnel+shading*sunSpec; - - float alpha0 = gl_FragData[0].a; - - vec3 np3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition; - - float borderfog = clamp( pow( length(fragpos)/far, 5), 0, 1); - vec3 bordercolor = skyFromTex(np3,colortex4)/150.; - vec3 finalborderfog = clamp(fp10Dither(bordercolor*8./3.,triangularize(R2_dither())),0.0,65000.); - - // alpha0 = mix(0.0, alpha0, borderfog); - - //correct alpha channel with fresnel - gl_FragData[0].a = -gl_FragData[0].a*fresnel+gl_FragData[0].a+fresnel; - - gl_FragData[0].rgb = clamp(color/gl_FragData[0].a*alpha0*(1.0-fresnel)*0.1+reflected/gl_FragData[0].a*0.1,0.0,65100.0); - if (gl_FragData[0].r > 65000.) gl_FragData[0].rgba = vec4(0.); - - - } - else - gl_FragData[0].rgb = color*.1; - - gl_FragData[1] = vec4(albedo,iswater); - - // vec3 np3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition; - - // float borderfog = clamp( pow( length(fragpos)/far, 5), 0, 1); - // vec3 bordercolor = skyFromTex(np3,colortex4)/150.; - // vec3 finalborderfog = clamp(fp10Dither(bordercolor*8./3.,triangularize(R2_dither())),0.0,65000.); - - } -} diff --git a/shaders/world-1/gbuffers_armor_glint.fsh b/shaders/world-1/gbuffers_armor_glint.fsh index c931e5f..d2a0cfd 100644 --- a/shaders/world-1/gbuffers_armor_glint.fsh +++ b/shaders/world-1/gbuffers_armor_glint.fsh @@ -8,7 +8,7 @@ varying vec4 normalMat; uniform sampler2D texture; - +uniform sampler2D gaux1; uniform vec4 lightCol; uniform vec3 sunVec; @@ -66,34 +66,15 @@ void main() { gl_FragData[0] = texture2D(texture, lmtexcoord.xy); + vec3 albedo = toLinear(gl_FragData[0].rgb*color.rgb); - vec3 albedo = toLinear(gl_FragData[0].rgb*color.rgb); + float exposure = texelFetch2D(gaux1,ivec2(10,37),0).r; - vec3 normal = normalMat.xyz; - vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize,1.0)); + vec3 col = albedo*exp(-exposure*3.); - - float NdotL = lightCol.a*dot(normal,sunVec); - - float diffuseSun = clamp(NdotL,0.0f,1.0f); - - vec3 direct = lightCol.rgb; - - - direct *= (diffuseSun*lmtexcoord.w)*10.; - - float torch_lightmap = ((lmtexcoord.z*lmtexcoord.z)*(lmtexcoord.z*lmtexcoord.z))*(lmtexcoord.z*20.)+lmtexcoord.z; - - vec3 ambient = (lightCol.a*sunElevation)*(-NdotL*0.45+0.9)*lightCol.rgb*0.6 + (1.2*skyIntensity)*vec3(0.65,0.7,1.)*30. + skyIntensityNight*vec3(0.09,0.1,0.15)/1.5; - - vec3 diffuseLight = (lmtexcoord.w)*ambient + vec3(1.,0.4,0.1)*torch_lightmap*0.08*1.0 + 0.0006; - - vec3 col = dot(diffuseLight,vec3(1.0/3))*albedo; - - - gl_FragData[0].rgb = col*color.a; - gl_FragData[0].a = 0.0; + gl_FragData[0].rgb = col*color.a; + gl_FragData[0].a = gl_FragData[0].a*0.1; diff --git a/shaders/world-1/gbuffers_armor_glint.vsh b/shaders/world-1/gbuffers_armor_glint.vsh index 40823aa..ab59388 100644 --- a/shaders/world-1/gbuffers_armor_glint.vsh +++ b/shaders/world-1/gbuffers_armor_glint.vsh @@ -1,6 +1,6 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable -#define TAA +#include "/lib/res_params.glsl" /* !! DO NOT REMOVE !! @@ -14,7 +14,7 @@ varying vec4 color; varying vec4 normalMat; #ifdef MC_NORMAL_MAP varying vec4 tangent; -attribute vec4 at_tangent; +attribute vec4 at_tangent; #endif uniform vec2 texelSize; uniform int framemod8; @@ -26,6 +26,12 @@ uniform int framemod8; vec2(-7.,-1.)/8., vec2(3,7.)/8., vec2(7.,-7.)/8.); +#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) +#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) +vec4 toClipSpace3(vec3 viewSpacePosition) { + return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); +} + //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -38,16 +44,20 @@ void main() { vec2 lmcoord = gl_MultiTexCoord1.xy/255.; lmtexcoord.zw = lmcoord*lmcoord; - gl_Position = ftransform(); - color = gl_Color; - - + vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; + color = gl_Color; + gl_Position = toClipSpace3(position); + + #ifdef MC_NORMAL_MAP tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); #endif - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),1.0); + normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),1.0); + #ifdef TAA_UPSCALING + gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; + #endif #ifdef TAA gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; #endif -} \ No newline at end of file +} diff --git a/shaders/world-1/gbuffers_basic.fsh b/shaders/world-1/gbuffers_basic.fsh index 97072f6..7bb4bf0 100644 --- a/shaders/world-1/gbuffers_basic.fsh +++ b/shaders/world-1/gbuffers_basic.fsh @@ -1,4 +1,6 @@ #version 120 +// #define ENTITIES +#define BLOCKENTITIES #define WORLD -#include "gbuffers_all_solid.fsh" \ No newline at end of file +#include "/programs/all_solid.fsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_basic.vsh b/shaders/world-1/gbuffers_basic.vsh index 5078151..2577f65 100644 --- a/shaders/world-1/gbuffers_basic.vsh +++ b/shaders/world-1/gbuffers_basic.vsh @@ -1,4 +1,7 @@ #version 120 +// #define ENTITIES +// #define LINE +#define BLOCKENTITIES #define WORLD -#include "gbuffers_all_solid.vsh" \ No newline at end of file +#include "/programs/all_solid.vsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_block.fsh b/shaders/world-1/gbuffers_block.fsh index 95943b4..34cbade 100644 --- a/shaders/world-1/gbuffers_block.fsh +++ b/shaders/world-1/gbuffers_block.fsh @@ -1,5 +1,5 @@ #version 120 -#define BLOCK_ENT #define WORLD -#include "gbuffers_all_solid.fsh" \ No newline at end of file +#define BLOCKENTITIES +#include "/gbuffers_all_solid.fsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_block.vsh b/shaders/world-1/gbuffers_block.vsh index 9974256..31749b9 100644 --- a/shaders/world-1/gbuffers_block.vsh +++ b/shaders/world-1/gbuffers_block.vsh @@ -1,5 +1,5 @@ #version 120 -#define BLOCK_ENT #define WORLD -#include "gbuffers_all_solid.vsh" \ No newline at end of file +#define BLOCKENTITIES +#include "/gbuffers_all_solid.vsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_clouds.fsh b/shaders/world-1/gbuffers_clouds.fsh deleted file mode 100644 index 563a191..0000000 --- a/shaders/world-1/gbuffers_clouds.fsh +++ /dev/null @@ -1,9 +0,0 @@ -#version 120 - -/* DRAWBUFFERS:3 */ - - - -void main() { - -} diff --git a/shaders/world-1/gbuffers_clouds.vsh b/shaders/world-1/gbuffers_clouds.vsh deleted file mode 100644 index 90c4b9e..0000000 --- a/shaders/world-1/gbuffers_clouds.vsh +++ /dev/null @@ -1,14 +0,0 @@ -#version 120 -#extension GL_EXT_gpu_shader4 : enable - - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - - gl_Position.w = -1.0; -} diff --git a/shaders/world-1/gbuffers_entities.fsh b/shaders/world-1/gbuffers_entities.fsh index 0cd3e0d..234213a 100644 --- a/shaders/world-1/gbuffers_entities.fsh +++ b/shaders/world-1/gbuffers_entities.fsh @@ -2,4 +2,5 @@ #define WORLD #define ENTITIES -#include "gbuffers_all_solid.fsh" \ No newline at end of file + +#include "/programs/all_solid.fsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_entities.vsh b/shaders/world-1/gbuffers_entities.vsh index f4f07a4..460f566 100644 --- a/shaders/world-1/gbuffers_entities.vsh +++ b/shaders/world-1/gbuffers_entities.vsh @@ -3,4 +3,4 @@ // #define WORLD #define ENTITIES -#include "gbuffers_all_solid.vsh" \ No newline at end of file +#include "/programs/all_solid.vsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_hand.fsh b/shaders/world-1/gbuffers_hand.fsh index 21ac244..8350290 100644 --- a/shaders/world-1/gbuffers_hand.fsh +++ b/shaders/world-1/gbuffers_hand.fsh @@ -1,4 +1,4 @@ #version 120 #define HAND -#include "gbuffers_all_solid.fsh" \ No newline at end of file +#include "/programs/all_solid.fsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_hand.vsh b/shaders/world-1/gbuffers_hand.vsh index 39504ed..a2820e6 100644 --- a/shaders/world-1/gbuffers_hand.vsh +++ b/shaders/world-1/gbuffers_hand.vsh @@ -2,4 +2,5 @@ #define WORLD #define HAND -#include "gbuffers_all_solid.vsh" \ No newline at end of file + +#include "/programs/all_solid.vsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_hand_water.fsh b/shaders/world-1/gbuffers_hand_water.fsh index 2225473..59a7bed 100644 --- a/shaders/world-1/gbuffers_hand_water.fsh +++ b/shaders/world-1/gbuffers_hand_water.fsh @@ -1,116 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define PCF - - - - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; - - -uniform sampler2D texture; -uniform sampler2D gaux1; -uniform vec4 lightCol; -uniform vec3 sunVec; -uniform vec3 upVec; - -uniform vec2 texelSize; -uniform float skyIntensityNight; -uniform float skyIntensity; -uniform float sunElevation; -uniform float rainStrength; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferModelViewInverse; -uniform mat4 shadowModelView; -uniform mat4 shadowProjection; - -//faster and actually more precise than pow 2.2 -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} - -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -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; -} -float interleaved_gradientNoise(float temporal){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+temporal); - return noise; -} - -#ifdef PCF -const vec2 shadowOffsets[4] = vec2[4](vec2( 0.1250, 0.0000 ), -vec2( -0.1768, -0.1768 ), -vec2( -0.0000, 0.3750 ), -vec2( 0.3536, -0.3536 ) -); -#endif -float facos(float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : 3.14159265359 - a; -} - - -vec2 tapLocation(int sampleNumber, float spinAngle,int nb, float nbRot) -{ - float startJitter = (spinAngle/6.28); - float alpha = sqrt(sampleNumber + startJitter/nb ); - float angle = alpha * (nbRot * 6.28) + spinAngle*2.; - - float ssR = alpha; - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*ssR; -} -uniform int framemod8; -uniform int framecouter; - 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.); - - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -/* DRAWBUFFERS:2 */ -void main() { - - gl_FragData[0] = texture2D(texture, lmtexcoord.xy)*color; - vec2 tempOffset=offsets[framemod8]; - - if (gl_FragData[0].a>0.1){ - vec3 albedo = toLinear(gl_FragData[0].rgb); - - vec3 normal = normalMat.xyz; - - - vec3 ambient = texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb; - - vec3 diffuseLight = ambient; - - - gl_FragData[0].rgb = diffuseLight*albedo*8./1500.*0.1; - } - - - -} +#include "/programs/all_translucent.fsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_hand_water.vsh b/shaders/world-1/gbuffers_hand_water.vsh index 68dc1b7..afcff5d 100644 --- a/shaders/world-1/gbuffers_hand_water.vsh +++ b/shaders/world-1/gbuffers_hand_water.vsh @@ -1,56 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define TAA -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -#ifdef MC_NORMAL_MAP -varying vec4 tangent; -attribute vec4 at_tangent; -#endif - - - -uniform vec2 texelSize; -uniform int framemod8; - 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.); -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - - gl_Position = ftransform(); - color = gl_Color; - - - #ifdef MC_NORMAL_MAP - tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); - #endif - - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),1.0); - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif -} +#include "/programs/all_translucent.vsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_terrain.fsh b/shaders/world-1/gbuffers_terrain.fsh index 97072f6..d9afdd3 100644 --- a/shaders/world-1/gbuffers_terrain.fsh +++ b/shaders/world-1/gbuffers_terrain.fsh @@ -1,4 +1,5 @@ #version 120 #define WORLD -#include "gbuffers_all_solid.fsh" \ No newline at end of file + +#include "/programs/all_solid.fsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_terrain.vsh b/shaders/world-1/gbuffers_terrain.vsh index 5078151..d18fc18 100644 --- a/shaders/world-1/gbuffers_terrain.vsh +++ b/shaders/world-1/gbuffers_terrain.vsh @@ -1,4 +1,5 @@ #version 120 #define WORLD -#include "gbuffers_all_solid.vsh" \ No newline at end of file + +#include "/programs/all_solid.vsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_textured.fsh b/shaders/world-1/gbuffers_textured.fsh index 2225473..0f62590 100644 --- a/shaders/world-1/gbuffers_textured.fsh +++ b/shaders/world-1/gbuffers_textured.fsh @@ -1,116 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define PCF - - - - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; - - -uniform sampler2D texture; -uniform sampler2D gaux1; -uniform vec4 lightCol; -uniform vec3 sunVec; -uniform vec3 upVec; - -uniform vec2 texelSize; -uniform float skyIntensityNight; -uniform float skyIntensity; -uniform float sunElevation; -uniform float rainStrength; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferModelViewInverse; -uniform mat4 shadowModelView; -uniform mat4 shadowProjection; - -//faster and actually more precise than pow 2.2 -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} - -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -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; -} -float interleaved_gradientNoise(float temporal){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+temporal); - return noise; -} - -#ifdef PCF -const vec2 shadowOffsets[4] = vec2[4](vec2( 0.1250, 0.0000 ), -vec2( -0.1768, -0.1768 ), -vec2( -0.0000, 0.3750 ), -vec2( 0.3536, -0.3536 ) -); -#endif -float facos(float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : 3.14159265359 - a; -} - - -vec2 tapLocation(int sampleNumber, float spinAngle,int nb, float nbRot) -{ - float startJitter = (spinAngle/6.28); - float alpha = sqrt(sampleNumber + startJitter/nb ); - float angle = alpha * (nbRot * 6.28) + spinAngle*2.; - - float ssR = alpha; - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*ssR; -} -uniform int framemod8; -uniform int framecouter; - 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.); - - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -/* DRAWBUFFERS:2 */ -void main() { - - gl_FragData[0] = texture2D(texture, lmtexcoord.xy)*color; - vec2 tempOffset=offsets[framemod8]; - - if (gl_FragData[0].a>0.1){ - vec3 albedo = toLinear(gl_FragData[0].rgb); - - vec3 normal = normalMat.xyz; - - - vec3 ambient = texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb; - - vec3 diffuseLight = ambient; - - - gl_FragData[0].rgb = diffuseLight*albedo*8./1500.*0.1; - } - - - -} +#include "/programs/all_particles.fsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_textured.vsh b/shaders/world-1/gbuffers_textured.vsh index 51f3fd7..a6d1cbf 100644 --- a/shaders/world-1/gbuffers_textured.vsh +++ b/shaders/world-1/gbuffers_textured.vsh @@ -1,74 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define TAA -#define WAVY_PLANTS -#define WAVY_STRENGTH 1.0 //[0.1 0.25 0.5 0.75 1.0 1.25 1.5 1.75 2.0] -#define WAVY_SPEED 1.0 //[0.001 0.01 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 1.0 1.25 1.5 2.0 3.0 4.0] -#define SEPARATE_AO -//#define POM -//#define USE_LUMINANCE_AS_HEIGHTMAP //Can generate POM on any texturepack (may look weird in some cases) - -#ifndef USE_LUMINANCE_AS_HEIGHTMAP -#ifndef MC_NORMAL_MAP -#undef POM -#endif -#endif - -#ifdef POM -#define MC_NORMAL_MAP -#endif - -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; - - -uniform vec2 texelSize; -uniform int framemod8; - 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.); -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -vec4 toClipSpace3(vec3 viewSpacePosition) { - return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); -} - - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - - vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; - - color = gl_Color; - - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),0.0); - - gl_Position = toClipSpace3(position); - - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif -} +#include "/programs/all_particles.vsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_textured_lit.fsh b/shaders/world-1/gbuffers_textured_lit.fsh index 2225473..0f62590 100644 --- a/shaders/world-1/gbuffers_textured_lit.fsh +++ b/shaders/world-1/gbuffers_textured_lit.fsh @@ -1,116 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define PCF - - - - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; - - -uniform sampler2D texture; -uniform sampler2D gaux1; -uniform vec4 lightCol; -uniform vec3 sunVec; -uniform vec3 upVec; - -uniform vec2 texelSize; -uniform float skyIntensityNight; -uniform float skyIntensity; -uniform float sunElevation; -uniform float rainStrength; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferModelViewInverse; -uniform mat4 shadowModelView; -uniform mat4 shadowProjection; - -//faster and actually more precise than pow 2.2 -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} - -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -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; -} -float interleaved_gradientNoise(float temporal){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+temporal); - return noise; -} - -#ifdef PCF -const vec2 shadowOffsets[4] = vec2[4](vec2( 0.1250, 0.0000 ), -vec2( -0.1768, -0.1768 ), -vec2( -0.0000, 0.3750 ), -vec2( 0.3536, -0.3536 ) -); -#endif -float facos(float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : 3.14159265359 - a; -} - - -vec2 tapLocation(int sampleNumber, float spinAngle,int nb, float nbRot) -{ - float startJitter = (spinAngle/6.28); - float alpha = sqrt(sampleNumber + startJitter/nb ); - float angle = alpha * (nbRot * 6.28) + spinAngle*2.; - - float ssR = alpha; - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*ssR; -} -uniform int framemod8; -uniform int framecouter; - 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.); - - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -/* DRAWBUFFERS:2 */ -void main() { - - gl_FragData[0] = texture2D(texture, lmtexcoord.xy)*color; - vec2 tempOffset=offsets[framemod8]; - - if (gl_FragData[0].a>0.1){ - vec3 albedo = toLinear(gl_FragData[0].rgb); - - vec3 normal = normalMat.xyz; - - - vec3 ambient = texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb; - - vec3 diffuseLight = ambient; - - - gl_FragData[0].rgb = diffuseLight*albedo*8./1500.*0.1; - } - - - -} +#include "/programs/all_particles.fsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_textured_lit.vsh b/shaders/world-1/gbuffers_textured_lit.vsh index 68dc1b7..c9e7eab 100644 --- a/shaders/world-1/gbuffers_textured_lit.vsh +++ b/shaders/world-1/gbuffers_textured_lit.vsh @@ -1,56 +1,5 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define TAA -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -#ifdef MC_NORMAL_MAP -varying vec4 tangent; -attribute vec4 at_tangent; -#endif - - - -uniform vec2 texelSize; -uniform int framemod8; - 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.); -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - - gl_Position = ftransform(); - color = gl_Color; - - - #ifdef MC_NORMAL_MAP - tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); - #endif - - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),1.0); - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif -} +// #define WEATHER +#define PARTICLES +#include "/programs/all_particles.vsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_water.fsh b/shaders/world-1/gbuffers_water.fsh index 5d6f344..59a7bed 100644 --- a/shaders/world-1/gbuffers_water.fsh +++ b/shaders/world-1/gbuffers_water.fsh @@ -1,334 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -varying vec3 binormal; -varying vec3 tangent; -varying vec3 viewVector; -varying float dist; -#define SCREENSPACE_REFLECTIONS //can be really expensive at high resolutions/render quality, especially on ice -#define SSR_STEPS 30 //[10 15 20 25 30 35 40 50 100 200 400] -#define SUN_MICROFACET_SPECULAR // If enabled will use realistic rough microfacet model, else will just reflect the sun. No performance impact. -#define saturate(x) clamp(x,0.0,1.0) - -uniform sampler2D texture; -uniform sampler2D noisetex; -uniform sampler2D gaux2; -uniform sampler2D gaux1; -uniform sampler2D depthtex1; - -uniform vec4 lightCol; -uniform vec3 sunVec; -uniform float frameTimeCounter; -uniform float lightSign; -uniform float near; -uniform float far; -uniform float moonIntensity; -uniform float sunIntensity; -uniform vec3 sunColor; -uniform vec3 nsunColor; -uniform vec3 upVec; -uniform float sunElevation; -uniform float fogAmount; -uniform vec2 texelSize; -uniform float rainStrength; -uniform float skyIntensityNight; -uniform float skyIntensity; -uniform mat4 gbufferPreviousModelView; -uniform vec3 previousCameraPosition; -uniform int framemod8; -uniform int frameCounter; -uniform int isEyeInWater; -#include "lib/color_transforms.glsl" -#include "lib/projections.glsl" -#include "lib/sky_gradient.glsl" -#include "lib/waterBump.glsl" -#include "lib/clouds.glsl" -#include "lib/stars.glsl" - 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 interleaved_gradientNoise(float temporal){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+temporal); - return noise; -} -float blueNoise(){ - return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); -} -float invLinZ (float lindepth){ - return -((2.0*near/lindepth)-far-near)/(far-near); -} -float ld(float dist) { - return (2.0 * near) / (far + near - dist * (far - near)); -} -vec3 nvec3(vec4 pos){ - return pos.xyz/pos.w; -} - -vec4 nvec4(vec3 pos){ - return vec4(pos.xyz, 1.0); -} -vec3 rayTrace(vec3 dir,vec3 position,float dither, float fresnel){ - - float quality = mix(15,SSR_STEPS,fresnel); - vec3 clipPosition = toClipSpace3(position); - float rayLength = ((position.z + dir.z * far*sqrt(3.)) > -near) ? - (-near -position.z) / dir.z : far*sqrt(3.); - vec3 direction = normalize(toClipSpace3(position+dir*rayLength)-clipPosition); //convert to clip space - direction.xy = normalize(direction.xy); - - //get at which length the ray intersects with the edge of the screen - vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; - float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z); - - - vec3 stepv = direction * mult / quality; - - - - - vec3 spos = clipPosition + stepv*dither; - float minZ = clipPosition.z; - float maxZ = spos.z+stepv.z*0.5; - spos.xy+=offsets[framemod8]*texelSize*0.5; - //raymarch on a quarter res depth buffer for improved cache coherency - - - for (int i = 0; i < int(quality+1); i++) { - - float sp=texelFetch2D(depthtex1,ivec2(spos.xy/texelSize),0).x; - - if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ)){ - return vec3(spos.xy,sp); - - } - spos += stepv; - //small bias - minZ = maxZ-0.00004/ld(spos.z); - maxZ += stepv.z; - } - - return vec3(1.1); -} - - -float facos(float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : pi - a; -} - - - - - float bayer2(vec2 a){ - a = floor(a); - return fract(dot(a,vec2(0.5,a.y*0.75))); -} - -float cdist(vec2 coord) { - return max(abs(coord.s-0.5),abs(coord.t-0.5))*2.0; -} - - #define PW_DEPTH 1.0 //[0.5 1.0 1.5 2.0 2.5 3.0] - #define PW_POINTS 1 //[2 4 6 8 16 32] - #define bayer4(a) (bayer2( .5*(a))*.25+bayer2(a)) -#define bayer8(a) (bayer4( .5*(a))*.25+bayer2(a)) -#define bayer16(a) (bayer8( .5*(a))*.25+bayer2(a)) -#define bayer32(a) (bayer16(.5*(a))*.25+bayer2(a)) -#define bayer64(a) (bayer32(.5*(a))*.25+bayer2(a)) -#define bayer128(a) fract(bayer64(.5*(a))*.25+bayer2(a)) -vec3 getParallaxDisplacement(vec3 posxz, float iswater,float bumpmult,vec3 viewVec) { - float waveZ = mix(20.0,0.25,iswater); - float waveM = mix(0.0,4.0,iswater); - - vec3 parallaxPos = posxz; - vec2 vec = viewVector.xy * (1.0 / float(PW_POINTS)) * 22.0 * PW_DEPTH; - float waterHeight = getWaterHeightmap(posxz.xz, waveM, waveZ, iswater) * 0.5; -parallaxPos.xz += waterHeight * vec; - - return parallaxPos; - -} -vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter,float distort) -{ - float alpha = (sampleNumber+jitter)/nb; - float angle = jitter*6.28 + alpha * nbRot * 6.28; - - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*sqrt(alpha); -} -//Low discrepancy 2D sequence, integration error is as low as sobol but easier to compute : http://extremelearning.com.au/unreasonable-effectiveness-of-quasirandom-sequences/ -vec2 R2_samples(int n){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha * n); -} -vec4 hash44(vec4 p4) -{ - p4 = fract(p4 * vec4(.1031, .1030, .0973, .1099)); - p4 += dot(p4, p4.wzxy+33.33); - return fract((p4.xxyz+p4.yzzw)*p4.zywx); -} -vec3 TangentToWorld(vec3 N, vec3 H) -{ - vec3 UpVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0); - vec3 T = normalize(cross(UpVector, N)); - vec3 B = cross(N, T); - - return vec3((T * H.x) + (B * H.y) + (N * H.z)); -} -float GGX (vec3 n, vec3 v, vec3 l, float r, float F0) { - r*=r;r*=r; - - vec3 h = l + v; - float hn = inversesqrt(dot(h, h)); - - float dotLH = clamp(dot(h,l)*hn,0.,1.); - float dotNH = clamp(dot(h,n)*hn,0.,1.); - float dotNL = clamp(dot(n,l),0.,1.); - float dotNHsq = dotNH*dotNH; - - float denom = dotNHsq * r - dotNHsq + 1.; - float D = r / (3.141592653589793 * denom * denom); - float F = F0 + (1. - F0) * exp2((-5.55473*dotLH-6.98316)*dotLH); - float k2 = .25 * r; - - return dotNL * D * F / (dotLH*dotLH*(1.0-k2)+k2); -} - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -/* DRAWBUFFERS:27 */ -void main() { - - vec2 tempOffset=offsets[framemod8]; - float iswater = normalMat.w; - vec3 fragC = gl_FragCoord.xyz*vec3(texelSize,1.0); - vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); - gl_FragData[0] = texture2D(texture, lmtexcoord.xy)*color; - vec3 albedo = toLinear(gl_FragData[0].rgb); - if (iswater > 0.4) { - albedo = vec3(0.42,0.6,0.7); - gl_FragData[0] = vec4(0.42,0.6,0.7,0.7); - } - if (iswater > 0.9) { - gl_FragData[0] = vec4(0.0); - } - - - - - vec3 normal = normalMat.xyz; - - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - mat3 tbnMatrix = mat3(tangent.x, binormal.x, normal.x, - tangent.y, binormal.y, normal.y, - tangent.z, binormal.z, normal.z); - if (iswater > 0.4){ - float bumpmult = 1.; - if (iswater > 0.9) - bumpmult = 1.; - float parallaxMult = bumpmult; - vec3 posxz = p3+cameraPosition; - posxz.xz-=posxz.y; - if (iswater < 0.9) - posxz.xz *= 3.0; - vec3 bump; - - - posxz.xyz = getParallaxDisplacement(posxz,iswater,bumpmult,normalize(tbnMatrix*fragpos)); - - bump = normalize(getWaveHeight(posxz.xz,iswater)); - - - - bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); - - normal = normalize(bump * tbnMatrix); - } - - - vec3 diffuseLight = texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb; - vec3 color = diffuseLight*albedo*8./150./3.; - - - if (iswater > 0.0){ - float f0 = iswater > 0.1? 0.02 : 0.05*(1.0-gl_FragData[0].a); - - float roughness = 0.02; - - float emissive = 0.0; - float F0 = f0; - - vec3 reflectedVector = reflect(normalize(fragpos), normal); - float normalDotEye = dot(normal, normalize(fragpos)); - float fresnel = pow(clamp(1.0 + normalDotEye,0.0,1.0), 5.0); - fresnel = mix(F0,1.0,fresnel); - if (iswater > 0.4){ - fresnel = fresnel*0.87+0.04; //faking additionnal roughness to the water - roughness = 0.1; - } - - - - vec3 wrefl = mat3(gbufferModelViewInverse)*reflectedVector; - vec4 sky_c = skyCloudsFromTex(wrefl,gaux1)*(1.0-isEyeInWater); - sky_c.rgb *= lmtexcoord.w*lmtexcoord.w*255*255/240./240./150.*8./3.; - - - - - - vec4 reflection = vec4(sky_c.rgb,0.); - #ifdef SCREENSPACE_REFLECTIONS - vec3 rtPos = rayTrace(reflectedVector,fragpos.xyz,blueNoise(), fresnel); - if (rtPos.z <1.){ - - vec4 fragpositionPrev = gbufferProjectionInverse * vec4(rtPos*2.-1.,1.); - fragpositionPrev /= fragpositionPrev.w; - - vec3 sampleP = fragpositionPrev.xyz; - fragpositionPrev = gbufferModelViewInverse * fragpositionPrev; - - - - vec4 previousPosition = fragpositionPrev + vec4(cameraPosition-previousCameraPosition,0.); - previousPosition = gbufferPreviousModelView * previousPosition; - previousPosition = gbufferPreviousProjection * previousPosition; - previousPosition.xy = previousPosition.xy/previousPosition.w*0.5+0.5; - reflection.a = 1.0; - reflection.rgb = texture2D(gaux2,previousPosition.xy).rgb; - } - #endif - reflection.rgb = mix(sky_c.rgb, reflection.rgb, reflection.a); - vec3 reflected= reflection.rgb*fresnel; - - - float alpha0 = gl_FragData[0].a; - - //correct alpha channel with fresnel - gl_FragData[0].a = -gl_FragData[0].a*fresnel+gl_FragData[0].a+fresnel; - gl_FragData[0].rgb =clamp(color/gl_FragData[0].a*alpha0*(1.0-fresnel)*0.1+reflected/gl_FragData[0].a*0.1,0.0,65100.0); - if (gl_FragData[0].r > 65000.) gl_FragData[0].rgba = vec4(0.); - } - else - gl_FragData[0].rgb = color*0.1; - - gl_FragData[1] = vec4(albedo,iswater); - -} +#include "/programs/all_translucent.fsh" \ No newline at end of file diff --git a/shaders/world-1/gbuffers_water.vsh b/shaders/world-1/gbuffers_water.vsh index ec64b46..afcff5d 100644 --- a/shaders/world-1/gbuffers_water.vsh +++ b/shaders/world-1/gbuffers_water.vsh @@ -1,89 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define TAA - - -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 lmtexcoord; -varying vec4 color; - varying vec4 normalMat; -varying vec3 binormal; -varying vec3 tangent; -varying float dist; -uniform mat4 gbufferModelViewInverse; -varying vec3 viewVector; -attribute vec4 at_tangent; -attribute vec4 mc_Entity; - -#define SHADOW_MAP_BIAS 0.8 - - -uniform vec2 texelSize; -uniform int framemod8; - 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.); -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -vec4 toClipSpace3(vec3 viewSpacePosition) { - return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); -} -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - - vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; - gl_Position = toClipSpace3(position); - color = gl_Color; - float mat = 0.0; - if(mc_Entity.x == 8.0 || mc_Entity.x == 9.0) { - mat = 1.0; - gl_Position.z -= 1e-4; - } - - - if(mc_Entity.x == 79.0) mat = 0.5; - if (mc_Entity.x == 10002) mat = 0.0001; - normalMat = vec4(normalize( gl_NormalMatrix*gl_Normal),mat); - - - - - tangent = normalize( gl_NormalMatrix *at_tangent.rgb); - binormal = normalize(cross(tangent.rgb,normalMat.xyz)*at_tangent.w); - - mat3 tbnMatrix = mat3(tangent.x, binormal.x, normalMat.x, - tangent.y, binormal.y, normalMat.y, - tangent.z, binormal.z, normalMat.z); - - dist = length(gl_ModelViewMatrix * gl_Vertex); - - viewVector = ( gl_ModelViewMatrix * gl_Vertex).xyz; - viewVector = normalize(tbnMatrix * viewVector); - - - - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif - -} +#include "/programs/all_translucent.vsh" \ No newline at end of file diff --git a/shaders/world-1/lib/ACES.glsl b/shaders/world-1/lib/ACES.glsl deleted file mode 100644 index d9d6ce7..0000000 --- a/shaders/world-1/lib/ACES.glsl +++ /dev/null @@ -1,382 +0,0 @@ -#define log10(x) log(x) / log(10.0) - - struct ColorCorrection { - float saturation; - float vibrance; - vec3 lum; - float contrast; - float contrastMidpoint; - - vec3 gain; - vec3 lift; - vec3 InvGamma; -} m; - - -float sigmoid_shaper(float x) { // Sigmoid function in the range 0 to 1 spanning -2 to +2. - float t = max(1.0 - abs(0.5 * x), 0.0); - float y = 1.0 + sign(x) * (1.0 - t * t); - - return 0.5 * y; -} - -float rgb_2_saturation(vec3 rgb) { - float minrgb = min(min(rgb.r, rgb.g), rgb.b); - float maxrgb = max(max(rgb.r, rgb.g), rgb.b); - - return (max(maxrgb, 1e-10) - max(minrgb, 1e-10)) / max(maxrgb, 1e-2); -} - -float rgb_2_yc(vec3 rgb) { // Converts RGB to a luminance proxy, here called YC. YC is ~ Y + K * Chroma. - float ycRadiusWeight = 1.75; - float r = rgb[0]; float g = rgb[1]; float b = rgb[2]; - float chroma = sqrt(b * (b - g) + g * (g - r) + r * (r - b)); - - return (b + g + r + ycRadiusWeight * chroma) / 3.0; -} - -float glow_fwd(float ycIn, float glowGainIn, float glowMid) { - float glowGainOut; - - if (ycIn <= 2.0 / 3.0 * glowMid) { - glowGainOut = glowGainIn; - } else if ( ycIn >= 2.0 * glowMid) { - glowGainOut = 0; - } else { - glowGainOut = glowGainIn * (glowMid / ycIn - 0.5); - } - - return glowGainOut; -} - -float rgb_2_hue(vec3 rgb) { // Returns a geometric hue angle in degrees (0-360) based on RGB values. - float hue; - if (rgb[0] == rgb[1] && rgb[1] == rgb[2]) { // For neutral colors, hue is undefined and the function will return a quiet NaN value. - hue = 0; - } else { - hue = (180.0 / 3.1415) * atan(2.0 * rgb[0] - rgb[1] - rgb[2], sqrt(3.0) * (rgb[1] - rgb[2])); // flip due to opengl spec compared to hlsl - } - - if (hue < 0.0) - hue = hue + 360.0; - - return clamp(hue, 0.0, 360.0); -} - -float center_hue(float hue, float centerH) { - float hueCentered = hue - centerH; - - if (hueCentered < -180.0) { - hueCentered += 360.0; - } else if (hueCentered > 180.0) { - hueCentered -= 360.0; - } - - return hueCentered; -} - -// Transformations between CIE XYZ tristimulus values and CIE x,y -// chromaticity coordinates -vec3 XYZ_2_xyY( vec3 XYZ ) { - float divisor = max(XYZ[0] + XYZ[1] + XYZ[2], 1e-10); - - vec3 xyY = XYZ.xyy; - xyY.rg = XYZ.rg / divisor; - - return xyY; -} - -vec3 xyY_2_XYZ(vec3 xyY) { - vec3 XYZ = vec3(0.0); - XYZ.r = xyY.r * xyY.b / max(xyY.g, 1e-10); - XYZ.g = xyY.b; - XYZ.b = (1.0 - xyY.r - xyY.g) * xyY.b / max(xyY.g, 1e-10); - - return XYZ; -} - -mat3 ChromaticAdaptation( vec2 src_xy, vec2 dst_xy ) { - // Von Kries chromatic adaptation - - // Bradford - const mat3 ConeResponse = mat3( - vec3(0.8951, 0.2664, -0.1614), - vec3(-0.7502, 1.7135, 0.0367), - vec3(0.0389, -0.0685, 1.0296) - ); - const mat3 InvConeResponse = mat3( - vec3(0.9869929, -0.1470543, 0.1599627), - vec3(0.4323053, 0.5183603, 0.0492912), - vec3(-0.0085287, 0.0400428, 0.9684867) - ); - - vec3 src_XYZ = xyY_2_XYZ( vec3( src_xy, 1 ) ); - vec3 dst_XYZ = xyY_2_XYZ( vec3( dst_xy, 1 ) ); - - vec3 src_coneResp = src_XYZ * ConeResponse; - vec3 dst_coneResp = dst_XYZ * ConeResponse; - - mat3 VonKriesMat = mat3( - vec3(dst_coneResp[0] / src_coneResp[0], 0.0, 0.0), - vec3(0.0, dst_coneResp[1] / src_coneResp[1], 0.0), - vec3(0.0, 0.0, dst_coneResp[2] / src_coneResp[2]) - ); - - return (ConeResponse * VonKriesMat) * InvConeResponse; -} - -/******************************************************************************* - - Color CorrectionUE4 Style - ******************************************************************************/ - - // Accurate for 1000K < Temp < 15000K -// [Krystek 1985, "An algorithm to calculate correlated colour temperature"] -vec2 PlanckianLocusChromaticity(float Temp) { - float u = ( 0.860117757f + 1.54118254e-4f * Temp + 1.28641212e-7f * Temp*Temp ) / ( 1.0f + 8.42420235e-4f * Temp + 7.08145163e-7f * Temp*Temp ); - float v = ( 0.317398726f + 4.22806245e-5f * Temp + 4.20481691e-8f * Temp*Temp ) / ( 1.0f - 2.89741816e-5f * Temp + 1.61456053e-7f * Temp*Temp ); - - float x = 3.0*u / ( 2.0*u - 8.0*v + 4.0 ); - float y = 2.0*v / ( 2.0*u - 8.0*v + 4.0 ); - - return vec2(x, y); -} - - vec2 D_IlluminantChromaticity(float Temp) { - // Accurate for 4000K < Temp < 25000K - // in: correlated color temperature - // out: CIE 1931 chromaticity - // Correct for revision of Plank's law - // This makes 6500 == D65 - Temp *= 1.4388 / 1.438; - - float x = Temp <= 7000 ? - 0.244063 + ( 0.09911e3 + ( 2.9678e6 - 4.6070e9 / Temp ) / Temp ) / Temp : - 0.237040 + ( 0.24748e3 + ( 1.9018e6 - 2.0064e9 / Temp ) / Temp ) / Temp; - - float y = -3 * x*x + 2.87 * x - 0.275; - - return vec2(x,y); -} - -vec2 PlanckianIsothermal( float Temp, float Tint ) { - float u = ( 0.860117757f + 1.54118254e-4f * Temp + 1.28641212e-7f * Temp*Temp ) / ( 1.0f + 8.42420235e-4f * Temp + 7.08145163e-7f * Temp*Temp ); - float v = ( 0.317398726f + 4.22806245e-5f * Temp + 4.20481691e-8f * Temp*Temp ) / ( 1.0f - 2.89741816e-5f * Temp + 1.61456053e-7f * Temp*Temp ); - - float ud = ( -1.13758118e9f - 1.91615621e6f * Temp - 1.53177f * Temp*Temp ) / pow( 1.41213984e6f + 1189.62f * Temp + Temp*Temp, 2.0 ); - float vd = ( 1.97471536e9f - 705674.0f * Temp - 308.607f * Temp*Temp ) / pow( 6.19363586e6f - 179.456f * Temp + Temp*Temp , 2.0); //don't pow2 this - - vec2 uvd = normalize( vec2( u, v ) ); - - // Correlated color temperature is meaningful within +/- 0.05 - u += -uvd.y * Tint * 0.05; - v += uvd.x * Tint * 0.05; - - float x = 3*u / ( 2*u - 8*v + 4 ); - float y = 2*v / ( 2*u - 8*v + 4 ); - - return vec2(x,y); -} - -vec3 WhiteBalance(vec3 LinearColor) { - const float WhiteTemp = float(WHITE_BALANCE); - const float WhiteTint = 0.0; - vec2 SrcWhiteDaylight = D_IlluminantChromaticity( WhiteTemp ); - vec2 SrcWhitePlankian = PlanckianLocusChromaticity( WhiteTemp ); - - vec2 SrcWhite = WhiteTemp < 4000 ? SrcWhitePlankian : SrcWhiteDaylight; - const vec2 D65White = vec2(0.31270, 0.32900); - - // Offset along isotherm - vec2 Isothermal = PlanckianIsothermal( WhiteTemp, WhiteTint ) - SrcWhitePlankian; - SrcWhite += Isothermal; - - mat3x3 WhiteBalanceMat = ChromaticAdaptation( SrcWhite, D65White ); - WhiteBalanceMat = (sRGB_2_XYZ_MAT * WhiteBalanceMat) * XYZ_2_sRGB_MAT; - - return LinearColor * WhiteBalanceMat * 1.0; -} - -/******************************************************************************* - - ACES Fimic Curve Approx. - ******************************************************************************/ - -// ACES settings -const float FilmSlope = Film_Slope; //0.90 -const float FilmToe = Film_Toe; //0.55 -const float FilmShoulder = Film_Shoulder; //0.25 -const float FilmBlackClip = Black_Clip; -const float FilmWhiteClip = White_Clip; -const float BlueCorrection = Blue_Correction; -const float ExpandGamut = Gamut_Expansion; - -vec3 FilmToneMap(vec3 LinearColor) { - const mat3 AP0_2_sRGB = (AP0_2_XYZ_MAT * D60_2_D65_CAT) * XYZ_2_sRGB_MAT; - const mat3 AP1_2_sRGB = (AP1_2_XYZ_MAT * D60_2_D65_CAT) * XYZ_2_sRGB_MAT; - - const mat3 AP0_2_AP1 = AP0_2_XYZ_MAT * XYZ_2_AP1_MAT; - const mat3 AP1_2_AP0 = AP1_2_XYZ_MAT * XYZ_2_AP0_MAT; - - vec3 ColorAP1 = LinearColor * AP0_2_AP1; - float LumaAP1 = dot( ColorAP1, AP1_RGB2Y ); - - vec3 ChromaAP1 = ColorAP1 / LumaAP1; - - float ChromaDistSqr = dot( ChromaAP1 - 1, ChromaAP1 - 1 ); - float ExpandAmount = ( 1 - exp2( -4 * ChromaDistSqr ) ) * ( 1 - exp2( -4 * ExpandGamut * LumaAP1*LumaAP1 ) ); - - const mat3 Wide_2_XYZ_MAT = mat3( - vec3(0.5441691, 0.2395926, 0.1666943), - vec3(0.2394656, 0.7021530, 0.0583814), - vec3(-0.0023439, 0.0361834, 1.0552183) - ); - - const mat3 Wide_2_AP1 = Wide_2_XYZ_MAT * XYZ_2_AP1_MAT; - const mat3 ExpandMat = AP1_2_sRGB * Wide_2_AP1; - - vec3 ColorExpand = ColorAP1 * ExpandMat; - ColorAP1 = mix(ColorAP1, ColorExpand, ExpandAmount); - - const mat3 BlueCorrect = mat3( - vec3(0.9404372683, -0.0183068787, 0.0778696104), - vec3(0.0083786969, 0.8286599939, 0.1629613092), - vec3(0.0005471261, -0.0008833746, 1.0003362486) - ); - const mat3 BlueCorrectInv = mat3( - vec3(1.06318, 0.0233956, -0.0865726), - vec3(-0.0106337, 1.20632, -0.19569), - vec3(-0.000590887, 0.00105248, 0.999538) - ); - - const mat3 BlueCorrectAP1 = (AP1_2_AP0 * BlueCorrect) * AP0_2_AP1; - const mat3 BlueCorrectInvAP1 = (AP1_2_AP0 * BlueCorrectInv) * AP0_2_AP1; - - // Blue correction - ColorAP1 = mix(ColorAP1, ColorAP1 * BlueCorrectAP1, BlueCorrection); - - vec3 ColorAP0 = LinearColor * AP1_2_AP0; - - // "Glow" module constants - const float RRT_GLOW_GAIN = 0.05; - const float RRT_GLOW_MID = 0.08; - - float saturation = rgb_2_saturation(ColorAP0); - float ycIn = rgb_2_yc(ColorAP0); - float s = sigmoid_shaper((saturation - 0.4) * 5.0); - float addedGlow = 1.0 + glow_fwd(ycIn, RRT_GLOW_GAIN * s, RRT_GLOW_MID) * 3; - ColorAP0 *= addedGlow; - - // --- Red modifier --- // - const float RRT_RED_SCALE = 0.99; - const float RRT_RED_PIVOT = 0.22; - const float RRT_RED_HUE = 0.15; - const float RRT_RED_WIDTH = 135.0; - float hue = rgb_2_hue(ColorAP0); - float centeredHue = center_hue(hue, RRT_RED_HUE); - float hueWeight = pow(smoothstep(0.0, 1.0, 1.0 - abs(2.0 * centeredHue / RRT_RED_WIDTH)), 2.0); - - ColorAP0.r += hueWeight * saturation * (RRT_RED_PIVOT - ColorAP0.r) * (1.0 - RRT_RED_SCALE); - - // Use ACEScg primaries as working space - vec3 WorkingColor = ColorAP0 * AP0_2_AP1_MAT * 1.2; - WorkingColor = max(vec3(0.0), WorkingColor) * 1.1; - WorkingColor = mix(vec3(dot(WorkingColor, AP1_RGB2Y)), WorkingColor, 0.96); // Pre desaturate - - const float ToeScale = 1.0 + FilmBlackClip - FilmToe; - const float ShoulderScale = 1.0 + FilmWhiteClip - FilmShoulder; - - const float InMatch = in_Match; - const float OutMatch = Out_Match; - - float ToeMatch = 0.0; - if(FilmToe > 0.8) { - // 0.18 will be on straight segment - ToeMatch = (1.0 - FilmToe - OutMatch) / FilmSlope + log10(InMatch); - } else { - // 0.18 will be on toe segment - // Solve for ToeMatch such that input of InMatch gives output of OutMatch. - const float bt = (OutMatch + FilmBlackClip) / ToeScale - 1.0; - ToeMatch = log10(InMatch) - 0.5 * log((1.0 + bt) / (1.0 - bt)) * (ToeScale / FilmSlope); - } - - float StraightMatch = (1.0 - FilmToe) / FilmSlope - ToeMatch; - float ShoulderMatch = FilmShoulder / FilmSlope - StraightMatch; - - vec3 LogColor = log10(WorkingColor); - vec3 StraightColor = FilmSlope * (LogColor + StraightMatch); - - vec3 ToeColor = (-FilmBlackClip) + (2.0 * ToeScale) / (1.0 + exp((-2.0 * FilmSlope / ToeScale) * (LogColor - ToeMatch))); - vec3 ShoulderColor = (1.0 + FilmWhiteClip) - (2.0 * ShoulderScale) / (1.0 + exp(( 2.0 * FilmSlope / ShoulderScale) * (LogColor - ShoulderMatch))); - - for(int i = 0; i < 1; ++i) { - ToeColor[i] = LogColor[i] < ToeMatch ? ToeColor[i] : StraightColor[i]; - ShoulderColor[i] = LogColor[i] > ShoulderMatch ? ShoulderColor[i] : StraightColor[i]; - } - - vec3 t = clamp((LogColor - ToeMatch) / (ShoulderMatch - ToeMatch), 0.0, 1.0); - t = ShoulderMatch < ToeMatch ? 1.0 - t : t; - t = (3.0 - 2.0 * t) * t * t; - - vec3 ToneColor = mix(ToeColor, ShoulderColor, t); - ToneColor = mix(vec3(dot(ToneColor, AP1_RGB2Y)), ToneColor, 0.93); // Post desaturate - - ToneColor = mix(ToneColor, ToneColor * BlueCorrectInvAP1, BlueCorrection); - - // Returning positive AP1 values - return max(vec3(0.0), ToneColor * AP1_2_sRGB); -} - -vec3 Saturation(vec3 color, ColorCorrection m) { - float grey = dot(color, m.lum); - return grey + m.saturation * (color - grey); -} - -vec3 Vibrance(vec3 color, ColorCorrection m) { - float maxColor = max(color.r, max(color.g, color.b)); - float minColor = min(color.r, min(color.g, color.b)); - - float colorSaturation = maxColor - minColor; - - float grey = dot(color, m.lum); - color = mix(vec3(grey), color, 1.0 + m.vibrance * (1.0 - sign(m.vibrance) * colorSaturation)); - - return color; -} - -vec3 LiftGammaGain(vec3 v, ColorCorrection m) { - vec3 lerpV = clamp(pow(v, m.InvGamma), 0.0, 1.0); - return m.gain * lerpV + m.lift * (1.0 - lerpV); -} - -float LogContrast(float x, const float eps, float logMidpoint, float contrast) { - float logX = log2(x + eps); - float adjX = (logX - logMidpoint) / contrast + logMidpoint; - - return max(exp2(adjX) - eps, 0.0); -} - -vec3 Contrast(vec3 color, ColorCorrection m) { - const float contrastEpsilon = 1e-5; - - vec3 ret; - ret.x = LogContrast(color.x, contrastEpsilon, log2(0.18), m.contrast); - ret.y = LogContrast(color.y, contrastEpsilon, log2(0.18), m.contrast); - ret.z = LogContrast(color.z, contrastEpsilon, log2(0.18), m.contrast); - - return ret; -} - -vec3 srgbToLinear(vec3 srgb) { - return mix( - srgb * 0.07739938080495356, // 1.0 / 12.92 = ~0.07739938080495356 - pow(0.947867 * srgb + 0.0521327, vec3(2.4)), - step(0.04045, srgb) - ); -} - -vec3 linearToSrgb(vec3 linear) { - return mix( - linear * 12.92, - pow(linear, vec3(0.416666666667)) * 1.055 - 0.055, // 1.0 / 2.4 = ~0.416666666667 - step(0.0031308, linear) - ); -} diff --git a/shaders/world-1/lib/ACESSPL.glsl b/shaders/world-1/lib/ACESSPL.glsl deleted file mode 100644 index 81c4ffd..0000000 --- a/shaders/world-1/lib/ACESSPL.glsl +++ /dev/null @@ -1,115 +0,0 @@ -#define log10(x) log(x) / log(10.0) - - -struct SegmentedSplineParams_c5 { - float coefsLow[6]; // coefs for B-spline between minPoint and midPoint (units of log luminance) - float coefsHigh[6]; // coefs for B-spline between midPoint and maxPoint (units of log luminance) - vec2 minPoint; // {luminance, luminance} linear extension below this - vec2 midPoint; // {luminance, luminance} - vec2 maxPoint; // {luminance, luminance} linear extension above this - float slopeLow; // log-log slope of low linear extension - float slopeHigh; // log-log slope of high linear extension -}; - -struct SegmentedSplineParams_c9 { - float coefsLow[10]; // coefs for B-spline between minPoint and midPoint (units of log luminance) - float coefsHigh[10]; // coefs for B-spline between midPoint and maxPoint (units of log luminance) - float slopeLow; // log-log slope of low linear extension - float slopeHigh; // log-log slope of high linear extension -}; - -const mat3 M = mat3( - 0.5, -1.0, 0.5, - -1.0, 1.0, 0.5, - 0.5, 0.0, 0.0 -); - -float segmented_spline_c5_fwd(float x) { - const SegmentedSplineParams_c5 C = SegmentedSplineParams_c5( - float[6] ( -4.0000000000, -4.0000000000, -3.1573765773, -0.4852499958, 1.8477324706, 1.8477324706 ), - float[6] ( -0.7185482425, 2.0810307172, 3.6681241237, 4.0000000000, 4.0000000000, 4.0000000000 ), - vec2(0.18*exp2(-15.0), 0.0001), - vec2(0.18, 4.8), - vec2(0.18*exp2(18.0), 10000.), - 0.0, - 0.0 - ); - - const int N_KNOTS_LOW = 4; - const int N_KNOTS_HIGH = 4; - - // Check for negatives or zero before taking the log. If negative or zero, - // set to ACESMIN.1 - float xCheck = x <= 0 ? exp2(-14.0) : x; - - float logx = log10( xCheck); - float logy; - - if (logx <= log10(C.minPoint.x)) { - logy = logx * C.slopeLow + (log10(C.minPoint.y) - C.slopeLow * log10(C.minPoint.x)); - } else if ((logx > log10(C.minPoint.x)) && (logx < log10(C.midPoint.x))) { - float knot_coord = (N_KNOTS_LOW-1) * (logx-log10(C.minPoint.x))/(log10(C.midPoint.x)-log10(C.minPoint.x)); - int j = int(knot_coord); - float t = knot_coord - float(j); - - vec3 cf = vec3( C.coefsLow[ j], C.coefsLow[ j + 1], C.coefsLow[ j + 2]); - - vec3 monomials = vec3(t * t, t, 1.0); - logy = dot( monomials, M * cf); - } else if ((logx >= log10(C.midPoint.x)) && (logx < log10(C.maxPoint.x))) { - float knot_coord = (N_KNOTS_HIGH - 1) * (logx - log10(C.midPoint.x)) / (log10(C.maxPoint.x) - log10(C.midPoint.x)); - int j = int(knot_coord); - float t = knot_coord - float(j); - - vec3 cf = vec3(C.coefsHigh[j], C.coefsHigh[j + 1], C.coefsHigh[j + 2]); - vec3 monomials = vec3(t * t, t, 1.0); - - logy = dot(monomials, M * cf); - } else { - logy = logx * C.slopeHigh + (log10(C.maxPoint.y) - C.slopeHigh * log10(C.maxPoint.x)); - } - - return pow(10.0, logy); -} - -float segmented_spline_c9_fwd( float x, const SegmentedSplineParams_c9 C, const mat3x2 toningPoints) { - const int N_KNOTS_LOW = 8; - const int N_KNOTS_HIGH = 8; - - // Check for negatives or zero before taking the log. If negative or zero, - // set to OCESMIN. - float xCheck = x <= 0 ? 1e-4 : x; - - vec2 minPoint = toningPoints[0]; - vec2 midPoint = toningPoints[1]; - vec2 maxPoint = toningPoints[2]; - - float logx = log10(xCheck); - float logy; - - if (logx <= log10(minPoint.x)) { - logy = logx * C.slopeLow + (log10(minPoint.y) - C.slopeLow * log10(minPoint.x)); - } else if ((logx > log10(minPoint.x)) && (logx < log10(midPoint.x))) { - float knot_coord = (N_KNOTS_LOW - 1) * (logx - log10(minPoint.x)) / (log10(midPoint.x) - log10(minPoint.x)); - int j = int(knot_coord); - float t = knot_coord - float(j); - - vec3 cf = vec3(C.coefsLow[j], C.coefsLow[j + 1], C.coefsLow[j + 2]); - vec3 monomials = vec3(t * t, t, 1.0); - - logy = dot(monomials, M * cf); - } else if ((logx >= log10(midPoint.x)) && (logx < log10(maxPoint.x))) { - float knot_coord = (N_KNOTS_HIGH - 1) * (logx - log10(midPoint.x)) / (log10(maxPoint.x) - log10(midPoint.x)); - int j = int(knot_coord); - float t = knot_coord - float(j); - - vec3 cf = vec3(C.coefsHigh[j], C.coefsHigh[j + 1], C.coefsHigh[j + 2]); - vec3 monomials = vec3(t * t, t, 1.0); - - logy = dot(monomials, M * cf); - } else { - logy = logx * C.slopeHigh + (log10(maxPoint.y) - C.slopeHigh * log10(maxPoint.x)); - } - - return pow(10.0, logy); -} \ No newline at end of file diff --git a/shaders/world-1/lib/ACEST.glsl b/shaders/world-1/lib/ACEST.glsl deleted file mode 100644 index f8693d7..0000000 --- a/shaders/world-1/lib/ACEST.glsl +++ /dev/null @@ -1,63 +0,0 @@ - -const mat3 sRGB_2_XYZ_MAT = mat3( // Linear sRGB to XYZ color space - vec3(0.4124564, 0.3575761, 0.1804375), - vec3(0.2126729, 0.7151522, 0.0721750), - vec3(0.0193339, 0.1191920, 0.9503041) -); - -const mat3 XYZ_2_sRGB_MAT = mat3( //XYZ to linear sRGB Color Space - vec3(3.2409699419, -1.5373831776, -0.4986107603), - vec3(-0.9692436363, 1.8759675015, 0.0415550574), - vec3(0.0556300797, -0.2039769589, 1.0569715142) -); - -const mat3 D65_2_D60_CAT = mat3( // D65 to D60 White Point - vec3(1.01303, 0.00610531, -0.014971), - vec3(0.00769823, 0.998165, -0.00503203), - vec3(-0.00284131, 0.00468516, 0.924507) -); - -const mat3 D60_2_D65_CAT = mat3( //D60 to D65 White Point - vec3(0.987224, -0.00611327, 0.0159533), - vec3(-0.00759836, 1.00186, 0.00533002), - vec3(0.00307257, -0.00509595, 1.08168) -); - -const mat3 XYZ_2_AP0_MAT = mat3( // XYZ to ACEScg Color Space - vec3(1.0498110175, 0.0000000000,-0.0000974845), - vec3(-0.4959030231, 1.3733130458, 0.0982400361), - vec3(0.0000000000, 0.0000000000, 0.9912520182) -); - -const mat3 AP0_2_XYZ_MAT = mat3( // ACEScg to XYZ Color Space - vec3(0.9525523959, 0.0000000000, 0.0000936786), - vec3(0.3439664498, 0.7281660966,-0.0721325464), - vec3(0.0000000000, 0.0000000000, 1.0088251844) -); - -const mat3 XYZ_2_AP1_MAT = mat3( // XYZ to ACEStoning Color Space - vec3(1.6410233797, -0.3248032942, -0.2364246952), - vec3(-0.6636628587, 1.6153315917, 0.0167563477), - vec3(0.0117218943, -0.0082844420, 0.9883948585) -); - -const mat3 AP1_2_XYZ_MAT = mat3( // ACEStoning to XYZ Color Space - vec3(0.6624541811, 0.1340042065, 0.1561876870), - vec3(0.2722287168, 0.6740817658, 0.0536895174), - vec3(-0.0055746495, 0.0040607335, 1.0103391003) -); - -const mat3 AP0_2_AP1_MAT = mat3( // ACEScg to ACEStoneing Color Space - vec3(1.4514393161, -0.2365107469, -0.2149285693), - vec3(-0.0765537734, 1.1762296998, -0.0996759264), - vec3(0.0083161484, -0.0060324498, 0.9977163014) -); - -const mat3 AP1_2_AP0_MAT = mat3( // ACEStoning to ACEScg Color Space - vec3(0.6954522414, 0.1406786965, 0.1638690622), - vec3(0.0447945634, 0.8596711185, 0.0955343182), - vec3(-0.0055258826, 0.0040252103, 1.0015006723) -); - -const vec3 AP1_RGB2Y = vec3(0.2722287168, 0.6740817658, 0.0536895174); // Desaturation Coeff -const mat3 sRGB_2_AP0 = (sRGB_2_XYZ_MAT * D65_2_D60_CAT) * XYZ_2_AP0_MAT; \ No newline at end of file diff --git a/shaders/world-1/lib/ROBOBO_sky.glsl b/shaders/world-1/lib/ROBOBO_sky.glsl deleted file mode 100644 index ef8fcfd..0000000 --- a/shaders/world-1/lib/ROBOBO_sky.glsl +++ /dev/null @@ -1,157 +0,0 @@ -const float sunAngularSize = 0.533333; -const float moonAngularSize = 0.516667; - -//Sky coefficients and heights - -#define airNumberDensity 2.5035422e25 -#define ozoneConcentrationPeak 8e-6 -const float ozoneNumberDensity = airNumberDensity * ozoneConcentrationPeak; -#define ozoneCrossSection vec3(4.51103766177301e-21, 3.2854797958699e-21, 1.96774621921165e-22) - -#define sky_planetRadius 6731e3 - -#define sky_atmosphereHeight 110e3 -#define sky_scaleHeights vec2(8.0e3, 1.2e3) - -#define sky_mieg 0.80 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define sky_coefficientRayleighR 5.8 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] -#define sky_coefficientRayleighG 1.35 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] -#define sky_coefficientRayleighB 3.31 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] - -#define sky_coefficientRayleigh vec3(sky_coefficientRayleighR*1e-6, sky_coefficientRayleighG*1e-5, sky_coefficientRayleighB*1e-5) - - -#define sky_coefficientMieR 3.0 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] -#define sky_coefficientMieG 3.0 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] -#define sky_coefficientMieB 3.0 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] - -#define sky_coefficientMie vec3(sky_coefficientMieR*1e-6, sky_coefficientMieG*1e-6, sky_coefficientMieB*1e-6) // Should be >= 2e-6 -const vec3 sky_coefficientOzone = (ozoneCrossSection * (ozoneNumberDensity * 1.e-6)); // ozone cross section * (ozone number density * (cm ^ 3)) - -const vec2 sky_inverseScaleHeights = 1.0 / sky_scaleHeights; -const vec2 sky_scaledPlanetRadius = sky_planetRadius * sky_inverseScaleHeights; -const float sky_atmosphereRadius = sky_planetRadius + sky_atmosphereHeight; -const float sky_atmosphereRadiusSquared = sky_atmosphereRadius * sky_atmosphereRadius; - -#define sky_coefficientsScattering mat2x3(sky_coefficientRayleigh, sky_coefficientMie) -const mat3 sky_coefficientsAttenuation = mat3(sky_coefficientRayleigh, sky_coefficientMie * 1.11, sky_coefficientOzone); // commonly called the extinction coefficient - -#define sun_illuminance 128000.0 //[10000.0 20000.0 30000.0 40000.0 50000.0 60000.0 70000.0 80000.0 90000.0 100000.0 110000.0 120000.0 130000.0 140000.0 160000.0] -#define moon_illuminance 60.0 //[0.0 10.0 20.0 30.0 40.0 50.0 60.0 70.0 80.0 90.0 100.0 1000.0 10000.0 100000.0] - -#define sunColorR 1.0 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define sunColorG 0.9 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define sunColorB 0.81 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] - -#define sunColorBase (vec3(sunColorR,sunColorG,sunColorB) * sun_illuminance) -//#define sunColorBase blackbody(5778) * sun_illuminance -#define moonColorR 1.0 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define moonColorG 0.9 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define moonColorB 0.81 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] - -#define moonColorBase (vec3(moonColorR, moonColorG, moonColorB) * moon_illuminance ) //Fake Purkinje effect - -float sky_rayleighPhase(float cosTheta) { - const vec2 mul_add = vec2(0.1, 0.28) * rPI; - return cosTheta * mul_add.x + mul_add.y; // optimized version from [Elek09], divided by 4 pi for energy conservation -} - -float sky_miePhase(float cosTheta, const float g) { - float gg = g * g; - return (gg * -0.25 + 0.25) * rPI * pow(-(2.0 * g) * cosTheta + (gg + 1.0), -1.5); -} - -vec2 sky_phase(float cosTheta, const float g) { - return vec2(sky_rayleighPhase(cosTheta), sky_miePhase(cosTheta, g)); -} - -vec3 sky_density(float centerDistance) { - vec2 rayleighMie = exp(centerDistance * -sky_inverseScaleHeights + sky_scaledPlanetRadius); - - // Ozone distribution curve by Sergeant Sarcasm - https://www.desmos.com/calculator/j0wozszdwa - float ozone = exp(-max(0.0, (35000.0 - centerDistance) - sky_planetRadius) * (1.0 / 5000.0)) - * exp(-max(0.0, (centerDistance - 35000.0) - sky_planetRadius) * (1.0 / 15000.0)); - return vec3(rayleighMie, ozone); -} - -vec3 sky_airmass(vec3 position, vec3 direction, float rayLength, const float steps) { - float stepSize = rayLength * (1.0 / steps); - vec3 increment = direction * stepSize; - position += increment * 0.5; - - vec3 airmass = vec3(0.0); - for (int i = 0; i < steps; ++i, position += increment) { - airmass += sky_density(length(position)); - } - - return airmass * stepSize; -} -vec3 sky_airmass(vec3 position, vec3 direction, const float steps) { - float rayLength = dot(position, direction); - rayLength = rayLength * rayLength + sky_atmosphereRadiusSquared - dot(position, position); - if (rayLength < 0.0) return vec3(0.0); - rayLength = sqrt(rayLength) - dot(position, direction); - - return sky_airmass(position, direction, rayLength, steps); -} - -vec3 sky_opticalDepth(vec3 position, vec3 direction, float rayLength, const float steps) { - return sky_coefficientsAttenuation * sky_airmass(position, direction, rayLength, steps); -} -vec3 sky_opticalDepth(vec3 position, vec3 direction, const float steps) { - return sky_coefficientsAttenuation * sky_airmass(position, direction, steps); -} - -vec3 sky_transmittance(vec3 position, vec3 direction, const float steps) { - return exp2(-sky_opticalDepth(position, direction, steps) * rLOG2); -} - - - -vec3 calculateAtmosphere(vec3 background, vec3 viewVector, vec3 upVector, vec3 sunVector, vec3 moonVector, out vec2 pid, out vec3 transmittance, const int iSteps, float noise) { - const int jSteps = 4; - - vec3 viewPosition = (sky_planetRadius + eyeAltitude) * upVector; - - vec2 aid = rsi(viewPosition, viewVector, sky_atmosphereRadius); - if (aid.y < 0.0) {transmittance = vec3(1.0); return vec3(0.0);} - - pid = rsi(viewPosition, viewVector, sky_planetRadius * 0.998); - bool planetIntersected = pid.y >= 0.0; - - vec2 sd = vec2((planetIntersected && pid.x < 0.0) ? pid.y : max(aid.x, 0.0), (planetIntersected && pid.x > 0.0) ? pid.x : aid.y); - - float stepSize = (sd.y - sd.x) * (1.0 / iSteps); - vec3 increment = viewVector * stepSize; - vec3 position = viewVector * sd.x + viewPosition; - position += increment * (0.34*noise); - vec2 phaseSun = sky_phase(dot(viewVector, sunVector ), sky_mieg); - vec2 phaseMoon = sky_phase(dot(viewVector, moonVector), sky_mieg); - - vec3 scatteringSun = vec3(0.0); - vec3 scatteringMoon = vec3(0.0); - vec3 scatteringAmbient = vec3(0.0); - transmittance = vec3(1.0); - - for (int i = 0; i < iSteps; ++i, position += increment) { - vec3 density = sky_density(length(position)); - if (density.y > 1e35) break; - vec3 stepAirmass = density * stepSize; - vec3 stepOpticalDepth = sky_coefficientsAttenuation * stepAirmass; - - vec3 stepTransmittance = exp2(-stepOpticalDepth * rLOG2); - vec3 stepTransmittedFraction = clamp01((stepTransmittance - 1.0) / -stepOpticalDepth); - vec3 stepScatteringVisible = transmittance * stepTransmittedFraction; - - scatteringSun += sky_coefficientsScattering * (stepAirmass.xy * phaseSun ) * stepScatteringVisible * sky_transmittance(position, sunVector, jSteps); - scatteringMoon += sky_coefficientsScattering * (stepAirmass.xy * phaseMoon) * stepScatteringVisible * sky_transmittance(position, moonVector, jSteps); - // Nice way to fake multiple scattering. - scatteringAmbient += sky_coefficientsScattering * stepAirmass.xy * stepScatteringVisible; - - transmittance *= stepTransmittance; - } - - vec3 scattering = scatteringSun * sunColorBase + scatteringAmbient * background + scatteringMoon*moonColorBase; - - return scattering; -} diff --git a/shaders/world-1/lib/Shadow_Params.glsl b/shaders/world-1/lib/Shadow_Params.glsl deleted file mode 100644 index 7556167..0000000 --- a/shaders/world-1/lib/Shadow_Params.glsl +++ /dev/null @@ -1,22 +0,0 @@ -const float ambientOcclusionLevel = 0.3; //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -const float sunPathRotation = -35; //[-90 -89 -88 -87 -86 -85 -84 -83 -82 -81 -80 -79 -78 -77 -76 -75 -74 -73 -72 -71 -70 -69 -68 -67 -66 -65 -64 -63 -62 -61 -60 -59 -58 -57 -56 -55 -54 -53 -52 -51 -50 -49 -48 -47 -46 -45 -44 -43 -42 -41 -40 -39 -38 -37 -36 -35 -34 -33 -32 -31 -30 -29 -28 -27 -26 -25 -24 -23 -22 -21 -20 -19 -18 -17 -16 -15 -14 -13 -12 -11 -10 -9 -8 -7 -6 -5 -4 -3 -2 -1 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 ] - -const int shadowMapResolution = 3172; //Will probably crash at 16 384 [512 768 1024 1536 2048 3172 4096 8192 16384] -const float shadowDistance = 150; //[32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 ] Not linear at all when shadowDistanceRenderMul is set to -1.0, 175.0 is enough for 40 render distance -const float shadowDistanceRenderMul = -1.0; //[-1.0 1.0] Can help to increase shadow draw distance when set to -1.0, at the cost of performance - - -const float k = 1.8; -const float d0 = 0.04; -const float d1 = 0.61; -float a = exp(d0); -float b = (exp(d1)-a)*shadowDistance/128.0; - -vec4 BiasShadowProjection(in vec4 projectedShadowSpacePosition) { - float distortFactor = log(length(projectedShadowSpacePosition.xy)*b+a)*k; - projectedShadowSpacePosition.xy /= distortFactor; - return projectedShadowSpacePosition; -} -float calcDistort(vec2 worldpos){ - return 1.0/(log(length(worldpos)*b+a)*k); -} diff --git a/shaders/world-1/lib/clouds.glsl b/shaders/world-1/lib/clouds.glsl deleted file mode 100644 index abd35ef..0000000 --- a/shaders/world-1/lib/clouds.glsl +++ /dev/null @@ -1,16 +0,0 @@ -vec3 cloud2D(vec3 fragpos,vec3 col){ - vec3 wpos = fragpos; - float wind = frameTimeCounter/200.; - vec2 intersection = ((2000.0-cameraPosition.y)*wpos.xz*inversesqrt(wpos.y+cameraPosition.y/512.-50./512.) + cameraPosition.xz+wind)/40000.; - - - float phase = pow(clamp(dot(fragpos,sunVec),0.,1.),2.)*0.5+0.5; - - float fbm = clamp((texture2D(noisetex,intersection*vec2(1.,1.5)).a + texture2D(noisetex,intersection*vec2(2.,7.)+wind*0.4).a/2.)-0.5*(1.0-rainStrength),0.,1.) ; - - - - - return mix(col,6.*(vec3(0.9,1.2,1.5)*skyIntensityNight*0.02*(1.0-rainStrength*0.9)+17.*phase*nsunColor*skyIntensity*0.7*(1.0-rainStrength*0.9)),0.0*(fbm*fbm)*(fbm*fbm)*(fbm*clamp(wpos.y*0.9,0.,1.))); - -} \ No newline at end of file diff --git a/shaders/world-1/lib/color_dither.glsl b/shaders/world-1/lib/color_dither.glsl deleted file mode 100644 index 73c4960..0000000 --- a/shaders/world-1/lib/color_dither.glsl +++ /dev/null @@ -1,46 +0,0 @@ -//using white noise for color dithering : gives a somewhat more "filmic" look when noise is visible -float nrand( vec2 n ) -{ - return fract(sin(dot(n.xy, vec2(12.9898, 78.233)))* 43758.5453); -} - -float triangWhiteNoise( vec2 n ) -{ - - float t = fract( frameTimeCounter ); - float rnd = nrand( n + 0.07*t ); - - float center = rnd*2.0-1.0; - rnd = center*inversesqrt(abs(center)); - rnd = max(-1.0,rnd); - return rnd-sign(center); -} - -vec3 fp10Dither(vec3 color,vec2 tc01){ - float dither = triangWhiteNoise(tc01); - const vec3 mantissaBits = vec3(6.,6.,5.); - vec3 exponent = floor(log2(color)); - return color + dither*exp2(-mantissaBits)*exp2(exponent); -} - -vec3 fp16Dither(vec3 color,vec2 tc01){ - float dither = triangWhiteNoise(tc01); - const vec3 mantissaBits = vec3(10.); - vec3 exponent = floor(log2(color)); - return color + dither*exp2(-mantissaBits)*exp2(exponent); -} - -vec3 int8Dither(vec3 color,vec2 tc01){ - float dither = triangWhiteNoise(tc01); - return color + dither*exp2(-8.0); -} - -vec3 int10Dither(vec3 color,vec2 tc01){ - float dither = triangWhiteNoise(tc01); - return color + dither*exp2(-10.0); -} - -vec3 int16Dither(vec3 color,vec2 tc01){ - float dither = triangWhiteNoise(tc01); - return color + dither*exp2(-16.0); -} \ No newline at end of file diff --git a/shaders/world-1/lib/color_transforms.glsl b/shaders/world-1/lib/color_transforms.glsl deleted file mode 100644 index 4813ff4..0000000 --- a/shaders/world-1/lib/color_transforms.glsl +++ /dev/null @@ -1,131 +0,0 @@ -//faster and actually more precise than pow 2.2 -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} - -float luma(vec3 color) { - return dot(color,vec3(0.299, 0.587, 0.114)); -} -vec3 ToneMap_Hejl2015(in vec3 hdr) -{ - vec4 vh = vec4(hdr*0.85, 3.0); //0 - vec4 va = (1.75 * vh) + 0.05; //0.05 - vec4 vf = ((vh * va + 0.004f) / ((vh * (va + 0.55f) + 0.0491f))) - 0.0821f+0.000633604888; //((0+0.004)/((0*(0.05+0.55)+0.0491)))-0.0821 - return vf.xyz / vf.www; -} -const mat3 ACESInputMat = -mat3(0.59719, 0.35458, 0.04823, - 0.07600, 0.90834, 0.01566, - 0.02840, 0.13383, 0.83777 -); - -// ODT_SAT => XYZ => D60_2_D65 => sRGB -const mat3 ACESOutputMat = -mat3( 1.60475, -0.53108, -0.07367, - -0.10208, 1.10813, -0.00605, - -0.00327, -0.07276, 1.07602 -); -vec3 LinearTosRGB(in vec3 color) -{ - vec3 x = color * 12.92f; - vec3 y = 1.055f * pow(clamp(color,0.0,1.0), vec3(1.0f / 2.4f)) - 0.055f; - - vec3 clr = color; - clr.r = color.r < 0.0031308f ? x.r : y.r; - clr.g = color.g < 0.0031308f ? x.g : y.g; - clr.b = color.b < 0.0031308f ? x.b : y.b; - - return clr; -} -vec3 HableTonemap(vec3 linearColor) { - // A = shoulder strength - const float A = 0.22; - // B = linear strength - const float B = 0.3; - // C = linear angle - const float C = 0.1; - // D = toe strength - const float D = 0.4; - // E = toe numerator - const float E = 0.025; - // F = toe denominator - const float F = 0.30; - // Note: E / F = toe angle - // linearWhite = linear white point value - - vec3 x = linearColor*2.8; - vec3 color = ((x * (A * x + C * B) + D * E) / (x * (A * x + B) + D * F)) - E / F; - - const float W = 11.2; - const float white = ((W * (A * W + C * B) + D * E) / (W * (A * W + B) + D * F)) - E / F; - - return color / white; -} - -vec3 reinhard(vec3 x){ -x *= 1.66; -return x/(1.0+x); -} -vec3 ACESFilm( vec3 x ) -{ - x *= 0.23/0.267; - float a = 2.51f; - float b = 0.03f; - float c = 2.43f; - float d = 0.59f; - float e = 0.14f; - return (x*(a*x+b))/(x*(c*x+d)+e); -} - -// From https://www.shadertoy.com/view/WdjSW3 -vec3 Tonemap_Lottes(vec3 x) { - // Lottes 2016, "Advanced Techniques and Optimization of HDR Color Pipelines" - const float a = 1.7; - const float d = 0.92; - const float hdrMax = 3.0; - const float midIn = 0.2475; - const float midOut = 0.267; - - // Can be precomputed - const float b = - (-pow(midIn, a) + pow(hdrMax, a) * midOut) / - ((pow(hdrMax, a * d) - pow(midIn, a * d)) * midOut); - const float c = - (pow(hdrMax, a * d) * pow(midIn, a) - pow(hdrMax, a) * pow(midIn, a * d) * midOut) / - ((pow(hdrMax, a * d) - pow(midIn, a * d)) * midOut); - - return pow(x,vec3(a)) / (pow(x, vec3(a * d)) * b + c); -} -// From https://www.shadertoy.com/view/WdjSW3 -vec3 Tonemap_Uchimura(vec3 x, float P, float a, float m, float l, float c, float b) { - // Uchimura 2017, "HDR theory and practice" - // Math: https://www.desmos.com/calculator/gslcdxvipg - // Source: https://www.slideshare.net/nikuque/hdr-theory-and-practicce-jp - float l0 = ((P - m) * l) / a; - float L0 = m - m / a; - float L1 = m + (1.0 - m) / a; - float S0 = m + l0; - float S1 = m + a * l0; - float C2 = (a * P) / (P - S1); - float CP = -C2 / P; - - vec3 w0 = 1.0 - smoothstep(0.0, m, x); - vec3 w2 = step(m + l0, x); - vec3 w1 = 1.0 - w0 - w2; - - vec3 T = m * pow(x / m, vec3(c)) + b; - vec3 S = P - (P - S1) * exp(CP * (x - S0)); - vec3 L = m + a * (x - m); - - return T * w0 + L * w1 + S * w2; -} - -vec3 Tonemap_Uchimura(vec3 x) { - const float P = 1.0; // max display brightness - const float a = 1.0; // contrast - const float m = 0.22; // linear section start - const float l = 0.4; // linear section length - const float c = 1.33; // black - const float b = 0.0; // pedestal - return Tonemap_Uchimura(x, P, a, m, l, c, b); -} diff --git a/shaders/world-1/lib/composite3.fsh b/shaders/world-1/lib/composite3.fsh deleted file mode 100644 index cb2a2ba..0000000 --- a/shaders/world-1/lib/composite3.fsh +++ /dev/null @@ -1,78 +0,0 @@ -#version 120 -//Horizontal bilateral blur for volumetric fog + Forward rendered objects + Draw volumetric fog -#extension GL_EXT_gpu_shader4 : enable - - - -varying vec2 texcoord; -flat varying vec3 zMults; -uniform sampler2D depthtex0; -uniform sampler2D colortex3; -uniform sampler2D colortex2; -uniform sampler2D colortex0; - -uniform int frameCounter; -uniform float far; -uniform float near; -uniform int isEyeInWater; - -uniform vec2 texelSize; -float ld(float depth) { - return 1.0 / (zMults.y - depth * zMults.z); // (-depth * (far - near)) = (2.0 * near)/ld - far - near -} - -vec4 BilateralUpscale(sampler2D tex, sampler2D depth,vec2 coord,float frDepth){ - vec4 vl = vec4(0.0); - float sum = 0.0; - mat3x3 weights; - ivec2 posD = ivec2(coord/2.0)*2; - ivec2 posVl = ivec2(coord/2.0); - float dz = zMults.x; - ivec2 pos = (ivec2(gl_FragCoord.xy+frameCounter) % 3 ); - //pos = ivec2(1,-1); - - ivec2 tcDepth = posD + ivec2(-2,-2) + pos*2; - float dsample = ld(texelFetch2D(depth,tcDepth,0).r); - float w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(-1)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(-2,0) + pos*2; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(-1,0)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(0) + pos*2; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(0)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(0,-2) + pos*2; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(0,-1)+pos,0)*w; - sum += w; - - return vl/sum; -} - -void main() { -/* DRAWBUFFERS:0 */ - - //3x3 bilateral upscale from half resolution - float frDepth = ld(texture2D(depthtex0,texcoord).x); - vec4 vl = BilateralUpscale(colortex0,depthtex0,gl_FragCoord.xy,frDepth); - - vec3 color = texture2D(colortex3,texcoord).rgb; - vec4 transparencies = texture2D(colortex2,texcoord); - color = color*(1.0-transparencies.a)+transparencies.rgb*10.; - - color *= vl.a; - color += vl.rgb; - - gl_FragData[0].rgb = clamp(color,6.11*1e-5,65000.0); - - gl_FragData[0].a = vl.a; -} diff --git a/shaders/world-1/lib/projections.glsl b/shaders/world-1/lib/projections.glsl deleted file mode 100644 index 72ab381..0000000 --- a/shaders/world-1/lib/projections.glsl +++ /dev/null @@ -1,55 +0,0 @@ -uniform mat4 gbufferProjection; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferPreviousProjection; -uniform mat4 gbufferModelViewInverse; -uniform mat4 gbufferModelView; -uniform mat4 shadowModelView; -uniform mat4 shadowProjection; - -uniform vec3 cameraPosition; - - -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) - -vec3 toClipSpace3(vec3 viewSpacePosition) { - return projMAD(gbufferProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; -} - -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; -} - -vec3 toScreenSpaceVector(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 normalize(fragposition.xyz); -} - -vec3 toWorldSpace(vec3 p3){ - p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; - return p3; -} - -vec3 toWorldSpaceCamera(vec3 p3){ - p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; - return p3 + cameraPosition; -} - -vec3 toShadowSpace(vec3 p3){ - p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; - p3 = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; - return p3; -} - -vec3 toShadowSpaceProjected(vec3 p3){ - p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; - p3 = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; - p3 = diagonal3(shadowProjection) * p3 + shadowProjection[3].xyz; - - return p3; -} diff --git a/shaders/world-1/lib/sky_gradient.glsl b/shaders/world-1/lib/sky_gradient.glsl deleted file mode 100644 index 559faf3..0000000 --- a/shaders/world-1/lib/sky_gradient.glsl +++ /dev/null @@ -1,84 +0,0 @@ -#define DRAW_SUN //if not using custom sky -#define SKY_BRIGHTNESS_DAY 1.0 //[0.0 0.5 0.75 1. 1.2 1.4 1.6 1.8 2.0] -#define SKY_BRIGHTNESS_NIGHT 1.0 //[0.0 0.5 0.75 1. 1.2 1.4 1.6 1.8 2.0] -#define ffstep(x,y) clamp((y - x) * 1e35,0.0,1.0) -vec3 drawSun(float cosY, float sunInt,vec3 nsunlight,vec3 inColor){ - return inColor+nsunlight/0.0008821203*pow(smoothstep(cos(0.0093084168595*3.2),cos(0.0093084168595*1.8),cosY),3.)*0.62; -} -const float pi = 3.141592653589793238462643383279502884197169; -vec2 sphereToCarte(vec3 dir) { - float lonlat = atan(-dir.x, -dir.z); - return vec2(lonlat * (0.5/pi) +0.5,0.5*dir.y+0.5); -} -vec3 skyFromTex(vec3 pos,sampler2D sampler){ - vec2 p = sphereToCarte(pos); - return texture2D(sampler,p*texelSize*256.+vec2(18.5,1.5)*texelSize).rgb; -} -float w0(float a) -{ - return (1.0/6.0)*(a*(a*(-a + 3.0) - 3.0) + 1.0); -} - -float w1(float a) -{ - return (1.0/6.0)*(a*a*(3.0*a - 6.0) + 4.0); -} - -float w2(float a) -{ - return (1.0/6.0)*(a*(a*(-3.0*a + 3.0) + 3.0) + 1.0); -} - -float w3(float a) -{ - return (1.0/6.0)*(a*a*a); -} - -float g0(float a) -{ - return w0(a) + w1(a); -} - -float g1(float a) -{ - return w2(a) + w3(a); -} - -float h0(float a) -{ - return -1.0 + w1(a) / (w0(a) + w1(a)); -} - -float h1(float a) -{ - return 1.0 + w3(a) / (w2(a) + w3(a)); -} - -vec4 texture2D_bicubic(sampler2D tex, vec2 uv) -{ - vec4 texelSize = vec4(texelSize,1.0/texelSize); - uv = uv*texelSize.zw; - vec2 iuv = floor( uv ); - vec2 fuv = fract( uv ); - - float g0x = g0(fuv.x); - float g1x = g1(fuv.x); - float h0x = h0(fuv.x); - float h1x = h1(fuv.x); - float h0y = h0(fuv.y); - float h1y = h1(fuv.y); - - vec2 p0 = (vec2(iuv.x + h0x, iuv.y + h0y) - 0.5) * texelSize.xy; - vec2 p1 = (vec2(iuv.x + h1x, iuv.y + h0y) - 0.5) * texelSize.xy; - vec2 p2 = (vec2(iuv.x + h0x, iuv.y + h1y) - 0.5) * texelSize.xy; - vec2 p3 = (vec2(iuv.x + h1x, iuv.y + h1y) - 0.5) * texelSize.xy; - - return g0(fuv.y) * (g0x * texture2D(tex, p0) + - g1x * texture2D(tex, p1)) + - g1(fuv.y) * (g0x * texture2D(tex, p2) + - g1x * texture2D(tex, p3)); -} -vec4 skyCloudsFromTex(vec3 pos,sampler2D sampler){ - vec2 p = sphereToCarte(pos); - return texture2D(sampler,p*texelSize*256.+vec2(18.5+257.,1.5)*texelSize); -} diff --git a/shaders/world-1/lib/specular.glsl b/shaders/world-1/lib/specular.glsl deleted file mode 100644 index 40a8df9..0000000 --- a/shaders/world-1/lib/specular.glsl +++ /dev/null @@ -1,410 +0,0 @@ -//#define Specular_Reflections // reflections on blocks. REQUIRES A PBR RESOURCEPACK. -#define Screen_Space_Reflections // toggle screenspace reflections. if you want normal performance but still want a bit of shiny, the sun reflection stays on when this is turned off. -#define Sky_reflection // just in case you dont want it i guess -// #define Rough_reflections // turns the roughness GGXVNDF ON. sizable performance impact, and introduces alot of noise. - -#define Sun_specular_Strength 3 // increase for more sparkles [1 2 3 4 5 6 7 8 9 10] -#define reflection_quality 30 // adjust the quality of the screenspace reflections. [6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 25 30 35 40 45 50 55 60 65 70 75 80 85 90 95 100 ] -#define Roughness_Threshold 1.5 // using a curve on the roughness, make the reflections more or less visible on rough surfaces. good for hiding noise on rough materials [1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 ] - -// #define SCREENSHOT_MODE // go render mode and accumulate frames for as long as you want for max image quality. - -uniform sampler2D gaux1; -uniform int framemod8; - -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.); - - -// sun specular stuff -float square(float x){ - return x*x; -} -float g(float NdotL, float roughness){ - float alpha = square(max(roughness, 0.02)); - return 2.0 * NdotL / (NdotL + sqrt(square(alpha) + (1.0 - square(alpha)) * square(NdotL))); -} -float gSimple(float dp, float roughness){ - float k = roughness + 1; - k *= k/8.0; - return dp / (dp * (1.0-k) + k); -} -vec3 GGX2(vec3 n, vec3 v, vec3 l, float r, vec3 F0) { - - float roughness = r; // when roughness is zero it fucks up - - float alpha = square(roughness) + 1e-4; - - - vec3 h = normalize(l + v); - - float dotLH = clamp(dot(h,l),0.,1.); - float dotNH = clamp(dot(h,n),0.,1.); - float dotNL = clamp(dot(n,l),0.,1.); - float dotNV = clamp(dot(n,v),0.,1.); - float dotVH = clamp(dot(h,v),0.,1.); - - - float D = alpha / (3.141592653589793*square(square(dotNH) * (alpha - 1.0) + 1.0)); - float G = gSimple(dotNV, roughness) * gSimple(dotNL, roughness); - vec3 F = F0 + (1. - F0) * exp2((-5.55473*dotVH-6.98316)*dotVH); - - return dotNL * F * (G * D / (4 * dotNV * dotNL + 1e-7)); -} - - -// other shit -float invLinZ (float lindepth){ - return -((2.0*near/lindepth)-far-near)/(far-near); -} -vec3 toClipSpace3(vec3 viewSpacePosition) { - return projMAD(gbufferProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; -} -float linZ(float depth) { - return (2.0 * near) / (far + near - depth * (far - near)); - // l = (2*n)/(f+n-d(f-n)) - // f+n-d(f-n) = 2n/l - // -d(f-n) = ((2n/l)-f-n) - // d = -((2n/l)-f-n)/(f-n) - -} - -void frisvad(in vec3 n, out vec3 f, out vec3 r){ - if(n.z < -0.9) { - f = vec3(0.,-1,0); - r = vec3(-1, 0, 0); - } else { - float a = 1./(1.+n.z); - float b = -n.x*n.y*a; - f = vec3(1. - n.x*n.x*a, b, -n.x) ; - r = vec3(b, 1. - n.y*n.y*a , -n.y); - } -} - -mat3 CoordBase(vec3 n){ - vec3 x,y; - frisvad(n,x,y); - return mat3(x,y,n); -} - -float unpackRoughness(float x){ - float r = 1.0 - x; - return clamp(r*r,0,1); -} - -vec2 R2_samples_spec(int n){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha * n); -} - -vec3 sampleGGXVNDF(vec3 V_, float roughness, float U1, float U2){ - // stretch view - vec3 V = normalize(vec3(roughness * V_.x, roughness * V_.y, V_.z)); - // orthonormal basis - vec3 T1 = (V.z < 0.9999) ? normalize(cross(V, vec3(0,0,1))) : vec3(1,0,0); - vec3 T2 = cross(T1, V); - // sample point with polar coordinates (r, phi) - float a = 1.0 / (1.0 + V.z); - float r = sqrt(U1*0.25); - float phi = (U2 -near) ? - (-near -position.z) / dir.z : far*sqrt(3.); - vec3 direction = normalize(toClipSpace3(position+dir*rayLength)-clipPosition); //convert to clip space - direction.xy = normalize(direction.xy); - - //get at which length the ray intersects with the edge of the screen - vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; - float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z); - - vec3 stepv = direction * mult / quality*vec3(1,1,1.0); - // if(hand) dither *= 0.1 ; - vec3 spos = clipPosition*vec3(1,1,1.0) + stepv*dither; - - float minZ = spos.z+stepv.z; - float maxZ = spos.z+stepv.z; - - spos.xy += TAA_Offset*texelSize*0.5/1; - - // for (int i = 0; i <= int(quality); i++) { - - // // decode depth buffer - // vec2 testthing = hand ? spos.xy*texelSize : spos.xy/texelSize/4.0; // fix for ssr on hand - - // float sp = sqrt(texelFetch2D(gaux1,ivec2(spos.xy/texelSize/4.0),0).w/65000.0); - - // sp = invLinZ(sp); - - // if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ) ) return vec3(spos.xy/1,sp); - - // spos += stepv; - - // //small bias - // float biasamount = 0.00015; - // if(hand) biasamount = 0.01; - // // minZ = maxZ-clamp(fres*0.0004 ,0.00004,0.0004) / ld(spos.z); - // minZ = maxZ-biasamount / ld(spos.z); - - // maxZ += stepv.z; - - // } - for (int i = 0; i < int(quality+1); i++) { - - vec2 testthing = hand ? spos.xy : spos.xy/texelSize; // fix for ssr on hand - float sp=texelFetch2D(depthtex1,ivec2(testthing),0).x; - - if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ)){ - return vec3(spos.xy,sp); - - } - spos += stepv; - //small bias - float biasamount = 0.00015; - if(hand) biasamount = 0.01; - // minZ = maxZ-clamp(fres*0.0004 ,0.00004,0.0004) / ld(spos.z); - minZ = maxZ-biasamount / ld(spos.z); - maxZ += stepv.z; - } - - return vec3(1.1); -} - -vec3 mix_vec3(vec3 X, vec3 Y, float A){ - return X * (1.0 - A) + Y * A; -} -float mix_float(float X, float Y, float A){ - return X * (1.0 - A) + Y * A; -} - - -// vec3 gaussblur( vec4 colorout, vec2 texcoord ) -// { -// float Pi = 6.28318530718; // Pi*2 - -// // GAUSSIAN BLUR SETTINGS {{{ -// float Directions = 16.0; // BLUR DIRECTIONS (Default 16.0 - More is better but slower) -// float Quality = 3.0; // BLUR QUALITY (Default 4.0 - More is better but slower) -// float Size = 50.0; // BLUR SIZE (Radius) -// // GAUSSIAN BLUR SETTINGS }}} - -// vec2 Radius = Size/vec2(1920,1080); - -// // Normalized pixel coordinates (from 0 to 1) -// vec2 uv = texcoord/vec2(1920,1080); -// // Pixel colour -// vec4 Color = texture2D(colortex3, texcoord); - -// // Blur calculations -// for( float d=0.0; d 0.02; - -// vec4 Reflections = vec4(0.0); -// // SSR -// #ifdef Screen_Space_Reflections -// if ( hasReflections && NdotV < 0.00001) { // Skip SSR if ray contribution is low -// // float rayQuality = reflection_quality; -// float rayQuality = mix_float(reflection_quality,0.0,sqrt(roughness)); // Scale quality with ray contribution - -// vec3 rtPos = rayTraceSpeculars( mat3(gbufferModelView) * L,fragpos.xyz, noise.b, rayQuality, hand, fresnel); -// if (rtPos.z < 1. ){ // Reproject on previous frame -// vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rtPos) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; -// previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; -// previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; -// if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) { -// Reflections.a = 1.0; -// Reflections.rgb = texture2D(colortex5,previousPosition.xy).rgb; -// } -// } -// } -// #endif - -// // check if the f0 is within the metal ranges, then tint by albedo if it's true. -// vec3 Metals = f0.y >= 230.0/255.0 ? clamp(albedo + fresnel,0.0,1.0) : vec3(1.0); -// Reflections.rgb *= Metals; - -// // darken albedos, and stop darkening where the sky gets occluded indoors -// Reflections_Final *= 1.0 - Reflections.a*luma(rayContrib); - -// // apply all reflections to the lighting -// Reflections_Final += Reflections.rgb * luma(rayContrib); - -// #ifdef Rough_reflections -// Output = Reflections_Final; -// #else -// // interpolate between the albedos and reflections using the roughness value instead of the sampling. -// Output = mix_vec3(Reflections_Final, Output, sqrt(roughness)); -// #endif -// } - -// pain -void MaterialReflections( - inout vec3 Output, - float roughness, - vec3 f0, - vec3 albedo, - vec3 sunPos, - vec3 sunCol, - float diffuse, - float lightmap, - vec3 normal, - vec3 np3, - vec3 fragpos, - vec3 noise, - bool hand -){ - vec3 Reflections_Final = Output; - - float Outdoors = 0.0; - // float Outdoors = clamp((lightmap-0.5) * , 0.0,1.0); - - roughness = unpackRoughness(roughness); - f0 = f0.y == 0.0 ? vec3(0.04) : f0; - - - mat3 basis = CoordBase(normal); - vec3 normSpaceView = -np3*basis ; - - // roughness stuff - #ifdef Rough_reflections - int seed = (frameCounter%40000); - vec2 ij = fract(R2_samples_spec(seed) + noise.rg) ; - - vec3 H = sampleGGXVNDF(normSpaceView, roughness, ij.x, ij.y); - if(hand) H = normalize(vec3(0.0,0.0,1.0)); - #else - vec3 H = normalize(vec3(0.0,0.0,1.0)); - #endif - - vec3 Ln = reflect(-normSpaceView, clamp(H,-1.0,1.0)); - vec3 L = basis * Ln; - - // fresnel stuff - float fresnel = pow(clamp(1.0 + dot(-Ln, H),0.0,1.0),5.0); - // vec3 F = f0 + (1.0 - f0) * fresnel; - - vec3 F = mix(f0, vec3(1.0), fresnel); - vec3 rayContrib = F; - - - float NdotV = clamp(normalize(dot(np3, normal))*10000.,0.,1.); - bool hasReflections = (f0.y * (1.0 - roughness * Roughness_Threshold)) > 0.01; - - if (Roughness_Threshold == 1.0){ hasReflections = roughness > -1; NdotV = -1.0;} - - - // SSR, Sky, and Sun reflections - vec4 Reflections = vec4(0.0); - - #ifdef Screen_Space_Reflections - if ( hasReflections && NdotV <= 0.0) { // Skip SSR if ray contribution is low - #ifdef SCREENSHOT_MODE - float rayQuality = reflection_quality; - #else - float rayQuality = mix_float(reflection_quality,0.0,sqrt(roughness)); // Scale quality with ray contribution - #endif - vec3 rtPos = rayTraceSpeculars( mat3(gbufferModelView) * L,fragpos.xyz, noise.b, rayQuality, hand, fresnel); - if (rtPos.z < 1. ){ // Reproject on previous frame - vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rtPos) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; - previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; - previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; - if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) { - Reflections.a = 1.0; - Reflections.rgb = texture2D(colortex5,previousPosition.xy).rgb; - } - } - } - #endif - - // check if the f0 is within the metal ranges, then tint by albedo if it's true. - vec3 Metals = f0.y > 229.5/255.0 ? clamp(albedo + fresnel,0.0,1.0) : vec3(1.0); - Reflections.rgb *= Metals; - - // apply all reflections to the lighting - Reflections_Final += Reflections.rgb * luma(rayContrib); - - // interpolate between the albedos and reflections using the roughness value instead of the sampling. - float visibilityFactor = clamp(exp2((pow(roughness,3.0) / f0.y) * -4),0,1); - #ifdef Rough_reflections - Output = hand ? mix_vec3(Output, Reflections_Final, visibilityFactor) : Reflections_Final; - #else - Output = mix_vec3(Output, Reflections_Final, visibilityFactor); - #endif -} \ No newline at end of file diff --git a/shaders/world-1/lib/stars.glsl b/shaders/world-1/lib/stars.glsl deleted file mode 100644 index 38d3cbf..0000000 --- a/shaders/world-1/lib/stars.glsl +++ /dev/null @@ -1,48 +0,0 @@ -//Original star code : https://www.shadertoy.com/view/Md2SR3 , optimised - - - -// Return random noise in the range [0.0, 1.0], as a function of x. -float hash12(vec2 p) -{ - vec3 p3 = fract(vec3(p.xyx) * 0.1031); - p3 += dot(p3, p3.yzx + 19.19); - return fract((p3.x + p3.y) * p3.z); -} -// Convert Noise2d() into a "star field" by stomping everthing below fThreshhold to zero. -float NoisyStarField( in vec2 vSamplePos, float fThreshhold ) -{ - float StarVal = hash12( vSamplePos ); - StarVal = clamp(StarVal/(1.0 - fThreshhold) - fThreshhold/(1.0 - fThreshhold),0.0,1.0); - - return StarVal; -} - -// Stabilize NoisyStarField() by only sampling at integer values. -float StableStarField( in vec2 vSamplePos, float fThreshhold ) -{ - // Linear interpolation between four samples. - // Note: This approach has some visual artifacts. - // There must be a better way to "anti alias" the star field. - float fractX = fract( vSamplePos.x ); - float fractY = fract( vSamplePos.y ); - vec2 floorSample = floor( vSamplePos ); - float v1 = NoisyStarField( floorSample, fThreshhold ); - float v2 = NoisyStarField( floorSample + vec2( 0.0, 1.0 ), fThreshhold ); - float v3 = NoisyStarField( floorSample + vec2( 1.0, 0.0 ), fThreshhold ); - float v4 = NoisyStarField( floorSample + vec2( 1.0, 1.0 ), fThreshhold ); - - float StarVal = v1 * ( 1.0 - fractX ) * ( 1.0 - fractY ) - + v2 * ( 1.0 - fractX ) * fractY - + v3 * fractX * ( 1.0 - fractY ) - + v4 * fractX * fractY; - return StarVal; -} - -float stars(vec3 fragpos){ - - float elevation = clamp(fragpos.y,0.,1.); - vec2 uv = fragpos.xz/(1.+elevation); - - return StableStarField(uv*700.,0.999)/4.*(0.3-0.3*rainStrength); -} diff --git a/shaders/world-1/lib/texFiltering.glsl b/shaders/world-1/lib/texFiltering.glsl deleted file mode 100644 index 7d58676..0000000 --- a/shaders/world-1/lib/texFiltering.glsl +++ /dev/null @@ -1,19 +0,0 @@ -vec4 smoothfilter(in sampler2D tex, in vec2 uv, in vec2 textureResolution) -{ - uv = uv*textureResolution + 0.5; - vec2 iuv = floor( uv ); - vec2 fuv = fract( uv ); - uv = iuv + (fuv*fuv)*(3.0-2.0*fuv); - uv = uv/textureResolution - 0.5/textureResolution; - return texture2D( tex, uv); -} - -float shadowsmoothfilter(in sampler2DShadow tex, in vec3 uv,in float textureResolution) -{ - uv.xy = uv.xy*textureResolution + 0.5; - vec2 iuv = floor( uv.xy ); - vec2 fuv = fract( uv.xy ); - uv.xy = iuv + (fuv*fuv)*(3.0-2.0*fuv); - uv.xy = uv.xy/textureResolution - 0.5/textureResolution; - return shadow2D( tex, uv).x; -} diff --git a/shaders/world-1/lib/util.glsl b/shaders/world-1/lib/util.glsl deleted file mode 100644 index f701920..0000000 --- a/shaders/world-1/lib/util.glsl +++ /dev/null @@ -1,196 +0,0 @@ -#define TIME_MULT 1.0 -#define TIME (frameTimeCounter * TIME_MULT) - -const float PI = acos(-1.0); -const float TAU = PI * 2.0; -const float hPI = PI * 0.5; -const float rPI = 1.0 / PI; -const float rTAU = 1.0 / TAU; - -const float PHI = sqrt(5.0) * 0.5 + 0.5; -const float rLOG2 = 1.0 / log(2.0); - -const float goldenAngle = TAU / PHI / PHI; - -#define clamp01(x) clamp(x, 0.0, 1.0) -#define max0(x) max(x, 0.0) -#define min0(x) min(x, 0.0) -#define max3(a) max(max(a.x, a.y), a.z) -#define min3(a) min(min(a.x, a.y), a.z) -#define max4(a, b, c, d) max(max(a, b), max(c, d)) -#define min4(a, b, c, d) min(min(a, b), min(c, d)) - -#define fsign(x) (clamp01(x * 1e35) * 2.0 - 1.0) -#define fstep(x,y) clamp01((y - x) * 1e35) - -#define diagonal2(m) vec2((m)[0].x, (m)[1].y) -#define diagonal3(m) vec3(diagonal2(m), m[2].z) -#define diagonal4(m) vec4(diagonal3(m), m[2].w) - -#define transMAD(mat, v) (mat3(mat) * (v) + (mat)[3].xyz) -#define projMAD(mat, v) (diagonal3(mat) * (v) + (mat)[3].xyz) - -#define encodeColor(x) (x * 0.00005) -#define decodeColor(x) (x * 20000.0) - -#define cubeSmooth(x) (x * x * (3.0 - 2.0 * x)) - -#define lumCoeff vec3(0.2125, 0.7154, 0.0721) - -float facos(const float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : PI - a; - //float c = clamp(-sx * 1e35, 0., 1.); - //return c * pi + a * -(c * 2. - 1.); //no conditional version -} - - -vec2 sincos(float x){ - return vec2(sin(x), cos(x)); -} - -vec2 circlemap(float i, float n){ - return sincos(i * n * goldenAngle) * sqrt(i); -} - -vec3 circlemapL(float i, float n){ - return vec3(sincos(i * n * goldenAngle), sqrt(i)); -} - -vec3 calculateRoughSpecular(const float i, const float alpha2, const int steps) { - - float x = (alpha2 * i) / (1.0 - i); - float y = i * float(steps) * 64.0 * 64.0 * goldenAngle; - - float c = inversesqrt(x + 1.0); - float s = sqrt(x) * c; - - return vec3(cos(y) * s, sin(y) * s, c); -} - -vec3 clampNormal(vec3 n, vec3 v){ - float NoV = clamp( dot(n, -v), 0., 1. ); - return normalize( NoV * v + n ); -} - -vec3 srgbToLinear(vec3 srgb){ - return mix( - srgb / 12.92, - pow(.947867 * srgb + .0521327, vec3(2.4) ), - step( .04045, srgb ) - ); -} - -vec3 linearToSRGB(vec3 linear){ - return mix( - linear * 12.92, - pow(linear, vec3(1./2.4) ) * 1.055 - .055, - step( .0031308, linear ) - ); -} - - - -vec3 blackbody(float Temp) -{ - float t = pow(Temp, -1.5); - float lt = log(Temp); - - vec3 col = vec3(0.0); - col.x = 220000.0 * t + 0.58039215686; - col.y = 0.39231372549 * lt - 2.44549019608; - col.y = Temp > 6500. ? 138039.215686 * t + 0.72156862745 : col.y; - col.z = 0.76078431372 * lt - 5.68078431373; - col = clamp01(col); - col = Temp < 1000. ? col * Temp * 0.001 : col; - - return srgbToLinear(col); -} - -float calculateHardShadows(float shadowDepth, vec3 shadowPosition, float bias) { - if(shadowPosition.z >= 1.0) return 1.0; - - return 1.0 - fstep(shadowDepth, shadowPosition.z - bias); -} - -vec3 genUnitVector(vec2 xy) { - xy.x *= TAU; xy.y = xy.y * 2.0 - 1.0; - return vec3(sincos(xy.x) * sqrt(1.0 - xy.y * xy.y), xy.y); -} - -vec2 rotate(vec2 x, float r){ - vec2 sc = sincos(r); - return mat2(sc.x, -sc.y, sc.y, sc.x) * x; -} - -vec3 cartToSphere(vec2 coord) { - coord *= vec2(TAU, PI); - vec2 lon = sincos(coord.x) * sin(coord.y); - return vec3(lon.x, 2.0/PI*coord.y-1.0, lon.y); -} - -vec2 sphereToCart(vec3 dir) { - float lonlat = atan(-dir.x, -dir.z); - return vec2(lonlat * rTAU +0.5,0.5*dir.y+0.5); -} - -mat3 getRotMat(vec3 x,vec3 y){ - float d = dot(x,y); - vec3 cr = cross(y,x); - - float s = length(cr); - - float id = 1.-d; - - vec3 m = cr/s; - - vec3 m2 = m*m*id+d; - vec3 sm = s*m; - - vec3 w = (m.xy*id).xxy*m.yzz; - - return mat3( - m2.x, w.x-sm.z, w.y+sm.y, - w.x+sm.z, m2.y, w.z-sm.x, - w.y-sm.y, w.z+sm.x, m2.z - ); -} - -// No intersection if returned y component is < 0.0 -vec2 rsi(vec3 position, vec3 direction, float radius) { - float PoD = dot(position, direction); - float radiusSquared = radius * radius; - - float delta = PoD * PoD + radiusSquared - dot(position, position); - if (delta < 0.0) return vec2(-1.0); - delta = sqrt(delta); - - return -PoD + vec2(-delta, delta); -} -float HaltonSeq3(int index) - { - float r = 0.; - float f = 1.; - int i = index; - while (i > 0) - { - f /= 3.0; - r += f * (i % 3); - i = int(i / 3.0); - } - return r; - } -float HaltonSeq2(int index) - { - float r = 0.; - float f = 1.; - int i = index; - while (i > 0) - { - f /= 2.0; - r += f * (i % 2); - i = int(i / 2.0); - } - return r; - } diff --git a/shaders/world-1/lib/volumetricClouds.glsl b/shaders/world-1/lib/volumetricClouds.glsl deleted file mode 100644 index b5cc4e5..0000000 --- a/shaders/world-1/lib/volumetricClouds.glsl +++ /dev/null @@ -1,282 +0,0 @@ -#define VOLUMETRIC_CLOUDS - -float cloud_height = 1500.; -float maxHeight = 3200.; -#ifdef HQ_CLOUDS -int maxIT_clouds = 20; -int maxIT = 60; -#else -int maxIT_clouds = 9; -int maxIT = 27; -#endif - -float cdensity = 0.015; - - -//3D noise from 2d texture -float densityAtPos(in vec3 pos) -{ - - pos /= 18.; - pos.xz *= 0.5; - - - vec3 p = floor(pos); - vec3 f = fract(pos); - - f = (f*f) * (3.-2.*f); - - vec2 uv = p.xz + f.xz + p.y * vec2(0.0,193.0); - - vec2 coord = uv / 512.0; - //The y channel has an offset to avoid using two textures fetches - vec2 xy = texture2D(noisetex, coord).yx; - - return mix(xy.r,xy.g, f.y); -} -vec4 smoothfilter(in sampler2D tex, in vec2 uv) -{ - uv = uv*512.0 + 0.5; - vec2 iuv = floor( uv ); - vec2 fuv = fract( uv ); - uv = iuv + (fuv*fuv)*(3.0-2.0*fuv); - uv = uv/512.0 - 0.5/512.0; - return texture2D( tex, uv); -} -//Cloud without 3D noise, is used to exit early lighting calculations if there is no cloud -float cloudCov(in vec3 pos,vec3 samplePos){ - float mult = max(pos.y-2000.0,0.0)/2000.0; - float mult2 = max(-pos.y+2000.0,0.0)/500.0; - float coverage = clamp(texture2D(noisetex,samplePos.xz/12500.).r-0.2+0.4*rainStrength,0.0,1.0)/(1.0-0.2+0.4*rainStrength); - float cloud = coverage*coverage*4.0 - mult*mult*mult*3.0 - mult2*mult2; - return max(cloud, 0.0); -} -//Erode cloud with 3d Perlin-worley noise, actual cloud value -#ifdef HQ_CLOUDS - float cloudVol(in vec3 pos,in vec3 samplePos,in float cov){ - //Less erosion on bottom of the cloud - float mult2 = (pos.y-1500)/2500.0+rainStrength*0.4; - float noise = 1.0-densityAtPos(samplePos*15.); - noise += 0.5-densityAtPos(samplePos*30.)*0.5; - noise /= 1.5; - noise = noise*noise; - float cloud = clamp(cov-noise*noise*0.33*(0.2+mult2),0.0,1.0); - //float cloud = clamp(cov-0.1*(0.2+mult2),0.0,1.0); - return cloud; -} - //Low quality cloud, noise is replaced by the average noise value, used for shadowing - float cloudVolLQ(in vec3 pos){ - float mult = max(pos.y-2000.0,0.0)/2000.0; - float mult2 = max(-pos.y+2000.0,0.0)/500.0; - float mult3 = (pos.y-1500)/2500.0+rainStrength*0.4; - vec3 samplePos = pos*vec3(1.0,1./32.,1.0)/4+frameTimeCounter*vec3(0.5,0.,0.5)*25.; - float coverage = clamp(texture2D(noisetex,samplePos.xz/12500.).r-0.2+0.4*rainStrength,0.0,1.0)/(1.0-0.2+0.4*rainStrength); - float cloud = coverage*coverage*4.0 - mult*mult*mult*3.0 - mult2*mult2 - 0.11 * (0.2 + mult3); - return max(cloud, 0.0); - } -#else - float cloudVol(in vec3 pos,in vec3 samplePos,in float cov){ - float mult2 = (pos.y-1500)/2500.0+rainStrength*0.4; - float cloud = clamp(cov-0.11*(0.2+mult2),0.0,1.0); - return cloud; - - } - //Low quality cloud, noise is replaced by the average noise value, used for shadowing - float cloudVolLQ(in vec3 pos){ - float mult = max(pos.y-2000.0,0.0)/2000.0; - float mult2 = max(-pos.y+2000.0,0.0)/500.0; - float mult3 = (pos.y-1500)/2500.0+rainStrength*0.4; - vec3 samplePos = pos*vec3(1.0,1./32.,1.0)/4+frameTimeCounter*vec3(0.5,0.,0.5)*25.; - float coverage = clamp(texture2D(noisetex,samplePos.xz/12500.).r-0.2+0.4*rainStrength,0.0,1.0)/(1.0-0.2+0.4*rainStrength); - float cloud = coverage*coverage*4.0 - mult*mult*mult*3.0 - mult2*mult2 - 0.11 * (0.2 + mult3); - return max(cloud, 0.0); - } -#endif - - -//Mie phase function -float phaseg(float x, float g){ - float gg = g * g; - return (gg * -0.25 /3.14 + 0.25 /3.14) * pow(-2.0 * (g * x) + (gg + 1.0), -1.5); -} - -float calcShadow(vec3 pos, vec3 ray){ - float shadowStep = length(ray); - float d = 0.0; - for (int j=1;j<6;j++){ - float cloudS=cloudVolLQ(vec3(pos+ray*j)); - d += cloudS*cdensity; - - } - return max(exp(-shadowStep*d),exp(-0.25*shadowStep*d)*0.7); -} -float cirrusClouds(vec3 pos){ - vec2 pos2D = pos.xz/50000.0 + frameTimeCounter/200.; - float cirrusMap = clamp(texture2D(noisetex,pos2D.yx/6. ).b-0.7+0.7*rainStrength,0.0,1.0); - float cloud = texture2D(noisetex, pos2D).r; - float weights = 1.0; - vec2 posMult = vec2(2.0,1.5); - for (int i = 1; i < 4; i++){ - pos2D *= posMult; - float weight =exp2(-i*1.0); - cloud += texture2D(noisetex, pos2D).r*weight; - - weights += weight; - } - cloud = clamp(cloud*cirrusMap*0.25,0.0,1.0); - return cloud/weights * float(abs(pos.y - 5500.0) < 200.0); -} - -vec4 renderClouds(vec3 fragpositi, vec3 color,float dither,vec3 sunColor,vec3 moonColor,vec3 avgAmbient) { - #ifndef VOLUMETRIC_CLOUDS - return vec4(0.0,0.0,0.0,1.0); - #endif - //setup ray in projected shadow map space - bool land = false; - - float SdotU = dot(normalize(fragpositi.xyz),sunVec); - float z2 = length(fragpositi); - float z = -fragpositi.z; - - - //project pixel position into projected shadowmap space - vec4 fragposition = gbufferModelViewInverse*vec4(fragpositi,1.0); - - vec3 worldV = normalize(fragposition.rgb); - float VdotU = worldV.y; - maxIT_clouds = int(clamp(maxIT_clouds/sqrt(VdotU),0.0,maxIT*1.0)); - //worldV.y -= -length(worldV.xz)/sqrt(-length(worldV.xz/earthRad)*length(worldV.xz/earthRad)+earthRad); - - //project view origin into projected shadowmap space - vec4 start = (gbufferModelViewInverse*vec4(0.0,0.0,0.,1.)); - vec3 dV_view = worldV; - - - vec3 progress_view = dV_view*dither+cameraPosition; - - float vL = 0.0; - float total_extinction = 1.0; - - - float distW = length(worldV); - worldV = normalize(worldV)*300000. + cameraPosition; //makes max cloud distance not dependant of render distance - dV_view = normalize(dV_view); - - //setup ray to start at the start of the cloud plane and end at the end of the cloud plane - dV_view *= max(maxHeight-cloud_height, 0.0)/dV_view.y/maxIT_clouds; - vec3 startOffset = dV_view*dither; - - progress_view = startOffset + cameraPosition + dV_view*(cloud_height-cameraPosition.y)/(dV_view.y); - - - if (worldV.y < cloud_height) return vec4(0.,0.,0.,1.); //don't trace if no intersection is possible - - - - float shadowStep = 240.; - vec3 dV_Sun = normalize(mat3(gbufferModelViewInverse)*sunVec)*shadowStep; - - float mult = length(dV_view); - - - color = vec3(0.0); - - total_extinction = 1.0; - float SdotV = dot(sunVec,normalize(fragpositi)); - //fake multiple scattering approx 1 (from horizon zero down clouds) - float mieDay = max(phaseg(SdotV,0.7),phaseg(SdotV,0.2)); - float mieNight = max(phaseg(-SdotV,0.7),phaseg(-SdotV,0.2)); - - vec3 sunContribution = mieDay*sunColor*3.14; - vec3 moonContribution = mieNight*moonColor*3.14; - vec3 skyCol0 = avgAmbient*(1.0-rainStrength*0.8); - - float powderMulMoon = 1.0; - float powderMulSun = 1.0; - - for (int i=0;i0.00){ - float cloud = cloudVol(curvedPos,samplePos,coverageSP); - if (cloud > 0.0005){ - float muS = cloud*cdensity; - float muE = cloud*cdensity; - float muEshD = 0.0; - if (sunContribution.g > 1e-5){ - for (int j=1;j<8;j++){ - vec3 shadowSamplePos = curvedPos+dV_Sun*j; - if (shadowSamplePos.y < maxHeight) - { - float cloudS=cloudVolLQ(vec3(shadowSamplePos)); - muEshD += cloudS*cdensity; - } - } - } - float muEshN = 0.0; - if (moonContribution.g > 1e-5){ - for (int j=1;j<8;j++){ - vec3 shadowSamplePos = curvedPos-dV_Sun*j; - if (shadowSamplePos.y < maxHeight) - { - float cloudS=cloudVolLQ(vec3(shadowSamplePos)); - muEshN += cloudS*cdensity; - } - } - } - //fake multiple scattering approx 2 (from horizon zero down clouds) - float sunShadow = max(exp2(-shadowStep*muEshD),exp2(-0.25*shadowStep*muEshD))*(1.0-exp(-muE*100.0*2.0)); - float moonShadow = max(exp2(-shadowStep*muEshN),exp2(-0.25*shadowStep*muEshN))*(1.0-exp(-muE*100.0*2.0)); - float h = 0.5-0.5*clamp(curvedPos.y/4000.-1500./4000.,0.0,1.0); - float ambientPowder = (1.0-h*exp2(-muE*100.0*2.0)); - vec3 S = vec3(sunContribution*sunShadow+moonShadow*moonContribution+skyCol0*ambientPowder); - - - vec3 Sint=(S - S * exp2(-mult*muE)) / (muE); - color += muS*Sint*total_extinction; - total_extinction *= exp2(-muE*mult); - - - if (total_extinction < 1/250.) break; - } - } - - progress_view += dV_view; - } - - //high altitude clouds - progress_view = progress_view + (5500.0-progress_view.y) * dV_view / dV_view.y; - mult = 400.0 * inversesqrt(abs(normalize(dV_view).y)); - float cirrus = cirrusClouds(vec3(progress_view.x,5500.0,progress_view.z))*cdensity*2.0; - if (cirrus > 1e-5){ - float muEshD = 0.0; - if (sunContribution.g > 1e-5){ - for (int j=1;j<8;j++){ - float cloudS=cirrusClouds(vec3(progress_view+dV_Sun*j)); - muEshD += cloudS*cdensity*2.; - } - } - float muEshN = 0.0; - if (moonContribution.g > 1e-5){ - for (int j=1;j<8;j++){ - float cloudS=cirrusClouds(vec3(progress_view-dV_Sun*j)); - muEshN += cloudS*cdensity*2.0; - } - } - float sunShadow = max(exp(-shadowStep*muEshD),exp(-0.25*shadowStep*muEshD)*0.4)*(1.0-exp(-cirrus*mult*2.0)); - float moonShadow = max(exp(-shadowStep*muEshN),exp(-0.25*shadowStep*muEshN)*0.4)*(1.0-exp(-cirrus*mult*2.0)); - float ambientPowder = (1.0-exp(-cirrus*mult*2.0)); - vec3 S = vec3(sunContribution*sunShadow+moonShadow*moonContribution+skyCol0*ambientPowder*0.5); - vec3 Sint=(S - S * exp(-mult*cirrus)) / (cirrus); - color += Sint * cirrus * total_extinction; - total_extinction *= exp(-mult*cirrus); - } - float cosY = normalize(dV_view).y; - - - return mix(vec4(color,clamp(total_extinction*(1.0+1/250.)-1/250.,0.0,1.0)),vec4(0.0,0.0,0.0,1.0),1-smoothstep(0.02,0.15,cosY)); - -} diff --git a/shaders/world-1/lib/volumetricFog.glsl b/shaders/world-1/lib/volumetricFog.glsl deleted file mode 100644 index 83212d0..0000000 --- a/shaders/world-1/lib/volumetricFog.glsl +++ /dev/null @@ -1,118 +0,0 @@ -#define VL_SAMPLES2 6 //[4 6 8 10 12 14 16 20 24 30 40 50] -#define Ambient_Mult 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0 5.0 6.0 10.0] -#define SEA_LEVEL 70 //[0 10 20 30 40 50 60 70 80 90 100 110 120 130 150 170 190] //The volumetric light uses an altitude-based fog density, this is where fog density is the highest, adjust this value according to your world. -#define ATMOSPHERIC_DENSITY 1.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 4.0 5.0 7.5 10.0 12.5 15.0 20.] -#define fog_mieg1 0.40 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0] -#define fog_mieg2 0.10 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0] -#define fog_coefficientRayleighR 5.8 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientRayleighG 1.35 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientRayleighB 3.31 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] - -#define fog_coefficientMieR 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientMieG 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientMieB 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] - -#define Underwater_Fog_Density 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0] - -float phaseRayleigh(float cosTheta) { - const vec2 mul_add = vec2(0.1, 0.28) /acos(-1.0); - return cosTheta * mul_add.x + mul_add.y; // optimized version from [Elek09], divided by 4 pi for energy conservation -} -float cloudVol2(in vec3 pos){ - - vec3 samplePos = pos*vec3(1.0,1./16.,1.0)+frameTimeCounter*vec3(0.5,0.,0.5)*5.; - float coverage = mix(exp2(-(pos.y-SEA_LEVEL)*(pos.y-SEA_LEVEL)/10000.),1.0,rainStrength*0.5); - float noise = densityAtPos(samplePos*12.); - float unifCov = exp2(-max(pos.y-SEA_LEVEL,0.0)/50.); - - float cloud = pow(clamp(coverage-noise-0.76,0.0,1.0),2.)*1200./0.23/(coverage+0.01)*VFAmount*600+unifCov*60.*fogAmount; - -return cloud; -} - -mat2x3 getVolumetricRays(float dither,vec3 fragpos) { - - //project pixel position into projected shadowmap space - vec3 wpos = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - vec3 fragposition = mat3(shadowModelView) * wpos + shadowModelView[3].xyz; - fragposition = diagonal3(shadowProjection) * fragposition + shadowProjection[3].xyz; - - - - //project view origin into projected shadowmap space - vec3 start = toShadowSpaceProjected(vec3(0.)); - - - //rayvector into projected shadow map space - //we can use a projected vector because its orthographic projection - //however we still have to send it to curved shadow map space every step - vec3 dV = (fragposition-start); - vec3 dVWorld = (wpos-gbufferModelViewInverse[3].xyz); - - float maxLength = min(length(dVWorld),256.0)/length(dVWorld); - dV *= maxLength; - dVWorld *= maxLength; - - //apply dither - vec3 progress = start.xyz; - vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; - vec3 vL = vec3(0.); - - float SdotV = dot(sunVec,normalize(fragpos))*lightCol.a; - float dL = length(dVWorld); - //Mie phase + somewhat simulates multiple scattering (Horizon zero down cloud approx) - float mie = max(phaseg(SdotV,fog_mieg1),1.0/13.0); - float rayL = phaseRayleigh(SdotV); - // wpos.y = clamp(wpos.y,0.0,1.0); - - vec3 ambientCoefs = dVWorld/dot(abs(dVWorld),vec3(1.)); - - vec3 ambientLight = ambientUp*clamp(ambientCoefs.y,0.,1.); - ambientLight += ambientDown*clamp(-ambientCoefs.y,0.,1.); - ambientLight += ambientRight*clamp(ambientCoefs.x,0.,1.); - ambientLight += ambientLeft*clamp(-ambientCoefs.x,0.,1.); - ambientLight += ambientB*clamp(ambientCoefs.z,0.,1.); - ambientLight += ambientF*clamp(-ambientCoefs.z,0.,1.); - - vec3 skyCol0 = ambientLight*2.*eyeBrightnessSmooth.y/vec3(240.)*Ambient_Mult*2.0/PI; - vec3 sunColor = lightCol.rgb; - - vec3 rC = vec3(fog_coefficientRayleighR*1e-6, fog_coefficientRayleighG*1e-5, fog_coefficientRayleighB*1e-5); - vec3 mC = vec3(fog_coefficientMieR*1e-6, fog_coefficientMieG*1e-6, fog_coefficientMieB*1e-6); - - - float mu = 1.0; - float muS = 1.0*mu; - vec3 absorbance = vec3(1.0); - float expFactor = 11.0; - for (int i=0;i FLICKER_REDUCTION BLEND_FACTOR ANTI_GHOSTING MOTION_REJECTION CLOSEST_VELOCITY NO_CLIP - -screen.Lighting= [Torch] [Sky] [Ambient] -screen.Torch = TORCH_R TORCH_G TORCH_B TORCH_AMOUNT -screen.Sky=[Sky_coefficients] [Sun_and_Moon_Colors] sunPathRotation -screen.Sky_coefficients = Sky_Brightness sky_mieg sky_coefficientRayleighR sky_coefficientRayleighG sky_coefficientRayleighB sky_coefficientMieR sky_coefficientMieG sky_coefficientMieB -screen.Sun_and_Moon_Colors = sunColorR sunColorG sunColorB sun_illuminance moonColorR moonColorG moonColorB moon_illuminance -screen.Ambient = MIN_LIGHT_AMOUNT SEPARATE_AO ambientOcclusionLevel Ambient_Mult - -screen.Shading = DISABLE_ALPHA_MIPMAPS [Shadows] [POM] BICUBIC_UPSCALING CONTRAST_ADAPTATIVE_SHARPENING SHARPENING -screen.Shadows = [Filtering] SCREENSPACE_CONTACT_SHADOWS shadowMapResolution CLOUDS_SHADOWS CLOUDS_SHADOWS_STRENGTH shadowDistanceRenderMul shadowDistance SHADOW_FRUSTRUM_CULLING CAVE_LIGHT_LEAK_FIX SSAO SSAO_SAMPLES SHADOW_DISABLE_ALPHA_MIPMAPS Stochastic_Transparent_Shadows -screen.Filtering = Variable_Penumbra_Shadows VPS_Search_Samples Min_Shadow_Filter_Radius Max_Shadow_Filter_Radius Max_Filter_Depth SHADOW_FILTER_SAMPLE_COUNT -screen.POM = POM_MAP_RES POM POM_DEPTH MAX_ITERATIONS MAX_DIST USE_LUMINANCE_AS_HEIGHTMAP -screen.Camera = EXPOSURE_MULTIPLIER Exposure_Speed AUTO_EXPOSURE Manual_exposure_value BLOOM_STRENGTH FinalR FinalG FinalB [Tonemapping] [DepthOfField] [Purkinje_effect] -screen.Purkinje_effect = Purkinje_strength Purkinje_strength Purkinje_R Purkinje_G Purkinje_B Purkinje_Multiplier -screen.Tonemapping = TONEMAP USE_ACES_COLORSPACE_APPROXIMATION SATURATION CROSSTALK -screen.DepthOfField = DOF HQ_DOF HEXAGONAL_BOKEH AUTOFOCUS focal aperture MANUAL_FOCUS FAR_BLUR_ONLY -texture.noise=texture/noises.png - -separateAo=true - - -beacon.beam.depth=true -rain.depth=false - -variable.float.texelSizeX = 1.0/viewWidth -variable.float.texelSizeY = 1.0/viewHeight -uniform.vec2.texelSize=vec2(texelSizeX,texelSizeY) - -uniform.int.framemod8 = frameCounter%8 - -variable.float.normSunVec = sqrt(sunPosition.x*sunPosition.x+sunPosition.y*sunPosition.y+sunPosition.z*sunPosition.z) -variable.float.normUpVec = sqrt(upPosition.x*upPosition.x+upPosition.y*upPosition.y+upPosition.z*upPosition.z) - -variable.float.sunPosX = sunPosition.x/normSunVec -variable.float.sunPosY = sunPosition.y/normSunVec -variable.float.sunPosZ = sunPosition.z/normSunVec - -uniform.vec3.sunVec=vec3(sunPosX,sunPosY,sunPosZ) - -variable.float.upPosX = upPosition.x/normUpVec -variable.float.upPosY = upPosition.y/normUpVec -variable.float.upPosZ = upPosition.z/normUpVec - -uniform.vec3.upVec=vec3(upPosX,upPosY,upPosZ) -uniform.float.sunElevation = sunPosX*upPosX+sunPosY*upPosY+sunPosZ*upPosZ -uniform.float.lightSign = clamp(sunElevation * 1000000000000000000, 0.0, 1.0) * 2.0 - 1.0 - -#Max angle at frustrum diagonal -variable.float.maxAngle = atan(1.0 / gbufferProjection.1.1 * sqrt(1.0+(aspectRatio * aspectRatio))) -uniform.float.cosFov = cos(maxAngle) -variable.float.viewDirX = gbufferModelViewInverse.2.0 -variable.float.viewDirY = gbufferModelViewInverse.2.1 -variable.float.viewDirZ = gbufferModelViewInverse.2.2 -variable.float.normView = sqrt(viewDirX*viewDirX + viewDirY*viewDirY + viewDirZ*viewDirZ) -variable.float.shViewDirX = (shadowModelView.0.0 * viewDirX + shadowModelView.1.0 * viewDirY + shadowModelView.2.0 * viewDirZ)/normView -variable.float.shViewDirY = (shadowModelView.0.1 * viewDirX + shadowModelView.1.1 * viewDirY + shadowModelView.2.1 * viewDirZ)/normView -variable.float.shViewDirZ = (shadowModelView.0.2 * viewDirX + shadowModelView.1.2 * viewDirY + shadowModelView.2.2 * viewDirZ)/normView - -uniform.vec3.shadowViewDir = vec3(shViewDirX, shViewDirY, shViewDirZ) - -variable.float.shStartX = (shadowModelView.0.0 * gbufferModelViewInverse.3.0 + shadowModelView.1.0 * gbufferModelViewInverse.3.1 + shadowModelView.2.0 * gbufferModelViewInverse.3.2) -variable.float.shStartY = (shadowModelView.0.1 * gbufferModelViewInverse.3.0 + shadowModelView.1.1 * gbufferModelViewInverse.3.1 + shadowModelView.2.1 * gbufferModelViewInverse.3.2) -variable.float.shStartZ = (shadowModelView.0.2 * gbufferModelViewInverse.3.0 + shadowModelView.1.2 * gbufferModelViewInverse.3.1 + shadowModelView.2.2 * gbufferModelViewInverse.3.2) - -uniform.vec3.shadowCamera = vec3(shStartX + shadowModelView.3.0 + shViewDirX*2., shStartY + shadowModelView.3.1 + shViewDirY*2., shStartZ + shadowModelView.3.2 + shViewDirZ*2.0) - - -variable.float.wSunX = (gbufferModelViewInverse.0.0 * sunPosX + gbufferModelViewInverse.1.0 * sunPosY + gbufferModelViewInverse.2.0 * sunPosZ) -variable.float.wSunY = (gbufferModelViewInverse.0.1 * sunPosX + gbufferModelViewInverse.1.1 * sunPosY + gbufferModelViewInverse.2.1 * sunPosZ) -variable.float.wSunZ = (gbufferModelViewInverse.0.2 * sunPosX + gbufferModelViewInverse.1.2 * sunPosY + gbufferModelViewInverse.2.2 * sunPosZ) - -variable.float.shSunX = (shadowModelView.0.0 * wSunX + shadowModelView.1.0 * wSunY + shadowModelView.2.0 * wSunZ) -variable.float.shSunY = (shadowModelView.0.1 * wSunX + shadowModelView.1.1 * wSunY + shadowModelView.2.1 * wSunZ) -variable.float.shSunZ = (shadowModelView.0.2 * wSunX + shadowModelView.1.2 * wSunY + shadowModelView.2.2 * wSunZ) - -uniform.vec3.shadowLightVec = vec3(lightSign*shSunX, lightSign*shSunY, lightSign*shSunZ) - -uniform.float.shadowMaxProj = 150.0/abs(sunPosY) diff --git a/shaders/world-1/texture/composite4.fsh b/shaders/world-1/texture/composite4.fsh deleted file mode 100644 index fccda4b..0000000 --- a/shaders/world-1/texture/composite4.fsh +++ /dev/null @@ -1,37 +0,0 @@ -#version 120 -//Horizontal bilateral blur for volumetric fog + Forward rendered objects + Draw volumetric fog -#extension GL_EXT_gpu_shader4 : enable - - - -varying vec2 texcoord; -flat varying vec3 zMults; -uniform sampler2D depthtex0; -uniform sampler2D colortex3; -uniform sampler2D colortex2; -uniform sampler2D colortex0; - -uniform int frameCounter; -uniform float far; -uniform float near; -uniform int isEyeInWater; - -uniform vec2 texelSize; -float ld(float depth) { - return 1.0 / (zMults.y - depth * zMults.z); // (-depth * (far - near)) = (2.0 * near)/ld - far - near -} - - -void main() { -/* DRAWBUFFERS:3 */ - vec3 color = texture2D(colortex3,texcoord).rgb; - vec4 transparencies = texture2D(colortex2,texcoord); - color = color*(1.0-transparencies.a)+transparencies.rgb*10.; - - vec4 vl = texture2D(colortex0,texcoord); - - color *= vl.a; - color += vl.rgb; - - gl_FragData[0].rgb = clamp(color,6.11*1e-5,65000.0); -} diff --git a/shaders/world-1/texture/composite4.vsh b/shaders/world-1/texture/composite4.vsh deleted file mode 100644 index e6e3e92..0000000 --- a/shaders/world-1/texture/composite4.vsh +++ /dev/null @@ -1,19 +0,0 @@ -#version 120 -#extension GL_EXT_gpu_shader4 : enable - -varying vec2 texcoord; -flat varying vec3 zMults; -uniform float far; -uniform float near; -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - zMults = vec3((far * near)*2.0,far+near,far-near); - gl_Position = ftransform(); - texcoord = gl_MultiTexCoord0.xy; - -} diff --git a/shaders/world-1/texture/noises.png b/shaders/world-1/texture/noises.png deleted file mode 100644 index 6236ff19990bb213e4ec6f6a51df1fc13138e582..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 695035 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 yNUa~SuZo9zB z!Zf=JZp+cy*`gK$?PJiNHm~!0u^YW`RWEjkTQ2U-7p?fNXmT@ndl?Kb3gyBS4p;iR zB7ZOX&KZ6RfGMB`h zTITAEc$A@w5x9kkEltgKRM~~nsdE}9aVb=~UE03cUOb^t%F@>oc(V2G;WxF!!@SGfT<`YjocS z%BP}FPuA0n`kg@s5IH7P{%x>Di0&XD_L17rWP2inZ-nMLm=J=*(L%vPWUxKXBK3~ z02*Z|M}uX1gRLrXIOJO(o5@7;DHCfTwJ(Iffbl9(4=3$+L~c)Ze!P(nTv!5boKOAT$L)uEIS0+q%wlj(7PxifTnEkC`_8`Om z&QEmL2=wj|><&$8|6n`P3}ZsEBIaP-&jic7VtJKT$C6mZiOEhI;N*QKOfm3v1GY5q zKm%4cVh?ls+`J5S_eu1;3RW+X^{prCn=Z>c({*DS&JW|4FkDIKr9eDGVQ{icCGbe1 zcYa~^5TP9;U|53BN%l_&4^rhSCbumrs~42X1@@x@PaFMp(k`NDK1=OktT&Uno}{f3 z7)aVJU~`yYLy~$r#07(VEK$aZxE!qOh~54oHW&E4)boC_+$rI00ryh&9>o15e4em# z12(jZo3_?(QdM2GB9CktcL#aD*giqTqGUWqYO2uL2q?P)-DRaZoXWoySGiE&a$s|L zTDdF@&%t^xkoi`$vJ))U1lsceY%9dtQk*N*ZpyX})QuB14}iNt4u$C%pnEZ-ePR8s zg39SI?0}*p;qA%vc1u{D0JI+?d!J?YK0|OJ6J{|x!x*}rQ6FIFG#0)@m5<1Bh^alF z>4#cyTMPY>^py#pEcvd=&NU4G0N}^Qe94KKPVGXgA0zRUGG9v7X+gb1Y6*l{QSob=zecjOB;D`ZC+|A^t7VRjD_Mb@H zjBIW**?<(UVcG#Ej-hlCfOn;MI@SIt)o&uTL!<^N%FfEU_Fl{zQu8@86Gst+u`vYN**QCIf-%<#qAi_6ymp#4;8qeq%TOW zC~-dlHwnBKhM6?XP|>XkT}t4-q}`e1;|U#-(wH=@B(|r>ay-obK;+X<-iOo|nfZdU zo{Ea^IVVKA6M++8dA}J4%k&ypKPL1rvmVc^k5l<2B0ta2pBT0RqwL7YRS+?Y*?xw| zw1UxnF5x1<4g&BApv7U$&47&q+BZqxmbZ*MEbF?a z`Ug-CkhUs`has*B>;A#4-JZzXNKOL!{UB(#z`KERtI*C*W8srSh|6NY1uJPT$|!Tf0vuZnqv6ssxgj>z1` z)XZb(Y+uORjWNYw^8&dPg@>3q&47m-yw1Q~-L!_Io@k2CP27yahb~?3YF9RNmoU_o zNUcuTwuC+)`GnwWh-EDSyQT87Ie6??O3HO4JVjwk1C|1?4>D&ca{>YnFz_iuPh0AK zNWTSaDM0%O`3fzr7V=6;3qiU7+5L>lrKy-YM=PHDljSU`dx+82Fw0$uoJ{5)Q$7Ol z!AjdBQ|o5pI|(O4Ih|^kWX9=~zI0(ZFrG`x6^!+DLwgks*{;Fn60$qYq2W%h=D@rLK1yI^lG_qojO6a5??*2a;kGaw z+tG0sOc#UgB%^K+^Jy9vlldiKz8b(mL~cgq-hsT1s!I~Fp3rw&s693ms|E6AF>evM zEKxp(FwIeJF3@ESVtOG4Ik}QCw$7KMWkO!@@t^^E>UgDoXMM*xRlBJh?peBNg?c0Wy9KRzN^%* zU^^tOU6$s@V@{J|JwWS#Jv$NhF3=1V^oF2AiwOryaRt!a2iWz1P6Ba0sFg|F>A*<_ ztVeN6WNa<(Gu;EzeKagY$I-Mnp0HaCexjp%z~t_<<_t4`4{9bOdsbKU?3!*T z%HtShea=;uclqHaoMFk=Ks_wsMP}>^)PI6_3*ZxES(@}?jNQ))f4;xL?8h6og^TPB zCwHXfjwGG}?YD#t0CQRx4yN%;m@ZD^4r$!P%}#;&ac=k&<~xJsPN;LJEGMVBuLScb zdHsEqz6#h)Bb&hpysyZ;Q1u!ro<`)!$XpQ8m!LkT`C+nh zI$7o?wWv{>19>i}8xwXVfVTxaDd=#3_ei(}#z$ay7mlsi@MUX!v^V8rD>%d4o^aMJ z$lm|J+c#wKJDBbza2&-WC|eZfH^F=xA=a1jdI5JKb7ew{Ch?t_y`^IB(|m8yUJ*Nk z#m?4=oFsO?hx8Fx_MquFT5M?4P9&D2bUGqGL*zRte1qiPNZ!Y^2MPU1i<#-=H6tzt z;~tuq$YK#8~Dt;y|;qs#(9koAuk$tl6Gcjxzc- z$+9v~{!Vm;Q~j>W&^+$)-?g%E0jS{_YtCw4b+NF2 zKA6x_3GANm+kt$HiYJUQ)D@Sw>otYmhL!!(;&`DuCZm3vsc$Gej*M@W?cs7;Q_L5W z^=XhVlD0nR>%r_pxDSKzHjz7lm^8<}7V|;5E|qs0bBYrHY zWe=J#)iReO+JBLGj)AKgnpF)pupq}2#Z9jKoT!@+S`=vJBWw`VJVEAENXtn0CZ&~` z`GCUygv{SE>mQhTy(Kqi@(zd#EBS)b#vyS7Gq0m!3}F3%W+PC`h`G2dHUr`efbSsr zJ*d9}yauv206hxu4v1F*`h!qchO{;qSI=Rz__0iT3+Y=U{RgH#M7B#(?U@wrH(`pY z?q|q5fLOxRyKJI&F|z%b$Q>QIVxsPz$mNoF#0?L$#=9t7D&Zp~{$$|iqTOU@rT}&k z(Y)ZOOBbP2fXfT=Z6h})Yz7TC3Ajks`3l~QLa|9GdQ^^;X>|t>XB#k+)G#uaB<(j~ z&or^T5%BGhI7)1vGPI`vafVb+4(Z&AJU?X>lZYyp9vi8xs*HxSKCpm|6t z&m(cX3Ex1?TgbAj!mdcgtz?9eV=-E7q;x{TKxPFviD@5 zuL8XXg1x=4`W8&%!S+-#?wup#(RDDq3G+!bO@Ozv=rJFNA;vn)5j!{1i;et&CVQ?Z z+4Bnz+ohzhUEsfN$XUfZhc-6XhlTEq@nNT3@4)4T<{8VLHJF|6m^zx7iyJ%*&D@S= zOB4PdrK6czk69-(V+Ba_L%A4YkLcR9@gN0n|IK+YzLaq z0Vg(y(S_Zg+wA&j?m*WJl-x&6Jyj)NQ}G*AdM2QB&T_X?ifLf6_DW~pmyYhq zhIS=m`z);0@p?65}Eo} zi0?;Y&CECi(f$HePoVNlMd$Y!bKj!)#cx!5?o_qMRqYu?DOvf?tZ`nnIki^Xr&gX+ zqkPb2&-fOd&x4)aWpjNFpX*gQe-Fb>a12M`5EQ!(&gpV43Bw>*>l z_h5cT)&z7UiOoT642z*4`;$!}d%iYsBS#)p7zZ_uQN?|B<6OpF*SOnn&FpL=jw7@< zph*%}SC+>V*rmtz~e`Gc-)AmB*X{4Q=;zub&3Ks-4B4zKS_(77li9VND_7QBBVDAad z!?2z|$vY#mG*78?&dJg8CB`B( zKQecuy0=p8uYmjpM~Hp5Izl zNzfm@uFiFo6L~sF=loA}R(H3)OpNiwY{%Sw)hiYC&rHJ$xw)m|{)4dm2h*-6&eS>AGdY)oRUbhv z&{O6wr0L#dtdZm!Nk3E6Z(__9YD#fBl!?R?W|9#fTExYS?8B(fU^Y*K+NLSOZ;ld9Zei#S$<%aUn%|(X%i@nL8?22eh%B%tsLxD{_N(@nA@FZ@fjJ1 z8`aa8;~ePYz?)8N;EeAK%{vUSqDu!AVb4lAw~~4m>8--HBZ|lNPTo)m^W`g=8B`nt z@o=QAjl_I}&0&XV?DPP9F<+`aJoHdOO5Q~iiZttQQM8{HZgxR=wcvcp)gkR^v$ zsb|vb$Gqfi#dWiLUTdB!n_(K5bAWtEP$f0TrsBTLd_0uHLOLN3!virsp~ZqtA*#m= zJl(}@D>hCjtoA9;ArAiNvV9CW#*}}ccs9j{h_VLQ?lrLGTcI&5>5CGLUWt|ih3aCc zG$sFwWY-I2MWHc3XmpZV#z18(Q_1kh87q!Jthgz%`dMJVB<@V&*|h4qn*MH0yE|Yr zlNtikK6LBNVwb{sFU^O;%gb)Am02M~WJxD}Ac0r4QA z?G4SH9Qlt5ysW_9ag+y%>h9&4;PnnPzGrCJn((^_O)_MEW^6~)bCK24vhs$ko<#fY zAkvN!{ag^eY2Kb`Q%Iao@?=8SK$x$ro&wkphy|?UG+6T_v(^tP{NA;JWw$qwTUW}b z3v#~GKQ!bdSnMvZXQbDsq~()Ay_eK5k)4v7FXDaz?Gv$`5C=;6Fc5nSZ99U?HW%7n zfYt56I2>00U6y~PVGsM3Mql`Qmu=6RcXNno7 ze8y-UDfXgi1c+5gzY5?#02?FWLkKHFx+=*XMSlq5G=}z2<_2O6OtxN>Z0wovUjW<5 z6f>b*AL7=jcp|g>oNB%zcWNzO{}ei^?Jv4>c?3gu^jzX;_8K}!JLy}VZV9$|wBKh#iek;}b;4l=f$$7lO}a;@&#_ z6{MY{z=ve@Ap^J5IEl4&hc)_>e>jd@aSumhfk{uw>Y-wJP;7f0vS)>u2H1ZE+@j>h zkdFfR8O3{{aw${)Vc=vWuae5mlFdl?B*2~$v0ZyT^w;_&q>cybO z81bZ8z71k6(!Lh(1eM#d#`S=Ip{z!x>-H@5Vnse6!!sZ^19co&cZOkrEVq;C7MYzP zvlBr+0_s(eN5XkJU>!kR45~ArPeI%U>UmJV5;=m2p(M7VVhKD$jo_%RYYrEq1U-XZn-fuXX6qj8@JPc>2h5Wrxu(GOsI0Y3rF zML^k$;B`>_7iIl2El)M&@FFZMDrXki$1Y!LuulR1-GDocSYqIgfK~(R!zevqY}=2B zgT-n!Py>>2m%%?3{1dQR6O1oJ9uC9GBrh`HL?WkActpbSK>a54`$T5zfrxsb)vZSr z=9-21R$+ZsMRqKx&v4`0=DHqUFP6vO!`USqBS3pez*`CZ1k@V=^(PKrCzaQw>dU3( z^9ghpFh3C^jLktpJp+vYg7pQo9B9Os296?lp^P08wo{;aCZv@HOc0@^JZ7Y5ooCGcf17lhdx;dXN*?n`-l z$@e1pU$gRJn%^PgbXl1U^P@lw0I(`xk5W34$~}PQJYDlQw~} zyBu~n6}uVmkST|nte2(DG4K_N&(Ule$dv@n6ZC?lV+H;f#7_bj2)>h4eIk`TnZ6@y zpPRs|Y1u!C7em$Bf?bx1iBSEnq+JBv7Vy7^+O3qTCqj8Ig{c50P<}rXPcoagD|iW{ z2c&w45Yq(vMDQy;$iPw>M7s-hP|0D8Un06JL?O}GStnH0t906bz!Os(HAXNq= z&>P~LH2WtlUZv?lMs82|7L;u)*lLgul<;sWyQH|5U|l7BDdcX;CrWw;XxkIAt`v76 z+75&@#~|Z6GtL*vU?U$Ca7`Ls6&qKl`L=NGE5`H5(kYbd)n1QhjmyEZwF2Kl>}>R- z%(VcS&+r}4*y9zYGiARh)gU&&;c-Sn~bIaA;Y^j+pHs%$EJc?j1q|OjE zN>pc%mrMF2#miDTL5v}yHWTtdA$MF}<6KRQZ(+?(B;O9mRRO#V`inq}1GPwK8%>-W6klnEw*l8?=r@^=BlvWO7R+-%{9%N$&^d z{{ZYzkku%p&p>Tw(3<}<)5yYDTB)&n6>Wbl_WLTX>_#-t653Wz)g2N!I;HmlI57-e zX!VY;91X+%LF)lD_JVkggc$%=k?b6(yaTZ#v-!Ls`k3q)lWpy?2ON5g(!+$dFxK5& z9Btq>fbR%tKcH<_qU|Q4UIewi0k!outuPpBybe^)5siaH4Ggmz50UI-$gO}p z7Q(fLWhV%~e{NXz6V!UWXFb)@KJ?TfMQ!IhHN=hG-89M^$HH@W6-=W08Z>MQYM6k( z2pX5j8&hrjhU(dwIV7ny18wgmo1=p9H$xnjX#N+d2NAi%fM2M5&7eyiIK#l_37;nF zrer(;@&#Gr1X!+;me-{D_d$FR)OR8d0dtVSn_Z*jk{Z>gHGE#6(O>X?G0WD*>R;y8O{Vuj>?JEFhuTZZn#FS9JnTi)e&7%VN zKFAM~c9Fn4AnStUMv|Qd+9{B)OX^J;I#}APPOM%mzc0p}-LQ%&ucd4?!hfK|>Se zVJKz;&8LWZ0K^?AUkK&eNUpBblai(aIYQ9RNpwx>c2S?p^g|j?2;)Bkc4GoxNo6y^ zPXWqWg1scNvp=yUY*FW!`%6`q8umv-a+CAOie<>CJODWx|*BDkHT}_eUn6SXa$0YlT!k-|Fg?v}0 zuVLY@TgHi|s)tF>S@LzW<|iWNh}ayoX)sIxI8d-|l07BaE;7GY;Dsdqe?CfcuF!l* zz#{_Q5I7v-0?Ox6dX3Vd2%SY}v=Psm#Sk~_Qh?h%n`@QKLyP?40`)NZIA$3~@O+Aw zi1w*ek51VXN>dr=o`DmQwjPx|EbRvdHesj}!-pt22Ex-&E*1C!S-Oha1H@r4z9DN2 zPn7M&<{63R?GBqpaTSLRf_z(8d_=MXXq%CEm8$nAG?v+T8nSI9yHuzr3p^`@?S!^} z3-M6Wb{26iRG$votALG$>aU@;E5YVN%V9(1D_CQQSPdtaeV)WYa3ANMw9tbMncsrk?o!6=dcb2olC}>uzVKgLuJkVlGqTadXYXa z#T`u5mB=zkS?`L-k)T~B+P;8}_m=gKJAt&LNDMdXXjk*N24Z+6+)*WNsvk+2^y=waHC(Gsx1NxEG_b{9b&!<#uj@&ksx7%K}!g;c4eX;rj(DEY4twD?jInkI; z6x5GYsy8pH5A}?FEcA;dFSf|jJlnds@Gn=j*x(OSc@WjygIV9oh%+qO&a=91TGMv$ zx{NGgyA)w97tS=<22>ov)TapD!f39CsD~hJjpyN##yxdx5MOj^zSx(BdVVOQ663?Xa zO(}aYbu3b=F})9>F&M$06*y2y%gjeZd2o&Rx<-9a4c!pJ6HV&z8acU!omrz=m}m@5 zG&U4lZh^O(2yg5!_c5{-rnOw1EIq|)Pgr9j%+_Z?H@Yuo;b<0p%EArI{T_2)K(h(v zxu$!)v02;GwC1|7`c9zj4Dt65ldU5YZTAP;jt@1r3FOT|d01R3#_0gY17%I2oJ5qj zsB*1=zZrOvgEK4mR|S4>C9jKIMZDC-y-g<4CK$_=ginIXZAzmOJ0r@fh(;epqp7;8 zP*+10{wHMh471#a^z)JB3uWUKMPpp5Y!;~Y43y6koGD^F#M2;MNa=SZ&PH+z$i8Ff zekeAE@-bkw^ zrIlVuKP*^%nrzo2*myrtUQShiky@5P?Y@M{-V%FDak|vJJQbsrIaistrMRVFKMOcZ zh{qH8EP!DEP6T~dpxOe~Za%!)5N?A|S`LA?yARgV9&FqKa3SDZLXD@Pmg|A)0kUy1 z(K4B6IR>cyKs63W+TWmTv(%ZMIMbx|6xO0J0Em4=jZ7<#rByeim6MXyQ9{`h#0tsy zOIprKvlWxRxu}6)vpX3rg!+JS1CT?ooQ*Itfl*@oDCBX=KMc5r@~eny)Bn#w=uGk| zGXIa%$ABm{Hx}xf1&$H?PXcEF_2oi6M#9xfysoqb8GeUqpP6-eTXh+vx-{A3OK6s{ zsv9FvGbCLj;hL1~CwWh$wS%f{m@OM3t6Rv@nP^NS8XHihBY<=NKhI${sa9wGnp@j= zXRJ*kX!#hSkBm0a#O+>rjq$x>@EwH0fPwwnD}+c*oq)zd2rd*9NowB&!7Wp8A4G_yP+mFdfU=jB3K z%M-H3O=;CN$#PE8cNZ{N$hm~RBQV&+--`SSPyfNQ@q=f}HNG4+b_r$QLS;HsJqmGI z3h$=;j|n>~(Yz&9w*|CHB324E_ethDNxYYg17-0$sE_F7O0&i+TFWo+#xXEogI=D5 zm!5Z1OmLXyOK}~<7wiVh3+s#OpPBj0gm2!3|wBlG;Ik&Eydllm!-FSr4esucp zW!-Vosz@JWFLO>TK zFf_y+Qp{8tqO2NH0kRwo*?|(aL)v-FvLdru2ibBG)N&`ZLOZdVD3;gL%3Wc8NjMhP z1+!}_`!t=inpSs6^IyOfNVc0|T;UC}3R>9%#$Q0r5_!6qU()iJBIK@6+wsiYigm2x zst3DtXbJwWSh=lO%LQg-5RF@aF+JJ3Wuk3r(gw1q3(Rho+vefEx?7`HSj!ZlrHAAr z1X~SI2Oxd`>${0&Zz#q9x*e+DRW{d!umFl1p&Ub$?j)uV>OuKPWDEt$HA?J?jA4xC zC9HEKgFjowVpGmDFHO|96=o-mZbuLw>4M{|m~$O3f?5-v$HCvkmo9s`<4k zZy>UdA=fAL2$@I0VhSxkAaC-pup|7BDcqsAHh3YY#RHJ_H6eL^`eGA^#s z+TGZ?m08;%K=TBk`JuAyZI8As$@&sUy#Wv%K;B2=7X)9Y*pu?vkbRx<`2r70@Sh32 z8it!?>Pv4f#*Y z=2?uoA3T>T^6Ny5lQnz8nx}#FTgjLlXnqzJM+V~PghnUoHlUmg@J^_F0@#+z74Pgq zKded2-zs4uL}7#lJ834WCG8Dr7zsN!14e>Hxsy@TDCJ$9|-t*Mq8McyGZqPd7e*U zJqqKLHUZ!anN5)8c4@Irm^y^x+i-OXvta>S8nRE5ew?DLi{;ApzX`rnw5|!QR7-s` z*)i*COQEcjSq96i_Q@4*0a`8vw1-f?47Ob-Yke2Ut3Yl7auy8x$?9!obvGH_0c~qg zqd|TPa3;trzYO0pj%tZ4Yu6pd1gCyCFOXX)&lVU~US;p3!i9)Ru@>sLrF7Vxg5(Si;HaexqO z$TS~m{UF;_iI>STL5TMy-JD@3D#{k9eQO18Q_X`jd_RS~i^PAF7=ws8NKS>yfrxe+ z!EGxTcBgS=GaM?G59GKAirx~sK{^^%&o-e0oWlhzBy&5@INVdi%{bnK4JmwJzySum z>B6cd`A(7bDiKpl=9NWS!-0?7*u%ib3|eBuwT3*3JPw)vB>e3}UQ#n(4dfL` zo}P+%seDezQw3Z{R_oKs40v?}%sP|kNVDx^@uUnJz<3f&GeMmvlrAtWM%pKU&jWL1 zWF7?KzcTC()2%R^1Mnx%J^@4N0L_8TK(T;KqPD z3E0hq)sVOqX*){wxrycx$>z5~-Vx-sNp6?$ZVBHYWt)n2GZFh4mc1j?N1J?Kq45gP zGM%jM0(>o@<(Xv5p9sGP=1XZDN8`aXjwd-A7Dt2JfL1mK8`~4@MiVRc2O1-Q{6<=K z1d<0sz8TSaCeeHz;F<-%La6OEsBMNtj&pFdLqD6EJg_=d2J#WI z-k$EA0QQ$ve+#qeZnl%T-$Lp$Ap1g%T_oEAhzkMTL&h+%?I)q`k=eRYX6pmW<`xpQ65KLGx(rzv_;+{mEw47ilS?Ld40>JbnfK|c#DCxYcUv1|xh zZ?JhDspm+1YSjCNTma=Y%KCZBWt)R-gA?^vHR33<_$#yRWpUZI$=`1(`t2;BwU09% z7wYvTttGP)kbXUAi=b*Q%AGnb001BWNklH1M64+k}gL>~Y%1Z@cM0zg;7>upf5 z9lTrs_jO_A8^HI5a2rhhLGA%m&mvo%hA@Gyf~*rz&k-6IB-?fgtNWU* zun2~gEwvtrp+Mu%Obw3A`y%2@8K)X?wi_>?crSrN$a*ozO`V)WVq;?tS?<-&_F(i9 zV}CauLhux#oMf=W1g=bSA=vlVqayMkb#x5ww1Gq2eRhsS=$KJ?0}l5AmTt}9;MU=kbMMrUnWi@)t{D6fm%c> zFUxJNN(_Wze?**5=f{v;0B{_TtCBgOSngah-zk}Q8S$e5z0K?@Cmt+P4^MO}sdFmj z&Yrol2Rgg#&!l~08rGSH|hOgzA33A3GYCbVN$y}QY=j5b*a2G6sLz; zuM9PB3AFq~wc8DT}mb7+)M-W)kXdfm0+l1ecDE-O!9IVHX7z5Nt3OS0XpAuI1CDAfH zfHecnwG%l!Ws4&lo2S`KfmbE)tmvnJ)j6I{CawPxB zu=%ohL|91dbBpihWgY~V$Jt)FZ>V`$7Y ztZ)yp!cL%d75Sh{o5^B3(Jm0HcR;@v^x7nB1Ar&N+#blzQvH94=6<2(yhvSQ!mWe`gZ1h( z+-M$8OZ69NtzR;7l2V_lE;k@zcLwi4UG}l`^E}&@n%WMes(mQ?o6>fHayMz&N6Z*y ziHDW-@lb97{Wg~T^-}lFTeyZGxsqIr;mH@WhWG~S!$ z>n7Qow0{VGTPiL>#-B3tfRw$R;DkWgC|SA*+z@E?GSur3_2EDcN<^PztRKwzfqXl` z38^?TP#>GZ?2xS)@SSR^Q$YU?vTM>OC#!?g+HD{;9+7OgfYZUe1gvia^)!jTFk3|D z@u03FV^^rY7s$m>Swvx;6xS?Y$1Hn_Xr9Z^sU#mEc?A%wi228)=B4raR2i4Zx5T^$ zH(Iqj)~n2wgb)gQu1Ia zR+X|FvTT}ZV=cLs2VU^VkqC^n$li?H71=l#*>bGpy;A%Vp(Bxbu2C-%wwalqF4(rB z_MqjFq8|mctOCUL$hK3Fbtlk11Ne8yev`Nrlz)P9Lz$f`#sQ+Qk(S3K?U|&n74(x6 z)<-CtiRGrG&k?+@;71ANa;dsD#hX%?l+v9_?+27lCc9o)%}ADm1e+qDvxq(5^;U`I zjk35$Zl|ln*{akJ1p`rR16s}j@jQSNk^UED^$ox`VfCf(w!KhR*brU@g4N%^>UJb1 zfm#RPLlEwO`;7>n4Kx=*x)91gA#De!o($;;0S_f{b{J>VZF9-bF!NVw_NELolU$U* zze71lnFE+{V92@=)#e87PiSR>Zw&GnV;&uhBaP}}$b*RNE8=g0_crQ9%Fclr0|~w* z@D#D}s^ABJ`L3vbMjitBN6B&pkQXP*-YI`9;ZqWP1!~S?<||Bmh~(M|9G-RECu*FL zP0Y=vt(LX_S9NwrXQ5ztNK9D$!8wHvcO+*F?gHs4C(Ygo0fihU^AFl25GuUDn= zN`jpM>6PhP2i7yFvx$4SxW5x8xOA2a6FloPUG+{S^D<9%vc%d3O$PG= z5}Uy6Wyrfqjmv=Y0my-1JS^!Irk!SK-I4Z{(l(;1sf4XW<_kpr8>nv=v`;8EOJQoH z?VHLiQuVEnHU%4Z2#sliOAuoje1c?+XQn;0>hSvBynTV4gi|pn3_u@9Vq7MqRtTg4KXLn z_@6ZFoW@RJxFJjngE%Fv>Yt3x5?&Chp;9?ct_?xlk>u+^?;b$^r0uZWoyF&p{62{b zD2^lSurTdv)Ce;>nZ`Fo>u45MCe(6}z+Yu}FU$`J z<*7P{XJv$a4BC2^R5bwu7>3Yxc4t&cle zk9D=4WWXRp%q9Ofh5YqV*s^P7|Jw=n>tb-(bfE44_$om80Lpu)wtFdlL)m)<99+b) zK=h$vZO{%$@-$H&gSZ9Y`%0XV(m9c~YS4QUWm6fZ8tT44^d?#dK)6(?JxLA$)KjXi zW8xJg-=wM@rqa_;e{JwtRJ|=!^@JJ|n2mRs_BW=sVK&#YY#xNn=b&YqL(A@?Fxgc0 zG2w2C3klp0;3@(4Bz2=P4^LtfGdnk^p-ca=svN{TE_bHIS zP_2(q_2^XVqT1RCq0Dv|sq zRdorK<5G?7Q??yZ-z2nNO|Nz4p#Pt*DJy7I9hH(<`w|&q^b)5 zy9AsUI^kb7$1V^1W6qQ?6G{@ zj3)@5191%mc4eY76H}KfUA2UYp;XLZ;wl1rzi=_Eiy2%Q7sV;T>Um#OmHAFSJhb|-|lWws8I z4-p&-`O#9j1}Y~((J8ZjG>Jn*J2R=?0zXV*MAEhq>`2jHh01w=eFE5HNxqciODX?J zC~HaRD`2|7&q&+Up>9T6VgrubsDT*0;{iv;cS>s2QUcCaX|EkX?Iw&FRVTQ^xGgG55>ae z_lJdwT%TFLF4T`Eqeoc01~s405(5nA4C4?vUyxy1kY6V3I7tJD=xX3nL(7Gxme*W) zArLE5ni0? z^N zC!w){xFf(H3bI?EwWHuS1#~gQ832w4I25#bf~Er4O!Nzr_!w+H0^%g2zen?3NUZ>B z2~lr5d6x-S0KP4Vds4o6s(P}ZJW<4X1ieW0TbPr=d`{4NCi!84J0u(9LCgSiOIdZiXeTH1X#!scY;q8@ zgZ@mAmpO70!5)NNO6IGDu@)@H%i=6HsrLNgQgX#%e-1Ow$kLfKu&i$vd4 zsyiio%S7Aj0iO}D*(u(a^7kbhMQKTbr;u0=7V}Uw7iE<*P?cTj&FyII8-O|$tlk&O z&s75p`Z^YjaLn&#oZrRSdfly@WcJrJ@IUvI{j~-8=UA~!7rhVQPeT5&t<&2DJJhRRijODKV{EQ9eP3aKO~G5^iV?m$#`0<@1)rtFz-s*#UTG{R1Y)E z0W_S<5d?pLd?sWYDA`@WMgkv_?A;*m7kMQOtC%>~r0-3364N??x(~K}8ekN3(FL-~dbT#+~AbJ9=>jkV8!kGcxQ5d6IjQ_Tn`?u)d6zb^0 zysI!DYsveE{6WbkNgM##a0zpex_KcuM(0A-7v?|9>IrmAgK-qy*Q03y={-RkPWUeX zz9#ZgK~DqmG1a;kXg^&U4=dsa0SAD1SIA2xZVb0i;d&I{X`t?+VGgO0fXxB5l4zYk z&IbK`$PQ#;dln31;A4n;K^z0w_d<2Az^-C7TJWs^9s<`GDSHX=K?+k~`7CMA0KPp` zcSri-$a*%i+6ietF>yAeLm>SIU?mW1in$?KUJ$*X$ah7%AkBw?{s)*FLOK<)c|i3J zoaaKe4^$1y^lOFcdW8=X$|Xr#N#Iin>y(O73H>RcD}=iUE=S;9!pBO_*lxDVD^&X_kR%1cl=P3X{DiOQGngL^VmnZ)0-6HG#z1RJFuE;lcg2-p>;Y;3sKJ0yn zYyw3msP!699uRYxARm+a33OkRtapR)Qd#TxWIQd)DWWbX%elt5OoqqB>KmZ?3W^_? z3tmT-Hx(L^z%c=?LvnS%R}+1GLv^A7uS#|;!e51|uUz#>Qni_6BM7ZwmVJr*R`Nff z>P*R=Na5N@{v3(TBC&&%FHyXAA=yvQAZ>qzKbaA)WyC!Q>`&ojQ76N+7F>IS=nm6^ z$o!G1(=DtU$u3s1duD!|vEc1Y-h_r}GSJ^6Qc zo?wmvZuYsEx*2h#0ewxrD$~bX#^t8ga}FG2z!xU`Okf}q-5{MIdd-6R-GXYRB3>N8 zzXX3sP+yRD3pP5LeG)M=6+0)aZ;FpgcB$aw5*%*uAqo2l`&!Z5un3zL<`$xE16$VA_tT8Ww6HgskT*Rjol=iC$t^`FipUZfJ zE7NQW9oL}Bajcr#(%bhnYhM9YrjYp%&|0)=!-5?uEO@*^`(=hW$}D=BH`ju<#?qTh z!vFdSZ0|2(L!mwa!cPJ>l>BNXFG=NPnY_!7`oV16Uw=w$36Z|^V89|HU} z9c*3%8<7&(1Waa#6$iF6nt=*ZtjbXdda$RP1G!tE@e3-DaDQ#%7 zsV4iM%mmR03}i(UGdU z3H1n}{yA0dD2gWv?CBl~rmd4>QE(hAtr0q^(2$81(=ug-fflm=}6wus7Xmv^DL?n8! z=qm^-L4G2jJ3!n(<0(M3B7}2^I2*`U1lxtM0faq8@q3CdFfoULHCg-^qzwdkli(YR z`Z~#Tjn!ib|Col=0N$UnO#)>|N^8){JkXaHt0lmCFQD!M*$RLk3*rDVcP6+FkUc=| z4_PM=CyH8)#0R4NlEm`_t_8U&=&J#FB*~kI>J`YYg86=M|Chu!!TeQLy^(2$rgHBD zA5Ul#fnBA%SkP*OCP1x6Ox#S$1C7;yBzC6hGEzf9yiP_(V|F36E!etJjB5#hM~Jl~ z4HPhyD5GH5NXAXmG&QYxQo8n&+h9}}!K$1DuU-}X13(WT^BzPF0C))GXTW$A$Q1z1 z0m~X->;S|cAXfviDj27Ou@zW$1Izc|g7IMa4JeNh3%&>SCR9xq>s?_yBgi`eeh=e3 zSxl1QP?(MpV>l4Io9TWU2ZMSKR1Z)C34F`c`V4JN;$48JN_J|p8Wi$DfDKaOeL-7D zwujQ@Nq(VFZQ-h~68%(@HdMxDhS&$NjUa5F$&E9s417lO7FsR0Wuy44em7nIQ-YOP7NZ-!{!lU6o`m6d^5Elc)|j44dK25AMV zJm4ywT`|eP11bCm?l&Vfjv4P*<`Q1n4Q?3V?zgz(J~LiyhD`_@NBBx6-azG&6t^>R z8JC~$;u8+eb@^^I?#je5q&kxN-oQ@`Jk7*DWcDKUikqG9#{Opf+>CumYzTRGWPO^f zIytTNOIZ82W_crvZz*D~!k?Auo1w<3iFzMFha~k`0*?pc=`eH=T9;E;NA$PFYCkb% zChg%c-`2@)rq~l!^-=QA42($N{0PhpX@jIbCviG}xhDJ@)MEs{A*~zfy}{hWSguRc z^`LDna!5d{6xKruY_DMBmOo3x1 zuA7Np)2bl}KA+TF&`$(&Kw7RJruW>qq*)$n7RS5UTw`M}={rE&Un>8~tZvQpA(1#L z5(k8G!?f&{$-6-vYgUeO2iv|* zR%@r>m{i#|Gxti^W-0q3rIn=C=v2Hd`A>p>nc%F1zE9LYByy6#Uj%F(up@$YRUpp@ zw7Q4ckfXumtbtt6X@%f7s;N?72`UF*LCaU(s%>V3T_UDykeop4O z&gQdK2h6{)Mr($n)x%LPGRA&1b%FEWGXFZwwoS9~K<=pIw+Y`{(t!zEFXYRovX7*7 zsGMkOeM;a|ur&mne@nuT3Tj}o{We+iexP+Q5qBB%lZk(rc(6$qn(|dwIf16V5qU}~ zw?*n#dfiRVVUT|Z;z^4fWylL{;RO9J=01maZqOq(I}HLSh>;?`7o-?G}pRUPHx?v=`=rsi-H*M{n4A$uR-%|_04Pq57YxwgH(PW-EY-}^q~ay zC7S;NataY22)Pu2k4U~sqAQrs31xB$J6YsJz^@SN86f(QaRE%*B5@@#CME-J;70;juw1wvg#^}5j6CL z@eWvZgHU}bR09Ox1?1Bp=8<|x)GQE_B|Z(>c>u3m==NAT0(K;T{|NCdpz(lp1btt~ zr-8VWh9}|n5m*g2YPej}8GaU{It{5E0NW7cDnecZX(*6q0r@F2r$KqVQPV(xGxbdb{vCmz%dh}xPK&qD3r zrdnO0=2-LA0|;G+!fyp%mat_}v<)MsLuGB2{L&LMJ^6qsKVk4ZRCd0C(-=98!Go>n zD|g)Ep3~gRz2-cE=Dlckv;pHuPB-9wlb>YbrLO9Am-R5&t;XsN7p`@27Qqh;80*Yg zMolo|79{>*#NB56M`h@3t~1PdHo?~c%tAJfMOH_rwU%|$a9SA;a)U&*ccQVe)Yb#6 z&q>(QiRdI$>jkULL#0PR2PW(+kPj>@G3(o;wkqaVSG2*dvZVn>L3WSAdkWk)#3M8F zrd0DepiFY*Si(k%8Y?Lwsnr%wUV`1?} zSadSO-Dda?t-8=yKWnh}0IV;erxY7Xd6$$2B=k6dPRQ6?$f+XkM&d@APD=5v6hD-5 zjfD0$R7)T`+>Nv~rRMcYe3V-BSIJHVaJ7hWX{}XKabl(p2y$|$v05gMROX#hZZ2VL zs=7W^UytK};g-7s3a6+M8g#TEOl} z(+#pR9iB(Q%L???8?63%%Ki7>$v?IL{hJk5H*TYGrc698KpsK){RGGxCX zIUQb)LhvV8{T{sa3bQ(ZhVih{58l3)Y{6OL{QHDl3GzNl8;!`X#4?ng=P)(FRqa}- zZAg`vSSMz9=J%c)#H?m8TTeiGPqKN2YIU~`JuCO8-OC5G=uIoz0DeTG+Bx8B8f?EJ z97gEv0Pch^F%wq>`2(SKNeqNICXrh?$~u(&0oW~qy(82=hB{o5SmXw&!}7@Lc_h0j zd?d1-o!Rz@GM7zhZX#a_l%)%sFE-8Rw!{aT#0O1sYzz5rQJ$INPs;XR8I4y^stXY8 zqu_IpE*E?sfir}BAJCfwt^{Kyh=)Nx0>sMz9w4*^ltZX;CJ@^Ytv!hH9EbzRYAsMN zg4Jt4YYX`;001BWNklTwp;VHWjM3_F17XPP*J%vnI$EU8aInk3pK39LroW{H~!^)-T>M#L5X4g`E7p}Ifm zrzPt_px;i@Ef9J#wLF032@V$R1^{a+burYB-l7nY&-(iON(4j z)I&(?0dlYZ#jCJZf7oBIgX|3CO+aHNWVZrw7+^i2JP;@!05~7e&tR?#i~qpY5tiFA z$`k|!f}9K3U10S+SZyxz9;*BixKDwXsW9CKHhTl@yMh=audbJ&AIOn}okrM$0GvQ$ zzf?7c8Izcecfm!b%j`NCP7`sP=o3KRCFv;1*AQ$gA+Ch!7Q(h6>R$z%Pq4F6LzUS- zGCzoj)3ewNgesx4d@R*!;t)r)DDs+7_cOOo)Cs3 ztt+VW0Dde~*GRdl6gNS+JR<&WYOU?5Z#?m^C7z=D&nmX6TwkNodaSS~Trbcu$vs!} zI^Qv`4q(NTXfehtcO`Lvp*q!6U1RbUEbEg@wy)84bE|K3p|2}@nej_EeQS&h%{1PK zEkO=4tM_)R_H_5|?zV@SjRJWLRr(|KAhOXl-RDJ=E7fZC5_oK&aaOSLXQuxl+5JiX zEr7WIAC+u!!gmf-zX#if3fiNf^>A5eYyMGX{(B|w?$AIYKV#4X?Lg+~ zG=3b$9ccazt#LnT*Hc`TvROoR6QJ*a=Ivm6HzB47x)NwD0p;&VjnBXiAX`Qpn9$@< z83eYUBh>pd>s}UqqLs#T89o8o;YucMg4(}IESQjNzMYK6!s_*c)jkEb_((CrxJsa{C|-6LTD_^%NOXjJc+Pon3W*pzRA& zV_yf~PK&9s*bLU%7uI~A-oB>!{I$*he4m_uk)gG6h1j@8>-nlJ|Jt{LHmIz*yQ}qz zqpU)de@V^dQw#P8lub?XbyKB(iWi1>UrOs1#f3p`n(5CXcp9CvnRr9STLGMIh!Ljd zGp^Qoi3Oh}ng;{8z<^^fUO%u9V_S&vP_5ZK!7U= z_4`uWYqG{Wvg#8VkApSthv(kP=q8KqGJGs6lV#1%#Q8fV|9VZ(Zd5&7s@BiMZl*j@ z(wP8;n&N0reN|=a8PEEkRn+}F>?n)Y(eU^N>94qo58K zA=}O~+5QL)ROxU>mio&G|2#s&B5_J8dl%+j#W<%RuV~7iZpkN<#NEM|F2pb@_J({m z(l1l+Aw^sZ*}DKgUwHXSC!l;!lui!J6nH$ugQ;u*Q6evQ=5ptS*hvsrEg=5H{34BC)|S+l*$ z!~`TK!~9hmJ|JTNh&KQp4)|9BE&#ARfRRYe19UTmSuo5n=fUvYiPl_8)Ro3uIiVYs zI0Eu*7P80jrXhC`+mADqUQ}a6qfH@f1<3z`{6VShO`$qY=r9MW`UCY6f=_|+20)X5 z@(R$n8?=`p+yKUL3nLGMT3w(HW1+@>ko8)~>L4gyf$~wveh0ie(CPz=(IEbdr}0cV3+!3^gR*%{2~RO}>Twxo#wI)nDCiSI&q3W;;TI0%dx zLf)OyL#A>)7WzgEx6oNs{=nd_OrOo*SXh1l&z)89g4|}(u{5iAja5vd_@h;Jpdpu| zYc*3DO>%34eQDs2men^VJHuqR791R29<+L`n#%(;VC z{NB92!mRBalAWN|r_5ZS;I_p8r?vl^aR9WHT?fK4*l@n4a)0e+()K$!LkC0FB~?HhI>eR%&33T ztP@?E$aJ=mE5mY=B)TTBqEKBUF7mV3;RNw-SIgS2OKZ$aHu@&o_DMC~hB%nY&J^CI zY+EX~hU(c1`4RcO%+5^MTFLgYsW_*Adq7xGvQ-3Z;LvJ@x{v5fkX#C6M-bCMJSpb8 z1bP_j>kRenhURTVehIdpC@y$k(my2}%)~27OcKyh$Y}v=VJf%N_yd@43H}z-enI#u zQ5KnoQq53QmryYm${Q2y?*y7tk~uw~slgnUE2zwFK+Cp__qOo|g zZF*QeG0pc(^Kmj;D^WHQ%8p{aJcwJs)+AW$VW=j%Y-1vhGQ@^y_Mn`{!{c;V`>wPF zW6k~=X7<;LwC1&Bxq?{miYsoZ)!f{>blrMdL(N5Nl;3JY)LtH_Z2p06f4yn^>wa?n zF~EWyq1M+aog0~NN9ybVUJ2-GQLodqBrLuGH3_U*pzpX)L*Bl-_~+ijUm>)2H?$w@ zYW=NJPOVc9R>74j`51>DH?`g|H2Wc2doZI9GtXrBWG1GX7Sx9JBTcP84RMc2&frIg z>MUjbo8(ia8ks&el4~krtfGC{EbWz|IbTuk1maIx98cFgx+YnbFIE*-t}5JLRV`Lt z+A7b7EBCG3>a*NzC$}6!%k@~66Ka=bU_|a0et5nYuaI2*4GT9NyB^b6RlUG{SGnkEbMBB!Q##>0A z2H6B;ab)W%O3#z}n^{gZ&&|y8buu3z{S&gjhxCg{y+mjbm}k@SVyo~790$Vf4;UxX zI7qZdML$~5kICFNsAbdeZ5aL$hAYzW4Twj<6j?r?VO6>rDh8eVv(nP^)--zSN?Kk; zqmx{Pq>;FT%rnF?Lc}ncUnIj}>2_K=ho^IwtbD6<-(FUakvDDu>vKUa4&zTh_odTZF5i-JrB`g7NYGiMCDArOXyfKw}h3BWc!U^ zIgh|FFkgUUf7BR(Mr?#S=AdppiMqKq>IDa?Ji3Gmkdwhr-x03MIT2@(Kt8;O^QJXo|_682(3mj+q~Wyal+xqd447mzT{ zf%`OAeG42%(8{H<)<{^{ORf${9GSF#B&&0i9X1Fqx<|1^&M)59xp;?ni!Js_a`FEY z7dteuSZ|=ipHh8B-Hc)6#YT)FV`(y%BX~Zk7wLYZIW}d5ds$%_ zTB9F)kv_1-Oc|d{s%w&-u>VSpi;$H=x>zWu!CL3VWV%^TK!YHh72YPKI2@I@hEzOtiL4l zd?24A>?K34?V5j{G=Bi)7m2*ZmD^Q`O+0YBt6t4BcQci1iI|7XVMslP#3&^DK{koX z+o*UFYTgdm^i;ea(lvnf5gN}Et=WKYk!anNs73+WiO@@i+(2lpA+!z!;~)S-WcFNI z+f+JFg2ji%7;E&-hCI?>Q%o__vcAePJ6q&lOnXS;O_I7%?W-B`R)dc=NfceK5e=1%C{v?@3lGiPlBt+a>J^q1q!+p90la8L9~; zo1w7X71equdQ8E!vSiOF^{kS7t*BnVC4avKtx|-cq4uj2WncpRfn0$o9}#vJR6PKB zKZ2i#?2)wHl74!!8UyoBz-qM7`$Bj|;)O~cL1GiAe1z2fpl)aKb)+6<#$rrNWZHg= z#>ED^4nSuDzk_XW0end;M+?3i;KxbXA6Xtll%FNP1B^2PeM2?=ZSl7;7LCunrHM^3a7|8ntbQP=7K;2KUaeyuabU&oin6{B6zeDm6sY4AdG8<^z z2>2HOXG?h^z{N;RqhW1BE^TH%ks43rXb9^?7nsfV~Fdbcur&t}p%qv^``KnLG@s9uOat+4^)lkZvo>a;~gA0>iLG z{2^$7(hov#U!|R?w5LpLGio1W9z=@|X?7Or+fwxzj2y~{ZyDHB#cl+6B9!;Rv^jvy zAnONVS4bCtJ`=RjU;{(Yo93y8l zumV)y4cK^4vq9Vl*?a%P^sWnP49z=3_BO!%$kt&%_67Yl(oZD(aL~p{m< z0~Cu>(UpmjbUOoH?MdYXFfT?lE(Um?B9DOLS)_(3*h9pAGH#=~T3zJ7WaW35y-urE zGx~;(a*bK6V#Xr~F5xKsTUbAurnJbZ{3z;{< z;#u=NfUeEq_B$;{fOSWz@g~?fL(l{uwg=*1$RDEksKG`Vu|4GnQ;iOkj-aqL)7GG} zzh#_cftyI%70}aQtRvRvC2R>pc`~KdftU#8B@n)aqOX9v0Xzog%IO#-a%*`#OSD;F z{gGJqudFd9t?X*dc?5?DT3%>uSn#){f{Pv*)}c?BuaIoJPW;<9$wi+|w0$SF^-|g; zVDnipP6lJBvGofP?~8df>0MwvON_mf&0&eSODMkr98S|5m~MyRF|k?_Y+NC9cu(T} zN*>}$)$vr_efksq41E+MNyfUOI~yMj%CYm*Kw<-zp0g3?Wpb(Pv~R`Nlyak;Eo zTh^E^Eb=|r*q`*@NE;4naWTJ3#waoRi!n0|8_IMstn@bG0YIavGLwu?z0zrH_@>s# zAy!9!ugjTU zwl1LR$;?IPG8<eCmNO1U1Cv#4@E6faXc7HTaAWiKOEN!f-5Ur(^fCiQS(H45t~ zeB=KiXfGG|M6&)Wt(qeE%b~V6gKcwzRc`@16I|bEqlJ2L!MZE)1G0Klg}Z0TLn82O zq@57S4@0?pQR!Z!n^OD&YF~$mYnkW@+3`$26S8du`+%_BMLQZ+^%d*uX}%0t9RlxA>#A(92q73zmG6gT+CuP|0`>zi9MT9XPN8@rQiGtzme3+6LT!goHr~V^DgH+Ba{})W)(4h1!>}A3 zJxSb2kM)-l*`icD7ftd#~Jh-D&tHTk0bGT0)M2iBZ8Ns=us4`WXY3_ z=x1KmH^&GwyVS`p4%;-tw^OlhB1aN>LyD=$_!6d%K%NS4I;6M2cpRu+1?s^-{STnk z570<}t3bFN+4>&Qyc4DU2b8!BVFyFm11vj$^REEf`+;R+u$&FY4Pdn;D(i$=yP?9a z@E8hfKNxI(9%x@1YVHr^21slG=>S3Ri;V|F4oLB(fDVxOmWNiPw4K4eFkrZZ87bS* zl)Fp$Jd}45xPa6gWSO8WBb7WMqZ%p15`-?I%4|!m0O=-(`v9$XX#9NP8Ekwi)VERg z0+c;qJ_>2eA~_J$)q*~u>AzrJMV5JlKO*I?RI@jv)e-suD0@)0uQK0+>s@m`2Di-t zTNl&;1lIugK7^%J@GO!emFxxbS2^F7`N|o-uENJ4{4ACZT}Yly#l1$9&~pkgMN#Q=&5j)DqGFku1{ z7(fh+0tSp2Fya_6i-O<`<^*OzK@=lK%=vKy&bhmHy?^k2g}r*M?%G{-756prEt(Ia z`3AH&iH4U+%>wf_G+jl*TPwXzIu4e$2e}*6SP#I>5XM329Euy8$7cp^ZM2zYv4p|H zAiOK3Qz6?x5q%M5J)-q;DxYT&^BuYdD7y%p5Biy+O%rr*D7q45Pe|uUWr?Iur1%8D zbXd9|Oq0U%p0c$1%56d8s$jh6EE_p-3lT2>@mrwjih@--XKOR8u<>%CUsl+7rm(S1 zu(4jCF;Hl95IG=-W5lv0ECvziOW7|pb)>PsGX~MBH^`>T37lwbonxrGnU!da#g}LVVK0wvsf#h+alNnda*e{%5KjO~rPi`iSwQfJG`? zTTwbA%Eh2P3FW#sc<48_7 zaFSq4Nlv5Nu~ym5UTHvT=qyh<#XWkO<+aKDE+fve$h#2r)l};qsY&?;ME$5mxz~{o zC0A@qEFUQ?n~YF5^Va*#V`(z(1Y!)Ct}*zoMC=JzTZs48gUx}VZ?c)g>u z9xh;yAnz|$-xstk0IqAn2Uf25TYqMhGpN!7!kG;0u3~p0<4a^+ij4oTU}q0L>w(+6 zV3cM3i#a->V4R93E7VC*pULoZS!@7{CL*w{Max4{Im*CSKpZS9?d0f)grVksvKbFI z@GeulV#=?w=m8Y{3uXD6$jkb|s@W(_ucP2-6rPWgE>ZClQ4$^~Ad6lYPrm-sxC(zM@$!;ygq<2kUuJ7PZ_WB zu+1TyN|e{7vN43Eh`b@9v}eT2fKCE+Fr}Lzbw#uuDaLr*qsR{f{nYtGLEpfu-AN znrBFp2z^TFIWs&)#;Rltqv-=$JO_&zq&m=AN5H%bO{c>0P4Lz^u(CT?-XNnREk2^@ zCNdvI=4ZjCzXH_~uuKQ@U7*h;o4zyCwL<-nQzs>+hojgNnf#IR*^vJ%*$rUyA>vF% z^{laVA7|Z5)Ei)VH_V=<;$$#Ah|rsexJSwx0eOPNLnUJ4%D)Rw!8xxMB!|+p~ zpC70m4tNKresWY3DBTL^?Lal9uxaap#tk)_x6iB|EL`Qk!KQrz>HL7bFYh$!L9WmXP$42ZHzY5;IA7vl#K3T=_YE^kgie0aTGQO{Bh78HsVGiK4-+4 zrg{fPOJ@p)2W%%p$~%VKk6iHquwuhN%hf=1Bg&Ib zO@rwpV_9g7Jq#L4ptF?r1Z+nXteRDN2QZGZjVs{ZX0``dYp!ydqFl8i z$41EYGc0@!CGW+EI~1+=Qu!+|&!)HTDQg`k_a9+sXBLahFyE<#CLiww8qCb)h|MICRh#&M0XMoi)Gy~Eh6JWuxu}JQHUdo?8jPZ{|qiH zs&6Q&=7bt!Al_q2Ynw2P;NC>;3$$JV;48At`(k6HU_C?|4BD?SpB!vl2&SokKLDh! zfNH8#eGl;y5KF1@0D#j$eF2~sXn=|}JY&^D6r0TDe3?FdE( zfSU+aN2%J3k)|-3Z?dS~u(^*07*naROvNA>j`>_&>39W$afA92Ll`}rEV(K3n=M36gw7~(^d3718YL*O|guJ z=?ghVg~wo{{t9vt#p@aIAkn(Jnf_vKcbnrpbB#2|0cO#G9tVN;T>$?v;8l`mYGrJ2 zS5cQU^n?XoBFbo}o(Je*DLxO?U1{|QqMo$!qN*>Xr=@V41ux&jV-UbY0SrdeqlJ1l zpe+gZfa@Z%456u~dD+h`)(QAD0T)Raq-gY0w$~wFw+MX@x)Y9@%C<-=?uY-e1?-REV#}^j?uN+QBj=8QzXRc86n2oxF~Jp`fyVo=rmjG20n>F9 z-eJ)}iZ}_%KSE^|RK_66T_|NKRF44j97r7zIt5mGg0VVSwgbxNpt=b$g_Z}y^n|Ru z1mmOf^eC+L2tgwO+X7+hB5W^^J0rAMjKkpC1*Q#Paf28)OEDfLE@iREvq+ABrC!n-_uk5wQzhn+Tc(@I25j7JQJxFGu0u;MK(^s6BaapPwU>;n0=3jahZ_kr4!ERPvd ze`o7yGJ6}uYZfivh`NNqr-0}M<*z|(C3v5e(eF4i5IY2Undp1M()7Z()5%|*X;z@I zU18I438}lG^-QY#256*^-YjT5UD*76<|>^so8}g49#z;pBaluI@DfzN0K>sRSqIQ1 zM1F~inKWOO#($e}sF`&zq>IRE78#Ss*qv-T6|{M@_zuQjKui|cF2J=4cxQ$mRl+|m zVPit|{)YP3MD&tykpZWeVt*$Nl{6ZtR|WDgiJJ%FRj6EL;bRdvm$L4FW)tW}Xc|;L zqVf=+aR808A-fl}FGQ{z#D+l*7OIcMcp{89)6;oU8XnPjKh$R5%vHY2Y#v|eCxziv z0qq0m7-5e~)s?~YYIZzVs`6T-`px2bU6}@gXist~SoWcn1x9Y{}5!wtYhf;N4DIKNoM;5z``JD9#DFpns6fwD7DO%l>pVBEH{EQ6B(>`m$ipiB|$`4CRe!Fx;i zW<{J?)Yvo>3nZ>?Xq`*dR~fXSi6;_iCdeIN`WIOB7pj>-JrA%8;S+#rFxfa2X!<~? zz7ncUq3SWQdIhq(q4F=#hJZW?fd{~t%)sh^eM!WX@En)G7i*_h%^+Yjij<8 zl)r&|K3H8WSUZ5%K-K0b%~!Da^Q_T{*fMWWv&rY+>Wf+c@wp|%Vi zPnEkFEuA4fqEK6@o+swd$^4Kpwt;Cd=)1zX9ZWaNFi-Ru5(kMoL%=Ek&z1Y35Jmwp zmMncqyW0$N95_(o7ZI^IgquBlqQqxH94+Yr!tR7&J;8nld~e9^0Q>{Uzk_lQ2qO^~ zh{E2eu>rD{qAY&{D*MBlwgzJWyya!ME&{OzSY8A3Kft&KrtV1f`KaPzRQYPA))DY! z9bqjef~60H-U$8%vKz#;5E!Z`lO*p0mU&@iD45S6(H+2t2(1CbcF1`su;Oou{0>4V zAj&z4@*ayW6=SL*rqggOtey9SB@c>V8;x5?+pympfqPC$Ovq#YME3MQRd&(TM0L;#blJigtoo%rLjN3F~RF zZ3uLS$`_Jd#z=D+WjIjp5#(IS&jQkIfFA_0t%8eGd{;S+Ua6Mjc#7A8TmvWL81^=^O-Zgx_|FtKB}Nb<_vqBQQgmCdqC+Ogq|VGQEqw`D1GEji=o&hLZ`^^ zAToPG@w3DQ2b)P*c;v#@0;{ z@x9QP5SI2W*0f8p=39z4UM^Pk7x@;DKLv0#WSb(&dVn^ExFw16$vlEqPM~wRSy^aS zPc+sW5al!ymw;Law10w)t7JL_^y9?lzY5j$0{;@S-2--O5iZUV+e*2U7|$YXxQHVy z@@%)(uR{3)Q(QpB=?Fd|*_H}EM)?6Md>m2kMx-l%rnx}#8e+O%)O=C9gLqNo#WMR| zNOuIQn}WKkuyMWML&C~u1mA$tiSjfgRCO!(^IC;}+br|X6APPXfYlv>KNhMk4m4j- z)VQ(GuP8}}=M+myg(JfAC$QYxX#GGx3&z`NrKefh(t#J8aZR#3p|WL*6I*5^w$3mv zn@cR)-MQj)x7K%!`CV8UmKwHV-SC#hik2IR`cdGI>C$g!7qlD!)nkDCXehlRrHun= z02R*)7+6%zPf@R*WiKQ&wU=}h#7>Ozrde5HtnZ+4ny4p^CDf*Btt z8%tm<^I=W@k*A+zSP#TWQfe#tc9FCMitQNjFxlGQfVGG;9g*Hp@gF4nT(Vi9-zM1W zV!Bpn>`7D`6FhjOy4Lps*Oz<{5YwdmDijk49t~+niMvba8sb?J9#r5q$!>wtmsEP% z0-tzrfCnaelp{=KLn59b(;~9{0`G@xSIWMmN`EL%hByG>Pk`xjD7FxMEz0(h_@ctTM#KPE*;K*j!Sr7t-3nND z1(qSw(}>gs+3!T=Fk~Kv%ZC19pb%`?go8JqUm-DT@CRBRJLa1J51b( z;7pkBDzs@2q!$r!fFjMaWi-=hW9D&GNp_GGB@(3_~ z23r0JYdJ_(?iBN9uy`Ge=U~xa+#Zsr2SKhY;w`A025~519~0aE;x1%h2t7zJ_q_)G#yRn4is)S;1z=%O7IfOu2X14 z7;l1O3TXQ<>{CWM4e-NA{|V&rK&&ZgvQ+n$a&HJn0{$F;BS>_G>vAT07!}S@h25g! zu2HdnRBRt9PE{&{khmC?bzt(xXpJefYAT`LP+SCQJj3p0*iuS^A)Q2FI)Oa_o(86Y zg1>FnIETi8Ksg2CJcPGp@f!(kY~tUn#Bedjz`2W@r#RUMYV=|FtC6v5fL}{xH$>H5 zD1$?>eIPCk#O?uHT7ZuP-UFpGsI(fy`9!(_;O}C6tjPvb*o%sGKs{Wv3Bl_0utxvz z>IHfAZkRnM#-~7enBpxEj|Ad6sXPp`SpePyVqchUr`dI8+QqDNHEZ48Sh|3*2q-&) zWpB_97pqOcbhyyCJY?@i*k~b*kkZEr-KMDfMCe?R??QZ9&_q-HK&b3uz;`AtU{w2| z;58HsQrOd8e5eZlt0+%M=|FLny=1F=BTKi1rQR@K15{rj_7B=&h1Cavv?Q>~;z0ac z^pPYx0rn73%?;S}BKvF6Uk}gx+wFy`To!CINNm0zvdyH%-i6IyW;M3Rv|VcFdD*pf zaqa`pm(Z|2EKMX+d%CSli?eCv-^RSQYsFX2*7cpsw@hrkC!ro@`faN5_vwzjmm_8v zV*;7)^llq? z(SY4#(i*DqP`wczCBP}aUtVwOV3MrewnT#ASu9^Ax( z`=tV;$Vt->jht#GtOr-f|aPJMX17Q9On6g;iF5~M0&K13nP^}0hhnx&ADE=%9 zzp>2UEMpi8+9CXFsL7%(e@&4@XYdDO=wtJYB*}P}guJm}Nca)J zIW~dnzk>Btm`1`iiK%=~FIUrBC(&Cc!d7fVTlOq`*>gxMmZ8eSkm@<`mgVpjXTVx7 zCF?$9J(1GB6d!@G83T_~97pp*nfykkG!H2qLr*``a5*hbBJ&1B-h*iEg=qN)qvb4? z)-93q|1s2$h-1KVCoJDbmbqH#yEv05--7uhusjUYLb=y+KTOWmWZp?ueJ-XSK|7wX zyC}X%U?-z4w-ndY%Z2p(9=se2>Ozu#GiU;Zo2cl`l5a$4Q%b!|xWQmw7^>S%jYkds zKSw&3;s+)SCHRrS$B~VmWb*@L)8%CIi*D&JZnoTAZ@I@8?&V!~oo~i|?)Hc~wsY50 zR+X)+vhA#q+Of&5V#Ck2Cg0zh8dJPVPkJM*=1uJ5O&n{DxZEnWW3qX0zD(1O##m0U zUWqaHPpGEfsp>|;GvP-Q91Et0!t8-?XR+$$Y}GD>jdL^Yz5@F#0xgoxfpiND7t%2R z&JMCPN^G+Z&}KuS(N6M5Rjeqg#Sx7@MgC;S?+fv6fj5aZlXMyyUpgAU7#d3qUYWQC zz=;Be24Y|#H_7Isa;ioaZ`xDdbicg%8CD%n;{;Oo8Sw?diGVf*VgeA$!B_~xY4kYR z4Wr#ka;tm0qSoEqIjFgK2Nz?%F=YAMcT;K=w)m(n%?vwQk#)TO|LLD zwaOc7%6(ZeOfBa77xPZ-?0^I6q+0E0(mnrE;oU zYp-O>W>&WR*2HD!B`)jh{9`x6Z+9mBer%-`Q&Q9elj?&FEhi^WfBXjfqg_PHht!I# zfMx#@TE0@O*wbP~cgy+IpdSyG)hU0GYAng>OS{KkF(H@udxu9->h7ei==vf(KKum9ez9gV75WYiT3l?3)oPSY{i;;1R3b$0j zo+#KBg(DdGVp9x*w3wkwyzmH%YG+eCY)W5J>H^skh!+7iKgiu_dWhnwMr|wTSE8H= z)YlU1PL?Hrbp`Pem`*KBtA}|vm>ojPmjU@YNdMnmtcw7j3sn1w+)IohAol<H;2>_ik^rp)~!vtJZ`g5YTuwgbcyKp!jE;t;nM)f2+kjPx;KH&OLM zs4Qh@6atf#wSyw{meTQn=0UArNWKO_+bg(c1P?{w?g*br>PcDs4#kZKpF+e}#0l`;5js*r=H5}x{ zVBU==9RTeCU|&Ed0;T=Rb75@(8w#>Jh`w+PljB!9hluzkq%Tb|Ou%-Em==+DrnfE* zYncJWiAFm%tUeyJm&|aIOt%Di7RAvJ-Vf+73oInHNQk>6wT18+g#H2sKrx9ZHv)NW z$=)&GeiF~o(2o{}z_c+8n}YZc;QJB2A&93zTq33&V2%B0FzQ;7rfYY)cBR|KmT}8G-o}zZ`j3pUdIXxJ<^_>DDu8WYcBvUYUsY*jqRsvN--{pi{dh;t#0R_IX`{S{Py01rZb zCgh)kX#iw90WlNg;jrig#sJXP5$$tCwG>Qy0Qd+I2g6EdGPR@GSi-KPRlg9WH=*~) z^gQJMM3hPL);Gg!RG{^!fYuCI?@*Z{#NlE-AMm3o>u$0RCOgYv-3*#w^j#tK6Y|zU zbPYC+3$vbu_=}A1(=dsq2Wc@J#14ecVZ>w@el_wl5c9(7`=s(PP+v@xjY#fe)XB8+ z*Ol`v-+-;BfcbMEE(3Tnqzw>w28xFer4z%hr+BzU-N6FadX(oNZ7tNJVD+XlZ47Jl zm2q>yzh_i8Ffbd%IwSKw7JJM>pN2HB&^It|n$Ohq2vYO@@~W-Ok2Bg{qHitmhAewL z!=Eegj=|JR^asgw0@UaLOSb`j5mdb@wV5FQbI0H+|0`^>RiGLwrkz4<&J4EMuORK6 zfp2Q^#q2siy!;c^wA3u7!|`Xao(b31GTU2j8_MzrK>a3Ezem-dQ7xZQe{2W+evRS( zo;56==7FnRy2GIDVCC5tc;{~d{39st-Ch%cn_A6Ru2 z$oGKee@U%dA^0ewx&nxAL5zm^DR8|A+D$^bjo|wNZWCj?(6T=Y6UfY?CL zAjy9X;D>;30L8UXzMMc$0M80oBT#k?U|bOf2^sP=9io9JZIIR@>Op4V+{+(>< zMPisE&T!#EnjK@XpA7zmSuCb&CcJD&j~$JAhSbM2>|vI+rrEbf|DNC@6yKz5kc#aT z!1fTnKyXimEmTQMSZunb)Xm(sF_zxWGRatv1O0Y*y0?%Y0600+=mItmhWrBop9pC+ zMfIZKM~dlDp_(J$CPm!BNIN3Ow~_N)W=&Dn9MxqwGS^YIwGlCe(uI_5ZNWVmJkBER zZ=umt`Hj*zMhr%9D#QmVyNqTFp;!+nM-b(BBEL(vz6i1(S?^4ypJ9#mV45h#jv{Un zy$5LHVevVEdjNg}rPl#Y1gh(S<}UzyP0%qwnJvUqLKzX@EXj74aIX+E6zOz^e}HVy zMD{n3`8-MX}izwfgNPAM8N0l2G=?#P~L|_dC{)lW7S#Y<7 z`bm02$g75QBjmd=cpzl$q;x*b?iQmfS>H*N^Ng_p5c`o>LfR>W9wspx)FmQs6K#Tw zzk)nSEZt=>3zoN}M|URsfzB;t7#qY10sRmtr$^+!E6QY9o-J#gF4phBayy{D23EfX zD+j<^e}Jtxl~&(vX4@L!YyJME9f^VURH1* zB3%k;1f4>^xVU1p(J50t7aP>lyU z4#W{)UJoq)2J^o_tPNsISw594CxEd8Ugp5DC0vKlu!M|>APxhpv*0@k`KFa=gSa2k zrvN?&;%X7QgLXa1cg4~vsGdYQKY%YtKb{s>k@d)6`I;I1$P(Lh0X9^T~jB z3&oLw4-~nld8}`a1DK*eQ*^hKj%MN{tIF=4Y=Kw4TdMq1YgFsAVb`J&}Uz?%r%Uu3}cngwiGwgc_ENGOWF#NcVGF4u@Qg|hpM9x_M(760KW%$rig_yyd5YfNlY&Zjbj;UPg*{a7Ms9)0la)kwag%68d)}@VmHwCg{8}7ab3_~3(FS-V=Wr-g?B-%$hd<>gUr}Xqu&g7NC1hD!#tz{&3Xa!d`BpKnPO3kc z=8}FNfnGE%UirJDtIRB@b_`T~0;?eLTGlsX9`y1488>3O_UANCeh{G*+Rm z5!it8uO$1G!Z(U~amY3bv27N255(nyO(d&loT;Nx&j9*Air*4xO`<$Nw!TEy=5+ha zjMLow5T}hWvjwzjA6m5+m_8@`ULbWsSa&dwh3a06>K8@xzKG__S^Rkvyp5!j=-QXo z+JjafNXwto>)s;Am}y!>brP-m2b2Z~_OiemL+K8&X^_;IFZz0bJq+y^6@KG zd-)8o_aI-@5L3ze88FV5*}rJjBe1do*gRk4WKjzRyIi!XpbY}j34q@SrY?YOAvJe| znr?tNP~rd~ca&P+4_QZvcMA4%01rcD1_Ea*+l|Q8-N=oZCEH7imT6S|IDsz-eFwz; z6t^Sd2nu~cI}Ea4ARa+gUqDy{@k2?yARLY0dy&iIC6{Xvww6%N6>zSggNQg0;sBZY zf3&H$WHtSgsZ>lN3w)O4j+jh|Rye^&W+R{0pK$~>>qY39B< zlfH#xeWo}asdS|I)}VDq;4#u)0#ZAOqoJl5C{1U}(klqO3Zf5)J;Sh3kke%LI9S~e zRNE82BbgqgH7_D{JWZFFr!AoTV^LZPl(T_+F^HoC_6e{{AomZ{Zw7ol(bfbpgjTvi z+Cxe=0RVeIguiVb{eLW-_v7E=`Tfs1*Zq9GLsjkCdxpebF>3EoyJljy^&l%5-lW zGglz=2L?BVyd#*?DcnSri$EO+;042n68;eBKM-D=&S|XPNImW7+Ki1X_axc_()e@5 zfWs?tqNzvCIuykEWakCN<8_ioTWuq+dn;IMw;^SmY zo!J=TDHVOwdYJY8ntjXJ<#w4j5pg@+SsU`nGpEzbGXO?dxCY>IW^A48oKrc=U#bT@ zQPG*)vJC41uePW+XW(UqCs;h#$_>r@-T!y5&L`?lfG;CFkl<7h``W!7jqVqT?&Qqg ze~tD)u=k@;7X|8TV0{R}M+M5cWiLx+ykb@NyHwpiS*IjsJ=W|y7L4aX4Tf`DI1dMMOCWY7aFdc-nz<`crvSdg z_QTaVkjB}}xPr;One8*odI^)OBe4Y1KLPUosste0a6C$DNx1ydnP(tzpVR9) zd%r>Ts;=!=0dokrSoA=m&IjbhV2%a21>k?v<@P}5R2w%X+BFk+P~;M3T_oB2JE_Y7 z3?^_Nq2CianP{GYI?GwU81z&tUbOH}EAOe{=UZZ<7I8%z_4JzgX_fa+c`GAN0rLmi z(?H)s`8N!YmN-u0t5p3J>Fwy8MCxN8H!?BV#(qTIlFa=9YzgPHgvW!J1mZKZxz6+p zX8pu$&jc|R!ry`3@4)`SV6!2hHDUi9_MZXmhr|QOx(l+t3Fj_gy#UezAO`_n8}Nc4 z)&_AfiNne6Nt9n^XdH@9K=^&gn&KH3lAPfdHiiu}X+e_hg1!q3& z8c$epS-Re4D(N^*989w#*L~pTV{zfb(MDWT|Vqk=JjN)BYdhf9025fL8OF3GlGo8_SPz~p2Q|4Bw%S6fb zBjQ^Y{FTu?k;StkydRYdPN2^dVy2LDZ$dc5@SRSXv@O53`iZ6lJI*=0a#^ zNSAv9I;i6=4FK*mar@7HBEhBHg{Cca&GI{ZcWd!EVEe`$@OWBhP5t? zl?<)vsRyvOK0LU}Glz8Y%37iK&n&KOJj z0U+iEI0u}!(YjuUlLW3Nbk`*MS0menfVz&|u9|KiPxeku_7($kNlIH5GJhQ?M-$}( zFt#OQs)@M;F3RjJinck$==-Ls+|@?8sHMJbg-=^@w>Ik2l|H_r*)I{_Ch}W@8=ATa zz_*}|5o-r@ zS0PU;)K^7)s|IJ;OPb{wVz&K>*>->jY(zJ20~`y)PNe=!;C9rU48+lfJ~jAsx^HIf z%kA0;jv+PO(p_fnO~YG39Av}-3BH|<%hR1Tj5vah%>`|3cn74%I_nhF{3Lrm!#({q zyWGybeA+e7wR2mT`xx2`&JzOME`&t_-dpxXG#93|9T?Xbb+lP8PGW0PPXjR+z&n8d z`u}N-<4KRAv>-ym5V<<(?%nh zKFx!G`Y4Q@oxECEE<-jKBRvh-K4P~!GUGaD{ZPrdWM3=zy_u+0e+XeEAQuv_JHdHv zj&pWSPIK9G`5}$R)8370Ux4CRN}EGG94sG_&2=IdBQXXnW5Hb9%soNAYH{O~cWRY) zwBn?eJhC;nYlY!ec&rjP*|-tV{j?S%F$ahpC4ES>b5MEX%qB`bg7#eiZUfp?f$q70 z<^tkeqs|NHw@A)!lc077H45U1j@$<3Yk>a(;0m~|2(*L2?#1-aOW9hN&^iFthjAEc zeuvuo9>x|>yAjxqK=dtxnPXhPh4C|(_mR0L>1Czvja1zk5u+VtPXu3vx_2Uee4p{- zzAQi8t&*b{*p~7@AdZBwBGlWBXvf1i$yGyY#xrCbUztPA?w5c+g5wETLjjFK_AYa6 z_IAxrv;O=za>gD&`=x}Zll+(DK^a`$;zSc?lK7s$FvG{ozLd$YX&wl0h{gXwxt!&j z&GtC4-jL+ZgdQTiBB7N*E(`conzzt#E$y=njW?LBSF4GaAC4<5)@ZOXd)5c$@NMBQ<40Yp0Wf2GJl46MtN zpCYh6O3dvjMv~`)fGwo0%$e^%1U5a3+QZb zmd}%A5*QzVu`g7fqniamUtsB*RJq8Efq)(bVj`&}#MnrRe@Stvq%%@nSfOKWuFF~{ zGV9KC-UhedGwU`q_8_&dRF-v=^Wok+B&HyF5~|(=nom%5KdkA1UMA~%L_Lbos$?t& z*25sKLB)HFIF(VZLX^`HWq(Ax4Cyj3e+~9FB={8J69~^u;7-Fw$v%_j6cP)Pbs^bb z1@qewo-5LNfq0knt~8z_x&Ln5~1?)RLQ_vjdj0LK(dIk1NagS8~vZ@|hl}okAl`85vX*}l4O_1H8 z;ocTxyJkf1uwegLh~6>QT4AZ11piFup+x`9$h;F-E^w9+wU(D_+jn8x&iZ* zkk+wkkL7ng;m4lz*Q#b(W#{aw0lTHjsun&Wc{$0eX^f&Z8#69}`+l;+Mvk=on%(T@ z?A+_xJc(LXW$mnwT2^5jC!t1{b-=Q0%dBj@se2fW9?o^we{+wcve&nDwsKqB%WCG5 z)$wSmvl`TQo>&$OX@ta$LfTc#M}__)g?4RGiv_iHA(n2yIU6-i(JzJ;&U$`uwx5OB z_oZihik@|XvhOBl41&wXK)DXoR5IS8VgX8blen71WD%3eIt@evVlRU~B$|IzG=Hit zd$-mmHDjlmeS25;{W@!T*0o%Xs)Jd1rdn*M79X+4_tnkw*lpKk&tuTmiOBl69Sa-H zAS2EYbze}M6!E`7j}Q6MnU80#Ah(MU?YwaQ9n^m<-I~M!7LSMYE~6R3=*&RyK9oEa zk&iiY5(4uhbiJdjWyw}^X|it}u8pK<58RSo$)_cABr}ga?RUa^A^{3PG_BB=SaJ51h*fXc{1cp8C+V5V?*&Y8M{b& zoYY9ExrmDCi0mQaP)FaM8J%uMoQ=>PkZ5rq$onHW!NGYlI9~>?sFC~BsOMJsg`Tq4 zQ}@&!yDL`Ka}w=Dp#FO1hC>|*&RB@*9!1uNr1pHNx1^Y>l65~aS0vaWVtb=GJ{h~D z@`I`zT7m5=v_wK9tK+altZT+|7WOi8QzM_X{jJU8X`V^oFJw~4p#(Mvdp5aUk@@pw z%HG|C@0Hq+dN+jhhNy$ZI+e^t#dfOHy*SjJRjR*b{gByP3pKB2 z?VZ8e|39`f9%k(xO6SQW&Zg=?i2Nf0TR@u6p(QMRX=!6f`-8E!sWVM3Xz{mM>OPL{ zJ}&ipl-?Co{(|Brj65I82_yx0f|=_9E&ye7l&v*p);B@a=2o=jR$0(U(v-AAvO_b|f4a!t6!yMhWd4#S5r-F*WY6 zuA=)k zVGh^}**A&V40V>b?7r!C-xp?_V5ytZ#TK8a(s9Yo4T<<)qUlR?{##v?jy>&QLK9$2 zcE(!H@{7!JP$s83bBtXdnCYD4@8R}au(uY_ZUff$4V-Ckr-YU!Vs9Zv26d2>AB1>^ zR2CpLH^S#y+A~Y+lo4Oo5{uL*qcX}Z2+f7i1yoL^gZ(Df4NN@nD&ZP?9t3Zi}9U{tH5piaO=8A}Y8GWZP`W~~IXB;so zgU;}*Rdt_M$X;~L=&5gy9;3D_dsH?P%ou0!8ALhTDhFlo=2Vw{0dtK1TGf%eR2E0 zf*+4>{L|-w?oNT;4q|U4*&a>iZ~#{U+7Q$_WM?BWT;N&1fXft^BjMi1u+9T~sDZP< zc3)5n+XKF=wOO{M$F|uH>A@p<;-H>mMC&-ewQjH0VKwnSvR<#mGFJ1Nv$>h{{4fr6 z>I7SFn{^>4-$?b11^NcTJOr&bXXUe~IE$4xW*soUvu{r%&Oq&cmMl{l`F`vyFh8QU4!7T{7qZbkcag0IWX za&lZQ$8=?ROwemUbDeX*ZE#tI>A_+=MB;EFPcZX0U_A-U%~H4~iK{F1EF7OZ^E$LS z7ob%Vab`8|smui`y<3br~Q8S^52 z4iI}L%aLH`JyN?<_yg$^g|d;{zC*Xqll4^48=73j;_5`K1^OqFM}m0{s0*QZ9?~B{ zJZ$P5C=arHf>r0Se4dGi0W4(uL|C^uJD&jqJ|zbnWtF+0dMT6-nmEObCkzfx_;^Ei z*twM*>lk^G-MoO>+~%rbXxpXS)?1xe))|jyYM+_BZU4>8*8$unaI(P{(|SpcJ8hoI zlQOtEOWza+ABNhcq`Fa%8;kK5s#%@X^Jblx?7op~7p>I4Ds@_q z^{!Ukqg%{4sJb1P%!L4qB5*l?n^1KwjG;#E3)TaS`b)$67~U1g6$z|A6Kh;XnHphw z^#s>TaDh}=%+^sRheLdi;svs|iL76nTrH53opo*3T$J#dcKb_s#(mDtF+g(*p)Fw# zL(LVDm;&l_!H*LDfarct)OQViW|UWrW*m%zA#>o&*1ays+k5u;d1IlGcUJ2yWNL&lIOCWtP zYJDG>&%!(kR%%{9roEU zZUkaXGUfpAHqkphiT5qe2gEf-nP7TjBJUQxrTY6;DZ>XTj!kh?_zD7ovQL=_C^zWnL=dJHclNIX;2^g3S)5HU`?G z2pj;^$wXb1tm7yTXS9dIy{{eJMU3v1rUxc@qrqj2vX`M@2B(^35!1Vy8V}-X6C0WB zH)gwHGM6*k6HPs3>LU~PiJqABTwtCLv~vM?j=+Ory;$z!?U=pyUBeE-2%DTC2c#*wFAy9$zybqwz7o-<#zfGd?hM zosshs+)-%um3mi2w5uudYbu9;+$4i{r8FASwMkxU>W&HyNn*W9tXLUmR_gVnb}@2x zqW4JvHx}lLMrR$NZy4dr?YdZIy}7zxQ`P%0gWsn*JJe`rOZK0hh^1gpK-MQzyBkE? zj*Zmj#d&t1H#gD$GThtW$kXZa7aJpqyasHCfcZM;Euq)~Y8C{`qDJ4{HjYc`0Ha+Q zXwH|l0@4?j%-L3<`|qYT6xQ_QtZSxnSx4UB{P`qDe&Sl5$m&zt^t2v$SxwMu=S@JB#>6O|Jo9cN%&iz}GTwn#03-VD#N8M~^L^L*>3~ z>jSLX9ktmYGd^~0zjNYv^?V|Gx}M#3N%nB3d-%w0Sv;$*sE*4j@wgEi8ZjxsJF0Wp z)|wbD|EjGNqz3`94alb;ES$t~q*o>J4C&=S|AVO^6n~H8 zV5r=V)C8~|W#VoS@0q#{;yRYrMqo3@yO}Yb3ebY@+` z=^YLK8OYy}o@V6OB+nJ%T3h=#%RWf%jOv4(yw4SHvGN79_#ADVu3FAU^_5I5>*Sh9 zzi+p@C%O*;?VC!@341>P4;$LV&>cqkEFHtExgA_bn|vnKnLsu3Gs;p3ego<3Q1?g> zUzmB9nCpP`J+S^Q*?YIL{j??jP>CT`?Oj#fXDj=!Pxm&1c@B|V8rXusJcf^F#!Gg& z!>Bvkac(*{2D~Jp0|9IR$Du$uGNIuKE^TUvp@DX1h^a?RzRB=N!3)8?ZOA;C=6EKr zN958_Z}+Tmo0BivngVoR0m^#-XD~Ge86V61hg1(!wkt@UU2Zo6ye$wvB${2!eAn*V z+Ziv-gg~{20o_gDpRZ5Pc-rW{%=qbf;(vDl-9ORgO?zVSk){;lW`$cZcb?qtIT0_Mq2|ew_<`rdpNKh zBG!Yn4_H1iV;i8i>r4SxuA$2kbh#7R40m?+u*))bIh5c6CWa>Uy@{7o_=o8&55suYlkzs8UQcqf3g4RWqiKI-@LH3Pn0ZzO$C4Oh z)~k%X(#UB-JC^7!PV`O{{F%VH3b{}q_7c4!fro^?*~Gq!1l=I`F}Yq_&|9w{hlM## z)_ZguCTm`r%fOt|8I!8>NK~H-Z~;?`r@6LNwwB8%8}kwRFxWXc_|x2>{-vb+n5rv* zcrEGkQthK)nVxDsuE1!J7aH6ysV6I&S6juY6+9xD`-;6+Q`ijBj$rQvvDr$F_v|{@ zSx-v$?n<;zXZUX!onuq+bc(we`aih6hMD70>q1iRR8=3Z?Cq`m`C7UE1hadXQLcu| zpv;&b$jg)ZC>h_S%C<&lr$pV2XxAq6sM-9Em@!IdFC+4r1V$(7Ev0gnZ4DhSa6H%? zljzOWvVEkwJ-KFcevR&zHR?mzwjb1*m$bkyyV8(ejceLy?#$Zv1;9&TUBfJk!DTL^ zjAC~7wc_{57>gWmKavxj-H{33S5-GO^fH03VNFBZ*%6i7yUjP;YMg6lSXQlu?0uQF zE}@nK)x(qQ@ey=63@uM^+e~tn4}PJD~%SF(=@Y2!G9tP02DJ;R^^}MB^}+Z!>ijt9M2%Pb2dPxO*8g7iP`f z-Ri=uT#wZ^(i%gySBCOR0(X+VdtnYFa5mr-fLzSvUH}gRn`c4%GnE@A`4_`Gnf$GZ z`z>DNDB~TP9jb>@7*FW`JQGr}aY{?4^rs{aPt*r8>wRW^VAp>dzJsX0g76NcEiL}a zaAVtNL1{OR*Rxy3ssC`)iJC(7&X6SZQr7ML*f1vjPAl_yH_S& zP}W!NJkQ`TQ_m*jF|d3B@KRHglCi&}!Bp8sGiR!wmh!e#97WZ`z%o<|bke6*)%mJ=ccr>>TJ35;ZzZ_?ALx@oy=%uBFb_9$7*bE$8kN>b%(Ab^yF~9` z@Sk*f%PwamV!1?lI<12enlIg~YLt0EZ$R{(2-aui-aCo*3Q9{*<$Vh0kQmn@=eM~N z($j5B1^67fvx64PYWrKQ?AuZgk%Qav``}4cDiE&I`6aC%q^###mUG)*tLL z8E9??oB!Blf1n%*`#_*B24WDRT^8XL81*Fw$0y5FG3NrbL|QM>dfnhgHWnjzC&4+G zSe?c>tYvppK8LCy%yK(34~Bc^0NueP{{V0l(D#v0Ha2txkQ;&Jv~-@H>^_ocZ%p-; zC48R2yG0!=1t>M59 zRx^*)d}eAFfFptKARq_Pu{GVS$Siw0n|+XdFTB0|I9W?Ov46fW07ykHGpJ(0_pW)3N5ytEXn1 zQ{7#xvO6ZJ`KmhSr^`ojtS86#>ikCVN@P1VR9B&TyI6IwRadX{G8J)Wg15qc8tyG^ z$E7y!fb-QvdpS`b4)lfv`$r1BqX0inlm|l1{Zjl(%*jG~kDw)mat++M3f6LTyNH+* zL|h@@eZf10^8mWpmf5+9&Wn(k;^gwE*v82N6ETV`>!3z6%HIys>O$#_AGgT&5oGEOkLs)hG!v_~-Xah12AdK-cL z3j@tg$o5y6?VFi-pTTP_-{|m5md;DX)MRf5yMG%cPm0#VNnbAJzm@F*ti5%S^*bg9 zgXIFU^E_A%G5A$7Zky>iw@0?-e01Dv@OiO&Al*9)?93v1B`FSV_x~k z+vM^r(A^+0W0#8lU-hIDdV#@hK+esjjzyREUKS! z`Yu+k>{j2q*GzP)5omcZE1!co7s*4Ym`dsa66=7yhk+bH=vOqpWNkkcyL$-UOU47T zb`O{1!kzCz19lLaJ;<^xILqBUG3iYp z-xlk%c8vad$<&Tb*}Q)e#l#?r_dW9!W9L?M`vTqVV|EXK+f~7KZD(Bx zGqV8qr0XpStyNK0C(4;1=YZllD{e{gMG@n~cm(ug!F&bc0hIQFJQ2bfrj`cdTdTb| ziStuDJyrjansJb0#$c=a8?ZNq>^)((XB#-nZpJ#e4^pStJkZ7>Hoq`pF}j>f79%8Y=#d^xZ@mNi?Suc?99N z3Eu;B--h`D-1`jfy#Tkw1FA8$1w-^--Hez*x>`{t69PogA>e5pN-z zKf<{b(C!ZQrjuSBY?rs{l~67Y)&-M%Sj1^IhS1s;h+7kSj*jt6J}czhVcu#qtJtx) zq5J7F62OyWjGHOs+BfKY6sf!6&V4iaAKi-#|1FuTR@X&HPZa9>RC|vQPZG_;0xlA; zFQKo&m;&MwGxvh^jh#EuIT)_9o4C#DY;Ngq4lbF&ZxMZ4Qq4SME@t)?OYqM`J3O6F z$}vA&ryyfIvKi=XRza3i-~kH(%?5;yB=8m4`iajJY* z6&opWrIKed@dKUXsU1_dT%pF3>;1=-)U|FKJo+Uf~Us zJYI~oNNpvwtAf49&Hg=7^%h2ZDuks{d16vKC-n@BEn(k-%%e=LQQ;v*Zz~|LB>OKj zetL-PUXt`vh7N$r`V>E*JW;B{1Ro;f4+IuQ;tHlugFTtRKL~zL#IXXuCa?<~?+LLn ztkYnBiOfl;b$_;)M)C=$SqAF7LH9i=^vwy>GX;$aG~WgEV1T<2Kb=6f-xzr?;H^yj zNyIT?9wT9nh;k0qJU}&PA#_hN2d20&qI~G0)lr)9jxr+E3?pMfgIhCkNG9HK<<;rt zp~?XhGMW*VcCxfj(rel6d(0SOa5R9m4E)B`hXc8mQ6?kG8)j#m)whDt+1b`&K>Jvw z$F=A^LX=N{8S{p{B+)mToN*}GIZ*2C4&rKI#_2uxwko}t^DfoCyMg~*3(UB|&|Q^z zL682hN4(M#ZtY1Ywox`{YiwOBU#saKv(?I`9)r0nvn&rb`;%oSvTqRUEMw5lvInF) z%={vax1ApBETiGhA4L9L_MCLHg=)No)Xr{WPqnzxEnh*KSD@y1u6d!V?qt=eZ27KR zu7?`i0URoM35xSVu~$k*lJ!KO{hr9*5!@g$*Ozl8xjjA1)dGAa+&mu{R|cBTq}W>M zye>9}f}P#KSW%vj$w&vb1bwtFk0;ua^Da?SaW zdX@HDVsCEP|290D$dwcL8uk&ecLlf=fX|Q~=B$?+d2}jYOmMQvQ_~n~>SU-h8XRye z7!R6UEQvos@w%BGS=!O`=p-+$z<(-Y_hf8n@C<-&7=8@KaWH-ZVom_RGBMG>Ee5A2 zd78;J44$6O6_E7{XI|%8x6f>scFo1I=2dQe7Ha(g*}E9P2oSfXcrZ}5AhdRMy%6?$ zw&$a{1035pJKxw|2*|sM`YzFZI>F7vx*|}&hwB)){u`(t8dwY9oHBlkY_FoVj9quO z>p6+uc>op$@x0l$k{H{Pm>uK~V6IKLPpE5>c_^6!DIN{QabR<*RX23xoT>WHRPU8k z_nB08L#w+X*&RdlRwI0%h0m?-MV5AQc#^>>hUPY!ZCUY0m@C0}71U{FUBQf-l3c{( z&53wEQI@S)#-uw}6TDKWYtuLi@Ori{PW#@p@1g7Fu*V~@uFaQ_Wh$>PyxD$0dJZOs2xV?$8HCgkuKBBM{o8EueL7DkI#&a;{EZn?NX$X!TTXuh z`&(rD8)RPWtZ&(QhmC(a>o1+TcDi{}?0W{D zxsKM#Fb)Uv7qDLfuoZ!~fbtNG(+vIE?Ef&){~p<$H{ITz$SDEL1MnXt=BBYd=%Wd2 z1n@CK&%v>dQO3f)()RoU1{prz;(88EbHrX5@f@W^liHf}vZPJ`v_IY1n7~y|9b>m| zWa}YZ6Ry|7-i*#q>D~eG&#MtX?L+h*!kJ;fmtjnUc}rURR_E<4x?3fBBZbaq zGc!`{$7c6089zU-=zXimArP*zbRrmES^f*C3AU!$8tKIEY`;>SOC{>Yq^|~Xgy;#O zoXd*kKn{U$5+kn$^I5{j5nhANdx88D%xQ#Qf%70ZmWAU8n^R#7gnhQ1Lz&zW$?cqZ z8PW$h<4#jcm|Wohv2@lCTUXiFUTg1j-w){Mj4?X4hyiwD7h)GGCMFiv0AeDx4vGqj zn5c*?I(D~MDAr(i2Rg=#eqVX+&)IvuKQMpAIeYK5t_$#qpnp%=1d<;Z?G-~_Oz8zm zKNKDg`|0JI^to=Qx0i$A2{BKA;XstG{nhHxAEn#@wzrl2@$TJ0hAc0Hdab;%CpQgbnYyq@aBHBL# z`7e1{BGEc4*|luS{+zO-sAfrEuAQWEV#;=QwJ$Wq0$_R9EO&EjeMjQG%AWf}b^FrT zyl*pG_d&M4;9I3~%~0pYin@1&?bQvxp)vcQu`;2WFJ9AkkK{~M^pkKGy!95XwK3V_ zA+qN+hMvpNd+tChYs>O+G4`Zl08$$=c`(u1hlmNLm;_-51kXa~TvQBK<4;)4wKD2U z895Vy^BMS(p+_0`Z-%WdU@{#e2pbLhO)$Ph>Lf8f1+^2D!%eZCv3bujAGE}-7G(=l z+1upvn*2zU9ZN6EljTveJ%DH(L$$x7^*Du``#hq@8iul*rN8X37mP8LYF>sqeWm6m zWh`&jy<5r7w}rUe(Z1J&D}j7Ph^-T4N5TdHwUdnHllaWUnFYRwXye54goxt-Uqy*6 zlzE4u_D8ahLI)}M3$h+a+G#-%8Z4NgbBvcZ;q~g{5O#+0I?caduvWgejb@NmT{sS zx5;Do^rpYO?k8&&(45fa0|4Ftu(X(Gq~$?!OcwHF(LNGePm}g2p>LUbkJ12G*E%w- zn8wwUyf4Y66TBkRCMUQo#IKEZlBGXE*$G6mv=mz?>WdNe0Y=`5$hVYsOG)2dDhH&> zc%=QHw8tr1*P-E#T-23M7UZZRZd#;wJ?fHR9tLA44Tq$4zD)alc&Z+djK^f%@6%?l zgVOy$s{6TA-OQjNLcUGJZ$w?nfj2C341yaWvTxSrwygP11cp}RYGTYZ=zyf1K-#c5 zCojE%;8dmVW9oHeET>d&MNU!VYl{38^4AjW$@JFqP?<)x#wxpBp|#cpTMG*uC~#H4 zZYO;wNy|a4y`iqvsOB3Wp9C}>uzN(C3}7iCwgNGo#tUd1YOuFNJ4?Y`g?fO*yJfzl z0V>_u^VDK7xUm16Y@j#jW3&u8pc7W`5z`m0FyHvS6g{>mX z2MAwB*_sDg`blLF;6D>~GthcV;7NjymV8J8X9%_&lve<;yE0Faa#yLduY|*;=1Hlw z46;0l%pH*R1t{-=nvqgmCB=47XCtY*Kh!w@sP|L(6VnDDTMr@Qaw%6%XxUU8DzmsWQ$Zx*%EIm|rnq~%MrauV5op76IsJ5{g=0ya+R#)RD*QJx9p<%B~+)iWZ z%rf_f=&gIrySAja4};ljAg97~1WI|YmYyG=RUU=cKCs+6sgDJ24{=hOFAlr&I6!XPM%pkiyf^vp0xALI(Q@kZqudF%y-HO>08g&k8 zviplp#z~EEOLzJKoosF1Wc&T9_UA&^jzAeowf3cY>`(RRPtErE39>stV{$kuaE~P&TQpI2q}uA@Cn&j%C&bpw5Lr9t-41LFWm44uDg66QzDoJWJ)W%x0FMxtMDDQ_ZtP z-e9y(Nq^4F7NT=enk`ND`&j%cI%dJKG2DMKwr0nVHa0$_k@>UWPVbbeI=G5V(Tc7-x)B~gl9eZzGeNyq8V!$+cBF_jAnh* zdNgV?PPMsDndeHepAa7<;sea7L;b~I;|uJI0-W1Y&M4B}C7X$^&e@*%vL!l9{7&T+ zL>&$0tz>hYarRH<-EW%D?y$sjG>oC~aWnOE=JhSquUe`nm-LTHmSs!T_TEHat93jh z#z8i((q4k<^-^bWW*w%~Xhgn?Kz~+TfY2aT9f_*P5Oxl0IRnu;ozb&5a;_7l_TkF* z|C8EhDg7#B8Ayc#^;YR^>FHz=( z+T)BpUNZV^P9A9}V@>4*%5SAOhO!pKz7Y09;yWnUgV+x$7a%z=)T}LZA0c#pOm=<) z;%t+iG~_1+%w+*{Y)&Oti3WbGIT^nK3yZ`3w0ie?Eb&V+1-&%q-O7#`u&*5->(RDKN5;5 zi7ILK_{`1@8O{0`&F-18awwOp!sM6}usjXo8AM$fHv1QOv%X3lnk9Ev(ZF?kD=N&bb2}C$l`WGv2su`F6gelX0eBnYY;7?${v!> zBVkWwOtS1OVbPhvtkapfArc28y^Z8oNS%Pd1f|YW*lL;Wt5fCbG&?4}-8;S2C*9VB zYeN=%Ot-VF*k9?I%u?q?!6hi=9+lQDSz1e^x0cDm(JDSSTV2ao>3WEz>qwTe4c&*+ z%ct$?D6HCwnl4x z$QDN8Vx&RoJ0k5xDQ->6o72k!*_!+EC_RRy^Kv-WHPi1jbP+fd$d>^QmC7Lr^iAgP z^1Kw}Uuaz;z^>6k*F&X)))2z(kXp|x%MBrI9$9~BvbnXY&fgK%YhWuh^rgevm&4m5 zDcgs_-yr)4IoB6Z*O6e4-GO=6rRJGTaThA4f!z~{GKI>UP570myBv0-K~F$=iDc6< zc$3qByJR&$HjOqnI8u6Xrhi) z{;>p6Z-sm<%C?30yuhysdjcvSQe7WXWqGJ9PqqIJbsfR%8emrLAboApS0-9-6798! z_Qz(nl3C|CtM(Yp)}+~&K)V z5mUif9HuA0I1$u21n)JJ1ql5s%_hlkr5H~d*XbWu;s zb4o&A5P2xcMUbtVkr+d>*FgLo%ws@(0G1#A2W+~P&}US=2J&?&e~HqnOgzG@Ux4wD zfVE`06UvtW{YYR#v0fpIm%{Z;c+4+v2EpSPT73|lJzR)eq}VyF{!`L&Fg`B&4wBz3 z<1n)92lx_%RsmY4QdnH%zI49IIh(6tM*dT3FHLpz2Dm%b{A$!S2D{CYFERLrf+sQU z90a$qz|JPEX_ia5Ypp~bnpU4mD?cO3zZkX@-g)PzMW{Ta)8k|`Fo)a!&l0r)tW zErX)TP+b6=y%~sq!Rru2vjC#5#i*m0+$F;%(aNi?_7=tB0T)JD@<-PEuR>>L@Hng7 zkJ(%W#8z_zHF`D~pCnr21m2y=TUD_kYU#^ryPQ<<2F&6xQPh&5sM zG{QHa*#LN4E9?9#Sq6f+JiU2<))~U=9&f2HU3k(`?=k%nGL9g4JYd^^SWjYK!S;gr zYebpoz;Q-QHeevdSxh|$i^XNl#YpTo#|dCJDSa{$mooSRvJOh*Mq~AEW_-aMAey)k5&57kvTw_zY_KdWCu(9fwHe4yA)|-rRJ$jJst4n100*+=!881 zaek!FP|ce%@{34KkL(^2nFCYWPIEp!OG$Nw#2?3t-R~ysA2RPcqXlTXLxQ4=V5d#D#xC*a-$4)8nuxDQzagqz&8PYAJBx5 zGNBa(JA%R?l71C9?teJ)KB5j2>aqg2lI(lI?@d{6O7|g~>y@#cvRNv#a|VTVgtCj6 z?||A0>{=hz9xB5FuvlAWd%;?(%KZiaH-fFpKwBTgd7|wMVrv;*NaNEi{_ia9y;-y^ z3dhKCae7%j&2Gukp1~3)!u0`5YhifT59S(dwBN|Cy+Hg`rYF-|LmT&%)AhP6w}$!N ziLzd#tz8+1R@o{EUsL2t5}%T6I^<^)z6z29k@iX^*H*>?8TxzXA8Qyp_tKi%QM5X| zxk%R9(7^sC^fB>d3tmXr#gNv`ncK1%s^Lc9vth(v3PLjI}DR$YT?-bQj{ zM%RGMt{bb$do^u*lN?`@57hL}0`2~=t}n^52vxSE{3B%RG-&Rfl|3Jmx;};Gz5wbP zhV-40c{YX3fO<2b6PcK5S>7{Ys>wEkv<;-gBkQxO8mGX+Xkt^;*}ozFcp2)vMdc)l zixTlM7&8QWT+ne4j-kp2kR6=D3kkeO)XS=7KbQF9I4Dn`+6O_cB>>wN!!8nzK;{Vv?&HM6#{AmM2Nu{ngl;GF5}4;C@JT>7RoIzTc9P`J zDETuJpFz1bpz9%T0s0QfErA#Z#eFc%g5fSeTZwoQ)IeD5Mys#V@>S4}Hu_VdE+*p+ zQ18PyTCksq@;a4^LpfT)zA1i?iUq^4vgnfmJBf1=%PSBu42VO4_=gbh0DKnE15hpp z(Lqu%}G}EchJ+RK7X>};9juUG?sa~qgACR#j0_Q054k%86coSeJiLp2= z`p+TU<^2GDh2a58KMKvELbG$C>tG|^kZHJpoy6!T){kU3TV_uqu#^%L1-n1phQTlh zhJ|4^-iT+!oFUjLKs}kMA&jm!X=T8idw6aQ=vYx#Ls(nF&r)mxom7PXQPP@gI=Bhp@7e+k$!#3)y~8W`{CuFR~s&}{Ga3g&bX>i}3^!lsaqMQ|5nz6Ie>0rQEPDPf0%{Q%fSWUgc63@3Y6=rSUo z5b`F^`Xl5k0A($ieJy$)Qqu%H0Qk`fTV2whAx@Vx4eGoF<&ntT2yBgj{0>Mnpn5ej z??w8Z${Yg4#wlz;*bzV;2;m*2)<$w(rS(hkvy^tKLhk@pPx$^RUMg_~MEOjSOR2_Z z5uJT%c4pR$^-^3E;F3Zd4t5R!XRn;-yqn@0Av+;~Gg2`y88ZU;Mne0fVr6BsofMl0 zTsY|q8SBb2Y$9v6m-BPEzXI2FFx@N14{3Iik#`XKCzQ`6_+3gDR_V?Fj!J1hAl4DM zqfky1u(!bf2pS_a8wuK9vgHIFC3Vh1`Y}p;$%sdk@uHMh33We!kHPFIqM4711I+U{ zPn}M)(V`ti+8C0L$gqyYJB?V-7!Qe@lJw6(j1#T5+zw7}FN4xrmqlx$;CZ=zNw;;= z>|}Y*AL-iDJU=vRkEM4VD{qcXYD2PXH4qo11)i@|(CVo0X0sr&_El(P zgk2hHJzmvw<(g$w1nv!$JHYlc=B=xM@+H)M7izzWXx)YAxw0_Vx0!RV40UaREXOO_ znNAg{Wp8?ud#04NHf_{n6 zIsz!S39Y529#a%uOQd@4Z0xZK(7sD(UqE&pOqSCO@sfpa& z&9y15?q$#^pr%6cCex2MXpOL3xM1MmY>nJB3x&{wG_;@GxJ`gy#w+xfTIYG1hh5K z{42@ZrE*CELkKcLi|9``$CKcnoB`$ zPuT`!>p8$K1L{UV?L&6PgPmo-?!Sx8mtbxVU?HStD)M`TZdc+TL|hNn=fJ!GP+tK{ z0N5IcZy@~$V=qyw2{|jNt7IGuaw4fwv}QW3b1x!$gZ2Z7r{*vicsAXyMzJ5@H~XF%3^X_u4=L^KwSj-C1lyisOcmx z0&EA;?he@TKznaMzX;8TbCkzCNWwdy4Fzo}7*0jz8Z`VwkHeWd!2^3DIV7nE=Y)*> zNI-u;;&QrwJta%YK2P^PkrcMauZ4O=>z#aw7F;Mf8CAN*QPc!}L3||I; zbs@h5Xq^Z6Q-bdy^jMJWc>&Qi0chO@`G-)sUchluoCoFl68qAy2gJ)vzN1UuyYyp8 zJIKhrjkecqM`q^sDIAem7s*s_%g*b{`j*)GJmpIf>Z^<`kob4PdzLS{`X4at*b=_q5)5$*;PBm90{cp1N8S=bIhA(9CUYb3O zf@{q&P0m+kbw8MGnrwdqpf?n!2>c|4J3?9{GOibMM=JgXV46^FPT3l%SSJ;aCUi_F zpEqE!MEBZI=U%G(m&p^5IYObWm3oBG9W;(M>27d;sGRI+sStL2&L3x2NH}0mTl6+kr4Ui`F`VR$esI1?J^# zTKjHTa|u~D6>We~!<@X?Y5S3!Df;S_*-MPO66_tYAJRClz(;81NM%_?(OLs2ivyg5 zv?r-DR>{>6+AU*t|IFFDfZgYkwHK*#Y1qn*Yql(Y1^H(v2LT!m@dl8$%WRw&>p^uf zWd0y>CxveV#EqsrGniL8;>}VkZe{qz2)i7a4`uM$%pMC$zKyc^rxcR_u0@v1Xg%&D z+YeD?GiCdmIfzW(LfPIBYJZ;5K1EUfi7b5}4kG5-mGEmEf6QyCQB3=RfxWH95Z3ZF zqWPA|<2i?gKSscc5XTaDj?5nooJN#hMC&tv&qz&gWS))4QLy+7p?@cQS3s|d^)IRB zGO7Mu5knDtjMDHqoq292;MIio7jkbwS0s3*q5Pg`_aWM+K>id^PBxY|0J|2_31s&$ zBF{49X_on+MVv9rT!?qjiK z;XKQ{++r-Vj5d(sR|1bCa5YdT05K!gSwpA;4ZfnO>l=fwYVv0(e}m$sb0*~2n8;rV zJBrY}kj?~j88iP1)X7v{Bj|gPTN3;nX1f7#1;Af`_z{TXh2{a_k1fIOMaUchauA?B zrCgSZE0x%oVV3~;BABCPxJTe<0VgH648aXycmc|dL|ZC}XT@g1oGFg`({gcS-Bzq0 zJM%md1B^UC!s3Fqq37muZj!D|-I~W?F_`3LhPV;rSily8VliadL)rQ)gR6)!nAuEM z<~5nPHGx?oXTZu;u>2JkU(n(%7|#QFG0c`Dd;)=AN!FDmlfz0?&nYSRbpA=7;G~N=UEOL7$ zzjEM3Ne5E+DYG-&~M%C6HhY_~}670}TET;4zjgtT7>U!=H@(w0&379?Iq z#!zKEFX45G1Ee}bs5^^wUs>Hbt&T`GGgGx+kmm<{nG~0a%+n*fSE}Awqef?PRp4e^dcr$6| z3YsACM9Egm|(M7&M&6G+TQVB ztqnlm1}NJ|?QNyj8er=j$@fym{TX#3)$SKEJA0*d#t3;nk^LQdhtNS{Y%1hnA#WBi zO|XB9^&y~HQkcD8LLW)3ABD15X6s^rE4qAHF&>uU6<>VWfy-OuC5&8)QU8pHeG$c# z<$NW7k#Gg*BhAWM=4FDhHHg+8P4>KsXkUnIy@+fdg7CXlZC8c;U15VM4s+q{f|#dd z9qz*6mg;Mvu^xG(MeJfVCRyMzW^OWvSX2iZn@UDcg9bVL4?}sIu#X6AZP4ciBoP-9 z^-l!v16of2{6QJNE1TJhW?4k0rCsD|4>z=SaroXYd&1=Zv}_Nu^eYJNM3x0v9D1K_IwPZY3c z3KKH1dPE!`)jvbpp5T2@Rc7Z9McxrLu8nF(*QRxSRPLf$_eFI2LfyLq%`j5Gk{U zzz+h-CqP+Q^m#%)_VJ45092f*3Pa63S#v5PZ)a*nCKjX08AQ2{u+IrTHb(-I7lZDw z@~+H}k+sg3l|CXy%Wxf-XTxG~Fkga!f>svsa?s9}2juP&*OYvS)as9H|3LM;itMo$*?z&$dW*0f0PIUy z7qab88K-0)W$v%6Hz4yRDeg*SJI#Jb%T;8}!m@gqEY6lSm&x)lf>WrnzGZ6*CVxlZ z2u2>xXdbq#^IOKF%(#t;ji~Gg;3P8}=f;bQ+u3e@x|@IFhF^^JI72*4J9d=aR%+KO4KwB)d+ebv;3|g@M{8>o2ez!J^%)#f?jg14_&0EiD^S ziv3bb9#Tpj)b2roGRq(WZWRuC1JcphR;Nd0eQQ?{RDeOwBevOl;zD9I8xC)Ju~i1l??;FV8V|E%E?p@c-l>tIjwl@`p|0UG*-I}(b^#EpZY{}Zjok> z5So|ez9?X)l9j2Z`-1$@a7)|4ekIQ+ZEDyn(7M318pY40CqQbj5d` z&0m1v%Qm31O@7-icE{1#*%F}IhRJu|z{%lu=*K)KoAuM3(6a1Wv^ zOSG;d%J(Ec1ma5(GeM3Qd5)+{Mcx4N9D(Okn8M6~mU*^?ej_je%D1HGlZH)`*g1vC zQvMUvsdTNx#BZS9q;LbofvEXCnz}Y>(~FHJmfGxNQAZ}~3Sw>m#_eQ%5XQ9t{tl~$ z%3^zZZpNay;hbr%bLmZQnl0^Sw;Oey!KOm3=f(I@!aQ@<$aoFpwWL33mr^A!*yq`X{N-UaJ!046Bw{>r+u za`tJ+=4z%smv}0nsX`2b#hLVY0f~=bWn)J6qjC(>t|#!PIS*=?0=6#$%OW6G6K#g5 z4MaNtsOyQi42W|@-pS-`2D^`Dv&=cjkjohJX}9>%*m=iH`+;#Pndcb%S+Z=M@Ffzt zN22Zp)h|r(C{&MtVj2{WLB6Y`)q#4wL08Ywn|At=`EQa}h`yL;FD309$d4piPf~dz zr3DCH0kj?i%g0iESgP*|xq3ol1bYoELj+z9;0eI~1K8$}tx4e)2#=ZkBc;8NvYQj_ zCFaG+cs5n87!?*0r-W6ZEN z%%%x`HNbO$x*n8EL)adPnGBrj757@=e2M$WG+(fJpVVrEZUTDzSI~%HE)HNmzz2~w zuUUD{RTd;|B56-byd1PkLE9Hr*Meyv+!lmmK{|e+V^x;i+)7+P&)Z3SWXui0{9LeW zA+7=POeyzB$xkItgX8Ibp5_LvFv_*yD2NOh`M`^oY+nO28sNkHF1x&*Ml0`{}e zx;HK76S%y97XjTXdZoHYni94&3A9aYoyNs5ca-^9D7Ot@#|mGxkzTLR zeUbR9#LJZ&#o)G#?9JfwNS`0sx&xWLk+D0J%cW_ZAWp1^KPo!UR>bxJjSR*n6`CBx z!@=09vhG%`8P|Aob7h?oz@>0LY(;(O`72FBNiJ{1Mueu)a2w6u6tyJDJpsNBVq>I@ zC;ZO@cO-BuVY6g9Uc~7M?MmediMm2$JwBpd8mMPfjp1>s~K25axG0Q$g*^J^ygHI>?KEan2$_{|7BHAPe*Kzn-iPmUC>*hp#1kiE- zHU;<-=J5jGli#28XD2=~>+QWpU zU06@53xJ*T0N*57mJ;k9ffpv42NLQP(2)|pk#Z@i-l_cU_|R`JMf|Z+WanO?-on5* znOzUYI%4O}R8GtPPttjXUsYXSdyF~PIX_VIsj-e25}VCdc#zvn|PpQ^P%_Xwbul%Inp9OVbwob?Q(=JRmQDCER;-w zb^(cPjNZ@C`pwX_71chJSq35PP)2^I+U%iFKQ+420>#t%v{d`HRI_Afsz>KskIrbT z@s!oh5XRgQ)Nel$znw(PmGSpK8-5>U$UdYWW^Dax;EG1=MCfgU-XUT)B8~2@>SPmg;jh0Z8Jy>Iisk5N5bFNuz;FgV9b0@92f~@z` z>Z|m;+FIJh9NT!|SaU67rqj(xvvRSqbQ#;f%-5b~7tx$Y=AktH*Uav6^S_fmkn|oz zxr%D754Hav(!ZwcT2Gwn!u~G4U*LBcy|=MkMU)+Ya;3oa#CoDwFG%8XQHx3OSZ4Er zvR@yu$Vpn ztFm8$x{q^f4=`$PV=i&pp>SU zmw9KqH`|!=aWgxMX0HxGRy{N)^W%8d& z&PnNHNXtPu4UAD>z7EDoVx0ok(O~1`yu--2gTw#;TM!%ylqXHC)2Y@^gkM1Ne=s|f zu6yCRIvjV>xTjfOU{=4S;}A2wN@h1h9cqf+rrdziU?{GXvIy#v zXx6H%cQmYB4eKox`B6nKS`{O!>eQM!ux9gpRj1u#^J#-xD&kBz4`z$wyv5m8yjUrF zn3tt#oI>N#q#sXfO(Xr^q+bV?v%vP7u=ZhK>jJP`2bSf%pmd@ zB4&|svO#@J)|l)AOFm&~Yf*NB0XNg~8knvkF~DeF7PKCBv?o}$pYkjVdG(*H;wUz8 zDI~?^G3W(D`$H<8QZ`>_XduIPGL%P& zauZoEC-XVb_W`+;HcLdq%1vIdkZQufD^eyoZAFyI1HJncEJ zKXdM?h+F_UZx%H7-@x1%z;8#AonAmQk*G7p@^=BZ2-p(D6_9QvH4Ng*LVM@=;7~kA z$wIS9f{!Hp+4-X#Jd=oD44wDL))b=ipkdws zqAX2v6%y+M?ezurOJGF6o+kV`sQnnk6@dB!)r_IIDYLUB)NH`iSBTtB-g+Oj{Xq?q z@>?lprgW^V-YK(ZlDsXUH!}6747{7Q4pq(ZR(TII?gX2EOU)%f{07wLgnU7We+v13 zBAz4l1Bo+e`kd4ypmqdtC1AG^c8bBrQ96jIABg!V$Wcb0B=dVju9EaU41TA{-zD%l z6gw%hhh&c$bfSw;xE%-$94S<$u`Zb^68&89k+XT+*_k26rhp9tVka;U1?n8_W%XPn_Yuq1RN0*JM<|T~ zIT^GcL4O{K9ijROpdo7$q#jq62Z^rZ$=V;tzC>O`)^9BF7YEjN@Ltm22K*OE z_XOieDF<8H4~()EGp=Xq-xjzRiLa4b6vp8xd_wuvVCyHad@695fQ6~Cj22~q8~j`#Kb7i6qOY3t!(kW*=XrDvm4`CR2?&2r$^Qu) zlF-tX^~nm~tE${x$%_T73+2I7PV&sV6>+(;PEf{bPz=q$Et&W=6r)p3k6?2|FgFPJ ztTY~-h;>qNV~Ue2VpM~CxS>Whck>`SyZpT9Ap>j5kdlvSzLizfbE$~l>~JPczMoTcy^GqG8s`FCd7C1slhIopNP zQ`$9^4-@rn8lQu3A7rNmaJ$n-g!tE#mPqjE6wa2Kamsj($7?HyS*%ZRb6bqNLTRpKXQ z87JAF=R=R>Ln8la(qPN@p5EC9mWzpeEW!Jg*g#Q_V&HOCy#(26qVFZc%3z)f)Ta)#(n2)Q^B>rlA?Qe&a`V@k^m8n}WGQDBQCk$Giz!bqAlQ>?m*CC$;lu;&| z3)sy@zXi0hFy9TPYX$z8;HLz85x#?HCkVVDfgL3Mhsv2iPBY+p7vD1E8c?1f=6c3D zkkkc$mXI|g60uo8=K^!r6y^<<>Sj>%hGK-Weu~5`k{>MC1W~=<+8e+^R31X9If2jT;W&xyXX5F1IcvV={Pc9lbi$gqL|&l>oV)LDzNttel{GOlA{ zEoLms$dzEt5s2C!(5r;sPPCV#>@6yuCp9a{HvxVL`ubvdS*)`J_7(C#v9m9jS0~~V zXx@Pk{wS0sO`Ht*yHM_?^i?xCDWf?(qrMY?og!_BQV-Meb)c?JHn)p;9KflB?@rhc z5(WVp4(MAbzeLs_E$bJSt?{h>5G&4RSU)B=A~=b_-!0ouTH0q!zns~%7L%L8bO{6J zL!2fye>doCYVLm=b+{!jcj9d)mNB&Y0=y>WlZ?0o(t1i;$HUg}_`OF)o{Pkj5QkBC zMbb>FyhHf%f{ioaRVT**_|+7HfmjoWDO6_}L+4XRU5SYO!Fr_7{yX8*!Pb&8@0*M> z#5h&ZkYKD5$U_3W|cg5C$oEFq1zkF(9KJ6xn$% zQ2$sFi$=sbK^!0OyF=xxK%Nz7T^(813(cDrn72{|UZ~*hLHs1_e0bKs_Yr48j)zx}LSP=Tr4(OWdc_b0XhJTF;EQ zH?sYCi06cwp|0F5kRMs*tp?pm=B*H?2|h@$B|xnnz+tKUIx;@@>^!HmhcdOhr5~uo zKq+6#Y+gw5IHCRjgnUZCY{=dKY!!)jW#)y-`V+!8MB1eYej>9)Ky4_+PEu=x=x5FU z7nK(wj8--qiLp&e1B0<@WgZ)>Ly}yTZ2to0*<^lV>o+7S6Y7W3TK-bMko5PF?EOT{BuIU+*-T10m{AkSGfxJX&w#~@(7-a=h zc^2dmVlF1kdlJlb2s{O1E2K67bRQXGicp^i>Qj*Rf!fzX`afj7Nyp0K5YerLi*0(#8gTN`3Csxw5$ zo(en_z-tD+V6q=6Ke3{m0kF5h)*^C8Lu_b>b;-K9sqRU}1fugFV(wn1Zlg)to+v9g z%0!oc?7)SVrJvDz6LA5lX@Xsm@?}k}|4H3%h}1HqUIO!a86HoIM}?dY@Kwo9kBl8c zx*!l|RdR&}9ACkIRANyME`11)~Ahj0MpUl6NaT^ zaS07yid-Ayi2w%4^A=g04y&hv`JEBtpgN3-$$@+ch)0PS1I1$!j+FdYDVG!KB}%L$ z*c8xLf;f`0T>#An;#PpGL1ikku8H7>_lXJl}C z20w)S%w#zLD0>O**CD%;RyLY;TjFK>0w2hPybxnTI*G2Wig&t*6sD zgwz3&CTGS(4<6*vyb@VAL~;>GX92j5=@XLv3zH`pG0kZIb@+aS9qr_P5H5qT3WWQp zSkX{FCE^q?9~5#O!lwc4r2*{)*1rIFBoP~i>N6pGAjDTKwIqqj$nvq^(ki_-$;5%i6Khu#LT5EbC6{&Y|=9n-hea+%Cn$&NzAc8 z{s`ln1cwuR*fXDZ;1@&r(Ae!^qP00`#{#xJVJ8FrIFOeK@p?eNh+K7k-8F|0(Zduc zTjoO{O{a7yq(50|N3%SI!lqEY8)$6;v{#49rV4*SY3C$#MY7o_V2=m=%8+KJaxJAT zBXNC+e`I0@Dc_LvtqI>TwWG4xJF@d(WOG!7zOC@hD)WvS{367QE77OIdj)V~sI_XO z9ae?ULwZ55TLJr-tjEE$6HGVBvR9h*qTy09Unc!fP}hQW8q976{2S0F1HKx?GXVAn zY&hueP_2K+e0`*EC1Q-o!v$Xf;GROxNZ_7~&Q+ngBSQ23ZK;z?wmj#vF>g9^hNN|5 zi%|O-Vx$&XA$iciE=ZuY|pe6 zl(|KQ4N%|@sD2o%tOYBJ3w|*idjq(c#!bNT2e7=G)ZK~Bx{0|b1?nrITs)LJCE{Db zjuCVt5c`1nB`hZa@d<#zU|Ao~lPOG%;LNDLQ&eq)ntx#ERjT%!pOlsvKvvD8_>FoGW`CYqdBEu-aReG%>~iNsiO?~i0t}M;P(lx zov@Wswp@~*q-;d6+*V~TC2T5@V+{2KLZ=X%0NKI`F5$pa ztW(K45UQ(Ebs1*<1LDCDkAvw;QtNs0GS8gB#N9}rAhzC+wf0V0PpP#*qAU!Skp}iK z@L>W!5%!j#&yqGBu*FTSYb;xzxa>xk{n3DXoy{%)ULf$H0V7SAWXPUSvyB*6gRPO0 z#wFOtRUdNeyliNmH|RYH{gqfknVU%QJ`nek@i#I4D#jf!^#XVlQEoA7?L;d}nAKZo z^*yMy0FZwNupVd|fWESf8^dya7&fQnw(yt^i#uUBNoGR@+Ysa&Io5-5gv>sqp?@N` zCU90N&!C!RsAjQHz98Wy$tEc42Fg4E$OoaAK<1Z3Yc9}whv0Vxya42l5T-!bM_DFi z_yMfklq{p6t|e6Xw=}#5`thJYWYk1Ay9A~OB+UeJzeLkJRnJJo1~MBUa2SBufUZgD z5~N!a#V3ZGP5P^}G8&oyXnBM`d zneZ5_jAMarV<}t8We>HGD>-r{xB9w;&La7D9!Yh)@`h|E`N;C3=TrFcBd-xatm;ah>_GqL@kxZo#Zw_8CxB~uTX{RFml z1Z=3p+a$Xmvgr(cZK;htag-|$Hr0vD_>s!v6|p%KQ^XhqPL zM7~VK3^Hbtd;zrA#GEawm(k*WSp6CFmq2|E;1dA@|!F?%NS9#7olhA)gfGr*y+wQ|wPy?E zm_+=X$^n^m#|+$oC=;1l%Vf_Kb-Tr6&zSss%3g=GF)}u^Ecbfo)ME8vvpUf^?|QO6 z1Lzs3HB4FG6Z170Zw2+7s5`{E3d}YJ&_9I-Q_UTzygFsel~8*aGTx`^XUe)lii0A% zE{?Dp1)h(zUL>A`HE#%*E!eb_-GIafj5yIEzwoNTtTD#JRy64dla2AT*`E2eXP#rK zzZvV%gmyK=IxWnd+~V(7w2-H@Xxlk3*~o1P^c8$U!e<5SiDYY|RM&e+`!r-*7I zk;3ZA+%Cl}Le{5IZq*ReD|mS@2Z%fphA-$C468qZc@hvOL(MVF&Il;Cp==by)tLI$ zjQxwsjTS!9jQ1n)y$stVTIUmGNzq1=t+j=A4}-2WaA|_)5PCwuHjp+?@kXfqAysas za&byu8uBnho-F3-M6BS-kp|lU!Yn`!LjEy{0c81r;9qFgGDyb*SX<-lc6^leaYBM!gfOZL(;U&<~3%lhHUKu*ig_v1YR&2q{A;^4F%9SH?_e^^_ zleZ!A1rrt%S_{Z>%}nbDSBTl6&Ywjap73FobvKKcXwiKL6FsSUS4kQyl{X;%6UZ+>d~7V|5$$8lx_==o zbUn1d{>=6ZQ1^?a?mbfrO#-?d$F8`< zGp;vef6H7FiJr(D48>QXeuVHO4R;c@Bf-&**3yRVQ=Hw_GPEu*=W2j`47HY)xUf=> ziusJ-qeZL_#&-l>hd5j+hX?c90BR+PKC<#Chkn=ZYpOG`K=)jGBryZ@R$LQl6sG< zy=eJ8T)jm6O!9ERMiONf<#QtGMH8lG4oZ7b}*&85d2ZqADZv;DBHu@tHa8-@O+!%nMA#Jeg&H2KwpK_SRh9O z^%rUGsEm3<8ZH<8IHBw1gsm%bZ;_XTxPQp63bl_6+1DXkJC)C5=9bLbo7w)(;G4J5 z?Wm&G|GDfMOTU-Nm5{YRLKh-h@3`VzC;J+;FU`&+$}56RfNWi%`86$;REZxihh7rcJQJ?o>6FL6yp=l_PTD}(%Ah_;{tDz3*KZ{ zXuP4@x{kILv<`6CD2L3bqvl7K>fx*(lFcY0b`}|)?>|7ZHIcgz`il`~nPG?< zE_Gu!x3ZjBYdDSnq?eQ7-3P$BcBi#I0J=sH?cFFVChJZ3?x6n%;Fm&fma_d*?ISbG zb&>gXDo2Ovr-`~9pr4F6#FPU~@hhRr33L~6kH9@rW|9s{G`mZ6J0(tK;*XYfjMdnX z!KEzo4I&;fs3)cW&OfYq8HJvdU2I^>q%#TLL;0gX>z`ulKC#FT>Vikzj`lTsdWJWqy;HXJ^IejPhMZnVV@FMU-WM0u3(-+@xdt^)F{HMGxl_=_&? z>}dzMc!Z^$NtCO|?njZ`_XE4GmfCMa?QNy5#gtuFDZ1a2(S2FfauupivRZn0Ej>%+ za8I1;ss5f?)Dml2#-7aPLq;twePzP^p1j#%Ba7OnxfVRGV8Nk|?qeM7nNGXYX=9zX ztAU#t<5ELxW8gdo7BI*S80NBrU0l$mt1M#$W*%&b;|M<(XnzQKcgc^Fx;D-18kO1g zxoWrmiuR?MWsy`lJHfrBG6L|?$ZU{#jgoz`YNc#+k!syJYuzHFJ{TEM)lpU5tpalz z`nbm1PgU>!QseEjJBIfgtAFXRvv&v0gAHPVD*ZKNW0Cx?rQY`Ba8tS0$+L^;fnq$} z%}zAqGEN_D30rVac-JFvPJ;Wg za65#CDKPIQ^Q**sH97C1)Vv{~&JjWEE99Gr*e~H52CZ*Wy9Tv>K<`%B*;VDBCjF5n zIJ<_QouOM8oNL*=)6xQeXl2(&?d&?M6|JjVwR~2ZGO0AW)vF!g(SET6pDB@#cg^hwwuQqDnQEVK0-v%MmtY*#up$9cs}hOR`Q zrxH7-@@F9~k$5!|mq6$P*_%*#8{jQSjeztPGRG15qAB(&$f+&*IxS(nLd_{`t~WG4 zIO;D%-V0zVU@sfWUM;kqYC+Gm5Hkw$8b{g5&}}NvwT*yN1Y0Fxmm6&D3VVnsH-TkO z$Ok3sJ4DPd;CMq$C-5p@y9zkjpn(S88_@NFZV>bek;?+PTmk;%Y|n7C)-`rrO?15m zE^v#mz-dCaHH5MQz)=LhAh`67xL2)9*y9n(9 zVheL$gU%o5Jcnj8X}&$Ep#XoJ4=nl1Kp6v+FCacHVRJ!;A+ZsNFXux@wuoeRNt_^Q zq=Y*X*+bAP5+(uo9@0bL~6+Y%lG>UYGvD~Pg@r?v!aPe9w4G&s`wNjz1; zaVh&!;PxTDM%YZsho^Emfk%S&nt|t$m<{G2m?br&hBYmdSULuk!DC{Z9&LDKZdFe-V-xgT#EO4Ri#O})z zU0ckLw!3!7?0PxXK3nMe7r5ZXK=<(=*GS|xMopBk6H<2}TH}pa62L4MPV&SX&ek%{ zI^Il2xcg+P^%B^gnrICr%Ee^+3aNcK(!WQxdqV9uA-_PG>sscWOuxvI|Dtjo=G>u{ z|GS6!{Y6WigtYCMr6;rfGKmRh`K}qJAj>kwZet7!{OWAIX4aZ&u*1l_i^%5zEh^wj zAb(J*4_xO%xLU%xFu%uWvz)o4Beryu zp~trX03ZNKL_t&!^Utf>n8w;Y8ruFHb=K&JH*|!%YI2iMd;rzOOm?Y(cQ~z|!QORp zc_S|}U^bVms3I zfb>1UmkY2x9lO%(bHH8&eP_5WE6Yb@&1A6s2_Nw`V#sM;L{0?OlVrlUQU(eLfv=FT9-|AHc8d*L-qAUz8c^|0pB}hYgV?dZdCSY zk|Szr>l9X}%9el)b(ZlhaK9FKd65q;;#e2gr*IgO_aJaHD%Y^I=_bBG>NHX}i0#h; z{8+3H(Cl5AotEh%A~i6nTZPVTNR2UKdnvDF;x1Ht<{*?8z2!U_rCDL;s(pv;5nu zxVrFKd(XL_hftj0E(MCy;#MF8cS&#yt_cJS1W6!h2%4b5LV@4}f(0+Zic66~X>lv? zwlvRuX7BZWNdJKIZO+VZX0LT!#~He>80!BS+XI019zjbGW#58wc|ks0z`Y7|q@!m` z!z{Z9%`gFX3HCP8J1@}OB{mmJ5o0_QKNvLF!3At4Ok!U`TS(f)pyjFZ4uGwM z+&JN%6EOnFX$BtW;K7E@B95L9jLjK_W_?4?7_vEhW(7zK19>H+??62P#qBdUaXl|_ zTTuf54u>>B)SD2mP4IRA-%6TK@DoDip$g4gk!Q5RlnPxP(rW?z8OVuw^-^kJcbwG;090x!`|m>WwxPS8z)?i6t&z%u|FNBIbb^(Q$3j9CHQk+A**AC%)F zm`|eo2gr_{dB}65fg2=n2#KczE+dqSB^#a47%}b_wT~G0ida0MvlI1V9%{yYADdyf{eM8iaGP?>McQEsKv$|@bRw>kZ1%2;1^q|Y0wbXcKy9Od|rrD!# z9#6wxjXcfF7j^nQCO%`V8(8G2Wb6&)WfrlxOzRo#Q->d0#4Ds`DX8}~h?5{Y8KDQ5 zJ_YJLX)O0TeI%`SG;_8+WWU)B==n_OSy|}(Me4mjG|S=4e(NQA$ALXd0nOhwK9m_NWvV}|U4zWe!8k#RNy@S!VwROrd!Ea% z*CK3u$iJD{5YWSw_DWd15?*(VVu#n#S-7=kR15ytsu|jSzM}31liZGIAxt9wBfPq~Q=hfbtng&p=#(>X~NjS&C@ZrEnnN{RvyaPO(M}MsU7~#?*&R*B{$#96i!-WeXSt1({D}~+2Xq|O9Ov2oO~{*-{8)*-Bu)|d z0uYly-Y)47fk!6LKgh9kyiC(#1Wz^Ep#awfHCQ%danTn_^Zp5YK85iKdoE=oLjI=I z%nRAyk(>)ECt6}7C9b5f3Z(Z_eq~4t2RdI@#gzdJ4(Y1^4iLC_KraRAok9Lm!C~R$ zPnABXm4DSHH;v>@3Y`k!c|)^})1Gw3_64zHL3~zZ7kKJNChueLTn1ie&0UyzDT$9@ zmB9Wp;PWjCTNk-I1p_{nG;8)*udOP~LBZYdY#)R#5-x zz$CJ7e`DWHR9zWpHx+arSq386Y&@CVVJS9wmAYCVCzq z{Lh4bN96Ygu4wQvhP>FpI}GJ$fTxMw;gsD0;(kd(9kzBueqq4fg4QIthe7Wf<542+ zH{?zP_9AU#!agT+x)3J{dA-oiFX3+@pM!9eSiefdDNx;gW*=RX6EWXR%9{oP_%^|h zQ@A~VYXi8riW4jH)mAa8DsN2W5Fj6Q;dqCQqVNiY&!yZtg^g2o0@%Ad(5wgR3!tt{ z>Q%aLhf;p8((EiRU&_kOa6bYpbBoPMVp%}26$DO|_^ISeD(zHC`vBNUs#}WKHY`u7 z;Hat?8{&EaY!krcA*~kD>X23?+Nng`_dhG!OHh6QVQ-2{yK;X+?3?0^Hj_JWH-II{ zI5BBA5%H0LOQq&Z$ObU$Etz#gL$iJ$A57>ez%B%Q9?_l?c^PQO%luD(Eez-*5?cWF zd(bC?ToAy+U~UN5JEEQwbf(CSN&X_@T`+zC>$iZG2eBWNQ-M4e#DSu=CgUhEKM=L0 zfHy>~C-5y1M+K?Fz(|fbLHE=b*i;<|LOx7t9#D2ZL-xMJ;7$?_ zQrd5sJ+l*K3RK2YoS)YI1=4FKJw&xTP&!`H4hfrTXf6h0y+peB5hhCR)FJEC_av%QGy zo61`6N9M(_yvG=mow^9Xk(7=kno8INh(AbuZz1A{OrM`3x#dWxHy z*?&lVMmEoZoskGm5%3Gtyd!na6n#I*mO|PB41bH&hgvNsB5V;$-fH9>v~n24n<2jr zs&_;26tlgN(cWQ^&lkl3j`-Py?J3O8Y_2BDN)8*~#Ik0X4(Vb-^Fi2xnf+;bEi6}- z=bth2-#i`iM?t-3z&Hoba_|cy_cr)tuv{8y_L2CSRJN1(g2{X|rDs#PC^J@3whN{3 zrcA3LF`rp?5t>g2^_YaUl{ve@7Rj)$B0Hy4+4PELawwOq?71Y2dx!O17LKKA@e8W^ z{naqGOU>OC4{OsGsb~&J<<6Eo)zI$f%#|Fx*R5Hqs9aH~TMKP&gAFs<@c@4d<;}{x zS;<9_x(md|2A|DfLkMgG;3kM05&XiWXIymvmAeo;L5QakeY+*Pi;(#tEp~;lh@4{} ze;{Qi33^k|NXhO|;tGUz19Ad@X8`*Hz!L;K4CG`Yjsdi(h>2->IgAewd>t%HiheDn zZGd{N(04`BrUlD|0e%&1PEFZD3GS3CS7$a)A$)hGAB8BVSnzUldzoQx0(o#M*AA9H zRrJ15rJq~2M+7w{fyYw3Hxr*k>a1GzNLBu>Dz9%@|JB0ZZ?hbn)yE=rCWTMQ@`}-4 zHEJtk_X>xNc6D}g@kxsu=V{AX;1*{54bt*Jo+;S(Kr>MENklG0=1XGSmWH*{w0Kxq zv0CpkNv#ib=SAvuD(_+D&j{_Rz#^rE9+A)k;$AvdrSov0jD~zr>c4MfwAaXN8IgM> z>{Xz=>B*xB4l*`YSfH~n&~F6LSsZAN7CLJQWpfZip*jJGO+lA;`3GZT}W$)d8ko? zob^bDJwcTRk#@S0tCGGP*&Hk2O(C}c^K^MmhUNPzwigQbfOE%m9{`_aZCZH<#BpM| zK`0-m>~+aMOq5rpo;M|)gw%MbUM1y@Y4J)3%Lh3*WcyU$rK;SzLiYsX>_|NT;X8vJ zBGi{nxg?TPEisP?OHekR$_1r%9RpTMmAgRe58^G*CV>7DsNn#Q$h7`QJkHETDBp~* z&49R@Xm1d(Ea>})eqEZKBb3V_e;dFcLIVLFCYA?*@-@Jd1$#}v!9r{TieqFNBym1jXH})`4dfF5h9F~Y$i6~i z7@!}8Tnc6b$AD~0+!kl#Rh8L(XhJ(iZ^V7Y*-*)eEe1aVVE`*f(?ArX6~Vva=o zA;3RM{5n%xrub|oZ_R8L%Pik#`hLoCFrxVu*||ySqac5cXdX9lsKg-zb~AA?%iI&p z#lbo!z}X2~j4TTg{yr7ckhl%17eo0y#G9n{2O&Qu+II{y-f+Z;CQfl_Z&&@INOyRa zPds_1rw?T|p8#9{hTV}o%B&7?k70z5Bz+hX`+(dCvf-31%+RT1dz7&r?XYzXoS%p@ zh`3+U;yF`5b8gB87%<$Gj}>eFZq_-8S;m89zeF=W(K9~PyJ(_kU{(37$|h8CLkZi+ za1Df&6IvL+O(I4DIuOu&CO%~FPbsZVa(%$Zfp}Uh+e6Jnq&+2+y%IeeDVuLaI~LNa zNZf|NduZ*qR&70|9pbR_jrQeCuDk7s;t3~yPnN#` zx>2%k1wA6PH>C0?k_Q49o6`PO`9!ELk*X&vn+b$%@8IrKTtHxHNee1{r%2l>!v{y& z8Ub!lrPC{MTP1D@!@}YCE}SP;=ib%h>(=txmUXdKd2&z>3)q`!7a8qaqrKzQ(++Lz z(251@SAa(f>|_^zHtA4^8v)`0Xx080eQb%ADyP}wGEM`V_R6SFRpIqNT( zv#h1?kqG|Cz~5PI64BfNb^n@HF9_Ne0UX&fHmp{*3zmJwa){V2A>=4!ydZF8Nn1wd zmBGFMBm1Tus~4;~{uHEXOM8{)ez~ozU40Xh$349-^HWsqGWFTm={L*%#U3dkQzw z_#{ko!gI1poGGu{$+~+5UTu}pAwZXwGs5{CfX9OOx2eKS#~C3H22`^j=AP_806D}d!Wf^QqS zoS`$-*lEdfEnz={Y{6^@Jm};XM2sW4W58|?S^pw-XBWB;CSu2crUo!ifJX;7YrsDZ zm7^2fJfuk>ELLR~RoQt}zD7bn({h44_APa zj)rqx6u()e`HhMnFE1nDv+OSK%qnlTNo#&iE0YCQ!RC}~a>^c({OgpRn!@FY7#QFs z0Uuq#8CAA_6{l3`PgOd%#DQHJnzdiIsiJSN=L7@auiSt}628koL&TT_dr3hF_Sq^K7;~le2A*ZFwSFzfiTA zKeOkQ$XR|8`u#`fyd*S}0NX>rR;2Apaxb#(Yv|h)m@x&YD+8EUvKun<97T$uZ&|g1 zwcQJ?{yLq}-QKf1q2zz3mZ(pbh~Ig{uO2qJByTIJfr7+BNIcqTX*zJ%>`w4oLnVRE9y#W~A>=<6bcRO3xGNu?4-o z+pK%0Sv+sV?PmCh=DX0E3R=Rj!T%g3KPH;ll|8#e`Yj4RsIae4u{LWN$J)7!)sOPD z2`)d~Xrm22h~VZX-Dw%GSZa9}4=9NNC3%($Jp~-@v;`a(Y+^r8yQw74^TeqRz2?v# z4LsDvMIAZGke?dyF^NAKu^54kDa>uc+Xijx$jOd4-oVuj_PW6jB6;=9^%|9?(`hk9 z)L99<9%5UOmsQjON&8alxlZtXrTjseCo1#82rQRj6KnXmknI@YjurKq%6O-icGhUx zXQH&%MA2&1)!VurXswQEt?!~>cYxGgiRyl6S;Mn$bdz;Nk&Y~|g9^+Gv3-MFzA$ep z%MU$r#pDFqa0}}8(Z4HEb|7>9B!Fk7Nttov5s8Qk&l_hSXy13 z7I(tB%gEwvu`UUAj|ZX}G1(Z`5jhPgSDO6KhVpWOk8$HTr=8)%Ag4Ys^3ODGOT$xe zYgBBvY)Vln9To4D+sWzNK!&x#xJtl(4s`ac=pA0!Z(LxOrK)<@5B0k-@tdj1S%#!_ z)=t_3N!=dseFDw*A={;j*VW|Xt*~#)*sfYmOVeud1T3p8&r0O)C2SwE%QIj#^P31P zs=zUbcpj>|5!k|opB?#OQJvtC_msr^CGbpXHLcU)>ZavuO+ZC9##w%H_h;O=(ab7f zD>Ht_V)vnNb2NHT&XQi{m6tJe9_QBfYuH`JksmrVf#@Cw^}XhEExP$(fCiD84MkU} z#4~bCNQ)EF+Tp>veYH3uSw~7f-sG2<^s%#ToZYDnyQg)arUAwm=Gp~0k2B{m*0m{Z zN!S;FZ4LVQB!-jf=O`CA%3=oZA^eb;Oz>uZ$nO<8BNM&1Bxczl(esx?IY=zKCb1ci z{{nKL(atw`e*!-caX--hS!}Np+g%g&@FW%x(28~_*j!DN6F{s950fdY#YGs6}DJKb84cwDCFZq_&%h6 zRN=fTQ-$9auzA58VIHfP;{+>ygt?^|Ha3HiyaVJh0JaD7RHAz=tlbZetK>EorE{Z7 zxk}!70p9ZnyfaANtRU-*O6y%wY~~VpkHE7fPJy(h5=RL6O(J(oV&{N;5VGScv~QJ$ zSK*ARdR|4{uPU|*#e%6iR9WAE;(SU=Qno);{$<%LP1$LtT#SfY0Sy=NSAh$OcD=|Q zMcUlkp~;<`BdAbx<<4E$vP`p z&otIU47kYU$GUW;Bh3`U4Rr%kcV0t#DJd9vs5$4PIVjq4PSo=6 zjB;>hvrMXIzeL$fM1O%-h}aaw7|^aHV;8bJ4EXQ-WZxn}_gyLWP-2QA=Rn{c*0|l; zZfmt~U)Ep0v79l|v+wW{wc`y0fjok zO^X=WYp^>B|H*;195JjQ4sz5XZo18gmq;E5WG{i;1a2hhpHRJ)$kh#YvD4QoD9bkN zovm<|?+Sa@bo4vVG26?oS>G_ta+PJ%Sla9e3`KIhVE+JdHkpsp>vUQR^L8(KOIkge z)*fZ1dkOACE0+O20pwJXzlb)EXh@Xv0_E})Hp%2E2t0^tEovFh+RX21Q;Td32d_2I zOtu4sLCoC1lFxYJx{~&HPn_wQ?-j)jPCe*Uk3kz6d=^u=sEB_o%E2y-Ex`E&{KU!a z+;p0gT{GNH{p^b;2DF9utx!(EU*g-aAX1AD$qnneCW_* z1I8M7iiuAX{L+Lc9Js(`yPIqeOKi-{&n)AgCF>0(s};lv&RoS!S6ivC(CY|#>@915 z7UOfFjsWUSL~dcgdIl{<=myFrl76OB8=E2B@U#&F%tSYwZ)Tur4tO4f!h==HCFy0T z+{egqSh~ig=jb#X5iF|*dTy@jj0tsKt7_(}>fBe=j14vK1$t)$n{i41CBc1zc38mg zsVE;-+4&V1(jrTX7!_8(36Bvloha6uWjS2n&7wwy_^5ctm%i5YW1n#aWXOnJ8{=5loV6|`41kP5I(LEXpM?qrN=?7l|oYp_g# zmG|V$A4nVF#IFT*m!r6$^AlN)1$!0(dVT}=rGT#qbWQ+zKNLHYK)VUBQG}iabn(EdXBwXdWSZt`Ry_ zC^v|FUWl;2~KXmial=NL0Q3c~?3I~T-oAm1W$XE0BL;X=8s0{1WFTwT@~ z0qb`utn(49yi4y?S?7GQ^DnTB7H|T@H6c!s_$#3PV%(C{!9koAz@`j0lMSNsVxk=e_EA>H$h1My$E4YdNh}4^ zD48y!>1a@Ii`W7{7r?~=78C4cpxg=g8vsWFWlf;xc(AjGtoKFPtiPo7ZY=gboYr%- z*qNSe4wu=(FkLwF*3T2@b_oru(RDG5kI?u64P$9I%&4`=xN0U|y00bbDaP0r=%cZ_ zi=q8vBm1VnhZm?6#pSMcZb$c~!gedS+`d?z=d2q#V@dNIZjQ@o{xGZ=1^0L4?L+YH zi?TXh7XKIIgGoF&GYyR867A)IdQSikrEqB^2WOO56?TlOf1I`XuWF}e?QD^ilN6mv z%FdxgGY07V4)mP?O#tE;ARYv94yfCR_E(_$FxcKH%(zFIae*?1Dshh@E=6>2WBZ>^ zto_gBR{NG<{qIq%|2f^FeavfY?9mUR{U^l*E#!X1}H~RHtXCuOmuvLiisKK^0aH7Nd8}*qp&oi@a%$sHDHb33} zPHT1pZ9;+*6FEH9u9J#WLAw?3@c>^G@UY}BrplBMM%B=aNL&`;$w_vCd3>1uQ9VaQ zsS|6d3s$dpS8E4Viy^`2N!G`OdW@-WM^pF1lJRQ^99JUG^31m#`l0|g7jR9NelEaP z4*sDC;qr+Fd)K7hARTYQcb4eq$>&YF)1@=0*u*lro^eVM9xKX~3*%XLf;icf001BW zNklC`~w#EgE4Mq?kBz!G#AN91kWb8hXIwud@%l(hTqWiwGo%PYab&H zFvA;WypJCDvcxwtUjUjVRrp;N%qQ1(^8AM^rzN?6&<_rjSE_n?Yc^Jsr&ifEq2|V# zo$W$Br&n~Q1?=2__Xf%@RptB&|4W6nE$Y&h?Xb#tDlGOC+h=4kD;ST7alC*vQrtR( zk&#$4!oJMlv8tMj*}l*09!KTtCGMZo!#FVDmYp6vvW+@+-bVk-9&Tn_520CdhGb4Nl; z5jc&^1BCVf(ANR{6Tmkh${8u!P0Y&^@eP21LS6^xc!3jwxGj`l2HRVO8RMlqP3*Zn zQNBsxtfY+<@+2vb7x24OOmTGk5#>UIZ|m?2iS`>JUI03~Cj1J*r_N-k+dweZNact` zu9&FH3tU|2y(-}wN$o}{Y>>k60N1SG&=3~`HQ|4DtP5$rI4#eG=>a(IAaShBJ_X8G zfL?}jI?=pN+GZq<7WB5DPk^2+fZkzbd6V={iRK`n8BR1q1Y8Q_g+e|D#_wT#MC6we zZxG565;h6-9UtnRUy+wosefgBSJ@sDzO#p0r*1@ZbX)ci2R= zy$8^GUjsS^0G-W%=I?@CCvlj7VW7SQaTm0N&XSi_EPW})%pV> z??cp^l)jPVn*&+{wA0Ld6o6Na`7tto58*x_CX#UtsKvz`9BAhh>Px2fU@ER5Vo527 zA=@bo{l;o{6zebFFlUTJVl!m-ctqcQin>HbK9JdcJ=0H?_y%O_AUhW!@jFV-QSBi_ zP6B5c586#6ryA`7qb@S=8h~?CnC{B^OxVKEvj<^o1N@oDZvjkCwND%BVGi9>SYL*E zz9O`e0b2^bo1=FvNAK%~<}^b&0^ndst3&nrl$ImxM=1W9;#UE#?1(3&I9-V4fY?sJ zDuNvd<&{9aNyuYU`Fo-MsN`iL-d6ezVca&Qa}wMu!Dob63Yk}0;z>*VXjz`N%mbKl zrU}Qnc!Dwi0bq8f4TiWW)1I@$^OXNU`KD0$nJ9b1nn!1jv*I|QdnSo}4SAsx*E#&? zf;`&E9gMaiO`D4Gr$nAi*deLTGRU&4h^<7d3e(Xf!UmGf)}lR4 z;vP`{O5jXV%TqR%vSSSRSipGz<^bZ)DSntUX@aX~YLO5g7VM6s{+g`UhUM2m+aU}u zrs=#eJza^a56|v%o_e>Wo^sU19kHZA`?_?Qi%YsViSVPS zGK}!0Nq>mRe}P)Tp%sX{p5)$i9mB*}m|YCwMzK2-(6!FacsD!4P1_lKc9I8*IgzZZ zk=@ULx{jc^lKHx*i9voWvlS%UEsI9NbMcIPF%!3B<-fyivj`uU8OvtcnJGL^mXBbX zPWs$n^IlSqC$%+zAE4X`sRcn>NbucKcsoMJC+*xSELc-h+SHd7ygZ;wBXgy!F^8b( zDc?ZiDnZ*PiRoe7C6)h%a&9UIGw~TCrV{mCpnXAXuT5arP)v!eBQv-&s=dmv`G7ou z)}BJEPdKq)LH*R#JISN>VQc*jwl>{bdzIBsw7|NQT|N^&))wv0m7Whr`R}mKqq@Jv^0y zyiPVBhj1x~oN#rZ3{5FI^0UQ;` zp9F1X%%i}(3+B&*y@SEJBrNsPK{h4Y80OcmYHWlK$lm;f^Ik7zvu4RO>w$ywm+3ufF@N^9X$x0k#iN z`zPvsRQ(~X6?GHG5FDvw&3ryNhZ!CfajNxS%LMAmUAeqbXl4!IMq4ovUnSuu%lhrtk-# zekt`Gz?p23JB0Rqr`~kLcqa#m?Fq^HiI@k0b_(bdjk$}E_d;5N?9P|s?}U6+YR9CS zc~YH;HFZnCh9%lBq#Q=^D^EKY$s?Gy1EgmyV-rhGC2|@OKT&uM(kD!Q#pITrSje)B zWcD0P#m+M`7dlX=#|rJ`|NHJ(0^2(AOM$&otQ_KoZ_MmAu)ZL6*Cq2+f-6AWgeV_M zb}4A<0r~>Qp#>kIiJfb;(s zg1tfFXer-{tP6x}|AbwXrgf6>b6B1f#(jdEvmy?the`mSZ#WPJd9BS{7a(*IrBkDE)J`-%uggzB>9ndaL!(lS*HB$p` zYalfRk+;hEV1~^bVW&i3wa7Zuz}Y~5Scb<)e-H2{L~IqnL*7uJD)`*O0neBrJoQP^aGkgaK3)12pGh3};drkp9Zqokd(Y?}YbFH=I zes*~@+j0$Rb1Je~66kCV*iaznf^s=Y$3U6`;t5c>1M=G-?F89pNZXp!Q;zOn!;I4n zb&Msiu`Hh;o9&VH;#6JG`!BlH7s=+nq&=6$zNDR!)WBprI51^#c&o{e zC(8GtPXufs!Y%@vufd)lfu4T@z5RjCAp))tFh;1$iG8;SGx`JFHHG@`1U^o1Mj#Fi zv>PSsvw~&x;Q^$O#)$rcjGxK; zTd;8#+3px;yCKeYk2tG+9bOszM@Je*@pCG6X5=E2{bl9YFdP)d&OsX-racSu7lrl8 zh4sFf%MQub98j2tghj6~bXh)~$2=haLgh(7y$uxi0~inBVnDwOXH$Xd6T2 z0}S=Mrsh(ICRf0(6*;h?Hmq1bSFzcekcTJgx{BT*c%j`fQp;(f#x9cg1gfX0#$iySE7W)n zYT3!q@)t+d&Y8YUv}+u;#KGeY9A)B%6mAgnO@aDqF<&XhVPd_qtZfdgIT~Kih3AcA zL0F6d^G9I)i`aIHklP2tgXPv>yax8_Q%vzRXa@B$gu+@`H(a zu3P>wxu%%$3Uhr+SEg}1%nYnx$S~z&D||Pbx!0dP~545WW}uYr(IQxM2trL%Kae2L$Z*pp7roF2%}Qh1#;1ey%NF zQCoB0+VXle^C>k-3B*9COflteE$X8@qE4k;kxCv^MV?Yccm@5jLY$s}b6mdImAYH_ zWRndx+1DnXVZq)moREa+3EZGTepi|LR><2`D18%jhbf*j=x&35;>MnC_PAMGYnE4} z#Y1Gd6pWn#t}oeB5~c;TGYo?3WTtW`5(dbKzwoJun{`t3AZkB0tqU5})LP(^!H zaUBvKP_omC`}<+MCCHydJ{aJS!Nz`BEjJdmAV=fq5{-3BG>*@u<-{DV0}2`!7FH`{ z`cs85ys$=L++9qUXDbJ0)-Pw~S%qcCVDki_*%GSPmgY_3T2j1-vZRg~fS=8d4Z12bvE7zkXo)wY^1izLoqA3x=`acLu+Q z;>rZ8dPCe^h^<1gN2u)%q5eytoL5vjX7QU)8V&IWXZ%RR2WEPz80QxHl?B$Ri2urr z?+ltv^AU18KnauF@Tk)Ukv`eNZe;L%vMdJh5yfE?Ux(~gM70=5HvzW3;CBKo+Yv1n z64e!kw7I~qMf45jB|v-&=mh|42|OrZM+D-;0?aSq%K^V#X#7h^3j*cQ0DcHGt|(~S zU*Pi!?ATD+9B3>wHa>NwN0#eVO9!YvL$v+|y-UPdKx_@#!B9D#z$_vb8ge%x?`6o{ z0dx}Txd9v=vKKRAjiUOgg7R-DzhTI$LA)DErvMxv={pJANLX9IS^#zx^stbpO1wIx z(8hr^#R@M6F^KsE+*?+jL$G&HTZz~qSQZrFQb&v?;*90S zJbOs6{=s-UfK>$y4_HSb^$mEpfb|A+gW%J}G&0D=L0l-RH&g}#oCJC|&<-Yb3K{E= zr5h1D5;y@&6CtcZpg(E5lI2jdycR8*h_9$+oN!FQY)x1v%aePRl17!~dCn{`rg|<>OkAm9nCVo2& z`27qZuS4J_Qs;xQEv;-L!^>v=P>>e{(%3-NtDvz`pjuGC#RmKUU{e66kvPOzrWu;^ z4K~!3o=S-I9QiN<+C$h~@IET)A#i=EdR=Nf8t_44tW9`dL!Ja-2^0&2G7pLuAsy)C zPEPFN#FbQjjMM}ndI#z!3mUxy>>rE|3;C&2U7f0B<>$<@Js2HC9t^6d$OD6UkyyVZ zHjfcFT!`+0a%UjDTaa%I#E(Vwt_9WoLi*NJtqQe!ijkgB*d_{GjfmS7WgUbc4)GZT z=TKPP6nii@0$Ib5bt#HHC#AoFtse=T50-O?e5tXyo1>oT&{2-^jIkbK)?9_IY36A& z7`wpiOPXD3W@7*j{@?pCp2}|l_!E>?h^Ph&xi9Dk6WEktTO#ZOhISD0Mo`-hV7{G* zKM~r-5SJ3=eJK70;SKZ& zy=0~n!pg36z9Z96AYL`tKoyQaNyF)WB8;0yE}vvWUjm&$oh{R?X86X4&4hA^gaZ-W z=zq2LFNroIvULhZhhXU+#An5LP%&Ow3_q2?)mf!WM%lKYo*dF`q4HSBZ;jyfQR2H| zm(k=~;GaiVkpVyd8519~D*Mk&-A#062}xuD$?)HtC` zg7CIk3U;-(CLn5rH%wY*_bU6i7FI|Z+BRDUzH9!qa`Dm{J6gzH;fHbsti?+2-U;@rwDcfSPcUk=L6N2fbA*rxPbZwf`PJi09}Rr zhLFz{%6mf_1{AI zGpKomA+|MQRUPO@04h@gcIS$$iWfb#Vb-z#tuLSHKQ z0mQK;b5pw9!&_aIdo=n|)eWZ9kH8-Z`~uooLpsXM`X#d&iD_;^x-|ipIO2ixq{g29L(1QOBJU77UGve zo)U(W3(IcBa_@pTM9>QYZl$WlRO^$bmI)R<$$||AW-#pU3_sM0-)`ZXvalaZ+1pC| z&RpHWs4``b6LFC-+B@Q=1a(b}Gb${5uYu-D$@FBhyhcj-7;~P_#M9^)1P9^#FU_uV z+E}OGkf?>p>U*3q#SQluajApn6X{K|Dn#Q{0RIK@y+Xc4td|DL@PN99w24sKLSmNuT1X^wlwwxbKPlnk8*>rCXTrnSKw9^N?XM^r(#*9 zGMv$H`?)flnaEF^evrdHbou90qdQTJC2gsh2GhzxX0ZjSJHYa;pj!pZ3t%4^H&McH zRXAD=JcpzyNU=Aa@0q1t+!{YQ(l}#0NyM)tFNWhyrPxbVOp1!Xmc(YM%I}eKJ2`HX zX#%LOf_)mORu5I*MtD<7?Lv(xN-JcfQ;Te97LU)cEdx9?paX<(BzE&rYD4dE8Tx&vu4(0Z1D69bJMf%=62 z4h@vuggAk~T7cFdd?P?B6F3+2`9jsr)HsZ+J_K6V5?b%d!Wb$~6f~Of6M@uC^1lRA zC!+BXfo_ss24X2uUN>k>2fh^JITKGI(z$@$CB%OMI4^_;3hGxw^@&g{pke`JT_o%n zEQeds#X+71#6XaP1p9!Bw?$0|>d;Vp6{;5m^Ysz_uE9G}d23T1W~yH@;248n0dQT3 zZ_0Ewn5W2M5U7Jd>jI#&Shf@DD}-1OzMe%maqnZ@dQ7Ie0_jj z0p1MYG!V}TF;MXC0rmm-0Hl`;n8CmW1P_680z$oIc?uAF3+xfV!$SNN#3IR`2G~ik z(?V%;f!7n|EvVc~#CrfcgZ2Sn8v>XH@C?dNB7F}M3kGx1nQzQCAwHI^++ z91d7_z~%~^O7ayL?}Bj}%ytHBcc>f)l`mA{j{-X=v@k5rm6cGQ!7wfi$0=cYUu+IC zYrX-)Bch)Yi~|aJlCi!D)Wc$|9MtLscpBt|BK{P_EScT}H5ang6xB=-^D^QMA}%k8 zH45UC48MTF^@e;Ig=0*yRD~~~*pVoCo(iWT>>VlXBj9#e9!=E`8@Z>0OC5YTkvAm9 z{EB&yTkPkK^O*Pp99P53a2Xym(^dqIGnOw6_KhJe1bHKgtpUCo&pd(EEWkZ;4zbp^U#&1 zn90y9RJo4S;ZAf-%;OTYLPB&l#B*-3Vq&?mf<5j`I~l9D0Dne`MIjtd`OlOtE>KSx z`msbe8twsYcaoimm`PJdGu`EmC!^whO8yZN27{$L8J|IX+03WY*n=pm5@m^i<7HeJ zh$rRw!|>)p8qR_FfnYhpP$n_*l~(LJ);3Mnm?OrKhSsbR001BWNklK$CRO##j<(9xyDzaz>`V(T<1eJRmFUj@+@&`m`8 z8EiR>T@$hdX+g~76y$a)UgJZpL4W^W+uc4l<5$VXa~b={g9!^#IDKOnHNA+-m%0}u}g zHlxs217dngDpNvnPDCCqEt^KwmlAdb!LCwT!=k0HsWA(YUS{w>C@qE3U?5fnu_l~- zVfHa$?}Krw7>5aIhL8>guscw{31ELJUIXG10^TQxJE6Y<gsLl09RpQ6 z23v=kTKf{MLZNU2zc_@|_@Vp?86-3Pz<1d1)5^@{RJOXIjHc-DG z&}#+x)WYWBMR|un^b+(r5LW@%07y?8s?Px4B%q^!PXm}P={`y8gmjvO6$o@v#9m~4 zXW+UZ7SJ?Zf!SdBDNs5F@Mf^wD`{Ve-6i!4VK2!qko;ei4>8pJsk{qd<0(5E(rgKP z0(Jms>yg^dn6DBrNAyR4G>PEafCd<}5>Y-TbRwXmh&U6fe*~ICp?V3CKSAV27}$@& zFJ0W-!F`;#&FRk?{Zmp433R8lz@T@G=xD~BAe{x^bD`V`;C9j12W6n0_oXcnx=&|jeV9@11uFH>mc4 ze7_V6q;gvndy>UAV&P;9d&XqP0o5#6S_F?i6t0DM7eZYTJPG7Rl3fefsuVk#(z_Oo z?gsB{j14Wguc5IS#7zNi2-!xGEs^XcnN0?LEUfi2u$n@|d}BQwinE0nVW>|P_=cg( zN@|YtShm=$-oUJE4&!;js(+|?4Oo96qVDW1GlA4DWi(L|%{lr*GrniMSGf=-< zV5byd2B8hXJVA{00%dYRdl4&LaD?cK^qH#|TqZL#bCRe;eOIT1Y6DrtIi>v8PdZ=Y2PCMG+_M#exc+yO7-Ya z%$4eeLfZwvviqg_Ua4&Zp>3~_?;ZF1Oc`;Z$QizL+-X0aGm$QgyU zFbl8N;)pEW8q(S%{zlr`gq{F73P|hFa6QFiNUT8UV2YoyU^_@78Kol?(~b2_PAyEv ztt-apiq%*bc6P*;hUjeMSVw+0$?q`Y7QnU?_^%@Ll6a@2c>o5h#HY-VFV<#gsx>^?!+~xq)Jb;s-`ZXX{2C%x6ZdK?B*|N{2 zdQB-tBD9C($A)+^V9y8B<7E1d=9>c6M^W__s~Xli4QTyTv}c#YFL759PYQ8xK&uGx zUO?Lmnhn@wBK0EDUO-+M#BQKg0lk~pIF@R6y43QRtK9)b?Y=RzTx>`~0KQ(3UkvCx zf%k-TS|IJ;E*v{9)15UBqv#ixMo0rWHx z_YuC1A$9`N0f1f%=mVnsAHekm^@CyrVAo0B9>UuY&JoIUMA=X9N5N{>ARZ3J)j=K| z;4T4<7t~AA*8=(poDQYSAnquoDG#v+0D2Gh=f z&m{7*5C#Ey1}d#!*+bAgKp#R{kM=fjLIoiqt`1J(_BM zN!n{Pdy=ZwBJu=4!$RdDLQ?>{9k4fLykohfsoIaS-5B`Pq@`inlGJ^qMzi40^cX6u zzkxlfUSoQ_| z1;{U!Vpbscm6~(Jw)F#T?-aD1A+=q{&|{J>3gKyp`>^0M%0WG&DZVTBINcS-6QwSVEG`@x!n*bOp@WlW}t7r!ZmqPrU zW)A@Vsj;=IQB#S=?nHi6!gdnYgfPXhY&DnGcjj@f=B=i@6NF!AZQFytUuS6aH%ph9 zS0l|EbIiD>Tl6!=bTEAimL~w65yB;=YGspOC+NXYbGrf!b8;1MaQnrP<`TF)3q(tL9&JqEKoXt>G@ zJ&iWkEFEL?7maqjk)6$AZ!;`0<765>5xI()y)TQ$Np*JGtVE7<#t<{zP4mxSX{^|I zTGFth+>xOXh;jyiYlFH^4j#;h_loP$h0A@_0k6YUG+E#*&;y`sxTRA=Mq^ zU;ukTaWG`#5Y|V+x5m7xvEJBC<0{8%mBl_4bZJ7`+XI^r){#ha9kz`jHZsL$fW}FF zm1JvLa92Y)5RunX(QFvLjLh+%_M`Fd<~k^`{Ai4EG@C}_yR=vgvt4Oy5pW;D>kXV^ zj%^uyly2t;F`+0{EY!nF_%>WOhvyk#`2`Te4e59fEMW1iY3W(8`j=F_6RM5~R&Ru* z+ltvcnK(BCGfLp2D0n#v){7E*Nab{?ya?H9Qa&$)W1{5aBl5yP86x0bz_%9~hd|L= z&{{(5MwH`%97t6C!Nv#Xb_dkg=xRb=Q22+59ZgswRcDg?$e8bO%NLT-PgbvP zXr5S5uMCunl9fEm3qFJFQx7{N!tO0fXPFvD0@Y}#-P57QlSS!E1g}7eixg>s)bhN@ z9fLYQXzvBIzhsjFd@;l^q2Eu4$lHW?TgZBa+8!*SHLY+YBONRGdqj1#(awV586q7h zrZ<8u?O}}$U}`Vo{D?Rx#5YT@Z&7R$${r{q1$-j-(S+|o;aLKQgLoPiyTI~QuH36*~DrZQs3Z!v{GKMUFA@vxg-jwxZ*z02IP1;64xk89zB)l%^ zrGhvdQE{8Q|iaL}iQ>Z+MVcSu@#9)UA z7$q$0B4G=vd?(b~Ky?SiABQUZd?^o=%7s9F2`n!VTm<^3l6Ms_Ae7&YXr5WDjE%@A zLCybA@dyeZVfeKO4M4$LD4L0=p9W$sU=M@1MdVw7*iW9mP^8zxxQC3}hE?+{(lL@B zAfyh0&ynz%pn-xf5*klHEeiql3)q4nE-Wa24Pi8+>Pxon2mNsn`G@|?>%QYmqWKlT zV<8(%=^azsi^T7D8h?4(l-Hr6JESkDyg9*zWZOlwY8WjoruhIfTjJ)Yh&GLg%RnC} z;(mi3UcN?ZoRWaOi?oSD`y1jtqYiWAV}#NhD4nF}Vd55)`U2P>plgKKS1ezEwl9fy z%=9kB_h3F-!5hTf-N~EHcqGAD#yFVB7t`3Eme-@jp+@dZR!5N4a5D9#rJrebEG>4Y zVP8^%LHi0!ACMeQD|4Lwxf2uJd;@n|M8mVN++DOOAxwod8-X1ZZ68bciO{}cJwz-+ zmfI}zSSimE^Xo#hQ!qagh5?ez6}Wf6Pb;iG%x33gFCP`FA1q#v$`%{fjIRr^S16`S zIZqUy_Y-VJCqdjMgd1PEh`CcTp1Ih#-x&S^y;1dF0674u3{}t46=CQK7X1nwC z%1W;au|tv;Ik++9Z$XWhsg{GObOg}y1(AkAyqn_olx{X)KMH-oyocEL zh>HmZlP(seLDMu^Tb+#G==g?KZB3#HUaNZ&$@ z1EK0vDD42{gMk=L%h%J>MQ|G1>wP_J(#HsMf<+T3!aK^#zQ{h{u+* z1kKYN)+edu`~sV2z-$6%6Y&wz+|7`-HKZL))!|0l%fLq|-Alwwf+xDtc2GWm%J&gv zF;I^nVt+z+5V#w%bE9AzMtNSP`KCO-&J^=dm8lRO73>U|_L14MFkc7OSV^pw$aqsw z4}h_oP_6)Un4nKX_*+)okfm`&<&jYR&w^#U6y(#3)VV00$|!vbV&jlTP#j9=TtYjV zmF+3aBK$r|>w|GC$YG*?OX50GqkuRJk@^1}kk}jaR0@gp+><7eFfDIAyQsDQ^q+fQEe(Nf=o+{a4 zlAa6HgPho$WDf|t3hBHc&kE+J;{FnY2RSl zDOhb6h+_nd6I-4DR=NyWsXy5I4TvwudL+QdfaYMb?ORBPKrs=Fp#a_nwJsRrfH)7( z<6wLU#>PP0zr5*?-+_&*jV)h+90}&{z_bzQTLt+EpuK|_Wn^cA9y4NBQa=*fRA{23hr{$_U8URA6AhjsR@|%wEYrX9HIxEaU^Ni5jKaGo`N-QhqZ15Ya1lXpMv-f^b^RI(SW~eDBVfUH!Fk9Vy;l&%7~m2BC_P;)k=uRv`GgCbxMH$3i4gi_ZMx=fXx@m zo?@9M!`E``6Df8IFRvBmYYXeAgRygn2TC!RQT8*GnV_anxYfvO-L%kv&m1_+fbkTz z5Y$uPM5!7r`E3GU2IFcF50KT0My%nc$KCXko2{4N1C!D>4)4WMJrDfhTd6S~s>T4V zqXj-2&{0CX59AvuEGE(-DBUFCa?r1!;S9O&Aoph?aWoyHVccBQCW5Y#us!L26Z{~9 zy-r|#qKt*bYmjvkah?z-$eP2M%6PhskXNe}Yv~oRg9*IONE6A%k5D=UDfLk_){z?X zg)~6$bpmBug|=0({z_>&ysWRJ5h|J_lqZYwKq39Ch_3?q2%+tLp&kwC36**ul(yZV zyavUIl%EeZE;i|4BCScvtT&897<`0GLrA-o^3LGz zSCe^rqWO#|pW|z7f2a695kDH6 zH@P*hCi9*&+)3~dEZ?7wr)h5*dXZ{JL=9qh$R|jRAws$W@c#g*hhWc%HdAc5TGnVU zYn>3@dU#mN!l3mD;!lP6hfLFDxDLrGIQqe@3*3)_;ajroNS33_;|sb5&>K_Xtyjsa zfwGnf;va4fwi_AvL$89?p9|WZl+kW(X3L?O)oF#*6M_v8(&a$oUZ5Ht(2fE97QjHk z_6Rh#fm#LwEk^^b#{!MfLbVdm@(@*BYx3gYxrB~0#3hEflPHsjm`B(v0(wiiQ>eK| zs2(EZF0y)ac|K9D*Tdtha2y}*_rrY{t(s(J@4%vl#b#ne7)AtjR3UFG)TnIrn}uzo zf^8cHnxg}4>KMzP>;7{V(qOy0823;8Fx{BXkjs^$~s?f!A#IwE2ypPfQI4^{g3R0r?Fx_6=&i zK$;pze+8<4o6UuwmI`8w8C?LbW2BP}ZD(>c!JA-AqPa7uqbU6WDV-!$ONxzS6Vn5g zs{4|v>l4$7Vs*Hfo}==ApmrCiJqW75728{h^;2T~hs5?xiS_+LJ}{x)jVR+KJS%cs z1^trPJib!%?kZImrNqHW++E^M5}T6mWb#E!u?5855dUL(u!S|vSPX34L*%y!YzpIi zglEFM9Kl}^+8x1Dh?oY)lXU5VsK>G7zoC?KQR+Kg>g!zmD@u$(X3r5$zJO@Oi{<{TK^-De`

h^zC+C${lLLm&uO`7}cF{no3t&lg)lWwJq6LTiCK&Jttya$}fRh%&IO9RRcnemqVTHw0IAw^Kh&4Ag4b*jP!>@RdbZsq@qc-rh%=K zi285z@81*u9V+~`7ugyD=AmT%)XXB;0paHHVA_YMh7jp` zTFcNpgrS3IEo8(#vNub{jTP~3CCshFovRcNRLO5tDSk-F$E6hCCY3Exs#i$LE2M-6 zm2?49I-KGlNP9ueYry8#RO&{h-IDM^Qob#vdYDps52`Lud7jK;!S)kidk)yn!QblO z|K19=CYj|St6XR014FI;g=K0HJ}lyOS!s)`DwR}y8>#VHNu9csM#uQ*&^$NGuhGn{ zXynJ;$S)%0E0EgPTJ@D+?ghq?q>oDSTPekDNwH&+Cnqq=_)ro5OeIcI!K_rOUdh#U zf=)<6|3nX}$R{glw@Ui4Qu?aF^ln0Pe1(qD$sL2_PKVPSZxD^wfX2Vg=1XRC<8ZZ% zLBYj@-=MW5n2txqd)UA@bd+Iiwnwm0UyZ8FV5L);^fAO;K^#d@Us_v;CK%9xi-!>yeC-pHt{!t_Yk;+<|x`%(q(CQ;gg8p zCpcPD9IYSIO3VCpaYTI?{rgsAt3Q}O1o5@vgF(y-1TJWFcd zCgwtwzY_j05l4~npjDor^5YQ3Q5r{iU62!uv<*;o1JZf`F9g#AR&xobj_Z*+KVU7k zr`36GsMA%U#sfh<6pHa6K7`_5OyzG#aRe(5WI`vTcpA)CL1h-{EkWOl#J7-|yIUQ- zovH(@jt2@C8yD=jvY_+1nVnzE>^Lf`V@_7p%BpTH)X4$O0x-(Zd?TG~`nLanF&rIe zTx>UgCz_uE9TVY>72w8IaN`_UTM%huna_%NUWkU6r&Fz0$-ElC6HF8%F0$jBg18}o z#RGWS^7}}roZKu4OO=#fwbB%;8cbROR+i8@i#dX+f8V%i`{rzWbis6SA#A61T|$_Y^3n5mwSRQIUV z9#tt1s?@$+tX~%EJ;Zv7=p#tCL~NCm?ntbTsZ!cLB@9gonuEq43~(@Oq4-%UY5?2;j)lXmO^Qb zb;)PBl;L*%4X$qh+Ed}u$G}vhTw>%8job*tmw|F$IC_TTyg=UHD7yzdGEioRTkjRO zPKju*RJ^c{%Wpri{PvB?Z)dW!e^$v4tJE`6uAfl$Rw?36xn4lFphX78O=UhPcl;zb zFQc3H5!HEM>I`yUu{u*~?8DTtJk^*)XAjcuJDr5%ZPO!s%lBTeAKNs9yluR}ihk$XtAVnz zNAmEZGQO~!6pSxTUkLefq_hqa1|yaKS^0FU99Gy~tEk>Cvn-w&OBHHdu-eLKj50c{ zXLOnuZd@FZE-p^}iyN;MrfY$8q{yWOd@kTvnoG;PMZt$t;086Ql74I?{-sLX zuaUTNN<1u8n5R^ZNs8%7!KD1DeR9qvO-z+d%nEsvb|(H-P1IFs76KRr1Z1@LWc|XUpXfMP5e5>!gwZyZ%xo@YG+r{&5CCV=aXcLd68Jln_C`ZTxFf%gX8s(Fx)&SuC{{Qh z759eR1B!m8w=!`U=>9}mnr@v#wEB|yekcw@idjzimr(1@Q0vQ*>fej<_?%*gS{z!$ znI=y%v`#p!5N_TX?sQf}bBLpPlC3TXcY%EZqH(*UxwlKTnoIgDN;M=R^$a(DEl9To zw65tZ!16W}!-&|Fimj#CHihX#fBq07*naRFZI{#M{VfU9#GM&~Icc zNtVqZ4v?z8DOGn+)v^*#S=75Iy-EKDa$eB4m|i@R_D8~Boysmwsx`c9f9*0o|qiZF=8jWyaxY13Gw^7F2C*MlDDf^>K%!N z!^!&9K;EB-s|6klkDC$F^OsC_viaZ%kcN&eOh2|Lv)k_At z0j+(B`huXYF}1tJtxW6>@&fmT zMnr zd`iRsFdswdbc*93K1^{jF>Nk3CPMDIXfVy68F{A3KOm~RN&MaL(u=UYn1tY0fF6RY zAw)V~z>T)AAmVP7a&$2E5w!!6dLnR|jlmIIdlA_&UkjBd;4%+W{m#Lhj#%`OJEgMBR6I17xo;osi3%aV5VaI|)#TX!r%jh5XQWj_@^no8WLQooW) zoWkObs5k+L;|N>_c$+}H70&ku%44Az7{r62_`xMEwD?h2(~9%S8N39n);Bxu3wTc< z%_AG<5}n^9tKnqh9B{Fh%xcIYP*dkOh{mm=7bKRmgfd@<6JQQ9uvVCtg`4NWjc-j% zH9d~tk3c%c;F+*afOW2;yot!85M>sKl^|ba)~7<{b*p(i5}pY9hJrXh81ELQj|z2F zz=xR~bBO9wvat@)@f^{-iqU)#uBN~o0QwLh)&j~-K%V^nXNO-vt!>~9BSru|h{PBw z{UA05C8doLy}S@Z6M2dhD~TQeU^g4xZFMu#8$s?!aTpoBKrTn}OzOXPQ|)EISj&uk z%<^Wi{WAIchh*zCGG9P&2T;cvI?t?D2IEqoy#x@SQk+dUj;GUS1U3@lJ_6eim`U<6 z5UWD$ZB-vwX(k#mn~nB+s`O_!>OM*J>sA>JR^mF#mET*txFBGPlt9fvybgq`+)QWw%&0Xj3RWs9*vcDjMcR{*iH5krV- zE~x)OdIxIGh1i!WJ5pW+KtDLI3DkQnDyY|!0KW<7PEuVM)nhbI2I`j-?Js22aE?1MP>6g7yp!~wsm7LK8XnB`p~R)?`U+1Q0h4-x4-qWS{JU0@EP zI_6W&SIFiXK&QRoY7+uy0Oe>f9S(H-oz^Zy`zDCHnz29F9!@Vj8Ll5y;iikob@?9= zIGL;t2h$N&bGgEf&kCC_Wmmlmba_TBSyCQa!1n{yTH(~ExEdR|8g22BQpb5I=OY#I zzTk;sb1fpjkWddZ%0(uRGa9Rl%{fNZF98?9Wf?NI4|%hYS5Wc?7JHd#KA_#;a;n33 zMQCGF`xkqSuvaWL&=fVjc%rXUXh*+1Ye;XJXRex*d- zG*G|oQg(#VC!$med-uzn7z%jOAq9D3rTsuM6TkF<%yFj{xfdRC`Y7 z_Z^siyF$uaiup+)HiG$Qg7=ep239w_x`b3OLcb6gPsSKXKU??`^3M>45Y;Xu#t_w7 zM1H_%eFeBLSU$0;(J&Vn{v3$A;5-EMbs&BLxiO(#1oi-86PWKAI3#(27&nqAik#m_X48c z9Dy4d^~H!hR)w3YR6i=Wzf~#YnPU%?`Zbo;(<!i4$$uOyq^@MgHDu@cU}G~9&s1o< zB32_4yda@`Aah-z@iLhmakwkj)-s^(kDf2Ug3Oja>|# zVKm+{(mh114(BOwy3popcDV$|vw@fg@mQidO^g{zycnRurOAj@@-ISJ!s+InCint>k+`J3X@n7Xm(-d5j>Hybz2_;aC&aT#!9L z|I5tJ19e{@j{@R-Anr3T+QwZ*bTP_CfM0~l(NI|#Dz|}gz7fUbF#tX^(-xt|`~rMf zT-GXxn+y105grft`~Xfj>K@_rh|S@4b+8=+;IbNB4@#~tkvS4>tN>Tf+10f`ngeqH z;dcd}VEB;)KVin1W_d`JQe)#;8B5O8zhvJ)e-4rhO#h_rE*-GrXWRgD5Woc|esS z96CbrHJ$b!TTv}C~+>xCqXU+rx!rGQ?a+Vke5PFzVy&&bC=;|b!tHS;j;4~8RNelzI zEugPS98Y>4p<}^nJXp;EVsjw+fN21Lxj-HZVv3z_40=nU3`OAYAT}ep8pUg5FDGLO zz!$>)($=i7PeQ~8HkP!tXGG(S64+hFUJ2<^MAh3WKSK2xR6PT!ya(cKD?M)b?QnUY z_AuJ-!FmUXo^X8*P@bjR-@)ypQ9Kp79L-$zWbp_UKdKzpvTnW1I<8^HEEdmXD>tyY4O{M&KtoTW9T)b8eNzU22vj=^|hM2N{ycr|FjSM z$ANIVh-f?rcDzldo{2gH)KC$_1a2>Lo|odosNRj zV}W`^p#6D(Cl~X(fcAqqTjpv)UT@LX*6e0fj~7&z1vw%Z`(|;IEPa_-?Nyw%2sds3 zs*S+Lsbq6KK-(MaYF4w&#@7Zn3TT>9X2azWqr7HRw*qk~z?nwA6HNc4nlBQ(gDECa z?#mRR}Od`!I!cx$o@ zrrN(VVGmT%4=IKr#Rf>NyP-T8isgv>Uq$&CC*r4Aw7$-qGM%!L)l}^ZmlKL$Rk7b9y1K3G%}L9yjt9j>ZjkbAy6BH6nUA@BzZN zDB?Oqj6&fAMfDR)bpt~OE!v`W30+-Iq@_tr0OB;D{x_K3wYV&#O(`9!q@_}-rc1sf zsXaq*7oj?BQL2R%Q82=lHgWAsoiPng_k)}OX{=f93$%K|?U{)7p`m#h~*Es}g%1?@uf6jpc?LSLX>)yU%zF(yU%vC8!iiF`Jh znPo~LvbRpgZbms$ z&UeezWVyLKQLO{`X0v=9s@@3kVGHj->I!OI0N)}oiNbmWpQqy<(*2o6E@C3V@4YaRODT3_3l5z*`Pqg~)p%uq#8iAYvINFV%^=GiX1*G5FOkO*)deCp7xSS+If>BEWTQWsjs@@u5WgB_3eXr0HZKKuhZ%G1 z>HtP{C+NGWm@K7NsdTDPy_H-Ik>eBqTLL)R!P9Bo?7%=5tP-KspAKo<-;WaQYf{Upv;O`6*mBWYljm%GECA1JwCO z)qX~Gc~f=yp6&b!ve!Z307TUn$QJ^o7Xr6}z_d9eHrbi5IEcT{aCn6v(qEtIKuE2a2!hDbb&V}V+Y$m$~?JP zYX_>0vpJ}s^ejNn46YX7tHEkjqdL_{eT~MZf#w9Gv5%293Ui$RUJ1r2M!w1B#$+4; zXfL374bb=w%x8hsrBugfG9M!2RwhnoiszUxkZKI0G(*5mBGwl;2k>Y(`q+5h=BEK~ zLE#!OJ^~ls57gsGpGM#n3d=3(Q}A#ktm+j1QYz0X<*5{w z)&$~Hy3B()c#(0>2Lo{`z{f!SiHdnlWe!rF1Nj;&zYTg7v%R^M&jMo{fl(0p5qO!v z+C;1`=0nXq+RP&mSc#G5k)6&aG?*+Gi?LK$ z;fYbop-%1YcB_}sno(G;k5qPdYX1$XJRo7?P(8#bcNlyym}UgqR|gus3pBeJ4;1S2 zLOoF6V*|Q10{=0p368RDVH_RC0tQz=;ls)ri;~u1Ne8Q>OIf%siVj9JhX<+?gXsWL zYk-(;d9QNbEGB6xZ!||y~xgxRMr$T(1?EP8V-x7K%qPmDt-2{3cv-GNzwHM`|?byKJ zmx1Qx;p*Tb|2gEB0nZ~bU*umL`NoR%+mKfh>LZgqS>_W&tN`*(lTU-q#{k|1aDc(R z4U7cwp^ZO+zRt|Mn^+5ov8Io(VlAeQt1W+J`a>fhXq4N{*2ad9CDK7)83=nY;1|I7 zfOHp=e*wz&h`fsBEgg8;*7G(l3G?1!Ka^3%WNM3AF}G%UDgzf~@YDj|VaI#44@|^q z05^-!8AzTP1>HljQy9BJaj;Up*eT8p@~%Wrs$9Oay$4+Og|RZMbpdTi;bW*e-@+Kn z7bV7PB1Y2Q3@F|0Jl@LN6vubra)qH=EO#->nGkoNsu!(lf3tC*iI2=YNsjR_RyA;a z*dxQ`v~c@CqwYca36fK29|gwRM1C}oUjWK1MBD{?I2a$oSQ5Z=1lBY$1msF!{Dmk7 z!{rQw&u7HZ3?9bteA;`^Wu9DqBGNdb>_nA~hF$mVO|EO zL%=+NY+Xmz&j8%kj-iay8*Xey=Pq(grpwE8S)Q)D)8$x#%Q4dJMCmD(l?gsfc}>{s z(s?Xh#t}GH(4~a?0F5yK9|iK?>DYzVT?Cc`>VaUZE8sq)_9v=+L>(>EFD2$H#q`6CMjs&U zg}@qcOhKgU>HH#M;qoZ0w^{OXt~n63W}zK#p+t-b4R4AKU2D$YMdi3_KUFi`$F27 zZVm_1kwEMVYA?%o8Q#E118w~Y;n^0CMuA{$M5v1f@m7Uqu;vf@8yICY_63_a1I@>b=F&!UT{Ar! zPHP9M?*r+<0B;Y(ZGrN#;kymKVd8T$|6-M1w!THGo(FM0pixxnN2O(%_-`d_LDhFi zd{nGH5Sq6Oe1`DeFjg_VMxdNal-ZDfG0SCU>lC}}DPVH~kC0fGDV9SjTO#FoRvf0} z7n%G5g>Ixb0P73j*xF2!0yrcb7aNUT%rwsQGDi6b3I?_g7J-kzuMJ?0Za?VhCz-EV0s{39L#qV$IT`1RAf&xITPkKDBOyL3smr9 z%Dy}m9M6KE8F86`!z8{CNvk5N$88U^d5hVYWpx@7Nz<9qI3|3@%KITjPbzLA%RsR4 z9GyONq+Tc<2E_xEyHmQ(rMVrVy20j6K$#7+uOu2<0IiW`qbC&iIC+j!?2Y7~DfC9F zpH0fWrQ9naHmr=B8s2^XJVikTL%1ig6>LaTq%?<#Kz}jb0@IuYSy2H-8blsjCdT3 zuRt7QrY(WSLzKe*iL>W$(1$5q&Zv9nJ zx^R(U@G}rE((xc&zGLK`fR+H++ks1==n1n2%)9A$7xr;9RzdJ7QABM=*DR%S}|?kj7!`#P}vnW#^J^Sua+W?@f8^jFj~?ee{-6U?+ER4tEG z<{;vBD9;1S&SbfX_G)wfV~5Z1t{$g82@_}dEpz#?T4AuF04Bp$TnAC z_ID^g8z>{K{EJiE9tpQncsG$Z32FNT^{K$0Dr;_X;}^N{l)xp(cnR`-AQnJc5p1kU zrZ1_EyQNOQDDmy2j^m}~r9`LO>9i5iSP}5HcG|~ae>3+Aa)?pwX=8!G?+|4yS;m2_ z6^ZI3v9TjjUMD-B4(3gW-;aV@8`?f1fEAPZctmWdzz!jAQ=+wl!`-9k`=s=isHX*P zEb>M$y$k99qj9y+aVODn3)%S6;Nt;Y6ySjcSg+7K2k>2>THnSJcK$NJfdRc{d6bj0M|{2q{>vD)WY`I2D1 z0*K*2d~IVD+9OGBrlgH5O|&@2@~feA6GOcQyQr;m^#nh8a)U@ud|# z!m$CO9Kk64ES)Rl9p&o&R6JIUVTs&R)}gef6Pyd<76d**q$?23YZ1+*T+&7;Ri|*{ zh{AL@R2@w={t0PQ!%ro|9tnN~%!d*6M`C%F!XF?VK=O0azml;A9ml%(nW*tjPSwvP zbzI@9d}!w{jC=_YeE?1+^$L`hg34Km{=x8E(1#klLeu~PD*)cZ@T4G~3u((hwQ5)+ zg4K&w^@5pJhOi>(&xx2u7WpN~u_fEzxX0@zQoe`+c z1@vr5)fPyNJ(&0rQhb5rUo7to`8KdQ(dINb-a&F76d#Y|?yS&a;Ze+3fuYY4-jQg` zAsWkw)fCEeAs=Jaw;*9~Bu-N0Ymw^bnEXVNudRrg71+Cq^jMWKzRKy5RIm&qy##Q2 zusj`TOemoz&GfL`(T!1tFfF_h>GxZh{1a5ZCgKjdtj}CuP_g`P38FQROnWl43aj`4 z#-o6*A$h-1T}z_BfX8WV18@z=V+2eR{j%J?j!tJFc#hEiQugYMju$DeM{`Fwbq`~7 zao(S`X6IUvF-gv*H`-xA_imYyawn!uw9 zZ;ujJvc#6*_EZy3m}$pC3>VAYLOBgAr)2r?5cUrF5VO2x`kw~68Mq8AR~dOqvgZey zv%}R*!7{pH`C7n|35|axlv#4e*FxDGh^_$kHGI3lQ3lR4w3(?(jnosUHaE1EfD-~< zf%H{mYz3C_fJfNnL?RzVcy*E81auQ|f#_`r3|i!*&r8U8hLC@hJzMrtIbsrp3kz|Y z$sbLR0eB?9-bBoXTkFG(9)jiodc^Y8gfAxf5fRrBTu<~mgl8GCn-&?!{#2j~;j(gJ zbhWF~$+8t$UInWOX8j_ORtGvBBC!JLzGOL_Y#k)U-9$Bx=C=r4PgW}e=uVdt=+@n2 z{sfW6Lzw6&kC;9I^nr+a7+CfJI08(^fj$XH{r``pvy9fWJi74Sd+z5w2PhPW;AznY zEd&Xapbc6GE(MAPLV!Raf#4oAP^?IBOYk(f6$@J2wFH;1g$l_z?{m-oex(2B@2oXz zuRYgg>+(b{D0&;9S&ZyiljMdZZx!NIA+8qvvLgRa;nNiUE17qa{G-8h>^e_67E5E# zG%rl#*M?RUwLwzXk$z5UzH?#>*uR6(J=5sh1nye_XrF=m$H9Hu*?pto_68@`Ma4uU zpQka2t^);}Wa!(JHbZ(p%k!Fe$ZW@$?HzUwfZKC``U#-Nz_<^N?P0%-`qQbXGp=FV z_d9g!_GHBMzl|du?k&xhI@t)y~BZaYdZ$mxf3$iReFq*FVMLh z%_HsjQ&tWR`lCSpXy^qZpG{~HvY7;Rb^@Dq5@kw)JCnGa$Zdh{9{}y^S@Hi0>9Ro@ zizaz8&EZKMTh0HI+7}XaT8hI=%n50@=|Lv$G;te zP8RZRD&JwWeHrJ_WUs$!#Hg4tYpMwrZD3WK)0o@^!YxGmJGy^ARSt?4-$=SbjGbvtrsET4^AeKp zA-O(M|3YdfByK|GyGVUxX}+|+ZxzcLv6kt}!1^|cD~0x8&^udP2ILA*ybj`TV7>$N z-)ZL%*Y;o8)^WAv6NwxL@H9#f5}X9^AG8jD z;&X?lNpVE5Y-h)|1m6<%bc$D6Is)VikS{~bc9Z1=L0ka%b3@14Uc}}Irj};)*n9j6mLuMpjjsqQqW-UyZXES!(RCDHh4m3%>wH%oO*(T@i5!^k?ch)Wi= zgQHt6XDw5Jcrj5=sPNJtFERYRLgQHR4~WAl9ZB^+2eqRZIfQOMr)Mr6zxdfI$EEWo zTayj#YT#;+TZ8crQa=!7e>ff%c(mXP0)8uq+e(y~g`JT_<+OtGZGb0)+bzT0QczzH z*PFxnj*Jm>ZbH`s?Hq6CA%-t-#HKF1+zmg;QZ{jEj;kg1$>O;jo--q-LLNfmI5Iak zx&w{wfl2S2Y>!WNr&qNHSJpGz=>I;W-7bYAQ<`3>$CLH(8k~`VF&R3>QBFa04x&0I z%+m4lKXPoXj8l~LXrWqQnTPkm% z+V`ODmteOg+r`PeLToP)+xLSxHG~Btz@mC>VRs*~RiJ;2+<%PRuFcFtX>X;PKZomy zaJ~ckx6BOIdKlBAX>U*SNIHHF_G|~vcC@3c0deOH?3SSu9kDioGfDhNp%wEUvAzfT zAs{Er(i!7^!*ddt7xV*AZcpS1L^cHfOO!q3X4kM57V73g_wPhKf7XmoAaDeYzYzWl z=}*D-D5(1t*xkl#N0@b6qr0ow{|3-K3CPhf?}t4Ej_E+>_h6X{HY-9szkxclld*GQ zXWzo!!9~4mNA%nk(YY{6XOv3prN|)+9}eX}E00R@0wXRpx%#Y@ax8Adu0ZD(M9+9S zu9f2q8ULZ{E5yu6z|5h@K4$jUtTQ8P|Crk5L$&6PnfQ~ff5F@osq0}BCm(j={+cba zcK68a-`LsxCTs1>w)=;+GoNLxV==4zcY&(=m~{%# z_aLG^g2orRgAdV(N6_&xYPfRKVE?Azkfvy6iTrKDL;+3|I82C}#hyu0^Ay!AK=y1* z_G~BizEd>&oh4@5szhgIX!bFo-U-3-JsBsM91HpsqihA2NkkbL;01#2mbn14nW2nB zlzD+NKc;<#oR7=7lkBZ%tOQ_gX6^*%ZvYL4bS9OzQhq?fF`$QlT+NIfXA#UpJ@MfHpl`Dv(*Q{Xa%cUN$VB6kaQ2SxO+Ry5;y-8?y_#iOyC=vy|O4DBXL7 zvspH4ImQ`C>%^92jjHB`He!Reu-4EODV~w?K9&!MatAZ7GIFSq+Zee*BG0dE->+(K zscbK*(Y>ImzFs2_L-<(AM+IVhFouVDj_moA9-+#G)Zz$bT&ye;BAe|Zb)eGMDD|N- zrm4n5%$}C+IiF}Ahnq=8b1l&9LX^KyNHVvOunD8w0F{Fg&3~=(`y}s9`rgXCqD6}q z?X4~AORc)UsHK0Dqt4-|S0FGIp*{*bKv<2+{mFVb;Y$HbfH@n?tqpCG)7x!e6oIya?3@pH#%r zk}go-3WbA_&of#v>R%At0Yx{ta6vQ}tp?{t!|6?FvnhQ$Hqo8bs6Db_`(R-{6v&%n zmNNc0GFK#X6v!ihb|JcNqTK#U+5Ne)e>T=Snzj2KvTumd4mSIKOw62K(BNdW_yX?k zP2^5;Sv`{HE6ek>mPM<}eq?+K;%QRvQJN@ndZGUs6}31b0T(>G?~F?S?VN~yvy=sCjSlSBDncjm4_ky4bnq_W@DiD zg*4wwbnj32mdd(stL|x4{nL|mwAnmhm)kRaW+q>Sbu`Gg8F{N%9|P-HxcgPo^U!|J z(YXS(JqhIBjduHV-H@&;16&*6wT53X+7FGoe+3^gym`_ilDH$my8`)f>pU-<6N~dt zC3RvTUk&4=0M~8c^TYUgvDTE!+(O-q@O*$?Fv~?I2PgA-0|yZNw}5SpI>~Ntkn?-d zFOs-aYR@L?XGBh$r3Loq!MrBa{ZQzhL3iIZx-ZOfFvOs6j;V=*x{39X^%0;hOlqN| z|7v(83Qs~l8;V6NJpjc=AU2}BF@*CW?F#B*NLLAYo$ZSOd$1+a=_;;{#2i=@W_AUnEX(+D%ViyqKS~&=T zvk{tNm8*G{Ywh>Af}{8Qp% ziaJ4&`zX4bQ-0F)7`rY3m-he+0otwUSZkJm34=lW$HLpA+3}ZQq~fQE;<5QRYnWeZ$u}bu3&iN7g5h-H(vnd+ENZWHSNo-3jnS%Zcy->R$)W12{z6SdbHuppNOSs-= z)L-YU{>mG$rja_`#^L}^M8?Oa?gGp5K+oS`9b%V>aL=C&PDyw`y4|UwZkohODIJ=s z$C=&~;A;TyC9sB2m#}kdBA+3=IN;+A?_uWc$+~G(civXrCoAi(tMcC_e+BDXFh>J^ z3ig~R_>wLDMEOCgUPtK_0DHq+)Qsm66#aiS}Sv&O@y&0ksZ zoojuO(O!TW`vYYeGvA%15ZC8`z5(zd=pg_OBe^++XNVjqw>vo7!_v6|>_vbaLwHF5 z4{{cU`c^1MTXnEiU$gsuW7KN_tpICFNY63i<8Ws)u{ki={3g)+re+M4IY#ismAugO zb|f~VFa-sNqwp&S{tn?O(Dw_xQOTtv`ITA@WMC*;9N~&pk+F%hoIuB$fTlq>8G#QN zcplOHf#D|^e3zwv3N>Q~!sie^9+?Xfu`FF4qB%c}wV1hVI**}a1ktWX^sgkha|!hZ zqW=e=`xMwepEYA=l=d~S?=-W2pW@P9Xtl2*+sUvV5iy=Dcc<~lESX99Wo74XQ0p?v zZ-w$?5LXoDfB^0bYIoT?k=^?Men#_NT7MC69pGDlI*)-hlXVp!FM->yEu6&A0EM<> z(d8`I8pWqNbUCQ+3I52$8JU^f1=I(~_LG#awJ-+Ml@=aB;4H|GfE-ME8!In@a1O;^ zF}ND()j^&Kdl8tI1I=g3GSJAkWnL~~8?rt^dOpZ!3iUYxhs=WeWvU!khr;^<48X1U4Cjg9_oY+vP!D}i_d)Dm($ z4mF1pJ-@L#C&KL#hW9q}PLPwJ@(MzeDSl4jE()hnp32bNRG9*FZXkRRGWLVZuYvws znEl(4c-P=mXAVi#FB5eipzaRTAz=R5wZ0|#VL}hXu~AAdR>k<1p4tkdtNf7DXPNml z80!P^%l~n@&!_trAUHpvH4V;d;C2|(0E{8?ASe$6>b)dKi`_Sc?lpqX5PUP}S0V3B zaYM@25gspLa}@394%b4H8=}dFR4^g}BSQE;!3QbpA0;j-){lhlErh>7@8Nk*hkIAB<3VQ}3guWEpP6}((Vb>vF}rh=&5!B0J;|vR{4iX; zNb3-x-Ve<2CXlZh-MbAu4|bLZ_&d062zF0_dIpodOMx?=hWrM=V~Ch)lnF%dYD`>0 z`ZCy?5tuH$OB3X8R17?|`}=z%MLc4K}L+vwdvD zmvBt6d*@27+ld_&fb}u%%r60nX4*FD+ zuQ;?$DmJQWAF0BQCKdwt2C3tiu>`1BAnXSEJBYuw{I-QH5IP+yL%^~vScaSNYZDuQ zRKm>6hc zG89MAxL)*c(s>iz_aQy=4!W!-H}@Jo0&Eu{xhfC~TlsZH{VZ$UlJ;GIM#^<=s=Y|+ zjw13_f>XdUInntjp>-roRC+C%JCU9WaS#HN(O^w9{52YXnuQY}Pc*TgfIA{FDJsV+ zbU8!Ivuz(m_4-+J5hw1qV;MLG0QCUMQ>}c)st;53amW{#eHU0Wmp9sVf!qP$SgYrA zsJRQ$5X%R`dGM@s)GyH81)TkN(*29k?eCZ~mNB|#ne}Xk_ei!ECHt2(yBn7*-Q}Hi zfU~|#b2$S0LK;bGd7?88F1OL~5E-L_&5a?QCS(3^ToNpMggf)nb#Hp+$}p$Gevzqb z1g}Hr9Uu=&)+2~Izkydwd}PI{kk(--t1~*wu{2w`@OFeQ1Utvm@qy%xBHM{j9VVA; znRR6(ug~;nwQ`S|yuT%vZ{>Z=+}YAw04KwF571o(&~Ui9h2-jDECBHAL~cj4ZyD_u zM0^I;ZOCqdzRvUpDeR%pG@u@A=VoS}l<>Z3j7#VN6DuV>UlOMzxl%=WkHD=0o{;jJ zfJQ~?-Nt#GQP(DX5)hA&aXnbhH$0s11OR)PT+4wIT-rCR_Qi<&mcoM~w+MNoB0s9& zj*57Pr5s1$76DJnb!xZ{D9)pT+E6IH1fDbVw4@&(>H!s660Qr_o^0dSaD9W({w?V% zEw1T^ZyoW8!xJp5YXo7)s02`rPiB0Oy55{ZQmYMT}P9HptgP z*Z|ZWO2zDw%CsPPcd zSlyh9fTNjZb)jx8_rEJ^LRz0C+G(b* z0OBHLy9AMok=m8y#-g_u{mWS}F0TRjV1{oew5l=(D0~|lKZ*vkqrtz};Gihps}tCx zAvSBkTZ`)zA?!}-NU|A0be=SO{%iNnY0SB*vEa(^ygvYQ547i6&Ypdn%+7g9K9IoU zbRIRExr8hOA$&;WVMO~22rEK) zEfs$tu%(36NUSPqM^gI{Gxw(Zj$p7YruV*0KS!oXMwm6jC0^-N2uqQVDG_j^J$`No9>*N=3y0eqh$B%*7>&O$>czmIExkYn3e>sQD2|Q$C5{QowTo}qVL9RlS(*WEH`+b^|WUd6~ zuC&JkxCM$oK-|rdqcgheFw1eEt|8lJ#JnY>2gPP_G9~~TWMDvrf26S?$d3SzCGidd zkE7uVXt+5#-rWrcvfxw(P6e@tfHNZTXH{<)!F8y53Zw4=)OMt6?vS;8DHChkycMXw z1nT-`ZV%>4Wc#jA{|@$@WpoFd{X3`Y+{yB|RX$AByBIu!$sLfK-}b?F-}Uy40nGny zgzQd1b_c>U1_0gFOud}S8!Pk4mfbOx{nJZT|IlO(vD#0NK8ENW3u=;B)&OEbm?Ohn zFkB8SjwMTSy6C$FJt{Vv(&ag38HJ2}oXvvB`aGR4(|nQiLSWs~@PifH-i+0fT-GYb zA!2VTPDW@KsM!MQebFjUg7FDarU!g-8Uqvgt8ku2cgHz-wrjbewmi93kFMr0Gu{R3 zWdtrJIKarc!8{Ob4ki32kzW|`Ccr(3cois*)4Gf1I2c#cc+J2t%d2G6^MPE>^hZvd zp5V|RUJ2qbgVPBNs=yc^=dH*e4d0j4Efv0zz~3b=)G$WSct`eHLitF>3Pd~yat<*c z7xHSL&JN_&4u9<^@1uACiaurVO{rZd6pJYG(+JP4h~pVOV@ORSb2YhrKC%uCwG|O&4R#qLBsFbo(IgusCufyZ#wvb1MfQcYD&Mb$`XlKtj;3yJp}r% z6z8S1HG~r(3^C(wKxaA2*G_I_wo4)TCXjPb-Is&DjKsJAmL_5p9m^0NCwGsO>y>o- zOSnD&H+#UbJM7Qt`g?(|h&qhKXQU@n^>~n*TlgfEe<8Ifp(_b|KwuNN9Y{B$Nd8;k z-$`Fe;Isb~1MdaO4?>q(1c!%&qB=4ep6oFL;uSj|n z;X4IfCDn};-jfBFpmKmr+0P2%z56g;eQ`{<% zr}GcM0d>D!SGVhS2yBS(odEU(>qyw60SyE7C8%DoZxOgX6TmJ6Pefv4 zu`DBc_h20-;uuOxF!V4~e+kwjjl4cl*G_aFt>Avi+{4oDmM^pLD#-C5Rsr*RBHt$J z>p(q_@Ij#OwRIc7L0~y}*1^=Bn8@dWb^_ep7Uptvxr8WZiaiHVy&nO+Ip7-s{1+srqt z_BjZ{DNZ4^Cf%-0)VGwm2-Cxvy1~XyHU_3+5Ycm>Sq@8;Zz*1%!o}%2Jgq&`_#qJ& zRdntJIvc>vjWAzk@?m72Na%W?IRNN6)abc6-MP7<_g1raae|Kk*vjs1RKZa-e0rBT zrCaLwwyCGLrTbtT?L}6ZM#KupxEgI74z^Q?dLE45B6SHOw}tA~X5Av)T`0k$lUm&5 zcnkkR>J0?nhcwXaTnv z%3{1K;|^8b$1K05<0B#tAY&UU=R?%X5I8p@##P1smKsFoXJ~pqbkj3`mY%D!%r>#c z>?c(u_i(% zAn=@n-$Q?|Sl<8uAOJ~3K~&t+Mcb?3za==WM79y_O%d(%2+kfQ&QQd~5t>8c1H|^k zQ2$E7c2wAx2TY-^C)fL#?fS_2Ju(k~>$#}ig^~47L|un!cTr@p)ZG<4TA@)2foe`7 z=NJslF)z>@m5d<{?`Yu#tNi2=|3>I$D2|6ZgTXS`;EA>mO1M9nzc=gIV)w96_tIc@ zT%dbSpnJ63y;{x-X^vnbXgp1GP8xrpIauHhV(cI`&r&gxs_&9{8s+hzM}t`Ee>mLd z0X+xcG9voJoe#pz{BjHmbdD2yP7#|^gYld~dq?2tC^|Djr-k@vL_9>5@5ng)e{tqk zW=u(P-?VSCJqKN%5W3e2?M;NvCjA?;USf8SH2V)R>p@8@VsMh7P1AZO&10)|eg#Ig z@WYjLM0FjS&Z|rtjHwVOlR1>CFGAH&dn-8OU*ODjjK2Ta-JhGD1bUd5&lKjxg|S;< zXGRd$N%^JZT__(D%=d%XtpQJNki!~z?^3*8X>d?97+D&eQ3}pzO0#wo`n(hQL`QnG zQL|)W(*%1a27C4ZdL~1&|28$dQ*(C{^WA35`wB467QoM5BzmqUn~7vR3Fs=jxyNY! zX*2`P&I4BGUZ^Yjx1(%ajbtC)?11dumzeD+VzxifosH<(PJ-t+6z=^tQ7%k3pI2-D3Ov`s54ZAZ zHS+e9|B(W$9Awpn%yu`U?rr#%N;Os7HI>)3;Z1AQKc{l34E|_gJkkBHSpOZFvn#Q= zl1r)Te6^jI(KapG&O~JAOJwIX)aEo~8BS&!7ekL%`|53pr}3PmKx`UO!Aqn7r122Gr?4l4O%d2#4GvLS%Lg#CfcFGv z?iu=NP-x~lq3)<)-#5aHRl)xMn)xxPR>W&Xb(IqNa*6JaiWze-{?m*2>0i{$aZvYe zuucJNBX6_)PiMYqx4UM}*Z?_WOVt?{tM+x7{WrngA7M9kSJnT1tHn?KUH9GBy8nz) zF=KrL7XW1-P`?5CM-ctb)Ae-%ZxcL0;Dp9nwQ+pixLh07C`l&}<$NO#NY^2me4%Du zQ=u^?uZ7xS4y=ao0aiXm@=hU^N%oAidVdG?HfGOsvw17oyq_#Lr*t6-zhh{ul~y6n@H>)*0O>wBQz1lCx%WmbZ`P!RB#8nyaP0g%4M{& z9H?4$V8+(A4ozrK=0ca$;^E_z<8i-Auayv@<9YsC{(XFAyPk3@NjjO7R|LwX~U3rjK0jFl@{HGKzu*>NX z<|W%bNv{U=Ka|MN4BeC{&pBfSSQEtffQfHd`xhg%8IxPk-36F47e{udxvd8o^?f7X zv2$M1n}E5ZkUI&T2|&;LK&)u;BCs6@_8%PZr~n@bX>37zn9yC6f#D2{L|{(_=3)3G zg^nnS%ZqqTusl}W^J1{MLx_!u-VKs-oX}?PHFR?bYIB9#=AvvnUuN60Idb-&=-3U= zWE(dpaBna+4d^&AhEx2C$b)K}qpHi6%X zx{2tV4Rj`?H8{b|s>|Dn=5V{+#b~D|bWyc7Yf-Ogh4os-Yt`{ZS_fwO;ac%h3yo-5 zm#?aOSLMU0c3dXT%ghIA<_A@{HQgScs2>>Jxq+G25cNz!*95U>QCuIPU8T4L>e*nt2g106jvoNuYu3lC`m!T8m7BfgI4RNxm#U9L`lz7pBh}rg?khxn$Idf} z&bxFh4rmPpsWb#s;W)0f;-Qnzv-{7xEgx+*9nXMfGnF^$$h#jjHS(NN_UH-OAC9$ZR)M^uMlX zE@t9g#ZT)p`&NhQdsZH2F@~J93>EbV0 zViF>@lyX&wBgN((WA+i1vtOUlnP&D}WpS*e3a=-5Nl^F0^+`BZ zAapiZKTYP<6|r8RY?to5UR~CsIY!W`w$2605THIm_Rk~n!4S@jz>6WCqrj0OE*Ja9 z2J2ZtuN2^&f+h%YC!zZY>`T;Z==v8Jt08l9+uOn(33qR&+wWw*M)G_H-$98B5plKx zFJ;76R;-dLUs}yBq}C#RE8vNQ=a=GeirXeJhQiXRSP#TqcD<1F;*j@qttT4oD4>2% zx5p9nQlb3~(SAzgZiJ5qd^-_`0^AAELq>Bikefgl2w(+*V@S+Lw!aqqN0R#k`2m0> zZ4VXNad2!6_}6eQXX|(o8wh#4*xf?NaX@@R^qfjIOOc)5QCfoJRRUHQ^b3Lu1Kb^` zV}X1Uz=E0nYtlcMJPwGVOg?DqM>uve;%FkL*|{u`(?IQKbe05~s|@@(p@kEE*7DMj zJ_a-%h=q*!)b=n$|I2c-fXUlf+Y`wg$J(w!<+8}WeW>nHs<}o0Oa4DgcmDYGnEikJ z@i^ytzFzNQtfOJpG9`4}JfP>zs4l?gCE_XfH**8Bqq4c}D`X4E86$?f_D+fDRMv4$>ZWl(Q>f zaWd=T@)4Myq=_y!=J1AR0s^`zNJM*j`z18I5)%=?0|zTk&I)#e4U zw!rnldT${ng~g^t@v0HW!)zX9-;g?h;?|n% z7Q-{k2S6-FV10?Fn5-AWdP;VcVE0LOrNn^|SSU5O48<{wbgrVDLd8TOT>!Qn4mM7K zHGY9Lzag9FfW9{AV=3RnLK7MIfW#jKJSxViqK*|}OCT-~V>_`7mF2Z$XwQ1 zGV5(?YxK(A?3}G0SgdSXEY26>^g!F5hW4YV*4ZrRMN}K1j)ZY5?#J>CFzyfX za~ZBK&>N-X&k8U+2Zt8JMPcpV2|kA^ms!+ny8Jp1JCQ2miTV*y--q#iI5#qBh({dn zhO^x;#u0xq=EL3E|4Q;e(9VbISE>3Apt(QLb}fZ*L97wRc`!{E@!ksQ7V|}HV$^mZ zwi3M)>*j4`Q)IA>f64Zr2Yrjx^8dQG`^3Mp~=gJQfv8i$S=Wfd;nJw!BTfP9c z>}j#yF&Kk0Fjv+(L7^GJxX@X;xiwyOS69TcQ)$aLh1XB0l%I-~-iTOFtPd*4s}{uP zMR{q7<U0^g$}=ndW_A^AS0_}19o72= zK1JvPDK-g|7B6j zNLciZRKHzPbY&{vhQ;5ESZwk!Cf~+rms;_?0e=Uowh)@{fx3oFe>Rqjy!f#uKZsH8 z7PUR4X#_?9+=tR|leTl|S`U0_5z`nNF2q{Kj}=of*uIi*J=TMGH%pe+#NjR4yVFu`RX3%)sofs(JY;>Ey? z3H#N6nQj_U8TwSTE0X1H6ZLa4?U2Yl655YQ$mb-)LQ~8z#I;mh4&kp7=K<&e#UCYo zkI*7T?uuw_X3A4VeIkpEkhm$5?`-Z}<-9)3o(aPn#jvql&jfQ%S~=0+yFfa@$-8AZ zDBS*Rj`y=^kcfAscqw4B5S$IGr=hey2I^<1JQm99L-mV9K7i6BD&7F_S3q-#*0y3j zl9ulamaBkzhLQIgFw4X@9JtHi4^s9B5c>l5oMhvJ{0JzYN#&nJOe5MpH>7TEd8k2M zjd3Mm`-987lZ{QuvLVSGNz6BL10vp|VrPi`5bP{!45SSN93IefB7PzKhmhS&;i>=! z7^(}U`VdLI1>G0q&O+KEfNqj@F2W6g@>Q4~MdEje>J-xdz>>dU@Oqj}X5s=Xcml-g zEO>{={ixOeF!wa&SAcjx(0UH-D3slR_M?fILTFRMA0n_ZR9+GA0Koml^c>MxEwRi^ zh)pVT7pH${=07vFpTU$zT0&<_zL`0;hT}7mPnlH@7&`Q%R{ELNwi#h_Vbw`g+vbM0 zk&KmJvsme5WAnL!>M(&LgzA>a)ng%Bvk-rG^QYy_MPTX$!_QzmPL{X8>c{}s5$y%Z zR|VoG0An&RM63@ls)ri$H%8wJXr52DpJ!xG0%Hj~9B5n+XkHPh{}IARQrskzsUo@t zd_fT7MSd^fGpX(tz*j}STTOJ!$}iPuJyWX;%(8!F#dSIS$jo$59qH6ue0+i5FJd-; z+X#CF;1FZ{-N*$-K5yoG(byl1Ib!pSfW1`YZx_XN8P%SIT|xLFS~bzALC$)jn+-MN zNdS)q>|IfZIPjD!U4XFLA-hT7(IH-4!aj;f-$~UtM7j=N7Ht4%3W3!D>ke^MgpOcQCj{O?a4=MTAXQ(GzJ)BEAXM8?_8pb_MKlM} zt7jwgQjq-s9xU4Bu(UZmJ;A_RG%X3F$Bb!rsrjkYxLK?gGVEzY?17TsP}u!NrE8J> zwg!7;+KrjkCo>&USnXa|?H){zh}auQ$A+4317!#mLlFKYz^xSOjNr>~Tc4hW!1Xyi zZWqw001s!C7jpQ*BL1&LnHwx!h;pZ?y^o1~OzB`lk(= z&g0x;v7x@l*#4Gr*>qa;Cej*$-$3SH2yE~0&kL$61MCzQ8;N`%h&2S<6i|1G#}GJ> z;6?=dnsGFVz1>>-Smd4-x{@U}mCEV#ay}FTKu&e5t{3<=P!7e@atE=|IU=! z`v=Nc0Xu~>RMI$sy@mF7KbKSnD}iYgcgjRI&XCL4Cyfm0kYGV2wiVm#JP;}HwAj4 zU>y{Gpolp{zS)%ik)W$x(aRKj6S1p+r9^8rpgv2;>pHb%w%C)1sRpg=hQ)I10*miq z%Ll=ti(r!jc8Qt3a^i84Gec>^5MF_755oRNmiNItd_~q0A4xn};&?>0F~mJ79^xv$ zPrx3P>CuY(sbcO|QA;Yuf`l|WF^)=T-=R{zGN}wP#L`B3&59)7qKB3UghhsOn-Y?d=l(a5R9_mV45gI8& z*GM)mJNm)=bfJ75(%XO?C9@e|oCW5K5cx6yLlL}3&@Cb^m-rck$q<$hcv{3!Vmu?( z4};5gAgv3Fl{z}+OgkFc@5QS|Sv|E4}CgCq3d=^xv06r)1isb(WtcOsY zBxrLe))6>0fVB%^WI^m1;KoH9Rult+`FUA+jMP{&es08OhTO%X-h$GtfOaDCPDHs4 zDkFisE>wO?mK~^g9LU=PID*zIlM{yN_>kGV!@Wql1B>iPa8SAF) zoxZtyxyDlap_ZyGnOeO(;Yv$b&nzw>(^9c<8qu~P(QzQv@nooZidbz=HqHRrW&kVS z&sgOPmX+Q!w2gN8o*^3q`Sws_i2`4N^->xB09Fsl8jEE594s?r_9n>v1b!Lf#-g5v z>|ud73mhBb9}K#PDjS;083Z<@_%DO)WyEkG1_4|JXuK6jw*)u`;#*>Mi@={m8!3y) zFkDaSKSVtaD8CV^1A_5Q=C2ED=4)!Ct!p(-%Mm*lYC;A+$xKHUG=Cpxo-1PyP@QT1 zCYdfZ@>W{<&^&!$^uHOo9m$hG?k`|+fFBlNnyER;kOq;QV)SWdI^Stq8E^)Hmqi>U z;k5*fkgQLraWiF05ZnXek`Q+&@--E_SfPJXz9kg1h;lhtzK50ngIOnfa}RjqE_ixW zR_zF;j|E<$(D|S~5$r~RuSwiR#55W24cdD`zDLvsB8LZYNU&TIrtO0mD{>luFNpYz zDkn0^#Y9YpY!s*)C|$s?I}r9ELqiZgSE}|St8Im98mxIAP+bA9dMeUPne~(NC0Tk= zOcw^R1`SWicr9czX4vMBds6EjUoOLiqk`RuaNzife*7ZFN=LM zxI+W`+C;!9D_Ps?kq^)rSG`T#(O(;lgb3 zW~Ozmp~H&sPetirYJb`S-vQMQfDQ#p4?;T;_>#0&q{eK*COiFnXS&>&9ygE6h2(ta1mY91%oW>T7nW@UEZbLTe<;8&1NEq)Hv>$o4I)-PAL?)n)M1gU?Kwx|EmvcJqp^=6{ma;xWAfu6bdqv+(GDZ+ z?`C$DS^Uww%tWew<5m35Q@w|$<>Tn~fvjzj(BUFO<5no`CRLM)*~MnDGnjjX#lB(s zD;VpEHV)M30;Y+)HJG}RjUi@n2~j@wiX7Y5gs(4WArMr~rm%|@(8Xg8v42c-`f{x1sCtZ04`rdIUl8iwl{ zrn@WC&<5?`ia5?0bCb$e6}4?8?3NUl8e0p9*1BTp6vqBRtXY_E2kLF5`cOrA63l(T z*b0n;VX-sardq-dbUOekEm|?5@#{$*0kE`Z+xF^-4{Gz=8bgD7``i5h0bm`0{UlwcC>siRN1+}eJy;Mu1oR|uw!p!HZD>ey4doGlw+TMK zz`GWdZ?f=ShWZqgErYqgnC~LXNJpILid!9dj;Zd=&|u1^LG~$x9cbEw%6l5~KdC$u zEHj}z4Jc~?t@VV~b}oJ|G_NGR3sp9!a0ldH0oFg1_9xO|Li)^L!<-ss9y^)yB};Ll zrK-DC9rv=-+9XxW?{(KXW?BHIlZ3{ZP_rM@wx6OoL(y0Ww5=kpG*0Z;TUz-kSjU@; z9eO#c2?%>B0;eKkE~DH@=qs_z3$yvbvQ9AG4PrcLYmu4=>aIZfDiE6ocmjYvp}e}G zJWAmQhVC|Lk}2P5YQ1MFg9LU7*lfbq0(=I@=S4gwVzQ7P2W?UiV`b_C^Gj&9FIf&H z>phKmJWWS{c}Q6MfWq=(4gRfGSv5zD%t&7s@y9~zQCQs~YrGAld(F5D3_HtgXIeVa ztg#x+#?!Da$r z>QPsc8B<{2=1pypCf!OrIAFV3lLuet=qx&Ek(QvOCQUs1@QEFc>0XS{$gAZ z;?f{z2l?LsUk~E;kRA;1t{^`SYRL+!x||}G2Z9(BwBE&Ho1onrwCg3DD8-+pd@oAu z4B;*ce+K+AAbvvdGZYL#;h7N6hByJ>6QExQ*ci~yA{%#*X&W%U0OKnWgGGD^;yMs- z(X=)~KZDhSV){r-j|jd=fgc7`bAj|0;XMK0I}{rfVSG_JqXfnl@rEL;9f73^PE*+X zD=Yy&3T(UqGzKYJpD5xoL|G6Khe_2R3+?nkIYiXO6ki4KJ{T8=VXq)QEz}Ezad{># zDbk4$Z$kJzD3}OgV;}~Axf^LGkhTgCvx%5!()%v1@8Z!$EHcw9L;lFrejCLHDC}+2 zZKm`+VN1w*n9!Og@ckgV2JD*v?keK@S=g}%M*|vWwBH)h(;W|)#p+~hccL|xT7I3Z zeVI^S7*UR8#A}i!8?-f9KS%Nfpmm$H{EmqB*F)|76s@H|o=>%|1!J7RZ6kc7a=P7$ ze;d+`f$~F9eu1io0m~;6|Cu7S_b%d3CCZIi%O=*!f5^g7Ir3jr%5;W(keJ)XnpWD+ zwDNyUt9@u(} zjffs%`AR6~g0WE$eQ5py2u z^NiMyuot0v3Bu2(_#VaSlz(c_Z;g4HL30e+SJY$1*xOl76!DcTpJHeq?TDeGoh!!k zKz~5#}I9t0q%I-<=lv{O~hh9r$=PEF>L9Ws8v{7H~bAtc? zAOJ~3K~%%?ehtf4HyAr5=BWwG$2!_~sicQ0TDL@;>MX-xOO{Lm@fP62g>MPmw5HAxrA%NQ>;#*03MA2)ZxGof@3)mUtLIXZGV6-8& zGiV~9-v#WafZbYzGcxo^VL2eIHB^juxnk$GQ9?c`DevQo56y5Nom()}2WF$C>TRqL z9~V=cN!ih~e7=;=G3Eha`-WovLTvPRYktW{vsm(ni263dS_;31sxAWBPJz;V!f$qq zRo&~ytHR^LqeYP9kMt+g91Zw}KhV)b&+x5&VAwb(sJbyJ|)L*ZW{*pc$Hoo(Nn zwY?l}&&be=&h5&LuWq>~i*gb;n9H<6mm0?g^jL^oQ zItytpAzqJSPo?n17WScqzYf_65M}`J6=dB_zBa?g0GzoZ`o-ZZP$WGTY_1BcrqX;{ zn*AGwiDGmMVT&SNoT2wJVnim_E3#1qIJ6+PEy%|P^H`yb6v}HsOewSp0dx>KP_$85mr!8b8rl@*Gs zu9M;xiQNIe7qCAQ*n#kah~~G1-z3;ol0O*qH6?BVVs*&=8A?4%V0I2Zor5ox$j3z~ z-$aR9RrDDR4*@(%u8j%ZFW~M7yAw*+D)gab*N5z=ppD9~XG8Ibke>p}u3{_|ac)r8 z1-VXG8C?(y0$M`wRD*g*coapO0{J4+?uU6Vu$)20=@156pt}W@n$+8*3yi$qOgm6z zl$G|y4h(Qbe^;ZQfiDp0cVd0AsL4Y9Hc-7%)VMgye#78(2225Tps~E^uF2-Q#vD%o zlR#|08tZQi%QitQdqP;=S&_FasqPV_jFFY!8_Ik`zLTcif#nmWWmgw0f2EXsRtbHe z(7G@j4(LƳ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℞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

Yi2^SGZ6h!TfpHNG zYtU^5+-^qkx6#=8a6Aah-@y29finRNrL-ZEhYPkG!SMhu1$Zi;<7qLB&|p)JP;wB% zF7(t3o*d?^`x|kkv0e$_|EO{+(mzA!ezozLS{|UTuZUi*ZQXJOYuSfUoeQJA9!aws;Pwu@{D$u5!8=E?G{?$qdl&|ZI8@Nl0Dl7Q zPB=b6gG1Q(V%D)~-q=oFe2lp-Y}BTN7NM|=Sy`Fna$viVv2K9SQ$P;sV+z^{WIKe! zUMbE@*xyMG0poU}doLMVk{C|o0W9%2fTsceKw(uR_EYHKl*X!J#i%@m)%Hf%Ac4!u z?MA7&6)0~YW5WRcDDq=78*a#JO}+*b8_~-*WX~vA|EaQO#{h>Uad*J_g}9Mt+^>lJ z5PmR&3wq`wp7F5+)a$++-t!DzkodCWE@Qy@#0Z>0o z=-*V`M#3Hm>=3Z$tD0$%zHFpD705RN?G1t1+opOa0NpnUo1e6g`f~2`O$w(Obbuiz z7jn6hIm*#p+M{kqHHXl!3@p}>VYeh6Pt#7->O02X?+meQQlE*jFC9bax(H@#^^L}3 zLl}0W<>JQp+UVc7_21vDXCa!uYtD^WFcl@9mis-jo;_u@NMBDx=kLaz@uIIzbbc0p z@vyA_`0(;5)$=q;Sx8xL4D~(*)l)O=*7Wu*vU4$^hm3xY=#z~;fYgJezLnuUko$r- z-w>C=bi2$plXYGNJHHjn(}Mk3wBI{H78!3HnsT>Z|?dG|VA(k@mzXtuo zm;=SQOsJOt&FMf{11O&e`It}#LwSZFuP}55QvKec;#H)*j?_2=7E@poRh*-YDXI95 z(3gPDl=!StqZqNBTK$`CT}*Ag0k!^+**R3;hCsayXip_#sEC6=9sp~;5X{`MWCv*f6`x)A=3EpAQJqA4vG-M~o(oMh7u>F8KFwuLj&^ zMT6g-zybsY2+a*bv#Ee31#Kq8aY8OF=oq2wneaUlWrILxY76_QMSRdgueXTByU?%- zTOh#K5^*aKW1t+Jsk<5Y7-{n`%T-XE3)$R&T?E<~xZO-IU-+C$t?-Q%tZrWSHS3OW zs<(hygliqSqNk3sv;#fMyH=ZiUag;1zr|Zy*emz5v`{E#HTUajwh8Iq81ZMC zwqUV?*(oE@H1nV-Z?WMBHVhQ|9o!C(*~1{lf%qBVOMp!V%6PE3O!SjMYzNtyP>f~f z-6k$xQYU-G)urM;CG2j`+{C3lJ++91j<&#>)?y`V0dKjN_u6&dtI?&G$CfVkF0H0p zHR8Pa~|0y-c#>6kzA?Ezp z(Em54{rquoc~JOGDDaY3k^JJg_>#&7sdEV!0kXjPSnGVI^KX^Ir7Q^b_;yT0*x=g-wS+Kr$1X@cR2AMBln@@3}f%M zwAueO)~n1o-aIa$=TLf%WQjNFyp_(;X1c+R|0wQ97PmKw_uS&%e|#xEr4-Iniu!wr zx4qa4?wylp{ho)-c?@l?;p7}6oc;GP_MGYHH`&m$J<+o#(Q^~f^QF{$m?}?(I?skW z7X~;X$u;0URqj*ayc6ahz&H-ZV_@wiu-O-q-HmAR4XL~7J_go20Tu^rCDKRH{0x$p zlXg4JRyOiHV+vKeWNO4_cGeNNB#d>jC`-~VQb-2TBDe!&; zTGF8jPQ7o;0S1yPr&DDu!p=475<`CG%sn0Xqbc{Hv=oDZ-O+UJN_BZ%3%5wi|6%sSC9>u1C4Zw#|f zA=-<8oEyle06PUJYZ1O9!2=`Q9ae&VYl)@}uGXQ)*gTKpS46m$qCEFZ|HeO=I_tq`%TI+|hVMznlTkUS629l7Jf|&f3%BoZWnyGLi+_UQNZ0qeb`YKFyv8&_C`{-nCX04 zZcWAD-%)Ug8l8kDZY<=i&y98ssb7;k%b+JMv7e_tvcUUB9t&WkWV<1>H=?`0 zT3myQzp-|fWa@gr78J`!2!m5Gp6I?qX%v9%h#Udr5CW@F+7!wi1YII=5MX~1_*M#E zq~an27fRSGDIOchy$tph;!oDa$82p+B)$b~J)!fhz(=WA%Vn2a#iv&5J(hgmfQ3muWYF`Z zeMoB_h4C;Lu9xFo6x}1odoX_h#2t99Z*>)k;t?hmvBW)u4=~zC02YCC3#8=;Yy#M8lr3UW zpS9q<^nRPu=N!Ohj^m^`CWSgzwd{QE>Y46po-3hGRJ9kXZ-?qfBFa%zdCwI8GVr`U zi&1AA!VUwtFvTk&TnFX#fIrB-Hom7ottapWrk!mn-!bhNOKir(UI?6vsE1_Kzeix@ zNZ&b8woYOIkbfq1y{V3O=sdy45_Tr&heBK%8b3CxRAo;(b7m5!jlXha{quPwW&w&Cg5vBF(*^sTJj;6wspj1#=O#8 z4~ykmn5_zO3fa8~(L2VZb&{RyVYWU@YZ&DOIh`5S~&5UI}!LD%R2Tq;p#2_OM z{NMC&gpemEFio=OBz^$+JcMsX)M;Q`3FV1MUXSE~3_pS4%P@UKrY=|JMT|TFfhCx^ zI-?!Q@MlrWt*rJb+kBt34r1s?ChvuCkTSnO@W%{0REZxDajQoit=it9Y~Mw8ccAzQ z;O_&rsE~`N<@&I8gjipY@g_N_oWfQajfx)YH*6Loze7D#9+plO2rB-o2W z**3xTfxH0VhJ;oU_>Vpq(RK#39>Mh!KETkkqTqvtJYL`NhqfZ{(7MNm?(=^*zpw@Ucn(P znr*tkzbfoc0X_!A1%^1tkz*Zt%%B@7-v!B!QF9PX%gX9-d3Rx_YVzN@dO4Y|x9Gl3uq-xzwiw*rf$3#sfk;` zd>%vRTZ$7bF^b^=nEXzB<<^doV0pd+Er!nyy z72_!#g|sy!y_U$s47oOhVNwhXY5PhaXwDHt9xcOo8J11(wG>~<;HWJ2+jJkArlW(l zc0yO1^q|1EOl4=JU%`m|iJV06bfD}?@CH*(XXd+>FFVpo*B4c>d3tb3X)?nu*$!8jz4w^#PO zTiuV3;;+bkE?B=yL2hQOn;7+}5%-((n&R58@jRk9w)0}=Td@^c{5kj>lhgW-HS2$b zajwH#b|wb>M}T*O*ct43fZ6;3=7+j`V7TvUSst}gHn;RMO?5>_bFbKcrqE6Z=4W7i zh=^s9^}fOwCB!j6nL+3^Kpzo#FT{H#O$TG3Atr(L8tG4qJWFifNNPbqV+C!V$d63< zuF(6v&>ksaL1pjjLOU_xqa;3LzzYRsNTH1_g-1Ftn!-Ym4OWyVRWuG2-?Qc_%6h&* z(~@`<)JX&mA=?M2|N9W?y%y-+LCx9#iZca%n5knk;|WDRXrZeuc(;Y-M&u=6jOt?{ ze7R8P*UIKnrtL@N`*gpY!po37NZ4poPBOKR81OdX%Mf@D!a;z}pki|h#ZQj|3qt(P;DgyW>EPM zk<0ffWq(rg+mRfL%3E0TE7bUqsnL}71#%YwHv!$#MeGdMM)LZ;tb0i^mNsxpLjNMV z-%!mXfZYIa0>s}7{%;}o0qjRWTN=11kfVuqW2k)>sMis8Fi?LBbdMB#Z6Ox`__k0c z67?dXE=}YhLTmRaX&wNSzXQ!HgbgBaAfZ(VoMo`J0Dn=y*$F$5z%xMIMc|hLHz#88 zgsp67_Dz%>`d~|4knkx)vkPFm5%x9JOhuG)B_9BlkxV-Sg@ftXf#i#1PD93e$oeQF z-}K7uytd;#?NZ84AadV6vfq9y@L54y3wjyQVnF8x!v9S8i3CqJ=)Od5Pt*qiTO6{h zg}el?V+33;@@y88yY$0ynwh4x={M9h*5n(wFoV(@r0piyy#%iyd8(;d z*0Sti)fQyvB(#``)~BPJ`?DKITQ`1dZC%$QKB9btgc~F+ld?6CxDAOr89JHb$+U7H z$iubUe($m04^*D;UUv1>rmb z&NJXRoYZGfJR@?0L@q$YWGdI9+RMm%oWcgC+=H3>Gxaed$ENBr%=$ePKc(8^0(I5G z&hBnyLsI)9?U@8GNyVX=wobZFmTQ8{PLq|t$?|5I1}3?;;Oh#0m&EBN-R+qZ03AzW zIIGqK@eJA7g6KCt)eNS}mdNIMMdw*r|9O*sU!Yu+>33x|OK0u5HQQg@oOO;ZGMjUf z{-x;u6xu}r?gsEEq1+Gn7-n9fw0Qum3h)yU$3pfifD?rrF2u}4d?wYkk@Yp!?hMx1 zf3#?OEb84fqf>vJ?@f%qT4b%++zCp`8ty&orZo|@>w`KkVj8Btxxe-gc zmHFJ8qup%dQaHSEd&b=^u!5m1%|GRxkJI|!K+g3jIL8#R*&Hkf%WMk}Hv!E;$>yKT z+=k*~ROd2!=UQgjn$D9fJBK>@ABX5(5cz-Girp0xTtbZ1z;-{d`$tln6TU2gXC?fZ z$WKXJ3t)SoE=FQLBOd_y0oc5fz`p?8p1^S_4xxCFfI9%(24Hz9he_H)ic5t06X-+D z__|y3dGXF4i*Z$FE@JYLR8CUhx2pAaRW70GhbUuGs=fr}AwV4f=qsYT2lKy=0KNO0 zdM_Z_%OTCBNH4spUxDSK>&@h9I$3-_E&w2Q)WR z{2a7Psn~?--4Usmsb&YJ{X}71Bo1WO%aF6~M3#dk-%QeJ5*G!^6e!PE#^>|LfB5Zr290N4x z0`VfiKL9yTUr0~xPQ>Pf1`{?N;O%`bn4aGe974o6KsW#Ifd7oR!|kPnl28&nrV#PJGUgs?>vT7wZ!LfsFM9H`_O3jd2TpG9g#pd12f zXbNu$%?$}`m(q+(JT2lvLKBsm7lFrF{WY}Za8|sh(6Nl}e-QCYqS*T%L!dMSAe+l_gOMf()Ck@?PvwT>y@6_6M7Ow4p z3AGLwTp2ruIDe&90JJLMAwaBv?AryYvB)}&Sucb!gwzp&_XBa4nfE91M!P-U*?SK; zXDssn-bVi4g{ZTC!a941+#Mox&lS3l7<0}8avPY#jNDGFD~0P9M(##)Vls^S?n`AvDf$v)6<-xi^tGYuC9gyKc zDSv3U|XA;i8{xw?*egOTGzwn9$E_lz7g;*j5-VG>;u;C ztnPS3uEJ7wRx}f${NUK4cB!H|P3~KR*?j`FyS-b#Tzj4A+144E_y$?ug=gPj&lv-E zzlOWZGQS_EoU@=X=MK8vh}K$8&6^ePWG{AfkEgPDTm*-axRj17oV=6r;g&ZH=Xcfl zG>wU%m$31$&2yl581&9Seuu2*A@gozZVvl9rl&JK9JOwOT4vaFk`db(J}k|L0bOBp zk^Zfp54(*iZuz-e&4b#x6Im98bv7%;vic;pbqd-TjOw+K`6%E??*DdOL1=qAUywbX z?%jjTH<5LDWWATJAIMk-(Bp=N0hq`1duAPM1YBXyC8V}$a0?Pw9$KXc+t!~7+K;I5TdwimMTcUR}QEvhA38Nlo zBjWM?A*k+VG{+k`%qZI@VkCf701qa(3XppOc?i%u4#;;19zl2p(JW2GK)@RV zy&VltNW=`oHvs;QsLKoGCq_97D32BB*A2?19r&&W9$df;1F^^d;AN9D%in5k=23qS z!XCZE{Fyk9nI|yY-xSuquS~xTdtsn=t=(Sj)HSYobGCRxZSL)C_h#Y_xQ=tyA-wme$8GNhwtPr!{E3+>(Y{W`wQxQN z*N@?P6I`!JH$SCuwCx>%_7oD=w&X1mXHqc_73&&$iogm4w-LO%;aiCEKG8fvG}i;% z-`1LR+?4*ePQk`8a{qK#Raqfk0G zE1FHII2q(I{by&dZ`b)@tpRH&f`bt`10_FTXmu!0huU$V{(=6DcvKRvfO!+m8_0Z8 z^p|A)1=YSD=>rvfM#x9ye22=_!CZsH<4KIAak`v;XZ4k;dRWeN<@{-wi;3+bB(Ebo z7n5;ee`L(Vsdi-w(-3|P1?Oa9A7tD_`z|_fC%kJS2NS*3lx<3PQrrpoTq8dq>)W(GvUwsBqmi*P zYuwMo+aiv1_-nGg+ia&8b#=S0?b`0=I%ienoWHVm_hqerM*10{P7LG@6<*5dO$X{| zL(2(TSKv?pPXN7Bh~A?Bt_5+rsNIvDs}28_%v}{eF+$Hap~af;Crx2fQuBHzrSjc(qX;aF&xYJ>K%=hL%W|3z4xWvuqUEcRP)*SnJ}< zxlX3Fk?b9k-rUaLkQhy18Pi85{k(~xB#x&sI^ZWke@Nz6WV5gyei?Srm!g(AMYN<>eHn3p!c$ z<4E7+S~f&rQ_;H;&0@@$0pwB$uE@lOOngVy3&H%U$+1oyg2Z@a??oC%(OjCTZBVro zlWYBN+uJ+Ahsjvj$W4&g(sjV|sPVNcuXpv?sO4vL-x+lC4$NV+*HGqQCP&N7=FGlb ziE;#3wua((WL=8T`$F6w=4fRufb3m^I_D40dLrzRbUBaE3I-oY>M{VEf%#7pKezJ6 zB-W{nM*y!&wWDM|EBoh6Tqtr>03(EYDS?v-e<GxwGLb3EoZQ zI|bg8XqOUjrGP^Mc#^1gW<;#J_Nx11a308m5_S@xwzqhM&1YWOxhWHI8Y5s!p)M=58w9Y9fQJFB2EqrP)wFLZ03ZNKL_t)PrVD;g;Gv1K4UtO`x)c5J#wU%w$wm$X z>H>hb>W7T^T%+9+XdfkVT|ol@txaem;U$6kVgH~IOA#0=)Q1G$EHqmHeNPKqxuAU2 zLD{$gPio*h3fh+g{Hc(u1NnNI*D9M?%(5M_GZYoC*V;bonm4NUt}pD(^{U;@gzB<} zX4vHqnRQv#-g9VsgI#ebvn&UDFStGn&l&E_=istgKNZRUqP-Q2UFaOC#0)7ewdOk0 zY}W?bEs^cNk-hDdx(96>33GdZ2NAwa=C5g-jm$MN+ut%{170N0KHTXBMP9wRl z7%v0md4Nj_d{NeZGB<|xh7t!5I)m&S!R-7Q8Ry#NjLdkSnIj_W+D<$&=Vr#3^yyO6Fh<7W=fLTE(~ZN^$gbD+^#E!j5$!dOT*fw>A< zhXZwGD4u5NEU!insQB-t<24}64 zv&GMA%+{>j%{f_o@xV;D!i=kk1M7##ZMuZNa z`9mtkGB94zoDlLGP~PMIi{N_5vW?RpBI`(k-!Qc~&C{6t8-RVg^01&k3+ZLDm!C)qrY@QMB8J+4N_T14rm1)}?f!5q)!~)-r@2BYG#%T3X;&LU~ch&)NS+^&H^S6L?hp%z*d*hp|0O@Ua1XNHm)Q z9`-*i`%r@m813^3A8lZ?5&QMG!M3*;yY3nA7C z@J|LF>o+ap_x*;^`d7eb0x=6{{*d6RKyP28erfb(81+@44kWN7$RiVRKd5sE96);) z+6NMtMC8u|YzfpA1KJD76%*aZ0y(KcXM+Z1=>~YO0smQ0UJBs%M0X_M9~)Xt?z^A0 zJ&SFOLyI%n_NKXqiBS7W%)7wK-yw56Qr|h7fvC;CY;i8yx+2<~<5tIH#s*Fv0O#DO z^)4h{q;VEeyRx??^jo@I2IE55hoi=yQI%+86IQK`id|XrG$y9gagP!oGxJuZzf;!j z1dk$kJfxe=m;^QJnjuFVh!Pz%B8omna2A4ZK>86Bw}P=eskzB=q}XgNbQYDHC+OxO z)xO(U`))wnSqwG0$he*6451DUXNtLhl{)4@B=K=COeP0puo$cArFjFS9o(J!jGC+@W>; zusTnwHq!o0+Q&O{GSc^;)^ywbN4D(_*|ytfcAu{9EmTo2tKe%1eraPckUh{Nz}yI| zlYrhUM0XVA-;ps8&;x}2B{!$b12%4QKxwk?yryloEo~VQZIi5J6K2^7?(77|>2Mr@ zjD?)#YG+w8-AvEasWs#BT07rnEzf4{JJA_e+Wr=(eQ+ye9p{SMUE9mD?J3*t1-0$H zQrkHTXU-X6^!{tKuNpkX&>4o$1nMV7?+Bwi1L%Gk=x!69b8et}rO^F?oZUzE4hSZM zIwhq4HW9z*G`z7>cyOoW!A;bSKMj# za#J>Or!4K#jL%Y5%HoMNa8wmHsMM&W?lziPKsgQO$w+R)whlqf38=j%=w8UZO~|^G zlvQkJD%wd@9S`;PfO`K2*3*c5mZ;Z}`V#6~4|Sfg${or0c`ANXHDF4{T&Fqu#<|gE zDD`nRy^~pb>#}KgW`mE}DTl^@!lqAWHGO=n>FChX??amIGYat_^D9vL4qaUv_I^g1{&7i1drKsgX)y}EKoyn1%t4o#( zN|wEgJC}qz;{)Z;Fdi@VUXfa}R7hE0RNGEwZD+yl%A_CZe_zgo%jwB-WU?G-l_tes zr&Lq=EQM)g-9Fe}RalP;)O!l@iGaTEr*8J$M0PeIwE@ke1w9|&2?5R)@J%5963F8P zfM`x3Vs|2T{-0TG+W-a$Jec5}L>+_v+TS#Aq2b#Mj5KtTq49=C8F{|ZThXXvfc%7T z74({*D+7{H&KAm>Lfk0C(L_0kC}#rkAA|oj;yIvmk5P^X)B&2SfO0c|VM4iIDE}@f zV*<@d1-dlg7X;rWR10$sCwgxX_z4l)5X~BZCK~!XpxuDjjOdI6Ivqmq3jRBxs|h?q zw4e3+6!KNW4+B2fXsKO&T zqriWRe)RBEfhQ9lNY?8hd<^+&vb~J-cBKAOVzwVd#L6jt3C6c@z1{9@=*rPq<0E9b zh-eNc{5!dQQ_kmz-i9P!2FoFUX9D_P0RtXF<{rqpIgEoy+>^vtBvu6TH6SlR`a#=o zq%j)K+llrfLjQ!dwQGLlnm4(vt5EGv>L3! zkN2NTnuXcoY_{Bqtv*$+d6&J;7U=0>^t>Q??QU+%o@l*`T@SUp$2m3287l)g$nt3x zKd{P9mgY(6L96qzRhE@70j%qry#>JB8SqPR{2uPiG~y%Bw~=`W=(9*aM&{RG`!>jf zfOai7uZOv#vkV0CRT|4M+rg~8msz`e(YYwl3?gD6nSX}cJ&4}=iQbwg7a`8$=OfkAkBw`ICew1xo zVCUyHCfFPVa5#-wU@i*g>II%4>nM<~hV!tJm|l{zN}KPi#pz1CO7IgS_OIZ+pw2b4 zK$@c~G&6*)MD9iOeFt+tIPOO3R#{^MxnH1Oi>zN7y_qzAiuB?(7sytp*4liUHO@lj zUx_)l5_66h+Rp=VMgcc8G|?!_39+-Gi|JU8)EL1>(Cxft_X(qWqmgR>y{TqzS6W9E zm)(jvq`)f{c-`VTPZ!KNDO}$q%5T8F)y*=Vj7ea#2&LDf;Fv5JS4%xZ!bL61*~!j6 zsb&F2yox4fp~Sf;aUz<|2P~aERXTr{^g6>kpyY*Fay>Nd9~`|uq_k!wE>gdaxEJh; zUF%nFu|8CmrJ8?{Wgyv^1mIX^eb7B@fo{8yvU|F-_g4cy2IGCZ*#qp`8_ctyIvnC5 zAYK5lMzTys;&wn2%oqulX<)g)jDc19M>2<7+!xZzEclC}9x2WFNNk6b{se)?Sv*i3 zZLOj!RQM|@7m(UTgq)8qCo1tPDK{sv5y7P)40qML8F6{G<@E}^AjGR}_KmAG|7PTR zK)nLMK0tm*;-dbG2d_cmw{GjlbZ@L{?`ede&B!MlxWkNJC3TdAl^NVir7TlILn!Qo zh;1wLcDNox=f_OmDVL|{GMb3_$Z|5G97<_npqxZ=ueqCl(|E(^8z66%_So&q>8;gtd3Y49_GcLCl9@IU~E5qK5IO@Q2)@cMwS z>+dnqq(r=B-6;;Aj!s zRN!WT1Jh--gjY}G(FxsO5ko7QVPKA@crt}!Aif7;Ihb>pe2mD~nfxV<2>{O`a6iBg z|0fMR7|{L&x~jm}7WkF`o(p)l02dL;)&SNs@G>#`D7xJM)hD3!qw3X7k~l2kf0oXi z-XX1;8(VeGPvA-;uYmcSYxxT@4x+UA zZB!qE^vM9$Hgg!%{X3OE2mCEuPj%KY$eiG;_rv*u9k&3nBQo}Pi>ILOC>7qvj05cQ zYg-4W>#Egt44fY`HJ_mScEOcpohe zblbk}$~9ekhal%X>)M>-%+cxC((+Lb|2V0QEWK^TEUSECHG{#p(d0o%y(8vKfHTNA z2aF5AvIU?e30`OBSkkwW_!g|Ypg$*j7mPjO-Yv|WBIXjLHc|3CW!;e3o`{??&8~0t zBRx9<4K7LdRCYOOR zkKHZf#Fmw-4 z_6M+&-0sW#ekQU#(KQcqi!*EG(oW24^gac;OAx*F1xyI&ZA0f9%@T>e5sN#xrNl3iI03-Z2KGk9 zmFQx5%<)sGz8&Q6f%pb&zJYkEh5I3mf&3cSJ<(_vu{Fu?n+E0=F%FDtq0adx7D{<~ zDxXK>TMSN6iN8hBtPt;!a3AGAB6>Hl;3hTtt(rWJQHN8xEZI&X+TSX@X~}w0uw6;6 z=g{ph!QP!#{bN==m?*^8wY4gW2w+Qf` z0X!P!3gNg@nG@x@K%@>)a;VZ1Wj-U|Iz)ZZs<#ojDjmyami;m{#Hr<-b$vrynSEa+ z;$r|S5O_-HjSl$Lf;=mpX1U_yrJO13D1!RHA*fKcRt>`!`*zX_V!SSSR6kfn3|@4F<~E1n(ob zG=c32?@4qQ7Geg_w-ms)fm|Q(5Cek&EM#b2!;1kr1Mm(&9S87c!z&y0--JdHxv<~` zi2M^#KkR4Fbcgg;AomUhco5Jz&EV4jzc73;z|{cW3-EXX*8n~X@Ph!KK>zdUK>l2) ziyPiT$ZRco z?q)rd!ikiZgLD^IM#4N3-~&XnH_gN8_HiJ$0I-~ZcYwSCXx|Lr#{u3L;C%tz7>JDm zIbG--E97oOjyLMfL^~X4F9q;xI>%(q?cCOds=M39B0pI1In)7Xu$EQP<_GB2kJ-yf z>~SZyTvavKj+%p2^LW*|ei+Y_%}k>69@w`gSf&HbLqNPt`%7f)F+HCv_jK||*t-Mm z5p-^&#p?G^>+hZQG#dlq7-0_hlQH){4V?hh6IpyAi&s^l5Pp{7t1T}^;%-7C z!f^uKcQmu_VLATDESE6(Lsp%MS}sM~nc-e@8>*(E#`#DdBKr?Yj#I{CQF95^y05DH zkkKOhfZ8_?YUh5maR%DXCFqsm>^29eSN;>dzOU6AaHV>ki`na}>t3^|D+jpdLz%sA zv$ngr<~pvP&!~5#ytW&`O|wIGG&ma{;G*wQ;t)pc$=*h3*4Fdn}P} z!*w{^8|j>Ladr2ztnCkK&e@~p>=Rn|j!XMWTN^v^I+D}TY9?y=2Ws4s8Q*1PtrbJk zb#g^}U;=}za+%S0li8tB-b-*_^c!e)wyTgiH)Mc+!fjHa1=0@*P`}-#{yGv&6ep73AR_5$c>DikYbN*s<7wXsMnwx;Wa{+x~W}hAS_rAiv#|ht$A$n8jc3zsEM7t<6y@-u?zO?(Ifx%f z7$nA%ROdvf*%ac|XgrTP?Z@nEzh$R>%MLDbDc7Ls`zuQs$l!Hqv~)Cmv!nUZ{%U^s za*4iyCG=f{k5%z>HgO3%rqlos=po(7jzGa@k|(77tuw|SAD3gVT*D00jrls`l^i%0gY9Btnz(d#=gdd;KJ zZHB4Wk=o9`RGZ<<@*lbH3gui^EBkI!Ez3sbrlsmPs%3>p+@$n$C9YEX3?(|Wzoz^? zO0I(9r(8VC1^Z`kh=s8!+w{m(e3;Qp%A!sd+zx5!5awx^YXp2&oW zn8E7}KVy^wjQGsp8HSGo{3oHFLU=%bw*U?xG>FjF0{e(C(DyB%D*=3BU|t|!Fg(W4 zRYaK%#JU8#1Rnr&84(W)v1>p-Dk$p&nzIBwCgcr*Zy|CFk=FwCQ~)~|u>(+!0%8N8 ze3d8<8D*pq8v;BEXkIot(|~xBi0c5o3HTErw>NN9!tWS$6Za1SKLhX(fjbR74wg&6 z&cb9l7m8cR&Lt3vgt;kA70ahk`9HFZ1qW;l%)J5BH-PGlXEeJ~rINgr(CtM0g>J5( zb)KB(5OoP4hZBC0z@0*VRKRf!nr91|6AH>ff#xp(4;H$23Ui(#z8^_^e>&LRooYX# z+>5AhgytL}^!^>lv87YzUK8jHfw4b~Ct9~3J2@ZIf05e zH4j1ZOhDsEZ9;1s8e?R?tt?Nlb{?bo3V?}LInZoQ0m~3r+rqJ}YT1{y*^_PTrCP=* zwFAr}fw+L+mTh~%6M7Sr-8hk#J`C=oT&d~ zbgzJWo2S}SYvl^a{2j79h1xybIs1jocC(u8h;;i@X7{gl?r!57y6;Ju6XCLj(K*6s zR!wleKyK8sU7yNLL7qWzYk?mJ%5O3{zg3p)q5PWBUBQk$Y#z#t#gb+BbZ2y}ek&_~ z=-|$-aTbJkNzEXd#c6It`*XsZ&^VX&P}qk$Jr2&L4Lp|cs{jV4d1?ZG31asUwhVe= zKzjhV1H=>qFC@wtcJIn``xfobfOcu4JIa`Surd30Kt0zepBc?HKs|xr5Fu|B@>-#{ zL}2zMf$z@+x*rm~3yAg_!TZ8F80ZZneK3HNL0$vp1JIls#Qz)3V)m z2I6}VZ$^3z3ByUPq|*K-o8G}$d|PdJz6);%m9mjHJna2`=_BeaX5f2BPm z(+?XwKNa&r&CxbLO!(MDzHjJ0qHh_xI}~WY0_I$1`-DXIA|T%b^aji?;Pz=d&jR8v zVBa^2@`M6M6}2;q^iiYc&d`sJi_&+oitbQ@#Zdf92G4@{x|mCW^(XmK9L2R2^(% zQvkuod)Gz!7^Rnyd7c7O!8ni7 zuc#PL`c;BcOf7GhQLfEQw(&aK7=bo6L9erqd!38Xjag1DXveRNvbEj04DLGuRoAPw ze^B;rV(mSoil^A(V5Mi#J^-#mKp%nP%^bZKzneiHEB(GLro zPIyK?{Kr=&_=Uj7Dl`FzHI3NN{R8x5fae-s*T|tjKQIaX2GU)HI+DPBKx{;Gt_1j~ zQQrjoaliSwZ!sW#1~k_h?czjk26z>tjt2Z^fb#*IU*O~YNr3z%;AIFuOtdQ#<%j*{ zZ8??bo(gEBQLZ+)O@hl2e8R}p0h|Z$Xrg%l=sVBod}8R={Y6E1z^I=Y?eu;(ek>1g z2Y{y;dc?qDKwKf{v4R+$zz#(3pA|YP+1w-I<)XZ+vbQ>!cU8uGAn!6`Rnn*0S_v)_ zVGKfQFswbnTp6qCrMM_g~pY3<;ILTSob8WWI z?C!x2-Ive+03ZNKL_t){L*({avVB|fAyWQ}!X+xal8m1s>tja!8R6#)Uk+;UGFs{{2ED+d9-mxy&>t%lUs$YumGSAn^j*(^&pk3unxh-X##p{ggd<>Ki1 zB}9&bn(c_@U}juHaR{gpX6~4%V<>I`dVaEO1H>d4ODc0JGnW-&7U9*&oL9gf!um6v zuQByGYiB81lVPp`#=nf%-HfAwxRq|!q?>i*ats~I0P#G?JxQ)=`cg2b*zIo4`jjj0 z%c|cw%SfYH*Q^I+V5bbvRW)`_XSmf}Vr zR)*X4Z0$?)P-Q!s*}jUb50QBt>8DA)P3mKzj;4BxQQddJx+37Ac3ztF?P&dtYkLfH z_V#XP|0rvFer7#2T@OxUJ3BUDEyttAEy~W_$j%kvzUvdQv4~m0`V%qNA$2xYE|YVV zh#98d3S#%lyohRdgm@T*jVMl|IEE~n8@kTf9_?(8aK-gd9cq9hmNhp(n`Zb{WDNxS>${&!G8$&z(CBBqL)<8fl6maY)$7V6uSf^J%Ey)Lo=<1 zW*n?G{93E|lvZ<2tmgf`+B&OQT`c$$O17tj?!m@Bfp}2DREG63vkws7Nz8o&v`MWa zpzui!#o|x@LwY|HNv|g${!W=EJf*)Jsx22Udom*>}HGf zWD1@dp*KR_IU*Lh#|`e95rw_r)>px9AP*O~uBeen_71AX5JWW?(ee%=oyD;A%<=_b z%M8FK8LG8Y-L@vqTOO<#-iu9EcpBu_LgvKV|ghU)` zhI0taCNM+dEXc1g`238Rln}ca;uF9+3AhP}oeY>jU;)9c1H2c&HL6yQw2mjT)chzAJo)gGwB z=R`WRy$_E^fpi}c(+Rys;2XmBC-54O<^$lkm-eGCE?_Sre{0Z6qWZv)cO=_x2TRYOZ7GZAk?OZ# zI0B}ZM7s%09|}H$^v;59hDhfi@~4P=r6PU-`BMQN2kBIhCkpx2|9$uG0HjqywIyK# zfaXX;dXm6)32iGgG(Ll`WZ=IU(IrE@3^9c$cN1kQP~HM~fKW{p%I=h{&nRQyaUN)+ zg52Fz{D~>QV88%@ zKz_dri^c}#aU}yU((MVB>S?pazlp|wO}3om5E$MRV^pxb2=D;`d$bb``Hcm>fXeGOgN@fA8xHUopz(!} z-vrawA|DfcFG24q;y$_Flc&=Z)nh?i8WwAXVSSmO3&TPr`vK-Bkz7h}qKSu^aB4!D zlbFvmaxxh!#QHE&_mO!jh>M6gRN+hDc#o+Z%J6p){wU~MlYSnptVfnEX60<=W_McK zCt^8J&{zfUci7z$#>?xMfckPob8ZwL;Sv2^K3U?mQp?`(mYrByPC;pz%V<1K***k2 z6Fh;yAR-Rkx@n#4m!oF0rf3EzU$AwA}DliVh-zcmw z;Y{|35{B+UJ1JQHB(uFiTaU)+Ofd#YTPkZ}SiB}^t7wNq?I-X7 zsu~34fe{*7+;?%r?`2pQvghUYPZjeAo5x4@fO$iK27RSkOX&|PA{O)kx=b~3;lM;(k--HictR$Z80=Y-{!QVVr2M=oUz=b<3H}Mv3Q?;-TyDZ+ z1|DRv{swFUXtE{~Aay3HD3Cz6a6`KzbIa`T@Bo5N82c4%oIp z%mDlXAl4S}9Ki7a?;`90!agPJuV8*umZ!kDR95DNp{K08Ak*7Q`odD2Eb1^qvjr|7 z(ghN~gKQo=--T#Aq!Ryvny(P?nP`Ir8!VtJpr3>?0FG`4m4P^5+il7>JjkSk5Tp7<^ulZa23{3|)}6u6DRb z9`C@_Q|^btn+L&5lcBi;cOmR*f+qtw++a_WjgN^m1c=e?-FKX&;9hcjFT8P26h5hf zB~fr?lz1uJJ0Q{!M0$;$e?!kB>FH299;WO-D%Di=BH5U4R%NsNmRaNXmRp8fZtP;I zdMu^JZ^Jii@ChI+X8{st=`nhfrmpWg*#etf6rOk=`fL@lfM6MB_O{zE=fTdBON7 zS{@~S6?KeI(GW$P2h-xn@s=7oB`VBRm2N_A%wV=3nV8J->1OF4$+D-^n2{|1V1_%* zw15^h&DI1P7m=wCna0w1p;>IeR6j)eB%?oKXnvj89GTd*%2MkX=K4X)_4iEWNSKd< z#jYYJ2;HVt5uBL41C!y`6v=f&>&g@-PZSD&JEI1t`pv7*Csiu`yeogB(zT~&t? z`3(;}Uc9-XN88V(vY%wnMx?JoJjnySJ>tGlJS&wO7#svoEp)sLFTb`@KWm}2k~kzO zos!VuDpSjo#yr-TW{@p+10DVkz%?N-lm@!=W`y<&@Nyxq5X{;qVyiDTxNR>nZHuPo3OMb%m#@3B`l3)%6%+#9K_sl7_DUm ztmOh(%Rzz0_5nLzY}^&L=AXhkOm^hn4(k@OUn}yC;fP>SD0!E=$wIyp^n)7vPOSP8J$F z3oQ-6#)*EqjBiG23`J_WCgsKXni$B^BeQ>C`*}0uh)Z@oe*WVylL^V7h2RCC#=3b zqxI@6ADdOy$`KP&U`%oiV(53~b}!v}ne#LT-lgMJ3I_mrfKcreunncEA+^kvI$V$F zcod`YKEpPl_#DHow6NzbsxvIAu7+wlVgDu?*HJBZSX2`jRi;-PvvioidW{*VTkc`A z(aoBTYpq#rW;GwMTFPnOuvN<5yutxNJ|pCp@Zs9vV=S|s&F)>o*? zajcrBSXD2ztP@l6Q!UlQ&FasMK8~zM5zXTPbcb?ZF%44EMacE_mi$-Q;^1sNJ=2C| z>itANCs~=C$OQ?Fftl5oiD|IG?lkaAD#lTMuF3yy&?N@FXDC+?_(sref)KDr0(n^= z_Y3HFK>Y|TBVwjOYY@H<5o;1$1n^a~qty#xa}4~Fh_8uyEkK(IHc7}mh3e8kqrZ^% z4(P~$?<&L~LiZbdiJ`O@`~-t9BlJ9Bqk+^4*w=uT0_fQurnDanSYqJ21e$;j1^li6 z_6}5^I`YYZw4NiCK;uTCnir_H2w1Ox4G7q_0h=G-pg{cO(1-vb;9i0c5!}JZL(G_& z^HHquIT|`w4faNZhpWOORq-4e-UU@ThPfR}1&Zb&B)X5sM@a2e~(qABU_r zq4`v72NPu6ZSL2ViWrs>^Kv@Go@Dy+=q%UiI`2* zcLC8^(pZH(4fmVi+@7JSM84CQwn%2XCi9~bwJnJc!1$A>_vf>2)1tocb9N6rN1FGU7;gG>gj<69%;BD?*z{`0rg}_D?#)X>r!pt^?GCp<2cr-2M? z+g_Q|uz+nJ$g>0aXQ4DwffW(u525sQC_NN`P7&1vsX96W2S?!b5MGmFX9ZslVKb9& z8;W~O^`8SVCSU^{d7z`}@VTrfZZabM+rY&EYA`C zCZXemI3VET9A$$*^CX~k5zu-b)pohi+=*6yryOI{z#eRHHX8mOGX`2J-DxocNZkqB z9<;GCUXR4fV78cM$C&9aMx1S|UN`C(lJA3gbF!K*)V-40HgM@`lXfA4Y!|Zp2B^*@ z8ow2DC$Qx~V9g1E{7^u9A@WV|j_;tfj0~iaAsi*@W&uxyN*I?%ws*k7+yF-4P zsQUt#De^&B^aR=-fpD9moG2^z!^-!7Z!Y<{iufbIr@=JGsFh6KLX>li-k0DXA=^S~ z85+Vlj(TNL?3R=#*H(R)44plxmrExW`641F0{Iq!2T0X{P>12}Ek{EwFTxw6Y57c; zCdha!$fqT~E~IC`>N1Gm0v(4++7scQ%e4h*djWYQ)aVV*$HQ$9YCDw8e1tXmG@G1` zqV-X5pTvoT9;ejF5D%L)G|9g=L@%0dXTrlU-VN$Pr80x5Y-g$YR!U`}8E#4RFNyj` zseWB-t_U7mqmZb;8ZO7FvBAPpyxxx2xhHO6o=U6w*UEZBv_Ok-Sarl-w) zG|BIQ*iWG=q;eJEHxRlV(mX)}AuJVaywEZVNbeFYpBvIy3FRcAzR}QJYVgkt{&~Ch zH@*>Uu%R&%?*CIGd;Ld_g4PXnw-xqu%KqnE{4B!;P<`ev$ zz+A$|6Y2t_@7oD`{)OP(ffy9PhXL*p;C+D@Ncc*C0|fhAu)jHUutWC-)KAa|fU5vK z1(eAEdjoklz|IADHGy{oTnpemKv({6p!f@@t6*^oE4v4k^+J^|VpVNmiQ{QyN28uj z%+tu`jlnoX^t*&uiqK+3yd9nvCh(<#c-vIAH{cqRjSs6fPG+yVl@9~)oChxRKz~_m zK-M2py1}F!vZ8;656!60tx!Ku0ozvKmK93hgjkYL?@hE_2tphdQzbkq4J%iZie_R;WG*BZHT7{?E>(AftLezfzWtFXxWmq z4+(y3vU8|3$fQS8V7Q6>Eb=L|G~9v{j2Ld<6h_Q~%Jm4H2H^q)c0|}Jx*kN}8>(>- znLjhb4VGd)iO*=|Xb|hcQZEpf33hwH4hUK|S#_GM@dROi0l1OGV?&&dz=Lpq9*!dr z+)xoS!^?sQtqj?kP=1Z5wh>AXuz4uNGoZ8>u-Q_+1hS!$bw=QASiL)hiy&SJ={pE3 zgggRBbD&t4(oBlm3OorGJ23g1O7;Cn%@wlN9yA;d(|pmt7UDgj9t4y-fO;wDp9`cJ6R=p|5e~lV(($gCSR%gm zh^swpg-6TR9_r;`x4Gv(yX)C-eG(ok+;OjhH=4)SisqpfzLHUHhjf|H=r7=+0Qx%X zPYPSlHRj!kj*ke@Kjc#!>E3pwFU9~>4*|D)n9n8L*#5TW`K_xWcq~G;UT6Di%GkZ zrkBY$hrl8tze?E?kS&w&6;*m7FagA!BwnHLBE{_hJCD$gKum{he<*boI4+QmE6S@P zI&1@U{8DWBN~%W6wWZ)Y0NBX`1H8m~rLHEIrgibQI8#j?g1Wj}bz^hXyb}fE8Tf|5 zWfpv!Vf`Tn0$d`+tk z2Q(SrXoy`9zBpL#P3T-GzbQ3l%G2g3e2H~F0Chf!wSHo;POS4maPA_dEg|*+Vhh6O z80$XC^anG(!K_W0I0z~KAnIf>#v{cQDPhBu@Q*|cG_tEH{Y(+t2(8z9_(YMI;Z^Cehr-5UT+01Xv#-tqR0gA{|6QToN&=SyHVWhv7@uLqsc1>tpuy>A@FY}e8gh)JVHab}qVTj}_X!*h_{&0hUr{bo zXlc-naO!F+*3XUC7TUr@`)?$54Z~z_f3v$3X=ig^7Ur)J{%lfoONcYfHOUYYlJt54 zo=jlB41JMMcFFL^63SQt8w0vRh_?f=38BY`*xX?YLisqT+zT%^82x$4|Cu^t+x4Jw zH4$qNdOX3hkqt}rhL$jw*7)AcMi_Aq(RdVS`59Er2+w09syD;)kZ}9N-KKd|KZdtF z7OMILc&&itgja?*nb3CzP9rpl(3=GR0HlY3st4H8iB>&D<8Cxx+l*%=vnpAPO^IJ5 z%L|iLGmQ3yfjvwZY|=rDave)~4UR!9yom+3ThWHu{f}AY43oMfiJY?I|{9iY-@zjUCDK3&5IC9-+vi!^v>n?2b3Q#;aapv6uS9D7s6Y z)`Dznf!D+ICnY~iN&S`8RI=g7c@?bMlF6pi;$*X^jrJ$A+{G-NOtWLa{0%IfNZLD?jkngO)XusoI&T;~th;YO}nrSxf(9RhMKO zZ)SbXaDkaU$&}7Pu0|uJy=8t&Q2RL2=s@+9!+sR`fGqzNmJ2OSm*sIlhoeJ{(*l^~ zkw5iV^O2(e8&RU;+8&Kru4+akiw@J+_ z4fR3-Keij^?2jPU0`UoneF+;(cK8vg>djQ0Yw7>iV(R!g**G0&91qwfQkXSe-l=ls->k!RL4OnSl zE5R)R?9(2!wVMULEyQx5JVN^OVCg8v&Z0Gf_FjJ#|522+oM41_C%YAwkwRQ zKOkFAA?v4oEf1tO+J82&aUeY# zXlxb8j|J?{0bCWpb^*={U}5_jAgvv+>k0lNffEzbdMP#5u__(F7CW0QxD*|<2|C1) zYKZ}A#3D3&0V`c#87HUY+vQX?$mWxhl|77Q-9&9e#Lo?Qtet#_pBwG`lytsjKf+RJ zwG^P)c6S5-4{G_%DECfad!|=`Gc_Lv`?@=Xq{j7PW21l`2J(kMTt@f_0A3+@ zIFSAf=nSBY6!;8~enI3FfQ^)R0Hhr$9>$2y^m+%n7Fw}K%0)$)abvMQS+Y+AJ3zvRKltSCQX2be2O)1NG&>djDYkiKFZp@bv=v&SB>Z_6?Ly zrWzMOEpJHGoCtfzBj%K7>sCj(x0bJ6Lw$>Bb`eGw(=c~k?Ml7su$SxbnYH3}kC-j_ zPL%Glh|h9(KfzA`*cYfbB5Vavy&>Ao0o$vvd6v-jXsG$Ip)57!XAt%m1m2*ye?l5A z*jR(+3EtVj4S~EasUr-nUlz0-V&cyU?!oYrz~*kGUncl1LHyQPO)IpW3-b{LtDh{W zj|=*tMDrDL^=?FI3UQv$`VXP?W1>Ekh|vT_fiVN-J27bwX5T2KxYIJnF+~q1^+&?} zNcNP-3jtdN9;{uK0REHht=}Nf2AC4`9X>6!vKtSJs^;$~t z5zNkzmC3NW6IdT6)KjG9b_iYp#e9Vg@kpawwq983sgkY))5`>}Q|SKi($(Ge@;dic zosVQQ{oYFcN(Do#V4gW%Hpf~K*b~A)0%MGJyup4B%iGZ6IT+6qaTkGJ6dwLxz;YuX zO$0jhBe-rL4+GfQ;2UI=BQs+23{1$dBQn#)8M#vipUu#8W9vCP}&&M!-h1Th!rX4xn|bQvUX*QAJ589Lq<=Su9Kz3LV6fLXESbVmX0>_ zZ4zQOR8|0*C-MFWjii;MNDiQJf6yK#`K*x}lD-I5zbM+#vNS`8O(DEPlzpN28eq@% zby!+~q>m8wxA1rrDb9wlpP&x`e1On z>{vaYX#NuLyGX1HXuJ?Zfc$!>+EGYn671~I9R+wFXgnt54+8O(A;uD1B=FjRW(MM# zK)NJ=p#e?^*sB6}1F#)|vjvP5xRQu74c5!RyFpw;rmvW)OIh(0HlhbxVo$Zi324#B ztayoKeh0HoM&1MHQ$~zt=;sXdRbW^+`h@%UCN2uqTbbBB0b2*~U6_63<~zIjBZc_F zpo1uVM8|CoTm$J*y3euTmWDKo;wMykoqd;^07AH_^8bVrL_saq5mB-wEPeDcvC1HUusQ zc#p*H3LFPvHjtJ89j5{<`vNu@j57hO0{O6zUV^ZNfZc?2hM=whHY4m&!5$aveMw!Q zxDSzjfZG>#(}WZhs0~77LtBE87G^eKNI`IqA!vT0d)ru ze}iHPgkub898=nznJ*~Eu}pZEDb|wVN0|LeL|;*h1T6z~1`$hvv_MFIr}zy6mkMdT z7{3%^id0^aR-Y_29}Sf;A)ny#-CcgPi|>SNIfRjjv;~yTkn;BtJlvyPRAP0XI_h~% z#iS;2dXxI9X6jX#?siL07TW*Shy^v`%M#o-lmIsLVTOpHdKfiL_Rc-H#2Y}unYsrWCEZ4 zkF&i5sNWCN*ATG_5M2X)ZlSI$NDFG_XKGmA8nIQd9tHTe#_}StdIO+-Tli@!;HR?* zpKQ?fMCnee|6r-U%X0bAlD}^WbIr7`SzJc*>tPrm%e}%Hhk-l*&{`0tLa_i!TLEd5 zkUt4jA5d%T4t2Pi5m&2V|1gep*d~trO0b-w6qmvBUtqQ&65o;8k0QPcHaC#kjt?~s z47aZ%xJVJZhjeU2I$Ovi0S*(mNWtFW)frLJP?g*lHScE~Z?JAIVaX?%V;u`DhvNe{ z{))gI6b>fwmJyrDcp)tvNWl2N$Ol!QClm?i7 z>S~As6Rb-@elZ~*k)XX2${&;b4x?UAw3$ZTYb@WA7(?PK5xWVzRl+U+2b%KdRLi}T zZ)M`nMB0w1dl)d>(AY1d*|lPQQ3KUQ8R@EQKRuDGOr`l3FbtIC2i+QzX=Nd-^i;Cf zC3_-dT>?5&Vs|LLi1s_VG?{L9Hjgyp<_3PxzyVS|TFj>eT7Fm17#M2lFLc~L(4ng< zpJYrIQPo4F7=6MGWl1V$) zWmYxDSwokyT73Z;&DW5;n^Now!vff%uDnX8>Ct;GTkiB$PKr?1Epn+4+h#qX{Dm1JIEB?W<9x$u-hLuBzwq2qaZcnDWochF|VFlQg@>7ZEN%=sTHe$l;l=~pkPYAAou=AwqMWHcWSYt4-W)Gk- zO|TyAYEb@2;AIFm09>1}-x7H~kiI4?3%nSxHldmba36t_30u>|M-nj8geMJHVcW?j#ODyX|%j#oUb1WfQVjmhunAzdUaIIx+#|A4@ zX;U<~jw)XeIff`}mMnfR^ZSCjN8qhOOalF8QA#Gk~pt zT>@0+1{$+N`QIM=vx^4@@+F{6BcoL)-wNf2K>Vs*O&jZr^-%Dq*TB{#V3{K}yMoQV zf^7qwZ3~@kXB9LLFQ_}!XzpKBe^aw{Y0aM&Ie+RGY<)i1dTX%lt6=M2oUIdr&E>(k zSZv-VYimI&-7NcEmdj45DqC5ln^VPCE!okQZ8lOq7rDbhOdTiFs_$slk<0@PsY_CI zRZ`;sLt|ZI)nsZMO>6v3WUH9=4OWjiJ1h)qZ0X59jLKTrGfD3 z*eLjamd^YC@A-QF*LBY0`Fg)YQKhx2v1%nY5h@`zHGs?@>aHs;^ewujk{O>-$4Kf5hWwaH80?S0=#7umZiOT@2FX{prCBqLg z>;cCHX1Lpk(MC+3eYU}9inkN757n+k*lKBhPvcqx&$`PN96V(r=W?HiBIwXhkWv7V=vl?=WgJ zqt-CmBpQdC;WCgX0r)%6oG;D!a%S)NRPPCaIo}ZH7%TRU1DlhC=1Zyf5TWOxOuI{= z8&qvMw9Ub2eI@Jq71rgV*5(|nI-1o-F}VfghZ8sf;Gc}Xzq^g}j(zT(&R*6j>#?J6 z*ywb0un7u3LCI_2x}M}f1I{wmKO4KtlDe9}P^j)MX&+_I$c*Ds_&LZ8(==1o{eQH2 z2Mt|g&-2bQ!H_GM@?4XyVQM}g&YE|d!M1sL3EEKVgi6=|8H`>N&is^50K-8z8!=-N#KUFg+g&`A}>qm+9YNO z+J)f7MCU2OhZ6QZ(VPX82Lbz8;0(cTPLwAFUYXDe2`wAI2?4H?u$>Yz~b95Os4R*CBG60hiFZ9GwrC+jMj6P0N#Lz9x)!3%Lsr>qywlgyTK=50{U2 z`Oi)qZ~lyv~i4cKl(XMD=GhVmUrV<{g;m3a)!VTQ7lqxWE;-voi1 z0P${0Lj>PN;Iab#Cd9f4y#x5t2Hly+^$6_^*!uwg17Ia89%E=Alk+fbDO%Z_$z!P8 zkD2o_bP?Sar*Q!z_JgoX3Qs6<3c~)5w6jDUE~`H#a7e<|3vwqyCj{bK!ml9k0a7PH zIupVZGJPlLR57js>hA$xNRF{0u9jlnR18q%Vp-cisrK!Fv|}LOPiXfAW4f5zkog9v zufaG8jHk%%)0k~r8fMh_M17vf=SY4-vxChrFAZnFFdoGGAkQ=6dXiVua3T$x%DI)y zZjv{n(_`N>o+iT}0Vk#WMIn{|u%l9&7;%jgO9@<^&=e#eB=rm!yGz|~6!Elby(jB0 zi)O8hMb&K)c65YaQN#F0dr@{37%xe6 z0U`blU^53F1oRhS*5eL*N%UMu=7vDu=On*z*t252JduwH&BICE8;n8j*piI3!R|we zxGI%10@$@e8&uS#1AQwcyFUW$bRyO!+smQu!?RbDb!9LPHO5P3xnFT#-@LP{N_RfE zZ$jhcqz$C`-@!bR&dp%Wt~9>`ZnXzo5_t*oT9{N0QZ6TiQsVnZUeBefN>J` zlQ0Rwbr6oAuswm%1U?b?w-hgf{5&IOFyjeE?@`F|EOJ(VWF5}PQAB?4s3#Zp{n$ag zR&3U14t+t@`>D?T&>UYS@MKC`NzEu`-$2Vak5!WxJ-1r451Hx|qRyiEOB8aA6?E2c_`XhGfvC#^I?#ywh-QDVnNe70BxCPnj1K1DV0(I^zDn{&u^E$S_7${= z0f(E)+(6zeL^D5ITR7{BEUho56t=dQ%kx z*lJyL?J!oG#^}At(vG3(OC%pLD-Y7@6jGnld^x&pMdz{f&J-5@9VPcc!Bmyb zpKahpmb}lTr>R_=$d@2q33OJK@NcT_4aAOwwlvfW&6)+B_&LgZ~ zJr)h4=bG?b8J@#Yum+nr$eQj@mRT2>w`bGZL&@&J(yWyk@iuC%o*q|#?S^13K>9jq zwvH+OnT)lPd0xVPPhcSmCnIe~k^Pf)iP2sL;{&%i-i>>?Yosd&8|yNL+!D}UQqGgv z4vc6|24a{A-&1@Wu$e$koQ*W*!9ZEufbm2YB5@lh7ZIo!{Hk8u+hQ5}LP! zdZ-XD2pS8-<3xFw;FknH1b7#qJ*aq{!gfwx7Z&`1)V83W z1hf}ZW0|=KQcFlNR`iusw5Fhq1UpBx{X;w&!d!sf6Z{@iS%v9aL3X~xC4o9jV1L2> zAjNA+9XWfNj`7HL0R_gQ#@dLul^Ht_^sbDNXi^quW0TPOTM3><_)~yAOyEXRdyw`7*qlo?3jn?o$=yMF74)}39sq0B4v zPDym{l4c!4U|E6ZD`O{tk9n5;Ia|c>HJMX^I6|5=F{8U|*1qGj?M{tuovXIEv$kdT z8g_S83=G60iFVOU+aS}gkHpHMcszvrT4~QJ?A8_DZDo(N!o8t-ZU{SsnlDoLAi+~b zt^(TUqTNZ<&4^eanY#pX(Fz^xj0u$fKyVGQcZ3N$n|xb9Y(7r6>mtc%bv^NO3 zQ6fJ|@(?062J!$fmLoB@!+)RDivhfs%*BH3QpLNwxN%{#c!%u1Ddd4E^v~4(kr42WP0yFyY)N^UOWyBG8E%u|ELq$LxBjrw zA6AZn@m4an0&+4`P60SnD0745Mxygide6bI-nGciCt%Mtv!zTnl`3ZdoC=kCuF*oa$_yz(W!q0PvWAJtX`%+cS@sC2Xq1k06fwzkBX` zFpL**i^LlsTbqm_fIfnB8RY9B>>5N~3)7`we(mfYU+~L_j(7Wa6dM=WL7p1V%rQ(G zC}8WPf0n?$O235JEN)TOv|8t3aG1%rGL+qES_1ByKv=^RXIeH>4ZWjH=x=K0F~x97 zgCLzK`N-MzzVRKxZ*o?=}g)R4AWHz8|vlFGOcaWo(J8k27M7g&y;*lnknQy$#^l@Zk($BOw?v;2+d;vM*uz;@KuC*Qo@G_ zaT<|>5`EWrCE_BWu1VToh;|ZWizdqX0LKaWO(O0J z)bT+Z6!1r?as?re0b+YY-NX<-8g*EErZhUPG}^^IKJtQpnCl97TnNt*Dp;9? z&!CB8tkdpdOU&_{Frj@m7281m5wm%LvXg;k zjDSys+>g+E0EQDB2Q-HPHeJ94J`jI;2*@!2HU#V}(C3o%3w+Q7-z|ZAupu}wimLkgDM6(#tJOz}EiE@O&Z*bU!hR#xs zo^=i0I&hOAhdH!;LH^UhnFY2(5yrc62Uni$sbiQrjKS3zn4dL-8mFMvJyhdy)VhHp z{tLySWG+wUwPfB#*djnV2WnQ3>@&%4Q} zcSOXeidY$u2SM5ijN{369x$FF@@Z3yG}L2heHW8`U(?!ZR!1502s7Pnj-lq}=6*80 zoJ23PXx^W6BmESbZA1DxuyP(tDQN6A72S{}4^8K2Gf zUT7ajYPw|KAh^FW=T)uqD!QMjcIV8tyJNQP+R?3JYg-p;+uWf>j%m|=isZ>Pd4D8# ztx?Xe;m=m-#HzTuRXo&Y_HVN;+Gb8{lLy!2d>J_<0^>7K6d0hueu8fa+0zjIgUkmZ zeFI@Cg>wK5AaoL_D+QYqXf6_(YZGPN1lCTNC(1|3=F9{a73!IZ_(Z59MQoAKv%we` zjJ~8c7tv45LquH(XPz^zNhb?iaFp znXGS;tgah|5^mF@qkFTXOW45#>*R{w*j!f1Tjo7M@4blbhoh7eRZ0imTn6{yG;T)2 zjU+E4{bEBi)Y&t)d(*Mvt6Ax}!Mx|6^q&3TopG|xx3Zp*$$po~dj_TZKjh_iGTTwK z`NXngqI{9SDUsSLQu8WfB5QV8xq~HcqI5SEPQ@MwEUw7Q7473{>q*hJGou@qM?348 zZ2P{9Zp~=pq8d7{W?tH6yc)_|1^q19fdVf~U_TMV6F5V}*#i0-b%B8+Nz6-PMG$)c zxJ<-f#rOxTPGZp{x=uFYWH;Pfn7svYS%=-1I{f*mj{UN8hwc9w)1Mn+wE`XDjLi+c zzp1mD$v0=>EX&x#qq|gznCy{Pm2AH+>K;|p9_q+GgKjaz#mrdJrLT&#kSFG}%%PU; zdW>1`TCKraFGF;9M09sY*5j42p0b{mssE;Ml#=fNekM`YBX}WX^FY20R3=FMPRjh% z&lz)+jD9~UIUs~X5uiUu=cPoi; zCCiYa&Q1->F2#FRY^+DcZMot;%Dnj

    r`*%wWjg2o<3!FDJr@VHqPU9k#`#ewcI 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≫vUQb#-F!u*zClQN@?MP)=TWr=6%kyA9OtVAX{4{qPh3q*r z<>#h2R}i0pyacev1Ed$maPHL_ zw}R?Wq7DJ_X+R$XdI|D-kTw{Mzku;R&{+_)8Gz3R<)W~71gZ}Jogb*q+e97(v(sU| zIlVan?mNia4`6jMG5eD`2C%tj;fecRqS}pJ`MN`w7sDpS@vxg7cWPC#Zcf&}5xAbJ zivw6e@@;|g2H=|l!Hy8M^u`!;08q0IP+!8tAYAkqey`0rF_cPWpttWUey zbjq%#{6fj!lkgCs2LNm>VN@nQDVA%AK3?GNN^Zi$VyxWW!&kB7N(TSVg)v1~tH|$l z+0&FiOz}O)ZiVc0Dn`3-Il(t6n`A5px;Sr9b4Jl`K5tMCYoHyS@qtsf(l`g*mJ)G) ziiZbnM6zcvR92#z;k3?Q+?pvxwvT7N;n3hBjx*^a%lwG2yF}gz@LWmbnDxKR-ZdbO z5p$S~XQbspK|3|&%QG>F%%OljQS$ewv8Bkpl zP3NSK05DFT1 zg=-WXd&9IMT&uwF4;c;&!@rVtgjjk-+fjyFWOjoLKc{QgbZwD^w}sh?VRlTKeJA(b z)47FQl=+~vqM)x4Dto5<<&+(lwCB_6@8mN*z3*+6`fE5Y%fhe1c|{mUrL&XtMP)V@ zXgdkqPQ-r&Ob|6WT?@!{xC(ZMV+T3!gLAl94x{Diw7Mp(`&WAV3axvIS>FZDUndv* zdUm7UR~pq{n$!s;^VcH0RDdg;dd-mU8S<}G`@Lmd*s{`UeawO#6E89dL{2240qiQE zSy$o|NP808%0PG3b6j;#GIk)^Z^`cO!0td;9SFm!MlR*1JDlA`9PI@LT|@CYqC7>F zU#ZUJNWV$Rqm}tiX50&55fU#rZT(_Br#0*u(6F3ZP)eh6enHRVMm;YTm0unHpu?s( zb&oNxChP(NAGtW$;j7aH@VsWufmem75&Mm`d zp#BbOCSbclx==il}MGmioL4Cp%(sC@v=2J$vT_aR4I(?ML+ zLHExc#>ftH=Z4t1vAnRczGn;n_cCYSznyuE)Bf0qCpD_md$PM`6ZN=GV3Q_otCHm{ z&mxnz2EIq&SHk~6G^ z$XE^_y`hzJ!Ol0b<{xkllIQ%g_GOvY5u=FuLGbwjI}EUwz­iy+Pg%T8eDLy+%) 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%0A4os% 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 %Xwxw4s#^wgS`JdVVU#(cv} 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 P00000NkvXXu0mjfdVlSA diff --git a/shaders/world-1/texture/noises.png.mcmeta b/shaders/world-1/texture/noises.png.mcmeta deleted file mode 100644 index 33f3199..0000000 --- a/shaders/world-1/texture/noises.png.mcmeta +++ /dev/null @@ -1,7 +0,0 @@ -{ - "texture": - { - "blur": true, - "clamp": false - } -} \ No newline at end of file diff --git a/shaders/world1/block.properties b/shaders/world1/block.properties deleted file mode 100644 index 73045f4..0000000 --- a/shaders/world1/block.properties +++ /dev/null @@ -1,20 +0,0 @@ -#if MC_VERSION >= 11300 -block.10001= minecraft:acacia_sapling minecraft:birch_sapling minecraft:dark_oak_sapling minecraft:jungle_sapling minecraft:oak_sapling minecraft:spruce_sapling minecraft:grass minecraft:dead_bush minecraft:fern minecraft:dandelion minecraft:poppy minecraft:blue_orchid minecraft:allium minecraft:azure_bluet minecraft:orange_tulip minecraft:pink_tulip minecraft:red_tulip minecraft:white_tulip minecraft:oxeye_daisy minecraft:brown_mushroom minecraft:red_mushroom minecraft:wheat minecraft:nether_wart minecraft:carrot minecraft:potato minecraft:beetroot_seeds -block.10003 = minecraft:acacia_leaves minecraft:birch_leaves minecraft:dark_oak_leaves minecraft:jungle_leaves minecraft:oak_leaves minecraft:spruce_leaves minecraft:vine -block.10004 = minecraft:cobweb minecraft:sugar_cane minecraft:pumpkin_seeds minecraft:lily_pad minecraft:lilac minecraft:sunflower minecraft:tall_grass minecraft:rose_bush minecraft:peony minecraft:large_fern -block.10002= minecraft:black_stained_glass minecraft:black_stained_glass_pane minecraft:blue_stained_glass minecraft:blue_stained_glass_pane minecraft:brown_stained_glass minecraft:brown_stained_glass_pane minecraft:cyan_stained_glass minecraft:cyan_stained_glass_pane minecraft:gray_stained_glass minecraft:gray_stained_glass_pane minecraft:green_stained_glass minecraft:green_stained_glass_pane minecraft:light_blue_stained_glass minecraft:light_blue_stained_glass_pane minecraft:light_gray_stained_glass minecraft:light_gray_stained_glass_pane minecraft:lime_stained_glass minecraft:lime_stained_glass_pane minecraft:magenta_stained_glass minecraft:magenta_stained_glass_pane minecraft:orange_stained_glass minecraft:orange_stained_glass_pane minecraft:pink_stained_glass minecraft:pink_stained_glass_pane minecraft:purple_stained_glass minecraft:purple_stained_glass_pane minecraft:red_stained_glass minecraft:red_stained_glass_pane minecraft:white_stained_glass minecraft:white_stained_glass_pane minecraft:yellow_stained_glass minecraft:yellow_stained_glass_pane minecraft:glass_pane minecraft:glass -block.8 = minecraft:water minecraft:flowing_water -block.79 = minecraft:ice -block.10005 = minecraft:glowstone minecraft:torch minecraft:wall_torch minecraft:lava minecraft:fire minecraft:redstone_torch minecraft:redstone_wall_torch minecraft:jack_o_lantern minecraft:magma_block minecraft:redstone_lamp:lit=true minecraft:lantern minecraft:campfire:lit=true minecraft:shroomlight minecraft:nether_portal minecraft:soul_torch minecraft:soul_wall_torch minecraft:soul_fire minecraft:end_rod minecraft:sea_lantern minecraft:soul_lantern minecraft:end_gateway minecraft:soul_campfire:lit=true minecraft:lava minecraft:fire -#else -#wavy plants, translucent, bottom vertices not moving -block.10001= 6 31 32 37 38 39 40 59 115 141 142 207 -#wavy plants (blocks) -block.10003 = 18 106 161 -#translucent -block.10004 = 30 83 104 105 111 175 176 177 -#reflective surfaces (not including water and ice) -block.10002=95 160 -#endif - -layer.translucent=minecraft:glass_pane minecraft:glass diff --git a/shaders/world1/composite.fsh b/shaders/world1/composite.fsh new file mode 100644 index 0000000..ea05d63 --- /dev/null +++ b/shaders/world1/composite.fsh @@ -0,0 +1,467 @@ +#version 120 +#extension GL_EXT_gpu_shader4 : enable + +#include "/lib/settings.glsl" +#include "/lib/diffuse_lighting.glsl" + + +varying vec2 texcoord; + +flat varying vec3 avgAmbient; + +flat varying vec2 TAA_Offset; +flat varying float tempOffsets; + +const bool colortex5MipmapEnabled = true; +const bool colortex4MipmapEnabled = true; + +uniform sampler2D colortex0;//clouds +uniform sampler2D colortex1;//albedo(rgb),material(alpha) RGBA16 +uniform sampler2D colortex4;//Skybox +uniform sampler2D colortex3; +uniform sampler2D colortex7; +uniform sampler2D colortex5; +uniform sampler2D colortex2; +uniform sampler2D colortex8; +uniform sampler2D colortex10; +uniform sampler2D colortex15; +uniform sampler2D colortex6;//Skybox +uniform sampler2D depthtex1;//depth +uniform sampler2D depthtex0;//depth +uniform sampler2D noisetex;//depth + +uniform int heldBlockLightValue; +uniform int frameCounter; +uniform int isEyeInWater; +uniform mat4 shadowModelViewInverse; +uniform mat4 shadowProjectionInverse; +uniform float far; +uniform float near; +uniform float frameTimeCounter; +uniform float rainStrength; +uniform mat4 gbufferProjection; +uniform mat4 gbufferProjectionInverse; +uniform mat4 gbufferModelViewInverse; +uniform mat4 shadowModelView; +uniform mat4 shadowProjection; +uniform mat4 gbufferModelView; + +uniform mat4 gbufferPreviousModelView; +uniform mat4 gbufferPreviousProjection; +uniform vec3 previousCameraPosition; + +uniform vec2 texelSize; +uniform float viewWidth; +uniform float viewHeight; +uniform float aspectRatio; +uniform vec3 cameraPosition; +uniform vec3 sunVec; +uniform ivec2 eyeBrightnessSmooth; + +#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) +#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) + +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; +} +#include "/lib/color_transforms.glsl" +#include "/lib/waterBump.glsl" +#include "/lib/sky_gradient.glsl" + + + + +float ld(float dist) { + return (2.0 * near) / (far + near - dist * (far - near)); +} + +vec2 RENDER_SCALE = vec2(1.0); + +#include "/lib/end_fog.glsl" + +#include "/lib/specular.glsl" + + +vec3 normVec (vec3 vec){ + return vec*inversesqrt(dot(vec,vec)); +} +float lengthVec (vec3 vec){ + return sqrt(dot(vec,vec)); +} +#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) +float triangularize(float dither) +{ + float center = dither*2.0-1.0; + dither = center*inversesqrt(abs(center)); + return clamp(dither-fsign(center),0.0,1.0); +} +float interleaved_gradientNoise(float temp){ + return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+temp); +} +float interleaved_gradientNoise(){ + vec2 coord = gl_FragCoord.xy; + float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)); + return noise; +} +vec3 fp10Dither(vec3 color,float dither){ + const vec3 mantissaBits = vec3(6.,6.,5.); + vec3 exponent = floor(log2(color)); + return color + dither*exp2(-mantissaBits)*exp2(exponent); +} + + + +float facos(float sx){ + float x = clamp(abs( sx ),0.,1.); + return sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); +} +vec3 decode (vec2 encn){ + vec3 n = vec3(0.0); + encn = encn * 2.0 - 1.0; + n.xy = abs(encn); + n.z = 1.0 - n.x - n.y; + n.xy = n.z <= 0.0 ? (1.0 - n.yx) * sign(encn) : encn; + return clamp(normalize(n.xyz),-1.0,1.0); +} +vec2 decodeVec2(float a){ + const vec2 constant1 = 65535. / vec2( 256., 65536.); + const float constant2 = 256. / 255.; + return fract( a * constant1 ) * constant2 ; +} +// float linZ(float depth) { +// return (2.0 * near) / (far + near - depth * (far - near)); +// // l = (2*n)/(f+n-d(f-n)) +// // f+n-d(f-n) = 2n/l +// // -d(f-n) = ((2n/l)-f-n) +// // d = -((2n/l)-f-n)/(f-n) + +// } +// float invLinZ (float lindepth){ +// return -((2.0*near/lindepth)-far-near)/(far-near); +// } + +// vec3 toClipSpace3(vec3 viewSpacePosition) { +// return projMAD(gbufferProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; +// } + + + + +vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter,float distort) +{ + float alpha0 = sampleNumber/nb; + float alpha = (sampleNumber+jitter)/nb; + float angle = jitter*6.28 + alpha * 4.0 * 6.28; + + float sin_v, cos_v; + + sin_v = sin(angle); + cos_v = cos(angle); + + return vec2(cos_v, sin_v)*sqrt(alpha); +} + + + +vec3 BilateralFiltering(sampler2D tex, sampler2D depth,vec2 coord,float frDepth,float maxZ){ + vec4 sampled = vec4(texelFetch2D(tex,ivec2(coord),0).rgb,1.0); + + return vec3(sampled.x,sampled.yz/sampled.w); +} +float blueNoise(){ + return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); +} +float R2_dither(){ + vec2 alpha = vec2(0.75487765, 0.56984026); + return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y); +} +vec3 toShadowSpaceProjected(vec3 p3){ + p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; + p3 = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; + p3 = diagonal3(shadowProjection) * p3 + shadowProjection[3].xyz; + + return p3; +} +vec2 tapLocation(int sampleNumber, float spinAngle,int nb, float nbRot,float r0) +{ + float alpha = (float(sampleNumber*1.0f + r0) * (1.0 / (nb))); + float angle = alpha * (nbRot * 6.28) + spinAngle*6.28; + + float ssR = alpha; + float sin_v, cos_v; + + sin_v = sin(angle); + cos_v = cos(angle); + + return vec2(cos_v, sin_v)*ssR; +} + + +float ssao(vec3 fragpos, float dither,vec3 normal) +{ + float mulfov = 1.0; + ivec2 pos = ivec2(gl_FragCoord.xy); + const float tan70 = tan(70.*3.14/180.); + float mulfov2 = gbufferProjection[1][1]/tan70; + + const float PI = 3.14159265; + const float samplingRadius = 0.712; + float angle_thresh = 0.05; + + + + + float rd = mulfov2*0.05; + //pre-rotate direction + float n = 0.; + + float occlusion = 0.0; + + vec2 acc = -vec2(TAA_Offset)*texelSize*0.5; + float mult = (dot(normal,normalize(fragpos))+1.0)*0.5+0.5; + + vec2 v = fract(vec2(dither,interleaved_gradientNoise()) + (frameCounter%10000) * vec2(0.75487765, 0.56984026)); + for (int j = 0; j < 7+2 ;j++) { + vec2 sp = tapLocation(j,v.x,7+2,2.,v.y); + vec2 sampleOffset = sp*rd; + ivec2 offset = ivec2(gl_FragCoord.xy + sampleOffset*vec2(viewWidth,viewHeight)); + if (offset.x >= 0 && offset.y >= 0 && offset.x < viewWidth && offset.y < viewHeight ) { + vec3 t0 = toScreenSpace(vec3(offset*texelSize+acc+0.5*texelSize,texelFetch2D(depthtex1,offset,0).x)); + + vec3 vec = t0.xyz - fragpos; + float dsquared = dot(vec,vec); + if (dsquared > 1e-5){ + if (dsquared < fragpos.z*fragpos.z*0.05*0.05*mulfov2*2.*1.412){ + float NdotV = clamp(dot(vec*inversesqrt(dsquared), normalize(normal)),0.,1.); + occlusion += NdotV; + } + n += 1.0; + } + } + } + + + + + return clamp(1.0-occlusion/n*2.0,0.,1.0); +} +vec3 viewToWorld(vec3 viewPosition) { + vec4 pos; + pos.xyz = viewPosition; + pos.w = 0.0; + pos = gbufferModelViewInverse * pos; + return pos.xyz; +} +vec3 worldToView(vec3 worldPos) { + vec4 pos = vec4(worldPos, 0.0); + pos = gbufferModelView * pos; + return pos.xyz; +} +void waterVolumetrics(inout vec3 inColor, vec3 rayStart, vec3 rayEnd, float estEndDepth, float estSunDepth, float rayLength, float dither, vec3 waterCoefs, vec3 scatterCoef, vec3 ambient){ + inColor *= exp(-rayLength * waterCoefs); //No need to take the integrated value + int spCount = rayMarchSampleCount; + vec3 start = toShadowSpaceProjected(rayStart); + vec3 end = toShadowSpaceProjected(rayEnd); + vec3 dV = (end-start); + //limit ray length at 32 blocks for performance and reducing integration error + //you can't see above this anyway + float maxZ = min(rayLength,12.0)/(1e-8+rayLength); + dV *= maxZ; + vec3 dVWorld = -mat3(gbufferModelViewInverse) * (rayEnd - rayStart) * maxZ; + rayLength *= maxZ; + float dY = normalize(mat3(gbufferModelViewInverse) * rayEnd).y * rayLength; + estEndDepth *= maxZ; + estSunDepth *= maxZ; + vec3 absorbance = vec3(1.0); + vec3 vL = vec3(0.0); + + + float expFactor = 11.0; + vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; + for (int i=0;i -near) ? + (-near -position.z) / dir.z : far*sqrt(3.) ; + vec3 direction = toClipSpace3(position+dir*rayLength)-clipPosition; //convert to clip space + direction.xyz = direction.xyz/max(abs(direction.x)/texelSize.x,abs(direction.y)/texelSize.y); //fixed step size + vec3 stepv = direction * 3.0 * clamp(MC_RENDER_QUALITY,1.,2.0)*vec3(RENDER_SCALE,1.0); + + vec3 spos = clipPosition*vec3(RENDER_SCALE,1.0); + spos += stepv*dither ; + + for (int i = 0; i < int(quality); i++) { + spos += stepv; + + float sp = texture2D(depthtex1,spos.xy).x; + + if( sp < spos.z) { + float dist = abs(linZ(sp)-linZ(spos.z))/linZ(spos.z); + if (dist < 0.015 ) return i / quality; + } + } + return 1.0; +} + + +void main() { + float dirtAmount = Dirt_Amount; + vec3 waterEpsilon = vec3(Water_Absorb_R, Water_Absorb_G, Water_Absorb_B); + vec3 dirtEpsilon = vec3(Dirt_Absorb_R, Dirt_Absorb_G, Dirt_Absorb_B); + vec3 totEpsilon = dirtEpsilon*dirtAmount + waterEpsilon; + vec3 scatterCoef = dirtAmount * vec3(Dirt_Scatter_R, Dirt_Scatter_G, Dirt_Scatter_B) / 3.14; + + float z0 = texture2D(depthtex0,texcoord).x; + float z = texture2D(depthtex1,texcoord).x; + + vec2 tempOffset=TAA_Offset; + float noise = blueNoise(); + + vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(tempOffset)*texelSize*0.5,z)); + vec3 fragpos_RTSHADOW = toScreenSpace(vec3(texcoord,z)); + vec3 p3 = mat3(gbufferModelViewInverse) * fragpos; + vec3 np3 = normVec(p3); + + + vec4 trpData = texture2D(colortex7,texcoord); + bool iswater = trpData.a > 0.99; + vec4 SpecularTex = texture2D(colortex8,texcoord); + bool isEntities = texture2D(colortex10,texcoord).x > 0.0; + vec4 data = texture2D(colortex1,texcoord); // terraom + vec4 dataUnpacked0 = vec4(decodeVec2(data.x),decodeVec2(data.y)); + vec4 dataUnpacked1 = vec4(decodeVec2(data.z),decodeVec2(data.w)); + + float Translucent_Programs = texture2D(colortex2,texcoord).a; // the shader for all translucent progams. + // Normal // + vec3 normal = decode(dataUnpacked0.yw) ; + + vec4 normalAndAO = texture2D(colortex15,texcoord); + vec3 FlatNormals = normalAndAO.rgb * 2.0 - 1.0; + float vanilla_AO = 1.0 - exp2(-5 * pow(1-normalAndAO.a,3)) ; + + + vec3 albedo = toLinear(vec3(dataUnpacked0.xz,dataUnpacked1.x)); + + vec2 lightmap = dataUnpacked1.yz; + bool translucent = abs(dataUnpacked1.w-0.5) <0.01; + bool hand = abs(dataUnpacked1.w-0.75) <0.01; + + if (z >= 1.0) { + + gl_FragData[0].rgb = vec3(0.0); + + } else { + + p3 += gbufferModelViewInverse[3].xyz; + + // do all ambient lighting stuff + vec3 Indirect_lighting = DoAmbientLighting_End(gl_Fog.color.rgb, vec3(TORCH_R,TORCH_G,TORCH_B), lightmap.x, normal, np3) ; + // Indirect_lighting = vec3(TORCH_R,TORCH_G,TORCH_B) * curveinvert(clamp(lightmap.x,0.0,1.0),2); + + // float ambientfogshadow = GetCloudShadow2(p3+cameraPosition); + // Indirect_lighting *= ambientfogshadow; + + + vec3 LightColor = LightSourceColor(clamp(sqrt(length(p3+cameraPosition) / 150.0 - 1.0) ,0.0,1.0)); + vec3 LightPos = LightSourcePosition(p3+cameraPosition, cameraPosition); + + // float LightFalloff = max(exp2(4.0 + length(LightPos) / -50),0.0); + float LightFalloff = max(1.0-length(LightPos)/255,0.0); + LightFalloff = pow(1.0-pow(1.0-LightFalloff,0.5),2.0); + LightFalloff *= 10.0; + + // 0.5 added because lightsources are always high radius. + float NdotL = clamp( dot(normal,normalize(-LightPos)),0.0,1.0); + + float fogshadow = GetCloudShadow(p3+cameraPosition, LightPos, blueNoise()); + vec3 LightSource = (LightColor * max(LightColor - (1-fogshadow) ,0.0)) * LightFalloff * NdotL ; + + + + + + float LightFalloff2 = max(1.0-length(LightPos)/120,0.0); + LightFalloff2 = pow(1.0-pow(1.0-LightFalloff2,0.5),2.0); + LightFalloff2 *= 25; + + LightSource += (LightColor * (LightColor - 0.6)) * vec3(1.0,1.3,1.0) * LightFalloff2 * (NdotL*0.7+0.3); + + // float RT_Shadows = rayTraceShadow(worldToView(normalize(-LightPos)), fragpos_RTSHADOW, blueNoise()); + // if(!hand) LightSource *= RT_Shadows*RT_Shadows; + + + // finalize + gl_FragData[0].rgb = (Indirect_lighting + LightSource) * albedo; + + #ifdef Specular_Reflections + MaterialReflections_E(gl_FragData[0].rgb, SpecularTex.r, SpecularTex.ggg, albedo, normal, np3, fragpos, vec3(blueNoise(gl_FragCoord.xy).rg,noise), hand, LightColor * LightFalloff, normalize(-LightPos), isEntities); + #endif + + if(!hand) gl_FragData[0].rgb *= ssao(fragpos,noise,FlatNormals) * vanilla_AO; + + #ifdef LabPBR_Emissives + LabEmission(gl_FragData[0].rgb, albedo, SpecularTex.a); + #endif + + } + + ////// border Fog + if(Translucent_Programs > 0.0){ + vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); + float fogdistfade = 1.0 - clamp( exp(-pow(length(fragpos / far),2.)*5.0) ,0.0,1.0); + + gl_FragData[0].rgb = mix(gl_FragData[0].rgb, gl_Fog.color.rgb*0.5*NetherFog_brightness, fogdistfade) ; + } + + + ////// Water Fog + if ((isEyeInWater == 0 && iswater) || (isEyeInWater == 1 && !iswater)){ + vec3 fragpos0 = toScreenSpace(vec3(texcoord-vec2(tempOffset)*texelSize*0.5,z0)); + float Vdiff = distance(fragpos,fragpos0); + + if(isEyeInWater == 1) Vdiff = (length(fragpos)); + + float VdotU = np3.y; + float estimatedDepth = Vdiff; //assuming water plane + float estimatedSunDepth = estimatedDepth; //assuming water plane + + vec3 ambientColVol = vec3(1.0,0.25,0.5) * 0.33 ; + + waterVolumetrics(gl_FragData[0].rgb, fragpos0, fragpos, estimatedDepth , estimatedSunDepth, Vdiff, noise, totEpsilon, scatterCoef, ambientColVol); + } + +/* DRAWBUFFERS:3 */ +} diff --git a/shaders/world1/composite.vsh b/shaders/world1/composite.vsh new file mode 100644 index 0000000..6d29816 --- /dev/null +++ b/shaders/world1/composite.vsh @@ -0,0 +1,51 @@ +#version 120 +#extension GL_EXT_gpu_shader4 : enable + +#include "/lib/settings.glsl" + +varying vec2 texcoord; + +flat varying vec3 avgAmbient; + +flat varying float tempOffsets; +flat varying vec2 TAA_Offset; +flat varying vec3 zMults; + +uniform sampler2D colortex4; + +uniform float far; +uniform float near; +uniform mat4 gbufferModelViewInverse; +uniform vec3 sunPosition; +uniform float rainStrength; +uniform float sunElevation; +uniform int frameCounter; + +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.); + + +#include "/lib/util.glsl" + +void main() { + gl_Position = ftransform(); + texcoord = gl_MultiTexCoord0.xy; + + tempOffsets = HaltonSeq2(frameCounter%10000); + + TAA_Offset = offsets[frameCounter%8]; + + #ifndef TAA + TAA_Offset = vec2(0.0); + #endif + + + avgAmbient = texelFetch2D(colortex4,ivec2(0,37),0).rgb; + zMults = vec3((far * near)*2.0,far+near,far-near); +} diff --git a/shaders/world1/composite10.fsh b/shaders/world1/composite10.fsh index 25c81c0..298ca9a 100644 --- a/shaders/world1/composite10.fsh +++ b/shaders/world1/composite10.fsh @@ -1,45 +1,483 @@ #version 120 -//downsample 1st pass (half res) for bloom +//Vignetting, applies bloom, applies exposure and tonemaps the final image +#extension GL_EXT_gpu_shader4 : enable +#include "/lib/settings.glsl" + +#ifdef DOF + //hexagon pattern + const vec2 hex_offsets[60] = vec2[60] ( vec2( 0.2165, 0.1250 ), + vec2( 0.0000, 0.2500 ), + vec2( -0.2165, 0.1250 ), + vec2( -0.2165, -0.1250 ), + vec2( -0.0000, -0.2500 ), + vec2( 0.2165, -0.1250 ), + vec2( 0.4330, 0.2500 ), + vec2( 0.0000, 0.5000 ), + vec2( -0.4330, 0.2500 ), + vec2( -0.4330, -0.2500 ), + vec2( -0.0000, -0.5000 ), + vec2( 0.4330, -0.2500 ), + vec2( 0.6495, 0.3750 ), + vec2( 0.0000, 0.7500 ), + vec2( -0.6495, 0.3750 ), + vec2( -0.6495, -0.3750 ), + vec2( -0.0000, -0.7500 ), + vec2( 0.6495, -0.3750 ), + vec2( 0.8660, 0.5000 ), + vec2( 0.0000, 1.0000 ), + vec2( -0.8660, 0.5000 ), + vec2( -0.8660, -0.5000 ), + vec2( -0.0000, -1.0000 ), + vec2( 0.8660, -0.5000 ), + vec2( 0.2163, 0.3754 ), + vec2( -0.2170, 0.3750 ), + vec2( -0.4333, -0.0004 ), + vec2( -0.2163, -0.3754 ), + vec2( 0.2170, -0.3750 ), + vec2( 0.4333, 0.0004 ), + vec2( 0.4328, 0.5004 ), + vec2( -0.2170, 0.6250 ), + vec2( -0.6498, 0.1246 ), + vec2( -0.4328, -0.5004 ), + vec2( 0.2170, -0.6250 ), + vec2( 0.6498, -0.1246 ), + vec2( 0.6493, 0.6254 ), + vec2( -0.2170, 0.8750 ), + vec2( -0.8663, 0.2496 ), + vec2( -0.6493, -0.6254 ), + vec2( 0.2170, -0.8750 ), + vec2( 0.8663, -0.2496 ), + vec2( 0.2160, 0.6259 ), + vec2( -0.4340, 0.5000 ), + vec2( -0.6500, -0.1259 ), + vec2( -0.2160, -0.6259 ), + vec2( 0.4340, -0.5000 ), + vec2( 0.6500, 0.1259 ), + vec2( 0.4325, 0.7509 ), + vec2( -0.4340, 0.7500 ), + vec2( -0.8665, -0.0009 ), + vec2( -0.4325, -0.7509 ), + vec2( 0.4340, -0.7500 ), + vec2( 0.8665, 0.0009 ), + vec2( 0.2158, 0.8763 ), + vec2( -0.6510, 0.6250 ), + vec2( -0.8668, -0.2513 ), + vec2( -0.2158, -0.8763 ), + vec2( 0.6510, -0.6250 ), + vec2( 0.8668, 0.2513 )); + + const vec2 offsets[60] = vec2[60] ( vec2( 0.0000, 0.2500 ), + vec2( -0.2165, 0.1250 ), + vec2( -0.2165, -0.1250 ), + vec2( -0.0000, -0.2500 ), + vec2( 0.2165, -0.1250 ), + vec2( 0.2165, 0.1250 ), + vec2( 0.0000, 0.5000 ), + vec2( -0.2500, 0.4330 ), + vec2( -0.4330, 0.2500 ), + vec2( -0.5000, 0.0000 ), + vec2( -0.4330, -0.2500 ), + vec2( -0.2500, -0.4330 ), + vec2( -0.0000, -0.5000 ), + vec2( 0.2500, -0.4330 ), + vec2( 0.4330, -0.2500 ), + vec2( 0.5000, -0.0000 ), + vec2( 0.4330, 0.2500 ), + vec2( 0.2500, 0.4330 ), + vec2( 0.0000, 0.7500 ), + vec2( -0.2565, 0.7048 ), + vec2( -0.4821, 0.5745 ), + vec2( -0.6495, 0.3750 ), + vec2( -0.7386, 0.1302 ), + vec2( -0.7386, -0.1302 ), + vec2( -0.6495, -0.3750 ), + vec2( -0.4821, -0.5745 ), + vec2( -0.2565, -0.7048 ), + vec2( -0.0000, -0.7500 ), + vec2( 0.2565, -0.7048 ), + vec2( 0.4821, -0.5745 ), + vec2( 0.6495, -0.3750 ), + vec2( 0.7386, -0.1302 ), + vec2( 0.7386, 0.1302 ), + vec2( 0.6495, 0.3750 ), + vec2( 0.4821, 0.5745 ), + vec2( 0.2565, 0.7048 ), + vec2( 0.0000, 1.0000 ), + vec2( -0.2588, 0.9659 ), + vec2( -0.5000, 0.8660 ), + vec2( -0.7071, 0.7071 ), + vec2( -0.8660, 0.5000 ), + vec2( -0.9659, 0.2588 ), + vec2( -1.0000, 0.0000 ), + vec2( -0.9659, -0.2588 ), + vec2( -0.8660, -0.5000 ), + vec2( -0.7071, -0.7071 ), + vec2( -0.5000, -0.8660 ), + vec2( -0.2588, -0.9659 ), + vec2( -0.0000, -1.0000 ), + vec2( 0.2588, -0.9659 ), + vec2( 0.5000, -0.8660 ), + vec2( 0.7071, -0.7071 ), + vec2( 0.8660, -0.5000 ), + vec2( 0.9659, -0.2588 ), + vec2( 1.0000, -0.0000 ), + vec2( 0.9659, 0.2588 ), + vec2( 0.8660, 0.5000 ), + vec2( 0.7071, 0.7071 ), + vec2( 0.5000, 0.8660 ), + vec2( 0.2588, 0.9659 )); + +const vec2 shadow_offsets[209] = vec2[209](vec2(0.8886414f , 0.07936136f), +vec2(0.8190064f , 0.1900164f), +vec2(0.8614115f , -0.06991258f), +vec2(0.7685533f , 0.03792081f), +vec2(0.9970094f , 0.02585129f), +vec2(0.9686818f , 0.1570935f), +vec2(0.9854341f , -0.09172997f), +vec2(0.9330608f , 0.3326486f), +vec2(0.8329557f , -0.2438523f), +vec2(0.664771f , -0.0837701f), +vec2(0.7429124f , -0.1530652f), +vec2(0.9506453f , -0.2174281f), +vec2(0.8192949f , 0.3485171f), +vec2(0.6851269f , 0.2711877f), +vec2(0.7665657f , 0.5014166f), +vec2(0.673241f , 0.3793408f), +vec2(0.6981376f , 0.1465924f), +vec2(0.6521665f , -0.2384985f), +vec2(0.5145761f , -0.05752508f), +vec2(0.5641244f , -0.169443f), +vec2(0.5916035f , 0.06004957f), +vec2(0.57079f , 0.234188f), +vec2(0.509311f , 0.1523665f), +vec2(0.4204576f , 0.05759521f), +vec2(0.8200846f , -0.3601041f), +vec2(0.6893264f , -0.3473432f), +vec2(0.4775535f , -0.3062558f), +vec2(0.438106f , -0.1796866f), +vec2(0.4056528f , -0.08251233f), +vec2(0.5771964f , 0.5502692f), +vec2(0.5094061f , 0.4025192f), +vec2(0.6908483f , 0.572951f), +vec2(0.5379036f , -0.4542191f), +vec2(0.8167359f , -0.4793735f), +vec2(0.6829269f , -0.4557574f), +vec2(0.5725697f , -0.3477072f), +vec2(0.5767449f , -0.5782524f), +vec2(0.3979413f , -0.4172934f), +vec2(0.4282598f , -0.5145645f), +vec2(0.938814f , -0.3239739f), +vec2(0.702452f , -0.5662871f), +vec2(0.2832307f , -0.1285671f), +vec2(0.3230537f , -0.2691054f), +vec2(0.2921676f , -0.3734582f), +vec2(0.2534037f , -0.4906001f), +vec2(0.4343273f , 0.5223463f), +vec2(0.3605334f , 0.3151571f), +vec2(0.3498518f , 0.451428f), +vec2(0.3230703f , 0.00287089f), +vec2(0.1049206f , -0.1476725f), +vec2(0.2063161f , -0.2608192f), +vec2(0.7266634f , 0.6725333f), +vec2(0.4027067f , -0.6185485f), +vec2(0.2655533f , -0.5912259f), +vec2(0.4947965f , 0.3025357f), +vec2(0.5760762f , 0.68844f), +vec2(0.4909205f , -0.6975324f), +vec2(0.8609334f , 0.4559f), +vec2(0.1836646f , 0.03724086f), +vec2(0.2878554f , 0.178938f), +vec2(0.3948484f , 0.1618928f), +vec2(0.3519658f , -0.7628763f), +vec2(0.6338583f , -0.673193f), +vec2(0.5511802f , -0.8283072f), +vec2(0.4090595f , -0.8717521f), +vec2(0.1482169f , -0.374728f), +vec2(0.1050598f , -0.2613987f), +vec2(0.4210334f , 0.6578422f), +vec2(0.2430464f , 0.4383665f), +vec2(0.3329675f , 0.5512741f), +vec2(0.2147711f , 0.3245511f), +vec2(0.1227196f , 0.2529026f), +vec2(-0.03937457f , 0.156439f), +vec2(0.05618772f , 0.06690486f), +vec2(0.06519571f , 0.3974038f), +vec2(0.1360903f , 0.1466078f), +vec2(-0.00170609f , 0.3089452f), +vec2(0.1357622f , -0.5088975f), +vec2(0.1604694f , -0.7453476f), +vec2(0.1245694f , -0.6337074f), +vec2(0.02542936f , -0.3728781f), +vec2(0.02222222f , -0.649554f), +vec2(0.09870815f , 0.5357338f), +vec2(0.2073958f , 0.5452989f), +vec2(0.216654f , -0.8935689f), +vec2(0.2422334f , 0.665805f), +vec2(0.0574713f , 0.6742729f), +vec2(0.2021346f , 0.8144029f), +vec2(0.3086587f , 0.7504997f), +vec2(0.02122174f , -0.7498575f), +vec2(-0.1551729f , 0.1809731f), +vec2(-0.1947583f , 0.06246066f), +vec2(-0.05754202f , -0.03901273f), +vec2(-0.1083095f , 0.2952235f), +vec2(-0.03259534f , -0.492394f), +vec2(-0.02488567f , -0.2081116f), +vec2(-0.1820729f , -0.1829884f), +vec2(-0.1674413f , -0.04529009f), +vec2(0.04342153f , -0.0368562f), +vec2(0.801399f , -0.5845526f), +vec2(0.3158276f , -0.9124843f), +vec2(-0.05945269f , 0.6727523f), +vec2(0.07701834f , 0.8579889f), +vec2(-0.05778154f , 0.5699022f), +vec2(0.1191713f , 0.7542591f), +vec2(-0.2578296f , 0.3630984f), +vec2(-0.1428598f , 0.4557526f), +vec2(-0.3304029f , 0.5055485f), +vec2(-0.3227198f , 0.1847367f), +vec2(-0.4183801f , 0.3412776f), +vec2(0.2538475f , 0.9317476f), +vec2(0.406249f , 0.8423664f), +vec2(0.4718862f , 0.7592828f), +vec2(0.168472f , -0.06605823f), +vec2(0.2632498f , -0.7084918f), +vec2(-0.2816192f , -0.1023492f), +vec2(-0.3161443f , 0.02489911f), +vec2(-0.4677814f , 0.08450397f), +vec2(-0.4156994f , 0.2408664f), +vec2(-0.237449f , 0.2605326f), +vec2(-0.0912179f , 0.06491816f), +vec2(0.01475127f , 0.7670643f), +vec2(0.1216858f , -0.9368939f), +vec2(0.07010741f , -0.841011f), +vec2(-0.1708607f , -0.4152923f), +vec2(-0.1345006f , -0.5842513f), +vec2(-0.09419055f , -0.3213732f), +vec2(-0.2149337f , 0.730642f), +vec2(-0.1102187f , 0.8425013f), +vec2(-0.1808572f , 0.6244397f), +vec2(-0.2414505f , -0.7063725f), +vec2(-0.2410318f , -0.537854f), +vec2(-0.1005938f , -0.7635075f), +vec2(0.1053517f , 0.9678772f), +vec2(-0.3340288f , 0.6926677f), +vec2(-0.2363931f , 0.8464488f), +vec2(-0.4057773f , 0.7786722f), +vec2(-0.5484858f , 0.1686208f), +vec2(-0.64842f , 0.02256887f), +vec2(-0.5544513f , -0.02348978f), +vec2(-0.492855f , -0.1083694f), +vec2(-0.4248196f , 0.4674786f), +vec2(-0.5873146f , 0.4072608f), +vec2(-0.6439911f , 0.3038489f), +vec2(-0.6419188f , 0.1293737f), +vec2(-0.005880734f , 0.4699725f), +vec2(-0.4239455f , 0.6250131f), +vec2(-0.1701273f , 0.9506347f), +vec2(7.665656E-05f , 0.9941212f), +vec2(-0.7070159f , 0.4426281f), +vec2(-0.7481344f , 0.3139496f), +vec2(-0.8330062f , 0.2472693f), +vec2(-0.7271438f , 0.2024286f), +vec2(-0.5179888f , 0.3149576f), +vec2(-0.8258062f , 0.3779382f), +vec2(-0.8063191f , 0.1262931f), +vec2(-0.2690676f , -0.4360798f), +vec2(-0.3714577f , -0.5887412f), +vec2(-0.3736085f , -0.4018324f), +vec2(-0.3228985f , -0.2063406f), +vec2(-0.2414576f , -0.2875458f), +vec2(-0.4720859f , -0.3823904f), +vec2(-0.4937642f , -0.2686005f), +vec2(-0.01500604f , -0.9587054f), +vec2(-0.08535925f , -0.8820614f), +vec2(-0.6436375f , -0.3157263f), +vec2(-0.5736347f , -0.4224878f), +vec2(-0.5026127f , -0.5516239f), +vec2(-0.8200902f , 0.5370023f), +vec2(-0.7196413f , 0.57133f), +vec2(-0.5849072f , 0.5917885f), +vec2(-0.1598758f , -0.9739854f), +vec2(-0.4230629f , -0.01858409f), +vec2(-0.9403627f , 0.2213769f), +vec2(-0.685889f , -0.2192711f), +vec2(-0.6693704f , -0.4884708f), +vec2(-0.7967147f , -0.3078234f), +vec2(-0.596441f , -0.1686891f), +vec2(-0.7366468f , -0.3939891f), +vec2(-0.7963406f , 0.02246814f), +vec2(-0.9177913f , 0.0929693f), +vec2(-0.9284672f , 0.3329005f), +vec2(-0.6497722f , 0.6851863f), +vec2(-0.496019f , 0.7013303f), +vec2(-0.3930301f , -0.6892192f), +vec2(-0.2122009f , -0.8777389f), +vec2(-0.3660335f , -0.801644f), +vec2(-0.386839f , -0.1191898f), +vec2(-0.7020127f , -0.0776734f), +vec2(-0.7760845f , -0.1566844f), +vec2(-0.5444778f , -0.6516482f), +vec2(-0.5331346f , 0.4946506f), +vec2(-0.3288236f , 0.9408244f), +vec2(0.5819826f , 0.8101937f), +vec2(-0.4894184f , -0.8290837f), +vec2(-0.5183194f , 0.8454953f), +vec2(-0.7665774f , -0.5223897f), +vec2(-0.6703191f , -0.6217513f), +vec2(-0.8902924f , -0.2446688f), +vec2(-0.8574848f , -0.09174173f), +vec2(-0.3544409f , -0.9239591f), +vec2(-0.969833f , -0.1172272f), +vec2(-0.8968207f , -0.4079512f), +vec2(-0.5891477f , 0.7724466f), +vec2(-0.2146262f , 0.5286855f), +vec2(-0.3762444f , -0.3014335f), +vec2(-0.9466863f , -0.008970681f), +vec2(-0.596356f , -0.7976127f), +vec2(-0.8877738f , 0.4569088f)); +#endif +flat varying vec4 exposure; +flat varying float rodExposure; +varying vec2 texcoord; +uniform sampler2D colortex4; +uniform sampler2D colortex5; uniform sampler2D colortex3; +uniform sampler2D colortex7; +uniform sampler2D depthtex0; +uniform sampler2D noisetex; uniform vec2 texelSize; + uniform float viewWidth; uniform float viewHeight; -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// +uniform float frameTimeCounter; +uniform int frameCounter; +uniform int isEyeInWater; +uniform float near; +uniform float aspectRatio; +uniform float far; + +#include "/lib/color_transforms.glsl" +#include "/lib/color_dither.glsl" + + + +float cdist(vec2 coord) { + return max(abs(coord.s-0.5),abs(coord.t-0.5))*2.0; +} +float blueNoise(){ + return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); +} +float ld(float depth) { + return (2.0 * near) / (far + near - depth * (far - near)); // (-depth * (far - near)) = (2.0 * near)/ld - far - near +} +vec3 closestToCamera3x3() +{ + vec2 du = vec2(texelSize.x, 0.0); + vec2 dv = vec2(0.0, texelSize.y); + + vec3 dtl = vec3(texcoord,0.) + vec3(-texelSize, texture2D(depthtex0, texcoord - dv - du).x); + vec3 dtc = vec3(texcoord,0.) + vec3( 0.0, -texelSize.y, texture2D(depthtex0, texcoord - dv).x); + vec3 dtr = vec3(texcoord,0.) + vec3( texelSize.x, -texelSize.y, texture2D(depthtex0, texcoord - dv + du).x); + + vec3 dml = vec3(texcoord,0.) + vec3(-texelSize.x, 0.0, texture2D(depthtex0, texcoord - du).x); + vec3 dmc = vec3(texcoord,0.) + vec3( 0.0, 0.0, texture2D(depthtex0, texcoord).x); + vec3 dmr = vec3(texcoord,0.) + vec3( texelSize.x, 0.0, texture2D(depthtex0, texcoord + du).x); + + vec3 dbl = vec3(texcoord,0.) + vec3(-texelSize.x, texelSize.y, texture2D(depthtex0, texcoord + dv - du).x); + vec3 dbc = vec3(texcoord,0.) + vec3( 0.0, texelSize.y, texture2D(depthtex0, texcoord + dv).x); + vec3 dbr = vec3(texcoord,0.) + vec3( texelSize.x, texelSize.y, texture2D(depthtex0, texcoord + dv + du).x); + + vec3 dmin = dmc; + + dmin = dmin.z > dtc.z? dtc : dmin; + dmin = dmin.z > dtr.z? dtr : dmin; + + dmin = dmin.z > dml.z? dml : dmin; + dmin = dmin.z > dtl.z? dtl : dmin; + dmin = dmin.z > dmr.z? dmr : dmin; + + dmin = dmin.z > dbl.z? dbl : dmin; + dmin = dmin.z > dbc.z? dbc : dmin; + dmin = dmin.z > dbr.z? dbr : dmin; + + return dmin; +} void main() { + /* DRAWBUFFERS:7 */ + float vignette = (1.5-dot(texcoord-0.5,texcoord-0.5)*2.5); + vec3 col = texture2D(colortex5,texcoord).rgb; + #ifdef DOF + /*--------------------------------*/ + float z = ld(texture2D(depthtex0, texcoord.st).r)*far; + #ifdef AUTOFOCUS + float focus = ld(texture2D(depthtex0, vec2(0.5)).r)*far; + #else + float focus = MANUAL_FOCUS; + #endif + float pcoc = min(abs(aperture * (focal/100.0 * (z - focus)) / (z * (focus - focal/100.0))),texelSize.x*15.0); + #ifdef FAR_BLUR_ONLY + pcoc *= float(z > focus); + #endif + float noise = blueNoise()*6.28318530718; + mat2 noiseM = mat2( cos( noise ), -sin( noise ), + sin( noise ), cos( noise ) + ); + vec3 bcolor = vec3(0.); + float nb = 0.0; + vec2 bcoord = vec2(0.0); + /*--------------------------------*/ + #ifndef HQ_DOF + bcolor = col; + #ifdef HEXAGONAL_BOKEH + for ( int i = 0; i < 60; i++) { + bcolor += texture2D(colortex5, texcoord.xy + hex_offsets[i]*pcoc*vec2(1.0,aspectRatio)).rgb; + } + col = bcolor/61.0; + #else + for ( int i = 0; i < 60; i++) { + bcolor += texture2D(colortex5, texcoord.xy + offsets[i]*pcoc*vec2(1.0,aspectRatio)).rgb; + } + /*--------------------------------*/ + col = bcolor/61.0; + #endif + #endif + #ifdef HQ_DOF + for ( int i = 0; i < 209; i++) { + bcolor += texture2D(colortex5, texcoord.xy + noiseM*shadow_offsets[i]*pcoc*vec2(1.0,aspectRatio)).rgb; + } + col = bcolor/209.0; + #endif +#endif + vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); -/* DRAWBUFFERS:6 */ -vec2 resScale = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))/vec2(1920.,1080.); -vec2 quarterResTC = gl_FragCoord.xy*2.*texelSize; + vec3 bloom = texture2D(colortex3,texcoord/clampedRes*vec2(1920.,1080.)*0.5).rgb/2./7.0; - //0.5 - gl_FragData[0] = texture2D(colortex3,quarterResTC-1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex3,quarterResTC+1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(-1.0*texelSize.x,1.0*texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(1.0*texelSize.x,-1.0*texelSize.y))/4.*0.5; - - //0.25 - gl_FragData[0] += texture2D(colortex3,quarterResTC-2.0*vec2(texelSize.x,0.0))/2.*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(0.0,texelSize.y))/2.*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(0,-texelSize.y))/2*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(-texelSize.x,0.0))/2*0.125; - - //0.125 - gl_FragData[0] += texture2D(colortex3,quarterResTC-2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(-2.0*texelSize.x,2.0*texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(2.0*texelSize.x,-2.0*texelSize.y))/4.*0.125; - - //0.125 - gl_FragData[0] += texture2D(colortex3,quarterResTC)*0.125; - - gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); + float lightScat = clamp(BLOOM_STRENGTH * 0.05 * pow(exposure.a ,0.2) ,0.0,1.0)*vignette; + float VL_abs = texture2D(colortex7,texcoord).r; + VL_abs = clamp((1.0-VL_abs*1.05)*BLOOMY_FOG*0.5,0.0,1.0)*clamp(1.0-pow(cdist(texcoord.xy),15.0),0.0,1.0); + col = ( mix(col, bloom, VL_abs) + bloom*lightScat) * exposure.rgb; +/* + //Purkinje Effect + float lum = dot(col,vec3(0.15,0.3,0.55)); + float lum2 = dot(col,vec3(0.85,0.7,0.45))/2; + float rodLum = lum2*300.0; + float rodCurve = mix(1.0, rodLum/(2.5+rodLum), rodExposure/2.0*Purkinje_strength); + col = mix(lum*Purkinje_Multiplier*vec3(Purkinje_R, Purkinje_G, Purkinje_B)+0.001, col, rodCurve); +*/ + #ifndef USE_ACES_COLORSPACE_APPROXIMATION + col = LinearTosRGB(TONEMAP(col)); + #else + col = col * ACESInputMat; + col = TONEMAP(col); + col = LinearTosRGB(clamp(col * ACESOutputMat, 0.0, 1.0)); + #endif + //col = ACESFitted(texture2D(colortex4,texcoord/3.).rgb/500.); + gl_FragData[0].rgb = clamp(int8Dither(col,texcoord),0.0,1.0); + //if (nightMode < 0.99 && texcoord.x < 0.5) gl_FragData[0].rgb =vec3(0.0,1.0,0.0); } diff --git a/shaders/world1/composite10.vsh b/shaders/world1/composite10.vsh index 8d47d5c..634d9d3 100644 --- a/shaders/world1/composite10.vsh +++ b/shaders/world1/composite10.vsh @@ -1,7 +1,13 @@ #version 120 +#extension GL_EXT_gpu_shader4 : enable + +#include "/lib/settings.glsl" + +varying vec2 texcoord; +flat varying vec4 exposure; +flat varying float rodExposure; +uniform sampler2D colortex4; -uniform float viewWidth; -uniform float viewHeight; //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -9,9 +15,9 @@ uniform float viewHeight; //////////////////////////////VOID MAIN////////////////////////////// void main() { - //Improves performances and makes sure bloom radius stays the same at high resolution (>1080p) - vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); + gl_Position = ftransform(); - //*0.51 to avoid errors when sampling outside since clearing is disabled - gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.26/clampedRes*vec2(1920.0,1080.)*2-1.0; + texcoord = gl_MultiTexCoord0.xy; + exposure=vec4(texelFetch2D(colortex4,ivec2(10,37),0).r*vec3(FinalR,FinalG,FinalB),texelFetch2D(colortex4,ivec2(10,37),0).r); + rodExposure = texelFetch2D(colortex4,ivec2(14,37),0).r; } diff --git a/shaders/world1/composite12.fsh b/shaders/world1/composite12.fsh deleted file mode 100644 index dd63b74..0000000 --- a/shaders/world1/composite12.fsh +++ /dev/null @@ -1,61 +0,0 @@ -#version 120 -//6 Vertical gaussian blurs and vertical downsampling - - - -uniform sampler2D colortex6; -uniform vec2 texelSize; -varying vec2 texcoord; -uniform float viewWidth; -uniform float viewHeight; -vec2 resScale = vec2(1920.,1080.)/max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); -vec3 gauss1D(vec2 coord,vec2 dir,float alpha,int maxIT){ - vec4 tot = vec4(0.); - float maxTC = 0.25*resScale.y; - float minTC = 0.; - for (int i = -maxIT;i minTC && spCoord.y < maxTC); - } - return tot.rgb/max(1.0,tot.a); -} - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { -/* DRAWBUFFERS:6 */ -vec2 texcoord = (gl_FragCoord.xy*vec2(2.0,4.0))*texelSize; - -vec2 gaussDir = vec2(0.0,1.0); -gl_FragData[0].rgb = vec3(0.0); -vec2 tc2 = texcoord*vec2(2.0,1.); -if (tc2.x < 1.0*resScale.x && tc2.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord/vec2(2.0,4.0),gaussDir,0.16,0); - -vec2 tc4 = texcoord*vec2(4.0,2.)-vec2(0.5*resScale.x+4.0*texelSize.x,0.)*4.0; -if (tc4.x > 0.0 && tc4.y > 0.0 && tc4.x < 1.0*resScale.x && tc4.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord/vec2(2.0,2.0),gaussDir,0.16,3); - -vec2 tc8 = texcoord*vec2(8.0,4.)-vec2(0.75*resScale.x+8.*texelSize.x,0.)*8.0; -if (tc8.x > 0.0 && tc8.y > 0.0 && tc8.x < 1.0*resScale.x && tc8.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,2.0)/vec2(2.0,2.0),gaussDir,0.035,6); - -vec2 tc16 = texcoord*vec2(16.0,8.)-vec2(0.875*resScale.x+12.*texelSize.x,0.)*16.0; -if (tc16.x > 0.0 && tc16.y > 0.0 && tc16.x < 1.0*resScale.x && tc16.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,4.0)/vec2(2.0,2.0),gaussDir,0.0085,12); - -vec2 tc32 = texcoord*vec2(32.0,16.)-vec2(0.9375*resScale.x+16.*texelSize.x,0.)*32.0; -if (tc32.x > 0.0 && tc32.y > 0.0 && tc32.x < 1.0*resScale.x && tc32.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,8.0)/vec2(2.0,2.0),gaussDir,0.002,30); - -vec2 tc64 = texcoord*vec2(64.0,32.)-vec2(0.96875*resScale.x+20.*texelSize.x,0.)*64.0; -if (tc64.x > 0.0 && tc64.y > 0.0 && tc64.x < 1.0*resScale.x && tc64.y <1.0*resScale.y) -gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,16.0)/vec2(2.0,2.0),gaussDir,0.0005,60); - -gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); -} diff --git a/shaders/world1/composite12.vsh b/shaders/world1/composite12.vsh deleted file mode 100644 index 56683b4..0000000 --- a/shaders/world1/composite12.vsh +++ /dev/null @@ -1,21 +0,0 @@ -#version 120 - -uniform float viewWidth; -uniform float viewHeight; -varying vec2 texcoord; -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.0)); - gl_Position = ftransform(); - //0-0.25 - gl_Position.y = (gl_Position.y*0.5+0.5)*0.25/clampedRes.y*1080.0*2.0-1.0; - //0-0.5 - gl_Position.x = (gl_Position.x*0.5+0.5)*0.5/clampedRes.x*1920.0*2.0-1.0; - texcoord = gl_MultiTexCoord0.xy/clampedRes*vec2(1920.,1080.); - -} diff --git a/shaders/world1/composite14.fsh b/shaders/world1/composite14.fsh deleted file mode 100644 index 6bfa802..0000000 --- a/shaders/world1/composite14.fsh +++ /dev/null @@ -1,103 +0,0 @@ -#version 120 -//Merge and upsample the blurs into a 1/4 res bloom buffer - -uniform sampler2D colortex3; -uniform sampler2D colortex6; - -uniform vec2 texelSize; -uniform float viewWidth; -uniform float viewHeight; - -float w0(float a) -{ - return (1.0/6.0)*(a*(a*(-a + 3.0) - 3.0) + 1.0); -} - -float w1(float a) -{ - return (1.0/6.0)*(a*a*(3.0*a - 6.0) + 4.0); -} - -float w2(float a) -{ - return (1.0/6.0)*(a*(a*(-3.0*a + 3.0) + 3.0) + 1.0); -} - -float w3(float a) -{ - return (1.0/6.0)*(a*a*a); -} - -float g0(float a) -{ - return w0(a) + w1(a); -} - -float g1(float a) -{ - return w2(a) + w3(a); -} - -float h0(float a) -{ - return -1.0 + w1(a) / (w0(a) + w1(a)); -} - -float h1(float a) -{ - return 1.0 + w3(a) / (w2(a) + w3(a)); -} - -vec4 texture2D_bicubic(sampler2D tex, vec2 uv) -{ - vec4 texelSize = vec4(texelSize,1.0/texelSize); - uv = uv*texelSize.zw; - vec2 iuv = floor( uv ); - vec2 fuv = fract( uv ); - - float g0x = g0(fuv.x); - float g1x = g1(fuv.x); - float h0x = h0(fuv.x); - float h1x = h1(fuv.x); - float h0y = h0(fuv.y); - float h1y = h1(fuv.y); - - vec2 p0 = (vec2(iuv.x + h0x, iuv.y + h0y) - 0.5) * texelSize.xy; - vec2 p1 = (vec2(iuv.x + h1x, iuv.y + h0y) - 0.5) * texelSize.xy; - vec2 p2 = (vec2(iuv.x + h0x, iuv.y + h1y) - 0.5) * texelSize.xy; - vec2 p3 = (vec2(iuv.x + h1x, iuv.y + h1y) - 0.5) * texelSize.xy; - - return g0(fuv.y) * (g0x * texture2D(tex, p0) + - g1x * texture2D(tex, p1)) + - g1(fuv.y) * (g0x * texture2D(tex, p2) + - g1x * texture2D(tex, p3)); -} - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { -/* DRAWBUFFERS:3 */ -vec2 resScale = vec2(1920.,1080.)/max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); -vec2 texcoord = ((gl_FragCoord.xy)*2.+0.5)*texelSize; -vec3 bloom = texture2D_bicubic(colortex3,texcoord/2.0).rgb; //1/4 res - -bloom += texture2D_bicubic(colortex6,texcoord/4.).rgb; //1/8 res - -bloom += texture2D_bicubic(colortex6,texcoord/8.+vec2(0.25*resScale.x+2.5*texelSize.x,.0)).rgb; //1/16 res - -bloom += texture2D_bicubic(colortex6,texcoord/16.+vec2(0.375*resScale.x+4.5*texelSize.x,.0)).rgb; //1/32 res - -bloom += texture2D_bicubic(colortex6,texcoord/32.+vec2(0.4375*resScale.x+6.5*texelSize.x,.0)).rgb*1.0; //1/64 res -bloom += texture2D_bicubic(colortex6,texcoord/64.+vec2(0.46875*resScale.x+8.5*texelSize.x,.0)).rgb*1.0; //1/128 res -bloom += texture2D_bicubic(colortex6,texcoord/128.+vec2(0.484375*resScale.x+10.5*texelSize.x,.0)).rgb*1.0; //1/256 res - -//bloom = texture2D_bicubic(colortex6,texcoord).rgb*6.; //1/8 res - -gl_FragData[0].rgb = bloom*2.; - -gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); -} diff --git a/shaders/world1/composite14.vsh b/shaders/world1/composite14.vsh deleted file mode 100644 index 386f006..0000000 --- a/shaders/world1/composite14.vsh +++ /dev/null @@ -1,17 +0,0 @@ -#version 120 - -uniform float viewWidth; -uniform float viewHeight; -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - //Improves performances and makes sure bloom radius stays the same at high resolution (>1080p) - vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); - gl_Position = ftransform(); - //*0.51 to avoid errors when sampling outside since clearing is disabled - gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.51/clampedRes*vec2(1920.0,1080.)*2.0-1.0; -} diff --git a/shaders/world1/composite15.fsh b/shaders/world1/composite15.fsh deleted file mode 100644 index 74136a6..0000000 --- a/shaders/world1/composite15.fsh +++ /dev/null @@ -1,512 +0,0 @@ -#version 120 -//Vignetting, applies bloom, applies exposure and tonemaps the final image -#extension GL_EXT_gpu_shader4 : enable -#define Fake_purkinje -#define BLOOMY_FOG 2.0 //[0.0 0.25 0.5 0.75 1.0 1.25 1.5 1.75 2.0 3.0 4.0 6.0 10.0 15.0 20.0] -#define BLOOM_STRENGTH 4.0 //[0.0 0.25 0.5 0.75 1.0 1.25 1.5 1.75 2.0 3.0 4.0] -#define TONEMAP ToneMap_Hejl2015 // Tonemapping operator [Tonemap_Uchimura HableTonemap reinhard Tonemap_Lottes ACESFilm ToneMap_Hejl2015] -//#define USE_ACES_COLORSPACE_APPROXIMATION // Do the tonemap in another colorspace - -#define Purkinje_strength 1.0 // Simulates how the eye is unable to see colors at low light intensities. 0 = No purkinje effect at low exposures [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define Purkinje_R 0.4 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define Purkinje_G 0.7 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define Purkinje_B 1.0 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define Purkinje_Multiplier 5.0 // How much the purkinje effect increases brightness [0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.05 1.1 1.15 1.2 1.25 1.3 1.35 1.4 1.45 1.5 1.55 1.6 1.65 1.7 1.75 1.8 1.85 1.9 1.95 2.0 2.05 2.1 2.15 2.2 2.25 2.3 2.35 2.4 2.45 2.5 2.55 2.6 2.65 2.7 2.75 2.8 2.85 2.9 2.95 3.0 3.05 3.1 3.15 3.2 3.25 3.3 3.35 3.4 3.45 3.5 3.55 3.6 3.65 3.7 3.75 3.8 3.85 3.9 3.95 4.0 4.05 4.1 4.15 4.2 4.25 4.3 4.35 4.4 4.45 4.5 4.55 4.6 4.65 4.7 4.75 4.8 4.85 4.9 4.95 5.0 5.05 5.1 5.15 5.2 5.25 5.3 5.35 5.4 5.45 5.5 5.55 5.6 5.65 5.7 5.75 5.8 5.85 5.9 5.95 6.0 6.05 6.1 6.15 6.2 6.25 6.3 6.35 6.4 6.45 6.5 6.55 6.6 6.65 6.7 6.75 6.8 6.85 6.9 6.95 7.0 7.05 7.1 7.15 7.2 7.25 7.3 7.35 7.4 7.45 7.5 7.55 7.6 7.65 7.7 7.75 7.8 7.85 7.9 7.95 8.0 8.05 8.1 8.15 8.2 8.25 8.3 8.35 8.4 8.45 8.5 8.55 8.6 8.65 8.7 8.75 8.8 8.85 8.9 8.95 9.0 9.05 9.1 9.15 9.2 9.25 9.3 9.35 9.4 9.45 9.5 9.55 9.6 9.65 9.7 9.75 9.8 9.85 9.9 9.95 ] - - -//#define DOF //enable depth of field (blur on non-focused objects) -//#define HQ_DOF //Slow! Forces circular bokeh! Uses 4 times more samples with noise in order to remove sampling artifacts at great blur sizes. -//#define HEXAGONAL_BOKEH //disabled : circular blur shape - enabled : hexagonal blur shape -#define AUTOFOCUS -//#define FAR_BLUR_ONLY // Removes DoF on objects closer to the camera than the focus point -//lens properties -#define focal 2.4 // Centimeters [0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.05 1.1 1.15 1.2 1.25 1.3 1.35 1.4 1.45 1.5 1.55 1.6 1.65 1.7 1.75 1.8 1.85 1.9 1.95 2.0 2.05 2.1 2.15 2.2 2.25 2.3 2.35 2.4 2.45 2.5 2.55 2.6 2.65 2.7 2.75 2.8 2.85 2.9 2.95 3.0 3.05 3.1 3.15 3.2 3.25 3.3 3.35 3.4 3.45 3.5 3.55 3.6 3.65 3.7 3.75 3.8 3.85 3.9 3.95 4.0 4.05 4.1 4.15 4.2 4.25 4.3 4.35 4.4 4.45 4.5 4.55 4.6 4.65 4.7 4.75 4.8 4.85 4.9 4.95 5.0 5.05 5.1 5.15 5.2 5.25 5.3 5.35 5.4 5.45 5.5 5.55 5.6 5.65 5.7 5.75 5.8 5.85 5.9 5.95 6.0 6.05 6.1 6.15 6.2 6.25 6.3 6.35 6.4 6.45 6.5 6.55 6.6 6.65 6.7 6.75 6.8 6.85 6.9 6.95 7.0 7.05 7.1 7.15 7.2 7.25 7.3 7.35 7.4 7.45 7.5 7.55 7.6 7.65 7.7 7.75 7.8 7.85 7.9 7.95 8.0 8.05 8.1 8.15 8.2 8.25 8.3 8.35 8.4 8.45 8.5 8.55 8.6 8.65 8.7 8.75 8.8 8.85 8.9 8.95 9.0 9.05 9.1 9.15 9.2 9.25 9.3 9.35 9.4 9.45 9.5 9.55 9.6 9.65 9.7 9.75 9.8 9.85 9.9 9.95 ] -#define aperture 0.8 // Centimeters [0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.05 1.1 1.15 1.2 1.25 1.3 1.35 1.4 1.45 1.5 1.55 1.6 1.65 1.7 1.75 1.8 1.85 1.9 1.95 2.0 2.05 2.1 2.15 2.2 2.25 2.3 2.35 2.4 2.45 2.5 2.55 2.6 2.65 2.7 2.75 2.8 2.85 2.9 2.95 3.0 3.05 3.1 3.15 3.2 3.25 3.3 3.35 3.4 3.45 3.5 3.55 3.6 3.65 3.7 3.75 3.8 3.85 3.9 3.95 4.0 4.05 4.1 4.15 4.2 4.25 4.3 4.35 4.4 4.45 4.5 4.55 4.6 4.65 4.7 4.75 4.8 4.85 4.9 4.95 5.0 5.05 5.1 5.15 5.2 5.25 5.3 5.35 5.4 5.45 5.5 5.55 5.6 5.65 5.7 5.75 5.8 5.85 5.9 5.95 6.0 6.05 6.1 6.15 6.2 6.25 6.3 6.35 6.4 6.45 6.5 6.55 6.6 6.65 6.7 6.75 6.8 6.85 6.9 6.95 7.0 7.05 7.1 7.15 7.2 7.25 7.3 7.35 7.4 7.45 7.5 7.55 7.6 7.65 7.7 7.75 7.8 7.85 7.9 7.95 8.0 8.05 8.1 8.15 8.2 8.25 8.3 8.35 8.4 8.45 8.5 8.55 8.6 8.65 8.7 8.75 8.8 8.85 8.9 8.95 9.0 9.05 9.1 9.15 9.2 9.25 9.3 9.35 9.4 9.45 9.5 9.55 9.6 9.65 9.7 9.75 9.8 9.85 9.9 9.95 ] -#define MANUAL_FOCUS 48.0 // If autofocus is turned off, sets the focus point (meters) [0.06948345122280154 0.07243975703425146 0.07552184450877376 0.07873506526686186 0.0820849986238988 0.08557746127787037 0.08921851740926011 0.09301448921066349 0.09697196786440505 0.10109782498721881 0.10539922456186433 0.10988363537639657 0.11455884399268773 0.11943296826671962 0.12451447144412296 0.129812176855438 0.1353352832366127 0.1410933807013415 0.1470964673929768 0.15335496684492847 0.1598797460796939 0.16668213447794653 0.17377394345044514 0.18116748694692214 0.18887560283756183 0.19691167520419406 0.20528965757990927 0.21402409717744744 0.22313016014842982 0.2326236579172927 0.2425210746356487 0.25283959580474646 0.26359713811572677 0.27481238055948964 0.2865047968601901 0.29869468928867837 0.3114032239145977 0.32465246735834974 0.3384654251067422 0.3528660814588489 0.36787944117144233 0.3835315728763107 0.39984965434484737 0.4168620196785084 0.4345982085070782 0.453089017280169 0.4723665527410147 0.49246428767540973 0.513417119032592 0.5352614285189903 0.5580351457700471 0.5817778142098083 0.6065306597126334 0.6323366621862497 0.6592406302004438 0.6872892787909722 0.7165313105737893 0.7470175003104326 0.7788007830714049 0.8119363461506349 0.8464817248906141 0.8824969025845955 0.9200444146293233 0.9591894571091382 1.0 1.0425469051899914 1.086904049521229 1.1331484530668263 1.1813604128656459 1.2316236423470497 1.2840254166877414 1.338656724353094 1.3956124250860895 1.4549914146182013 1.5168967963882134 1.5814360605671443 1.6487212707001282 1.7188692582893286 1.7920018256557555 1.8682459574322223 1.9477340410546757 2.030604096634748 2.117000016612675 2.2070718156067044 2.300975890892825 2.398875293967098 2.5009400136621287 2.6073472713092674 2.718281828459045 2.833936307694169 2.9545115270921065 3.080216848918031 3.211270543153561 3.347900166492527 3.4903429574618414 3.638846248353525 3.7936678946831774 3.955076722920577 4.123352997269821 4.298788906309526 4.4816890703380645 4.672371070304759 4.871165999245474 5.0784190371800815 5.29449005047003 5.51975421667673 5.754602676005731 5.999443210467818 6.254700951936329 6.5208191203301125 6.798259793203881 7.087504708082256 7.38905609893065 7.703437568215379 8.031194996067258 8.372897488127265 8.72913836372013 9.10053618607165 9.487735836358526 9.891409633455755 10.312258501325767 10.751013186076355 11.208435524800691 11.685319768402522 12.182493960703473 12.700821376227164 13.241202019156521 13.804574186067095 14.391916095149892 15.00424758475255 15.642631884188171 16.30817745988666 17.00203994009402 17.725424121461643 18.479586061009854 19.265835257097933 20.085536923187668 20.940114358348602 21.831051418620845 22.75989509352673 23.728258192205157 24.737822143832553 25.790339917193062 26.88763906446752 28.03162489452614 29.22428378123494 30.46768661252054 31.763992386181833 33.11545195869231 34.52441195350251 35.99331883562839 37.524723159600995 39.12128399815321 40.78577355933337 42.52108200006278 44.3302224444953 46.21633621589248 48.182698291098816 50.23272298708815 52.36996988945491 54.598150033144236 56.92113234615337 59.34295036739207 61.867809250367884 64.50009306485578 67.24437240923179 70.10541234668786 73.08818067910767 76.19785657297057 79.43983955226133 82.81975887399955 86.3434833026695 90.01713130052181 93.84708165144015 97.83998453682129 102.00277308269969 106.34267539816554 110.86722712598126 115.58428452718766 120.50203812241894 125.62902691361414 130.9741532108186 136.54669808981876 142.35633750745257 148.4131591025766 154.72767971186107 161.3108636308289 168.17414165184545 175.32943091211476 182.78915558614753 190.56626845863 198.67427341514983 ] - -#ifdef DOF - //hexagon pattern - const vec2 hex_offsets[60] = vec2[60] ( vec2( 0.2165, 0.1250 ), - vec2( 0.0000, 0.2500 ), - vec2( -0.2165, 0.1250 ), - vec2( -0.2165, -0.1250 ), - vec2( -0.0000, -0.2500 ), - vec2( 0.2165, -0.1250 ), - vec2( 0.4330, 0.2500 ), - vec2( 0.0000, 0.5000 ), - vec2( -0.4330, 0.2500 ), - vec2( -0.4330, -0.2500 ), - vec2( -0.0000, -0.5000 ), - vec2( 0.4330, -0.2500 ), - vec2( 0.6495, 0.3750 ), - vec2( 0.0000, 0.7500 ), - vec2( -0.6495, 0.3750 ), - vec2( -0.6495, -0.3750 ), - vec2( -0.0000, -0.7500 ), - vec2( 0.6495, -0.3750 ), - vec2( 0.8660, 0.5000 ), - vec2( 0.0000, 1.0000 ), - vec2( -0.8660, 0.5000 ), - vec2( -0.8660, -0.5000 ), - vec2( -0.0000, -1.0000 ), - vec2( 0.8660, -0.5000 ), - vec2( 0.2163, 0.3754 ), - vec2( -0.2170, 0.3750 ), - vec2( -0.4333, -0.0004 ), - vec2( -0.2163, -0.3754 ), - vec2( 0.2170, -0.3750 ), - vec2( 0.4333, 0.0004 ), - vec2( 0.4328, 0.5004 ), - vec2( -0.2170, 0.6250 ), - vec2( -0.6498, 0.1246 ), - vec2( -0.4328, -0.5004 ), - vec2( 0.2170, -0.6250 ), - vec2( 0.6498, -0.1246 ), - vec2( 0.6493, 0.6254 ), - vec2( -0.2170, 0.8750 ), - vec2( -0.8663, 0.2496 ), - vec2( -0.6493, -0.6254 ), - vec2( 0.2170, -0.8750 ), - vec2( 0.8663, -0.2496 ), - vec2( 0.2160, 0.6259 ), - vec2( -0.4340, 0.5000 ), - vec2( -0.6500, -0.1259 ), - vec2( -0.2160, -0.6259 ), - vec2( 0.4340, -0.5000 ), - vec2( 0.6500, 0.1259 ), - vec2( 0.4325, 0.7509 ), - vec2( -0.4340, 0.7500 ), - vec2( -0.8665, -0.0009 ), - vec2( -0.4325, -0.7509 ), - vec2( 0.4340, -0.7500 ), - vec2( 0.8665, 0.0009 ), - vec2( 0.2158, 0.8763 ), - vec2( -0.6510, 0.6250 ), - vec2( -0.8668, -0.2513 ), - vec2( -0.2158, -0.8763 ), - vec2( 0.6510, -0.6250 ), - vec2( 0.8668, 0.2513 )); - - const vec2 offsets[60] = vec2[60] ( vec2( 0.0000, 0.2500 ), - vec2( -0.2165, 0.1250 ), - vec2( -0.2165, -0.1250 ), - vec2( -0.0000, -0.2500 ), - vec2( 0.2165, -0.1250 ), - vec2( 0.2165, 0.1250 ), - vec2( 0.0000, 0.5000 ), - vec2( -0.2500, 0.4330 ), - vec2( -0.4330, 0.2500 ), - vec2( -0.5000, 0.0000 ), - vec2( -0.4330, -0.2500 ), - vec2( -0.2500, -0.4330 ), - vec2( -0.0000, -0.5000 ), - vec2( 0.2500, -0.4330 ), - vec2( 0.4330, -0.2500 ), - vec2( 0.5000, -0.0000 ), - vec2( 0.4330, 0.2500 ), - vec2( 0.2500, 0.4330 ), - vec2( 0.0000, 0.7500 ), - vec2( -0.2565, 0.7048 ), - vec2( -0.4821, 0.5745 ), - vec2( -0.6495, 0.3750 ), - vec2( -0.7386, 0.1302 ), - vec2( -0.7386, -0.1302 ), - vec2( -0.6495, -0.3750 ), - vec2( -0.4821, -0.5745 ), - vec2( -0.2565, -0.7048 ), - vec2( -0.0000, -0.7500 ), - vec2( 0.2565, -0.7048 ), - vec2( 0.4821, -0.5745 ), - vec2( 0.6495, -0.3750 ), - vec2( 0.7386, -0.1302 ), - vec2( 0.7386, 0.1302 ), - vec2( 0.6495, 0.3750 ), - vec2( 0.4821, 0.5745 ), - vec2( 0.2565, 0.7048 ), - vec2( 0.0000, 1.0000 ), - vec2( -0.2588, 0.9659 ), - vec2( -0.5000, 0.8660 ), - vec2( -0.7071, 0.7071 ), - vec2( -0.8660, 0.5000 ), - vec2( -0.9659, 0.2588 ), - vec2( -1.0000, 0.0000 ), - vec2( -0.9659, -0.2588 ), - vec2( -0.8660, -0.5000 ), - vec2( -0.7071, -0.7071 ), - vec2( -0.5000, -0.8660 ), - vec2( -0.2588, -0.9659 ), - vec2( -0.0000, -1.0000 ), - vec2( 0.2588, -0.9659 ), - vec2( 0.5000, -0.8660 ), - vec2( 0.7071, -0.7071 ), - vec2( 0.8660, -0.5000 ), - vec2( 0.9659, -0.2588 ), - vec2( 1.0000, -0.0000 ), - vec2( 0.9659, 0.2588 ), - vec2( 0.8660, 0.5000 ), - vec2( 0.7071, 0.7071 ), - vec2( 0.5000, 0.8660 ), - vec2( 0.2588, 0.9659 )); - -const vec2 shadow_offsets[209] = vec2[209](vec2(0.8886414f , 0.07936136f), -vec2(0.8190064f , 0.1900164f), -vec2(0.8614115f , -0.06991258f), -vec2(0.7685533f , 0.03792081f), -vec2(0.9970094f , 0.02585129f), -vec2(0.9686818f , 0.1570935f), -vec2(0.9854341f , -0.09172997f), -vec2(0.9330608f , 0.3326486f), -vec2(0.8329557f , -0.2438523f), -vec2(0.664771f , -0.0837701f), -vec2(0.7429124f , -0.1530652f), -vec2(0.9506453f , -0.2174281f), -vec2(0.8192949f , 0.3485171f), -vec2(0.6851269f , 0.2711877f), -vec2(0.7665657f , 0.5014166f), -vec2(0.673241f , 0.3793408f), -vec2(0.6981376f , 0.1465924f), -vec2(0.6521665f , -0.2384985f), -vec2(0.5145761f , -0.05752508f), -vec2(0.5641244f , -0.169443f), -vec2(0.5916035f , 0.06004957f), -vec2(0.57079f , 0.234188f), -vec2(0.509311f , 0.1523665f), -vec2(0.4204576f , 0.05759521f), -vec2(0.8200846f , -0.3601041f), -vec2(0.6893264f , -0.3473432f), -vec2(0.4775535f , -0.3062558f), -vec2(0.438106f , -0.1796866f), -vec2(0.4056528f , -0.08251233f), -vec2(0.5771964f , 0.5502692f), -vec2(0.5094061f , 0.4025192f), -vec2(0.6908483f , 0.572951f), -vec2(0.5379036f , -0.4542191f), -vec2(0.8167359f , -0.4793735f), -vec2(0.6829269f , -0.4557574f), -vec2(0.5725697f , -0.3477072f), -vec2(0.5767449f , -0.5782524f), -vec2(0.3979413f , -0.4172934f), -vec2(0.4282598f , -0.5145645f), -vec2(0.938814f , -0.3239739f), -vec2(0.702452f , -0.5662871f), -vec2(0.2832307f , -0.1285671f), -vec2(0.3230537f , -0.2691054f), -vec2(0.2921676f , -0.3734582f), -vec2(0.2534037f , -0.4906001f), -vec2(0.4343273f , 0.5223463f), -vec2(0.3605334f , 0.3151571f), -vec2(0.3498518f , 0.451428f), -vec2(0.3230703f , 0.00287089f), -vec2(0.1049206f , -0.1476725f), -vec2(0.2063161f , -0.2608192f), -vec2(0.7266634f , 0.6725333f), -vec2(0.4027067f , -0.6185485f), -vec2(0.2655533f , -0.5912259f), -vec2(0.4947965f , 0.3025357f), -vec2(0.5760762f , 0.68844f), -vec2(0.4909205f , -0.6975324f), -vec2(0.8609334f , 0.4559f), -vec2(0.1836646f , 0.03724086f), -vec2(0.2878554f , 0.178938f), -vec2(0.3948484f , 0.1618928f), -vec2(0.3519658f , -0.7628763f), -vec2(0.6338583f , -0.673193f), -vec2(0.5511802f , -0.8283072f), -vec2(0.4090595f , -0.8717521f), -vec2(0.1482169f , -0.374728f), -vec2(0.1050598f , -0.2613987f), -vec2(0.4210334f , 0.6578422f), -vec2(0.2430464f , 0.4383665f), -vec2(0.3329675f , 0.5512741f), -vec2(0.2147711f , 0.3245511f), -vec2(0.1227196f , 0.2529026f), -vec2(-0.03937457f , 0.156439f), -vec2(0.05618772f , 0.06690486f), -vec2(0.06519571f , 0.3974038f), -vec2(0.1360903f , 0.1466078f), -vec2(-0.00170609f , 0.3089452f), -vec2(0.1357622f , -0.5088975f), -vec2(0.1604694f , -0.7453476f), -vec2(0.1245694f , -0.6337074f), -vec2(0.02542936f , -0.3728781f), -vec2(0.02222222f , -0.649554f), -vec2(0.09870815f , 0.5357338f), -vec2(0.2073958f , 0.5452989f), -vec2(0.216654f , -0.8935689f), -vec2(0.2422334f , 0.665805f), -vec2(0.0574713f , 0.6742729f), -vec2(0.2021346f , 0.8144029f), -vec2(0.3086587f , 0.7504997f), -vec2(0.02122174f , -0.7498575f), -vec2(-0.1551729f , 0.1809731f), -vec2(-0.1947583f , 0.06246066f), -vec2(-0.05754202f , -0.03901273f), -vec2(-0.1083095f , 0.2952235f), -vec2(-0.03259534f , -0.492394f), -vec2(-0.02488567f , -0.2081116f), -vec2(-0.1820729f , -0.1829884f), -vec2(-0.1674413f , -0.04529009f), -vec2(0.04342153f , -0.0368562f), -vec2(0.801399f , -0.5845526f), -vec2(0.3158276f , -0.9124843f), -vec2(-0.05945269f , 0.6727523f), -vec2(0.07701834f , 0.8579889f), -vec2(-0.05778154f , 0.5699022f), -vec2(0.1191713f , 0.7542591f), -vec2(-0.2578296f , 0.3630984f), -vec2(-0.1428598f , 0.4557526f), -vec2(-0.3304029f , 0.5055485f), -vec2(-0.3227198f , 0.1847367f), -vec2(-0.4183801f , 0.3412776f), -vec2(0.2538475f , 0.9317476f), -vec2(0.406249f , 0.8423664f), -vec2(0.4718862f , 0.7592828f), -vec2(0.168472f , -0.06605823f), -vec2(0.2632498f , -0.7084918f), -vec2(-0.2816192f , -0.1023492f), -vec2(-0.3161443f , 0.02489911f), -vec2(-0.4677814f , 0.08450397f), -vec2(-0.4156994f , 0.2408664f), -vec2(-0.237449f , 0.2605326f), -vec2(-0.0912179f , 0.06491816f), -vec2(0.01475127f , 0.7670643f), -vec2(0.1216858f , -0.9368939f), -vec2(0.07010741f , -0.841011f), -vec2(-0.1708607f , -0.4152923f), -vec2(-0.1345006f , -0.5842513f), -vec2(-0.09419055f , -0.3213732f), -vec2(-0.2149337f , 0.730642f), -vec2(-0.1102187f , 0.8425013f), -vec2(-0.1808572f , 0.6244397f), -vec2(-0.2414505f , -0.7063725f), -vec2(-0.2410318f , -0.537854f), -vec2(-0.1005938f , -0.7635075f), -vec2(0.1053517f , 0.9678772f), -vec2(-0.3340288f , 0.6926677f), -vec2(-0.2363931f , 0.8464488f), -vec2(-0.4057773f , 0.7786722f), -vec2(-0.5484858f , 0.1686208f), -vec2(-0.64842f , 0.02256887f), -vec2(-0.5544513f , -0.02348978f), -vec2(-0.492855f , -0.1083694f), -vec2(-0.4248196f , 0.4674786f), -vec2(-0.5873146f , 0.4072608f), -vec2(-0.6439911f , 0.3038489f), -vec2(-0.6419188f , 0.1293737f), -vec2(-0.005880734f , 0.4699725f), -vec2(-0.4239455f , 0.6250131f), -vec2(-0.1701273f , 0.9506347f), -vec2(7.665656E-05f , 0.9941212f), -vec2(-0.7070159f , 0.4426281f), -vec2(-0.7481344f , 0.3139496f), -vec2(-0.8330062f , 0.2472693f), -vec2(-0.7271438f , 0.2024286f), -vec2(-0.5179888f , 0.3149576f), -vec2(-0.8258062f , 0.3779382f), -vec2(-0.8063191f , 0.1262931f), -vec2(-0.2690676f , -0.4360798f), -vec2(-0.3714577f , -0.5887412f), -vec2(-0.3736085f , -0.4018324f), -vec2(-0.3228985f , -0.2063406f), -vec2(-0.2414576f , -0.2875458f), -vec2(-0.4720859f , -0.3823904f), -vec2(-0.4937642f , -0.2686005f), -vec2(-0.01500604f , -0.9587054f), -vec2(-0.08535925f , -0.8820614f), -vec2(-0.6436375f , -0.3157263f), -vec2(-0.5736347f , -0.4224878f), -vec2(-0.5026127f , -0.5516239f), -vec2(-0.8200902f , 0.5370023f), -vec2(-0.7196413f , 0.57133f), -vec2(-0.5849072f , 0.5917885f), -vec2(-0.1598758f , -0.9739854f), -vec2(-0.4230629f , -0.01858409f), -vec2(-0.9403627f , 0.2213769f), -vec2(-0.685889f , -0.2192711f), -vec2(-0.6693704f , -0.4884708f), -vec2(-0.7967147f , -0.3078234f), -vec2(-0.596441f , -0.1686891f), -vec2(-0.7366468f , -0.3939891f), -vec2(-0.7963406f , 0.02246814f), -vec2(-0.9177913f , 0.0929693f), -vec2(-0.9284672f , 0.3329005f), -vec2(-0.6497722f , 0.6851863f), -vec2(-0.496019f , 0.7013303f), -vec2(-0.3930301f , -0.6892192f), -vec2(-0.2122009f , -0.8777389f), -vec2(-0.3660335f , -0.801644f), -vec2(-0.386839f , -0.1191898f), -vec2(-0.7020127f , -0.0776734f), -vec2(-0.7760845f , -0.1566844f), -vec2(-0.5444778f , -0.6516482f), -vec2(-0.5331346f , 0.4946506f), -vec2(-0.3288236f , 0.9408244f), -vec2(0.5819826f , 0.8101937f), -vec2(-0.4894184f , -0.8290837f), -vec2(-0.5183194f , 0.8454953f), -vec2(-0.7665774f , -0.5223897f), -vec2(-0.6703191f , -0.6217513f), -vec2(-0.8902924f , -0.2446688f), -vec2(-0.8574848f , -0.09174173f), -vec2(-0.3544409f , -0.9239591f), -vec2(-0.969833f , -0.1172272f), -vec2(-0.8968207f , -0.4079512f), -vec2(-0.5891477f , 0.7724466f), -vec2(-0.2146262f , 0.5286855f), -vec2(-0.3762444f , -0.3014335f), -vec2(-0.9466863f , -0.008970681f), -vec2(-0.596356f , -0.7976127f), -vec2(-0.8877738f , 0.4569088f)); -#endif -flat varying vec4 exposure; -flat varying float rodExposure; -varying vec2 texcoord; -uniform sampler2D colortex4; -uniform sampler2D colortex5; -uniform sampler2D colortex3; -uniform sampler2D colortex7; -uniform sampler2D depthtex0; -uniform sampler2D noisetex; -uniform vec2 texelSize; - -uniform float viewWidth; -uniform float viewHeight; -uniform float frameTimeCounter; -uniform int frameCounter; -uniform int isEyeInWater; -uniform float near; -uniform float aspectRatio; -uniform float far; - - -uniform float screenBrightness; -uniform float isWastes; -uniform float isWarpedForest; -uniform float isCrimsonForest; -uniform float isSoulValley; -uniform float isBasaltDelta; - -#include "lib/color_transforms.glsl" -#include "lib/color_dither.glsl" - -float cdist(vec2 coord) { - return max(abs(coord.s-0.5),abs(coord.t-0.5))*2.0; -} -float blueNoise(){ - return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); -} -float ld(float depth) { - return (2.0 * near) / (far + near - depth * (far - near)); // (-depth * (far - near)) = (2.0 * near)/ld - far - near -} -vec3 closestToCamera3x3() -{ - vec2 du = vec2(texelSize.x, 0.0); - vec2 dv = vec2(0.0, texelSize.y); - - vec3 dtl = vec3(texcoord,0.) + vec3(-texelSize, texture2D(depthtex0, texcoord - dv - du).x); - vec3 dtc = vec3(texcoord,0.) + vec3( 0.0, -texelSize.y, texture2D(depthtex0, texcoord - dv).x); - vec3 dtr = vec3(texcoord,0.) + vec3( texelSize.x, -texelSize.y, texture2D(depthtex0, texcoord - dv + du).x); - - vec3 dml = vec3(texcoord,0.) + vec3(-texelSize.x, 0.0, texture2D(depthtex0, texcoord - du).x); - vec3 dmc = vec3(texcoord,0.) + vec3( 0.0, 0.0, texture2D(depthtex0, texcoord).x); - vec3 dmr = vec3(texcoord,0.) + vec3( texelSize.x, 0.0, texture2D(depthtex0, texcoord + du).x); - - vec3 dbl = vec3(texcoord,0.) + vec3(-texelSize.x, texelSize.y, texture2D(depthtex0, texcoord + dv - du).x); - vec3 dbc = vec3(texcoord,0.) + vec3( 0.0, texelSize.y, texture2D(depthtex0, texcoord + dv).x); - vec3 dbr = vec3(texcoord,0.) + vec3( texelSize.x, texelSize.y, texture2D(depthtex0, texcoord + dv + du).x); - - vec3 dmin = dmc; - - dmin = dmin.z > dtc.z? dtc : dmin; - dmin = dmin.z > dtr.z? dtr : dmin; - - dmin = dmin.z > dml.z? dml : dmin; - dmin = dmin.z > dtl.z? dtl : dmin; - dmin = dmin.z > dmr.z? dmr : dmin; - - dmin = dmin.z > dbl.z? dbl : dmin; - dmin = dmin.z > dbc.z? dbc : dmin; - dmin = dmin.z > dbr.z? dbr : dmin; - - return dmin; -} -void main() { - /* DRAWBUFFERS:7 */ - float vignette = (1.5-dot(texcoord-0.5,texcoord-0.5)*2.5); - vec3 col = texture2D(colortex5,texcoord).rgb; - #ifdef DOF - /*--------------------------------*/ - float z = ld(texture2D(depthtex0, texcoord.st).r)*far; - #ifdef AUTOFOCUS - float focus = ld(texture2D(depthtex0, vec2(0.5)).r)*far; - #else - float focus = MANUAL_FOCUS*screenBrightness; - #endif - float pcoc = min(abs(aperture * (focal/100.0 * (z - focus)) / (z * (focus - focal/100.0))),texelSize.x*15.0); - #ifdef FAR_BLUR_ONLY - pcoc *= float(z > focus); - #endif - float noise = blueNoise()*6.28318530718; - mat2 noiseM = mat2( cos( noise ), -sin( noise ), - sin( noise ), cos( noise ) - ); - vec3 bcolor = vec3(0.); - float nb = 0.0; - vec2 bcoord = vec2(0.0); - /*--------------------------------*/ - #ifndef HQ_DOF - bcolor = col; - #ifdef HEXAGONAL_BOKEH - for ( int i = 0; i < 60; i++) { - bcolor += texture2D(colortex5, texcoord.xy + hex_offsets[i]*pcoc*vec2(1.0,aspectRatio)).rgb; - } - col = bcolor/61.0; - #else - for ( int i = 0; i < 60; i++) { - bcolor += texture2D(colortex5, texcoord.xy + offsets[i]*pcoc*vec2(1.0,aspectRatio)).rgb; - } - /*--------------------------------*/ - col = bcolor/61.0; - #endif - #endif - #ifdef HQ_DOF - for ( int i = 0; i < 209; i++) { - bcolor += texture2D(colortex5, texcoord.xy + noiseM*shadow_offsets[i]*pcoc*vec2(1.0,aspectRatio)).rgb; - } - col = bcolor/209.0; - #endif -#endif - vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); - - float BiomeParams = isWastes + isWarpedForest*10 + isCrimsonForest*10 + isSoulValley*5 + isBasaltDelta*0 ; - - - vec3 bloom = texture2D(colortex3,texcoord/clampedRes*vec2(1920.,1080.)*0.5).rgb/2./7.0; - - float lightScat = clamp(4 * 0.05 * pow(exposure.a ,0.2) ,0.0,1.0)*vignette; - - - float VL_abs = texture2D(colortex7,texcoord).r; - - VL_abs = clamp((1.0-VL_abs*1.05)*0.5,0.0,1.0)*clamp(1.0-pow(cdist(texcoord.xy),15.0),0.0,1.0); - col = (mix(col,bloom,VL_abs)+bloom*lightScat)*exposure.rgb; -/* - //Purkinje Effect - float lum = dot(col,vec3(0.15,0.3,0.55)); - float lum2 = dot(col,vec3(0.85,0.7,0.45))/2; - float rodLum = lum2*300.0; - float rodCurve = mix(1.0, rodLum/(2.5+rodLum), rodExposure/2.0*Purkinje_strength); - col = mix(lum*Purkinje_Multiplier*vec3(Purkinje_R, Purkinje_G, Purkinje_B)+0.001, col, rodCurve); -*/ - #ifndef USE_ACES_COLORSPACE_APPROXIMATION - col = LinearTosRGB(TONEMAP(col)); - #else - col = col * ACESInputMat; - col = TONEMAP(col); - col = LinearTosRGB(clamp(col * ACESOutputMat, 0.0, 1.0)); - #endif - //col = ACESFitted(texture2D(colortex4,texcoord/3.).rgb/500.); - gl_FragData[0].rgb = clamp(int8Dither(col,texcoord),0.0,1.0); - //if (nightMode < 0.99 && texcoord.x < 0.5) gl_FragData[0].rgb =vec3(0.0,1.0,0.0); - -} diff --git a/shaders/world1/composite15.vsh b/shaders/world1/composite15.vsh deleted file mode 100644 index 5099bbb..0000000 --- a/shaders/world1/composite15.vsh +++ /dev/null @@ -1,25 +0,0 @@ -#version 120 -#extension GL_EXT_gpu_shader4 : enable - -#define FinalR 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] -#define FinalG 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] -#define FinalB 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] - -varying vec2 texcoord; -flat varying vec4 exposure; -flat varying float rodExposure; -uniform sampler2D colortex4; - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - - gl_Position = ftransform(); - texcoord = gl_MultiTexCoord0.xy; - exposure=vec4(texelFetch2D(colortex4,ivec2(10,37),0).r*vec3(FinalR,FinalG,FinalB),texelFetch2D(colortex4,ivec2(10,37),0).r); - rodExposure = texelFetch2D(colortex4,ivec2(14,37),0).r; -} diff --git a/shaders/world1/composite2.fsh b/shaders/world1/composite2.fsh index 281b2e2..581d559 100644 --- a/shaders/world1/composite2.fsh +++ b/shaders/world1/composite2.fsh @@ -1,593 +1,79 @@ #version 120 -//Render sky, volumetric clouds, direct lighting +//Volumetric fog rendering #extension GL_EXT_gpu_shader4 : enable -#define SCREENSPACE_CONTACT_SHADOWS //Raymarch towards the sun in screen-space, in order to cast shadows outside of the shadow map or at the contact of objects. Can get really expensive at high resolutions. -#define SHADOW_FILTER_SAMPLE_COUNT 9 // Number of samples used to filter the actual shadows [1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 ] -#define CAVE_LIGHT_LEAK_FIX // Hackish way to remove sunlight incorrectly leaking into the caves. Can inacurrately remove shadows in some places -#define CLOUDS_SHADOWS -#define CLOUDS_SHADOWS_STRENGTH 1.0 //[0.1 0.125 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.9 1.0] -#define CLOUDS_QUALITY 0.5 //[0.1 0.125 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.9 1.0] -#define SSAO //It is also recommended to reduce the ambientOcclusionLevel value with this enabled -#define SSAO_SAMPLES 7 //[4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32] -#define TORCH_R 1.0 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define TORCH_G 0.75 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define TORCH_B 0.5 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define indirect_effect 1 // Choose what effect is applied to indirect light. [0 1 2 3] -#define AO_Strength 0.8 // strength of shadowed areas [0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 ] -#define GI_Strength 1.0 // strength of bounced light areas [1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 ] -// #define Glass_Tint // multiply the background through glass by the color of the glass for a strong tint. +#include "/lib/settings.glsl" -// #define HQ_SSGI -// #define end_shadows -//////////// misc settings - -// #define WhiteWorld // THIS IS A DEBUG VIEW. uses to see AO easier. used to see fake GI better (green light) -// #define LabPBR_Emissives -#define Emissive_Brightness 10.0 // [1. 2. 3. 4. 5. 6. 7. 8. 9. 10. 15. 20. 25. 30. 35. 40. 45. 50. 100.] -#define Emissive_Curve 2.0 // yes i blatantly copied kappa here. [1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 ] - -#define MIN_LIGHT_AMOUNT 1.0 //[0.0 0.5 1.0 1.5 2.0 3.0 4.0 5.0] - -const bool shadowHardwareFiltering = true; - -varying vec2 texcoord; - -uniform float nightVision; -flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) +flat varying vec4 lightCol; flat varying vec3 ambientUp; flat varying vec3 ambientLeft; flat varying vec3 ambientRight; flat varying vec3 ambientB; flat varying vec3 ambientF; flat varying vec3 ambientDown; -flat varying vec3 avgAmbient; -// flat varying vec3 WsunVec; -flat varying vec2 TAA_Offset; flat varying float tempOffsets; +flat varying float fogAmount; +flat varying float VFAmount; +uniform sampler2D noisetex; +uniform sampler2D depthtex0; -uniform sampler2D colortex0;//clouds -uniform sampler2D colortex1;//albedo(rgb),material(alpha) RGBA16 + +uniform sampler2D colortex2; uniform sampler2D colortex3; -// uniform sampler2D colortex4;//Skybox -uniform sampler2D colortex5; -uniform sampler2D colortex6;//Skybox -uniform sampler2D colortex7; -uniform sampler2D colortex13; -uniform sampler2D colortex8; -uniform sampler2D depthtex1;//depth -uniform sampler2D depthtex0;//depth -uniform sampler2D noisetex;//depth +// uniform sampler2D colortex4; - -uniform float isWastes; -uniform float isWarpedForest; -uniform float isCrimsonForest; -uniform float isSoulValley; -uniform float isBasaltDelta; - -uniform int heldBlockLightValue; -uniform int frameCounter; -uniform int isEyeInWater; -uniform mat4 shadowModelViewInverse; -uniform mat4 shadowProjectionInverse; -uniform float far; -uniform float near; -uniform float frameTimeCounter; -uniform float rainStrength; -uniform mat4 gbufferProjection; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferModelViewInverse; -uniform mat4 gbufferPreviousModelView; -uniform mat4 gbufferPreviousProjection; -uniform vec3 previousCameraPosition; -uniform mat4 shadowModelView; -uniform mat4 shadowProjection; -uniform mat4 gbufferModelView; - -uniform vec2 texelSize; -uniform float viewWidth; -uniform float viewHeight; -uniform float aspectRatio; -uniform vec3 cameraPosition; -// uniform int framemod8; uniform vec3 sunVec; +uniform float far; +uniform int frameCounter; +uniform float rainStrength; +uniform float sunElevation; uniform ivec2 eyeBrightnessSmooth; -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -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; -} -#include "lib/waterOptions.glsl" -#include "lib/color_transforms.glsl" -#include "lib/sky_gradient.glsl" -#include "lib/stars.glsl" -#include "lib/volumetricClouds.glsl" -#include "lib/waterBump.glsl" +uniform float frameTimeCounter; +uniform int isEyeInWater; +uniform vec2 texelSize; - -float ld(float dist) { - return (2.0 * near) / (far + near - dist * (far - near)); -} -vec3 ld(vec3 dist) { - return (2.0 * near) / (far + near - dist * (far - near)); -} - -#include "lib/specular.glsl" +#include "/lib/color_transforms.glsl" +#include "/lib/color_dither.glsl" +#include "/lib/projections.glsl" +#include "/lib/end_fog.glsl" -vec3 normVec (vec3 vec){ - return vec*inversesqrt(dot(vec,vec)); -} -float lengthVec (vec3 vec){ - return sqrt(dot(vec,vec)); -} #define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) -float triangularize(float dither) -{ - float center = dither*2.0-1.0; - dither = center*inversesqrt(abs(center)); - return clamp(dither-fsign(center),0.0,1.0); -} -float interleaved_gradientNoise(float temp){ - return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+temp); -} + float interleaved_gradientNoise(){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)); - return noise; -} -vec3 fp10Dither(vec3 color,float dither){ - const vec3 mantissaBits = vec3(6.,6.,5.); - vec3 exponent = floor(log2(color)); - return color + dither*exp2(-mantissaBits)*exp2(exponent); -} - - -vec2 R2_samples(int n){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha * n); -} -float facos(float sx){ - float x = clamp(abs( sx ),0.,1.); - return sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); -} -vec3 worldToView(vec3 worldPos) { - vec4 pos = vec4(worldPos, 0.0); - pos = gbufferModelView * pos; - return pos.xyz; -} - -vec3 decode (vec2 encn){ - vec3 n = vec3(0.0); - encn = encn * 2.0 - 1.0; - n.xy = abs(encn); - n.z = 1.0 - n.x - n.y; - n.xy = n.z <= 0.0 ? (1.0 - n.yx) * sign(encn) : encn; - return clamp(normalize(n.xyz),-1.0,1.0); -} -vec2 decodeVec2(float a){ - const vec2 constant1 = 65535. / vec2( 256., 65536.); - const float constant2 = 256. / 255.; - return fract( a * constant1 ) * constant2 ; -} -// float linZ(float depth) { -// return (2.0 * near) / (far + near - depth * (far - near)); -// // l = (2*n)/(f+n-d(f-n)) -// // f+n-d(f-n) = 2n/l -// // -d(f-n) = ((2n/l)-f-n) -// // d = -((2n/l)-f-n)/(f-n) - -// } -// float invLinZ (float lindepth){ -// return -((2.0*near/lindepth)-far-near)/(far-near); -// } - -// vec3 toClipSpace3(vec3 viewSpacePosition) { -// return projMAD(gbufferProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; -// } -float bayer2(vec2 a){ - a = floor(a); - return fract(dot(a,vec2(0.5,a.y*0.75))); -} - -#define bayer4(a) (bayer2( .5*(a))*.25+bayer2(a)) -#define bayer8(a) (bayer4( .5*(a))*.25+bayer2(a)) -#define bayer16(a) (bayer8( .5*(a))*.25+bayer2(a)) -#define bayer32(a) (bayer16(.5*(a))*.25+bayer2(a)) -#define bayer64(a) (bayer32(.5*(a))*.25+bayer2(a)) -#define bayer128(a) fract(bayer64(.5*(a))*.25+bayer2(a)+tempOffsets) - - - -vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter,float distort) -{ - float alpha0 = sampleNumber/nb; - float alpha = (sampleNumber+jitter)/nb; - float angle = jitter*6.28 + alpha * 4.0 * 6.28; - - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*sqrt(alpha); -} - - - -vec3 BilateralFiltering(sampler2D tex, sampler2D depth,vec2 coord,float frDepth,float maxZ){ - vec4 sampled = vec4(texelFetch2D(tex,ivec2(coord),0).rgb,1.0); - - return vec3(sampled.x,sampled.yz/sampled.w); + return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+tempOffsets); } float blueNoise(){ return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); } -vec4 blueNoise(vec2 coord){ - return texelFetch2D(colortex6, ivec2(coord )%512 , 0); -} -float R2_dither(){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y); -} -vec3 toShadowSpaceProjected(vec3 p3){ - p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; - p3 = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; - p3 = diagonal3(shadowProjection) * p3 + shadowProjection[3].xyz; - return p3; -} -vec2 tapLocation(int sampleNumber, float spinAngle,int nb, float nbRot,float r0) -{ - float alpha = (float(sampleNumber*1.0f + r0) * (1.0 / (nb))); - float angle = alpha * (nbRot * 6.28) + spinAngle*6.28; +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// - float ssR = alpha; - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*ssR; -} -// void ssAO(inout vec3 lighting,vec3 fragpos,float mulfov, vec2 noise, vec3 normal, float lightmap){ - -// ivec2 pos = ivec2(gl_FragCoord.xy); -// const float tan70 = tan(70.*3.14/240.); -// float mulfov2 = gbufferProjection[1][1]/tan70; - -// float maxR2 = fragpos.z*fragpos.z*mulfov2*2.*1.412/50.0; - - -// float rd = mulfov2 * 0.04 ; -// //pre-rotate direction -// float n = 0.0; - -// float occlusion = 0.0; - -// vec2 acc = -(TAA_Offset*(texelSize/2)) ; - -// int seed = (frameCounter%40000)*2 + frameCounter; -// vec2 ij = fract(R2_samples(seed) + noise.rg ); -// vec2 v = ij; - -// for (int j = 0; j < 7 ;j++) { -// vec2 sp = tapLocation(j,v.x,7,1.682,v.y); -// vec2 sampleOffset = sp*rd ; -// ivec2 offset = ivec2(gl_FragCoord.xy + sampleOffset*vec2(viewWidth,viewHeight*aspectRatio)); - -// if (offset.x >= 0 && offset.y >= 0 && offset.x < viewWidth && offset.y < viewHeight ) { -// vec3 t0 = toScreenSpace(vec3(offset*texelSize+acc+0.5*texelSize,texelFetch2D(depthtex1,offset,0).x)); -// vec3 vec = t0.xyz - fragpos; -// float dsquared = dot(vec,vec); - -// if (dsquared > 1e-5){ -// if (dsquared < maxR2){ -// float NdotV = clamp(dot(vec*inversesqrt(dsquared), normalize(normal) ),0.,1.); -// occlusion += NdotV * clamp(1.0-dsquared/maxR2,0.0,1.0); -// } -// n += 1.0 ; -// } -// } -// } -// occlusion *= mix(2.25,0.0,clamp(pow(lightmap,2),0,1)); -// occlusion = max(1.0 - occlusion/n, 0.0); -// lighting = lighting * occlusion; -// } -void ssAO(inout vec3 lighting,vec3 fragpos,float mulfov, vec2 noise, vec3 normal, vec2 texcoord, vec3 ambientCoefs, vec2 lightmap){ - - float skyLightDir = dot(WsunVec, ambientCoefs); - // float skyLightDir = dot(normal, sunVec); - ivec2 pos = ivec2(gl_FragCoord.xy); - const float tan70 = tan(70.*3.14/240.); - float mulfov2 = gbufferProjection[1][1]/tan70; - - float maxR2 = fragpos.z*fragpos.z*mulfov2*2.*1.412/50.0; - - - float rd = mulfov2 * 0.04 ; - //pre-rotate direction - float n = 0.0; - - float occlusion = 0.0; - - vec2 acc = -(TAA_Offset*(texelSize/2)) ; - - int seed = (frameCounter%40000)*2 + frameCounter; - vec2 ij = fract(R2_samples(seed) + noise.rg ); - // vec2 ij = fract(R2_samples(-1) + 0.5 * blueNoise() ); - vec2 v = ij; - - for (int j = 0; j < 7 ;j++) { - - vec2 sp = tapLocation(j,v.x,7,1.682,v.y) ; - vec2 sampleOffset = sp*rd ; - ivec2 offset = ivec2(gl_FragCoord.xy + sampleOffset*vec2(viewWidth,viewHeight*aspectRatio)); - - if (offset.x >= 0 && offset.y >= 0 && offset.x < viewWidth && offset.y < viewHeight ) { - vec3 t0 = toScreenSpace(vec3(offset*texelSize+acc+0.5*texelSize,texelFetch2D(depthtex1,offset,0).x) ); - vec3 vec = t0.xyz - fragpos; - float dsquared = dot(vec,vec); - - if (dsquared > 1e-5){ - if (dsquared < maxR2){ - float NdotV = clamp(dot(vec*inversesqrt(dsquared), normalize(normal) ),0.,1.); - occlusion += NdotV * clamp(1.0-dsquared/maxR2,0.0,1.0); - } - n += 1.0 ; - } - } - } - // occlusion += max(skyLightDir, 0.0); - occlusion *= mix(2.25,0.0,clamp(pow(lightmap.x,2),0,1)); - occlusion = max(1.0 - occlusion/n, 0.0); - - lighting *=clamp(0.75+ambientCoefs.y*0.5,0.0,1.0); - lighting *= max(occlusion + luma(normal/dot(abs(normal),vec3(1))* mat3(gbufferModelView)), occlusion); // multiply ambient light by this effect - - // lighting *= occlusion; -} - -vec3 cosineHemisphereSample(vec2 Xi, float roughness) -{ - float r = sqrt(Xi.x); - float theta = 2.0 * 3.14159265359 * Xi.y; - - float x = r * cos(theta); - float y = r * sin(theta); - - return vec3(x, y, sqrt(clamp(1.0 - Xi.x,0.,1.))); -} -vec3 TangentToWorld(vec3 N, vec3 H, float roughness) -{ - vec3 UpVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0); - vec3 T = normalize(cross(UpVector, N)); - vec3 B = cross(N, T); - - return vec3((T * H.x) + (B * H.y) + (N * H.z)); -} - -vec3 RT(vec3 dir, vec3 position, float noise, float stepsizes){ - float stepSize = stepsizes; - int maxSteps = 12; - vec3 clipPosition = toClipSpace3(position); - float rayLength = ((position.z + dir.z * sqrt(3.0)*far) > -sqrt(3.0)*near) ? - (-sqrt(3.0)*near -position.z) / dir.z : sqrt(3.0)*far; - vec3 end = toClipSpace3(position+dir*rayLength) ; - vec3 direction = end-clipPosition ; //convert to clip space - float len = max(abs(direction.x)/texelSize.x,abs(direction.y)/texelSize.y)/stepSize; - //get at which length the ray intersects with the edge of the screen - vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; - - float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z)*2000.0; - - vec3 stepv = direction/len; - - int iterations = min(int(min(len, mult*len)-2), maxSteps); - - //Do one iteration for closest texel (good contact shadows) - vec3 spos = clipPosition ; - spos.xy += TAA_Offset*texelSize*0.5; - spos += stepv/(stepSize/2); - - for(int i = 0; i < iterations; i++){ - spos += stepv*noise; - - float sp=texelFetch2D(depthtex1,ivec2(spos.xy/texelSize),0).x; - float currZ = (spos.z); - - if( sp < currZ) { - // float dist = abs(sp-currZ)/currZ; - return vec3(spos.xy, invLinZ(sp)); - } - } - return vec3(1.1); -} -void rtAO(inout vec3 lighting, vec3 normal, vec2 noise, vec3 fragpos){ - int nrays = 4; - float occlude = 0.0; - - for (int i = 0; i < nrays; i++){ - int seed = (frameCounter%40000)*nrays+i; - vec2 ij = fract(R2_samples(seed) + noise ); - - vec3 rayDir = TangentToWorld( normal, normalize(cosineHemisphereSample(ij,1.0)) ,1.0) ; - - vec3 rayHit = RT(mat3(gbufferModelView)*rayDir, fragpos, blueNoise(), 12.); // choc sspt - - float skyLightDir = rayDir.y < 0.0 ? 1.0 : 1.0 ; // the positons where the occlusion happens - if (rayHit.z > 1.0) occlude += skyLightDir; - } - lighting *= occlude/nrays; -} -float rayTraceShadow(vec3 dir,vec3 position,float dither){ - const float quality = 32.; - vec3 clipPosition = toClipSpace3(position); - //prevents the ray from going behind the camera - float rayLength = ((position.z + dir.z * far*sqrt(3.)) > -near) ? - (-near -position.z) / dir.z : far*sqrt(3.) ; - vec3 direction = toClipSpace3(position+dir*rayLength)-clipPosition; //convert to clip space - direction.xyz = direction.xyz/max(abs(direction.x)/texelSize.x,abs(direction.y)/texelSize.y); //fixed step size - vec3 stepv = direction *3. * clamp(MC_RENDER_QUALITY,1.,2.0); - - vec3 spos = clipPosition; - spos.xy += (TAA_Offset*(texelSize/4)) ; - spos += stepv*dither; - - for (int i = 0; i < int(quality); i++) { - - spos += stepv ; - spos += stepv * dither; - - float sp = texture2D(depthtex1,spos.xy).x; - - if( sp < spos.z) { - float dist = abs(linZ(sp)-linZ(spos.z))/linZ(spos.z); - if (dist < 0.1 ) return 0.0; - } - } - return 1.0; -} +varying vec2 texcoord; void main() { - float dirtAmount = Dirt_Amount; - vec3 waterEpsilon = vec3(Water_Absorb_R, Water_Absorb_G, Water_Absorb_B); - vec3 dirtEpsilon = vec3(Dirt_Absorb_R, Dirt_Absorb_G, Dirt_Absorb_B); - vec3 totEpsilon = dirtEpsilon*dirtAmount + waterEpsilon; - vec3 scatterCoef = dirtAmount * vec3(Dirt_Scatter_R, Dirt_Scatter_G, Dirt_Scatter_B) / pi; - float z0 = texture2D(depthtex0,texcoord).x; - float z = texture2D(depthtex1,texcoord).x; - vec2 tempOffset=TAA_Offset; - // float noise = blueNoise(); +/* DRAWBUFFERS:0 */ - vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(tempOffset)*texelSize*0.5,z)); - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos; - vec3 np3 = normVec(p3); - - - vec4 SpecularTex = texture2D(colortex8,texcoord); - - // for a thing - vec3 wpos = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - vec3 dVWorld = (wpos-gbufferModelViewInverse[3].xyz); - float dL = length(dVWorld); - vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; - progressW = gbufferModelViewInverse[3].xyz+cameraPosition + dVWorld; - - - p3 += gbufferModelViewInverse[3].xyz; - - bool iswater = texture2D(colortex7,texcoord).a > 0.99; - - vec4 data = texture2D(colortex1,texcoord); - vec4 dataUnpacked0 = vec4(decodeVec2(data.x),decodeVec2(data.y)); - vec4 dataUnpacked1 = vec4(decodeVec2(data.z),decodeVec2(data.w)); - - vec3 albedo = toLinear(vec3(dataUnpacked0.xz,dataUnpacked1.x)); - vec3 normal = mat3(gbufferModelViewInverse) * worldToView(decode(dataUnpacked0.yw)); - - vec2 lightmap = dataUnpacked1.yz; - bool translucent = abs(dataUnpacked1.w-0.5) <0.01; - bool hand = abs(dataUnpacked1.w-0.75) <0.01; - bool blocklights = abs(dataUnpacked1.w-0.8) <0.01; - - float LightDir = clamp((-15 + max(dot(normal, WsunVec),0.0)*255.0) / 240.0 ,0.0,1.0); - - vec3 lightSource = normalize(WsunVec); - vec3 viewspace_sunvec = mat3(gbufferModelView) * lightSource; - float SdotV = dot(normalize(viewspace_sunvec), normalize(fragpos)); - float lightning_shine = clamp(phaseg(SdotV, 0.8),0,3); - - vec3 ambientCoefs = normal/dot(abs(normal),vec3(1.)); - - #ifdef WhiteWorld - albedo = vec3(1.0); - #endif - - if ( z >= 1.) { - - vec3 color = vec3(1.0,0.75,0.9)/4000.0*150.0*0.1; - vec4 cloud = texture2D_bicubic(colortex0,texcoord*CLOUDS_QUALITY); - color = color*cloud.a+cloud.rgb; - - gl_FragData[0].rgb = clamp(fp10Dither(color*8./3. * (1.0-rainStrength*0.4),triangularize(blueNoise())),0.0,65000.); - - - }else{ - ////// ----- indirect ----- ////// - - vec3 custom_lightmap = texture2D(colortex4, (vec2(lightmap.x, pow(lightmap.y,2))*15.0+0.5+vec2(0.0,19.))*texelSize).rgb*8./150./3.; // y = torch - - // vec3 ambientLight = vec3(1.0) / 30; - vec3 ambientLight = gl_Fog.color.rgb * 0.2; - - // lightmap.x = trpData.a < 255.0/255.0 ? mix( trpData.a, lightmap.x ,pow(trpData.a,Emissive_Curve)): lightmap.x ; - // vec3 Lightsources = (vec3(1.0)/5) * (pow(lightmap.x,2.0) + pow(lightmap.x,10.0)); + if (isEyeInWater == 0){ + vec2 tc = floor(gl_FragCoord.xy)*2.0*texelSize+0.5*texelSize; + float z = texture2D(depthtex0,tc).x; + vec3 fragpos = toScreenSpace(vec3(tc,z)); - vec3 Lightsources = custom_lightmap.y * vec3(TORCH_R,TORCH_G,TORCH_B) * 0.5; - if(hand) Lightsources *= 0.15; - if(blocklights) Lightsources *= 0.3; - if(custom_lightmap.y > 10.) Lightsources *= 0.25; + vec3 fragpos_ALT = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); - //apply a curve for the torch light so it doesnt mix with lab emissive colors too much - #ifdef LabPBR_Emissives - if(blocklights && (SpecularTex.a > 0.0 && SpecularTex.a < 1.0)) Lightsources = mix(vec3(0.0), Lightsources, SpecularTex.a); - #endif + float noise = blueNoise(); + mat2x3 vl = getVolumetricRays(noise,fragpos, interleaved_gradientNoise()); - ambientLight += Lightsources; - - #if indirect_effect == 1 - if (!hand) ssAO(ambientLight, fragpos, 1.0, blueNoise(gl_FragCoord.xy).rg, worldToView(decode(dataUnpacked0.yw)), texcoord, ambientCoefs, lightmap.xy ) ; - #endif - // #if indirect_effect == 2 - // if (!hand ) rtAO(ambientLight, normal, blueNoise(gl_FragCoord.xy).rg, fragpos); - // #endif - // #if indirect_effect == 3 - // if (!hand) rtGI(ambientLight, normal, blueNoise(gl_FragCoord.xy).rg, fragpos, 1, albedo); - // #endif - - vec3 Indirect_lighting = ambientLight; + float absorbance = dot(vl[1],vec3(0.22,0.71,0.07)); - ////// ----- direct ----- ////// - float screenShadow = 1; - vec3 Direct_lighting = SunCol * (lightning_shine*10) * LightDir; - #ifdef end_shadows - vec3 vec = -lightCol.a*viewspace_sunvec; - screenShadow = rayTraceShadow(vec, fragpos, interleaved_gradientNoise()); - if (!hand) Direct_lighting *= screenShadow; - #endif - ////// ----- finalize ----- ////// + gl_FragData[0] = clamp(vec4(vl[0],absorbance),0.000001,65000.); - gl_FragData[0].rgb = (Indirect_lighting+Direct_lighting) * albedo ; - - #ifdef LabPBR_Emissives - gl_FragData[0].rgb = SpecularTex.a < 255.0/255.0 ? mix(gl_FragData[0].rgb, albedo * Emissive_Brightness , SpecularTex.a): gl_FragData[0].rgb; - #endif - - // do this after water and stuff is done because yea - #ifdef Specular_Reflections - MaterialReflections(gl_FragData[0].rgb, SpecularTex.r, SpecularTex.ggg, albedo, WsunVec, SunCol, screenShadow*LightDir , 0.0, normal, np3, fragpos, vec3(blueNoise(gl_FragCoord.xy).rg,blueNoise()), hand); - #endif + } else { + gl_FragData[0] = vec4(0.0); } - -// / lightnign flashes fog - if (isEyeInWater == 0){ - - // vec3 lightSource = normalize(WsunVec); - // vec3 viewspace_sunvec = mat3(gbufferModelView) * lightSource; - // float SdotV = dot(normalize(viewspace_sunvec), normalize(fragpos)); - // float lightning_shine = clamp(phaseg(SdotV, 0.35) ,0,1); - - vec3 flashingfogCol = SunCol * 0.25; - float flashingfogdist = clamp(pow(length(fragpos)/far,5.), 0.0, 1.0) ; - gl_FragData[0].rgb += flashingfogCol * lightning_shine * flashingfogdist; - // vl.a *= 1.0 - sqrt(flashingfogdist); - } - -/* DRAWBUFFERS:3 */ } diff --git a/shaders/world1/composite2.vsh b/shaders/world1/composite2.vsh index b1cf351..91f9f96 100644 --- a/shaders/world1/composite2.vsh +++ b/shaders/world1/composite2.vsh @@ -1,68 +1,22 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable -#define TAA -varying vec2 texcoord; -flat varying vec3 WsunVec; -flat varying vec3 ambientUp; -flat varying vec3 ambientLeft; -flat varying vec3 ambientRight; -flat varying vec3 ambientB; -flat varying vec3 ambientF; -flat varying vec3 ambientDown; -flat varying vec3 avgAmbient; -flat varying vec4 lightCol; flat varying float tempOffsets; -flat varying vec2 TAA_Offset; -flat varying vec3 zMults; -uniform sampler2D colortex4; - -uniform float far; -uniform float near; -uniform mat4 gbufferModelViewInverse; -uniform vec3 sunPosition; -uniform float rainStrength; -uniform float sunElevation; uniform int frameCounter; -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.); - - #include "/lib/util.glsl" +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// + void main() { gl_Position = ftransform(); - texcoord = gl_MultiTexCoord0.xy; tempOffsets = HaltonSeq2(frameCounter%10000); - TAA_Offset = offsets[frameCounter%8]; - #ifndef TAA - TAA_Offset = vec2(0.0); - #endif - - vec3 sc = texelFetch2D(colortex4,ivec2(6,37),0).rgb; - ambientUp = texelFetch2D(colortex4,ivec2(0,37),0).rgb; - ambientDown = texelFetch2D(colortex4,ivec2(1,37),0).rgb; - ambientLeft = texelFetch2D(colortex4,ivec2(2,37),0).rgb; - ambientRight = texelFetch2D(colortex4,ivec2(3,37),0).rgb; - ambientB = texelFetch2D(colortex4,ivec2(4,37),0).rgb; - ambientF = texelFetch2D(colortex4,ivec2(5,37),0).rgb; - - avgAmbient = texelFetch2D(colortex4,ivec2(11,37),0).rgb; - lightCol.a = float(sunElevation > 1e-5)*2-1.; - lightCol.rgb = sc; - - WsunVec = lightCol.a*normalize(mat3(gbufferModelViewInverse) *sunPosition); - zMults = vec3((far * near)*2.0,far+near,far-near); - - + gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.51*2.0-1.0; } diff --git a/shaders/world1/composite3.fsh b/shaders/world1/composite3.fsh new file mode 100644 index 0000000..66672e1 --- /dev/null +++ b/shaders/world1/composite3.fsh @@ -0,0 +1,187 @@ +#version 120 +//Horizontal bilateral blur for volumetric fog + Forward rendered objects + Draw volumetric fog +#extension GL_EXT_gpu_shader4 : enable + +#include "/lib/settings.glsl" + + +varying vec2 texcoord; +flat varying vec3 zMults; +uniform sampler2D depthtex0; +uniform sampler2D depthtex1; +uniform sampler2D colortex13; +uniform sampler2D colortex11; +uniform sampler2D colortex7; +uniform sampler2D colortex3; +uniform sampler2D colortex2; +uniform sampler2D colortex0; +uniform sampler2D noisetex; + +uniform float frameTimeCounter; +uniform int frameCounter; +uniform float far; +uniform float near; +uniform mat4 gbufferModelViewInverse; +uniform mat4 gbufferProjectionInverse; +uniform mat4 gbufferModelView; +uniform vec2 texelSize; +uniform vec3 cameraPosition; + +uniform int isEyeInWater; +uniform float blindness; +uniform float darknessFactor; +uniform float darknessLightFactor; + + +#include "/lib/waterBump.glsl" + +float ld(float depth) { + return 1.0 / (zMults.y - depth * zMults.z); // (-depth * (far - near)) = (2.0 * near)/ld - far - near +} +#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) +#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) +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; +} +vec4 BilateralUpscale(sampler2D tex, sampler2D depth,vec2 coord,float frDepth){ + vec4 vl = vec4(0.0); + float sum = 0.0; + mat3x3 weights; + ivec2 posD = ivec2(coord/2.0)*2; + ivec2 posVl = ivec2(coord/2.0); + float dz = zMults.x; + ivec2 pos = (ivec2(gl_FragCoord.xy+frameCounter) % 2 )*2; + //pos = ivec2(1,-1); + + ivec2 tcDepth = posD + ivec2(-4,-4) + pos*2; + float dsample = ld(texelFetch2D(depth,tcDepth,0).r); + float w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; + vl += texelFetch2D(tex,posVl+ivec2(-2)+pos,0)*w; + sum += w; + + tcDepth = posD + ivec2(-4,0) + pos*2; + dsample = ld(texelFetch2D(depth,tcDepth,0).r); + w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; + vl += texelFetch2D(tex,posVl+ivec2(-2,0)+pos,0)*w; + sum += w; + + tcDepth = posD + ivec2(0) + pos*2; + dsample = ld(texelFetch2D(depth,tcDepth,0).r); + w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; + vl += texelFetch2D(tex,posVl+ivec2(0)+pos,0)*w; + sum += w; + + tcDepth = posD + ivec2(0,-4) + pos*2; + dsample = ld(texelFetch2D(depth,tcDepth,0).r); + w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; + vl += texelFetch2D(tex,posVl+ivec2(0,-2)+pos,0)*w; + sum += w; + + return vl/sum; +} + +vec3 decode (vec2 encn){ + vec3 n = vec3(0.0); + encn = encn * 2.0 - 1.0; + n.xy = abs(encn); + n.z = 1.0 - n.x - n.y; + n.xy = n.z <= 0.0 ? (1.0 - n.yx) * sign(encn) : encn; + return clamp(normalize(n.xyz),-1.0,1.0); +} + +vec2 decodeVec2(float a){ + const vec2 constant1 = 65535. / vec2( 256., 65536.); + const float constant2 = 256. / 255.; + return fract( a * constant1 ) * constant2 ; +} + +vec3 worldToView(vec3 worldPos) { + vec4 pos = vec4(worldPos, 0.0); + pos = gbufferModelView * pos; + return pos.xyz; +} +float luma(vec3 color) { + return dot(color,vec3(0.21, 0.72, 0.07)); +} +void main() { + /* DRAWBUFFERS:73 */ + //3x3 bilateral upscale from half resolution + float z = texture2D(depthtex0,texcoord).x; + float z2 = texture2D(depthtex1,texcoord).x; + float frDepth = ld(z); + float glassdepth = clamp((ld(z2) - ld(z)) * 0.5,0.0,0.15); + + vec4 vl = BilateralUpscale(colortex0,depthtex0,gl_FragCoord.xy,frDepth); + + float bloomyfogmult = 1.0; + + vec4 Translucent_Programs = texture2D(colortex2,texcoord); // the shader for all translucent progams. + + vec4 trpData = texture2D(colortex7,texcoord); + bool iswater = trpData.a > 0.99; + vec2 refractedCoord = texcoord; + + + + vec2 data = texture2D(colortex11,texcoord).xy; // translucents + vec4 dataUnpacked0 = vec4(decodeVec2(data.x),decodeVec2(data.y)); + + vec3 normals = mat3(gbufferModelViewInverse) * worldToView(decode(dataUnpacked0.yw) ); + + + #ifdef Refraction + refractedCoord += normals.xy * glassdepth; + + float refractedalpha = texture2D(colortex13,refractedCoord).a; + if(refractedalpha <= 0.0) refractedCoord = texcoord; // remove refracted coords on solids + #endif + + vec3 color = texture2D(colortex3,refractedCoord).rgb; + + if (Translucent_Programs.a > 0.0){ + #ifdef Glass_Tint + vec3 GlassAlbedo = texture2D(colortex13,texcoord).rgb * 5.0; + color = color*GlassAlbedo.rgb + color * clamp(pow(1.0-luma(GlassAlbedo.rgb),10.),0.0,1.0); + #endif + + color = color*(1.0-Translucent_Programs.a) + Translucent_Programs.rgb; + } + + color *= vl.a; + color += vl.rgb; + + bloomyfogmult *= vl.a*0.8+0.2; + + // underwater fog + if (isEyeInWater == 1){ + vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); + float fogfade = clamp(exp(-length(fragpos) /5. ) ,0.0,1.0); + bloomyfogmult *= fogfade*0.70+0.3 ; + } + /// lava. + if (isEyeInWater == 2){ + color.rgb = vec3(4.0,0.5,0.1); + } + /// powdered snow + if (isEyeInWater == 3){ + vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); + color.rgb = mix(color.rgb,vec3(10,15,20),clamp(length(fragpos)*0.5,0.,1.)); + bloomyfogmult = 0.0; + } + // blidnesss + if (blindness > 0.0){ + vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); + color.rgb *= mix(1.0,clamp( exp(pow(length(fragpos)*(blindness*0.2),2) * -5),0.,1.) , blindness); + } + // darkness effect + if(darknessFactor > 0.0){ + vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z2)); + color.rgb *= mix(1.0, (1.0-darknessLightFactor*2.0) * clamp(1.0-pow(length(fragpos)*(darknessFactor*0.07),2.0),0.0,1.0), darknessFactor); + } + + gl_FragData[0].r = bloomyfogmult; + gl_FragData[1].rgb = clamp(color,6.11*1e-5,65000.0); +} diff --git a/shaders/world-1/lib/composite3.vsh b/shaders/world1/composite3.vsh similarity index 100% rename from shaders/world-1/lib/composite3.vsh rename to shaders/world1/composite3.vsh diff --git a/shaders/world1/composite4.fsh b/shaders/world1/composite4.fsh new file mode 100644 index 0000000..30ed2e9 --- /dev/null +++ b/shaders/world1/composite4.fsh @@ -0,0 +1,361 @@ +#version 120 +//Temporal Anti-Aliasing + Dynamic exposure calculations (vertex shader) +#extension GL_EXT_gpu_shader4 : enable + +#include "/lib/settings.glsl" + +const int noiseTextureResolution = 32; + + +/* +const int colortex0Format = RGBA16F; // low res clouds (deferred->composite2) + low res VL (composite5->composite15) +const int colortex1Format = RGBA16; //terrain gbuffer (gbuffer->composite2) +const int colortex2Format = RGBA16F; //forward + transparencies (gbuffer->composite4) +const int colortex3Format = R11F_G11F_B10F; //frame buffer + bloom (deferred6->final) +const int colortex4Format = RGBA16F; //light values and skyboxes (everything) +const int colortex5Format = R11F_G11F_B10F; //TAA buffer (everything) +const int colortex6Format = R11F_G11F_B10F; //additionnal buffer for bloom (composite3->final) +const int colortex7Format = RGBA8; //Final output, transparencies id (gbuffer->composite4) +*/ +//no need to clear the buffers, saves a few fps +const bool colortex0Clear = false; +const bool colortex1Clear = false; +const bool colortex2Clear = true; +const bool colortex3Clear = false; +const bool colortex4Clear = false; +const bool colortex5Clear = false; +const bool colortex6Clear = false; +const bool colortex7Clear = false; + +varying vec2 texcoord; +flat varying float exposureA; +flat varying float tempOffsets; +uniform sampler2D colortex3; +uniform sampler2D colortex5; +uniform sampler2D colortex10; +uniform sampler2D depthtex0; + +uniform vec2 texelSize; +uniform float frameTimeCounter; +uniform int framemod8; +uniform float viewHeight; +uniform float viewWidth; +uniform vec3 previousCameraPosition; +uniform mat4 gbufferPreviousModelView; + + + + +#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) + +#include "/lib/projections.glsl" + + +float luma(vec3 color) { + return dot(color,vec3(0.21, 0.72, 0.07)); +} +float interleaved_gradientNoise(){ + return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+tempOffsets); +} +float triangularize(float dither) +{ + float center = dither*2.0-1.0; + dither = center*inversesqrt(abs(center)); + return clamp(dither-fsign(center),0.0,1.0); +} +vec3 fp10Dither(vec3 color,float dither){ + const vec3 mantissaBits = vec3(6.,6.,5.); + vec3 exponent = floor(log2(color)); + return color + dither*exp2(-mantissaBits)*exp2(exponent); +} + + +//returns the projected coordinates of the closest point to the camera in the 3x3 neighborhood +vec3 closestToCamera3x3() +{ + vec2 du = vec2(texelSize.x, 0.0); + vec2 dv = vec2(0.0, texelSize.y); + + vec3 dtl = vec3(texcoord,0.) + vec3(-texelSize, texture2D(depthtex0, texcoord - dv - du).x); + vec3 dtc = vec3(texcoord,0.) + vec3( 0.0, -texelSize.y, texture2D(depthtex0, texcoord - dv).x); + vec3 dtr = vec3(texcoord,0.) + vec3( texelSize.x, -texelSize.y, texture2D(depthtex0, texcoord - dv + du).x); + + vec3 dml = vec3(texcoord,0.) + vec3(-texelSize.x, 0.0, texture2D(depthtex0, texcoord - du).x); + vec3 dmc = vec3(texcoord,0.) + vec3( 0.0, 0.0, texture2D(depthtex0, texcoord).x); + vec3 dmr = vec3(texcoord,0.) + vec3( texelSize.x, 0.0, texture2D(depthtex0, texcoord + du).x); + + vec3 dbl = vec3(texcoord,0.) + vec3(-texelSize.x, texelSize.y, texture2D(depthtex0, texcoord + dv - du).x); + vec3 dbc = vec3(texcoord,0.) + vec3( 0.0, texelSize.y, texture2D(depthtex0, texcoord + dv).x); + vec3 dbr = vec3(texcoord,0.) + vec3( texelSize.x, texelSize.y, texture2D(depthtex0, texcoord + dv + du).x); + + vec3 dmin = dmc; + + dmin = dmin.z > dtc.z? dtc : dmin; + dmin = dmin.z > dtr.z? dtr : dmin; + + dmin = dmin.z > dml.z? dml : dmin; + dmin = dmin.z > dtl.z? dtl : dmin; + dmin = dmin.z > dmr.z? dmr : dmin; + + dmin = dmin.z > dbl.z? dbl : dmin; + dmin = dmin.z > dbc.z? dbc : dmin; + dmin = dmin.z > dbr.z? dbr : dmin; + + return dmin; +} + +//Modified texture interpolation from inigo quilez +vec4 smoothfilter(in sampler2D tex, in vec2 uv) +{ + vec2 textureResolution = vec2(viewWidth,viewHeight); + uv = uv*textureResolution + 0.5; + vec2 iuv = floor( uv ); + vec2 fuv = fract( uv ); + #ifndef SMOOTHESTSTEP_INTERPOLATION + uv = iuv + (fuv*fuv)*(3.0-2.0*fuv); + #endif + #ifdef SMOOTHESTSTEP_INTERPOLATION + uv = iuv + fuv*fuv*fuv*(fuv*(fuv*6.0-15.0)+10.0); + #endif + uv = (uv - 0.5)/textureResolution; + return texture2D( tex, uv); +} +//Due to low sample count we "tonemap" the inputs to preserve colors and smoother edges +vec3 weightedSample(sampler2D colorTex, vec2 texcoord){ + vec3 wsample = texture2D(colorTex,texcoord).rgb*exposureA; + return wsample/(1.0+luma(wsample)); + +} + + +//from : https://gist.github.com/TheRealMJP/c83b8c0f46b63f3a88a5986f4fa982b1 +vec4 SampleTextureCatmullRom(sampler2D tex, vec2 uv, vec2 texSize ) +{ + // We're going to sample a a 4x4 grid of texels surrounding the target UV coordinate. We'll do this by rounding + // down the sample location to get the exact center of our "starting" texel. The starting texel will be at + // location [1, 1] in the grid, where [0, 0] is the top left corner. + vec2 samplePos = uv * texSize; + vec2 texPos1 = floor(samplePos - 0.5) + 0.5; + + // Compute the fractional offset from our starting texel to our original sample location, which we'll + // feed into the Catmull-Rom spline function to get our filter weights. + vec2 f = samplePos - texPos1; + + // Compute the Catmull-Rom weights using the fractional offset that we calculated earlier. + // These equations are pre-expanded based on our knowledge of where the texels will be located, + // which lets us avoid having to evaluate a piece-wise function. + vec2 w0 = f * ( -0.5 + f * (1.0 - 0.5*f)); + vec2 w1 = 1.0 + f * f * (-2.5 + 1.5*f); + vec2 w2 = f * ( 0.5 + f * (2.0 - 1.5*f) ); + vec2 w3 = f * f * (-0.5 + 0.5 * f); + + // Work out weighting factors and sampling offsets that will let us use bilinear filtering to + // simultaneously evaluate the middle 2 samples from the 4x4 grid. + vec2 w12 = w1 + w2; + vec2 offset12 = w2 / (w1 + w2); + + // Compute the final UV coordinates we'll use for sampling the texture + vec2 texPos0 = texPos1 - vec2(1.0); + vec2 texPos3 = texPos1 + vec2(2.0); + vec2 texPos12 = texPos1 + offset12; + + texPos0 *= texelSize; + texPos3 *= texelSize; + texPos12 *= texelSize; + + vec4 result = vec4(0.0); + result += texture2D(tex, vec2(texPos0.x, texPos0.y)) * w0.x * w0.y; + result += texture2D(tex, vec2(texPos12.x, texPos0.y)) * w12.x * w0.y; + result += texture2D(tex, vec2(texPos3.x, texPos0.y)) * w3.x * w0.y; + + result += texture2D(tex, vec2(texPos0.x, texPos12.y)) * w0.x * w12.y; + result += texture2D(tex, vec2(texPos12.x, texPos12.y)) * w12.x * w12.y; + result += texture2D(tex, vec2(texPos3.x, texPos12.y)) * w3.x * w12.y; + + result += texture2D(tex, vec2(texPos0.x, texPos3.y)) * w0.x * w3.y; + result += texture2D(tex, vec2(texPos12.x, texPos3.y)) * w12.x * w3.y; + result += texture2D(tex, vec2(texPos3.x, texPos3.y)) * w3.x * w3.y; + + return result; +} +//approximation from SMAA presentation from siggraph 2016 +vec3 FastCatmulRom(sampler2D colorTex, vec2 texcoord, vec4 rtMetrics, float sharpenAmount) +{ + vec2 position = rtMetrics.zw * texcoord; + vec2 centerPosition = floor(position - 0.5) + 0.5; + vec2 f = position - centerPosition; + vec2 f2 = f * f; + vec2 f3 = f * f2; + + float c = sharpenAmount; + vec2 w0 = -c * f3 + 2.0 * c * f2 - c * f; + vec2 w1 = (2.0 - c) * f3 - (3.0 - c) * f2 + 1.0; + vec2 w2 = -(2.0 - c) * f3 + (3.0 - 2.0 * c) * f2 + c * f; + vec2 w3 = c * f3 - c * f2; + + vec2 w12 = w1 + w2; + vec2 tc12 = rtMetrics.xy * (centerPosition + w2 / w12); + vec3 centerColor = texture2D(colorTex, vec2(tc12.x, tc12.y)).rgb; + + vec2 tc0 = rtMetrics.xy * (centerPosition - 1.0); + vec2 tc3 = rtMetrics.xy * (centerPosition + 2.0); + vec4 color = vec4(texture2D(colorTex, vec2(tc12.x, tc0.y )).rgb, 1.0) * (w12.x * w0.y ) + + vec4(texture2D(colorTex, vec2(tc0.x, tc12.y)).rgb, 1.0) * (w0.x * w12.y) + + vec4(centerColor, 1.0) * (w12.x * w12.y) + + vec4(texture2D(colorTex, vec2(tc3.x, tc12.y)).rgb, 1.0) * (w3.x * w12.y) + + vec4(texture2D(colorTex, vec2(tc12.x, tc3.y )).rgb, 1.0) * (w12.x * w3.y ); + return color.rgb/color.a; + +} + +vec3 clip_aabb(vec3 q,vec3 aabb_min, vec3 aabb_max) + { + vec3 p_clip = 0.5 * (aabb_max + aabb_min); + vec3 e_clip = 0.5 * (aabb_max - aabb_min) + 0.00000001; + + vec3 v_clip = q - vec3(p_clip); + vec3 v_unit = v_clip.xyz / e_clip; + vec3 a_unit = abs(v_unit); + float ma_unit = max(a_unit.x, max(a_unit.y, a_unit.z)); + + if (ma_unit > 1.0) + return vec3(p_clip) + v_clip / ma_unit; + else + return q; + } +vec3 toClipSpace3Prev(vec3 viewSpacePosition) { + return projMAD(gbufferPreviousProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; +} +vec3 tonemap(vec3 col){ + return col/(1+luma(col)); +} +vec3 invTonemap(vec3 col){ + return col/(1-luma(col)); +} +vec3 closestToCamera5taps(vec2 texcoord, sampler2D depth) +{ + vec2 du = vec2(texelSize.x*2., 0.0); + vec2 dv = vec2(0.0, texelSize.y*2.); + + vec3 dtl = vec3(texcoord,0.) + vec3(-texelSize, texture2D(depth, texcoord - dv - du).x); + vec3 dtr = vec3(texcoord,0.) + vec3( texelSize.x, -texelSize.y, texture2D(depth, texcoord - dv + du).x); + vec3 dmc = vec3(texcoord,0.) + vec3( 0.0, 0.0, texture2D(depth, texcoord).x); + vec3 dbl = vec3(texcoord,0.) + vec3(-texelSize.x, texelSize.y, texture2D(depth, texcoord + dv - du).x); + vec3 dbr = vec3(texcoord,0.) + vec3( texelSize.x, texelSize.y, texture2D(depth, texcoord + dv + du).x); + + vec3 dmin = dmc; + dmin = dmin.z > dtr.z? dtr : dmin; + dmin = dmin.z > dtl.z? dtl : dmin; + dmin = dmin.z > dbl.z? dbl : dmin; + dmin = dmin.z > dbr.z? dbr : dmin; + #ifdef TAA_UPSCALING + dmin.xy = dmin.xy/RENDER_SCALE; + #endif + return dmin; +} +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.); + +vec3 TAA_hq(){ + + vec2 adjTC = texcoord; + + + //use velocity from the nearest texel from camera in a 3x3 box in order to improve edge quality in motion + #ifdef CLOSEST_VELOCITY + vec3 closestToCamera = closestToCamera5taps(adjTC, depthtex0); + #endif + + #ifndef CLOSEST_VELOCITY + vec3 closestToCamera = vec3(texcoord,texture2D(depthtex1,adjTC).x); + #endif + + //reproject previous frame + vec3 fragposition = toScreenSpace(closestToCamera); + fragposition = mat3(gbufferModelViewInverse) * fragposition + gbufferModelViewInverse[3].xyz + (cameraPosition - previousCameraPosition); + vec3 previousPosition = mat3(gbufferPreviousModelView) * fragposition + gbufferPreviousModelView[3].xyz; + previousPosition = toClipSpace3Prev(previousPosition); + vec2 velocity = previousPosition.xy - closestToCamera.xy; + previousPosition.xy = texcoord + velocity; + + //reject history if off-screen and early exit + if (previousPosition.x < 0.0 || previousPosition.y < 0.0 || previousPosition.x > 1.0 || previousPosition.y > 1.0) + return smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).xyz; + + #ifdef TAA_UPSCALING + vec3 albedoCurrent0 = smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).xyz; + // Interpolating neighboorhood clampling boundaries between pixels + vec3 cMax = texture2D(colortex0, adjTC).rgb; + vec3 cMin = texture2D(colortex6, adjTC).rgb; + #else + vec3 albedoCurrent0 = texture2D(colortex3, adjTC).rgb; + vec3 albedoCurrent1 = texture2D(colortex3, adjTC + vec2(texelSize.x,texelSize.y)).rgb; + vec3 albedoCurrent2 = texture2D(colortex3, adjTC + vec2(texelSize.x,-texelSize.y)).rgb; + vec3 albedoCurrent3 = texture2D(colortex3, adjTC + vec2(-texelSize.x,-texelSize.y)).rgb; + vec3 albedoCurrent4 = texture2D(colortex3, adjTC + vec2(-texelSize.x,texelSize.y)).rgb; + vec3 albedoCurrent5 = texture2D(colortex3, adjTC + vec2(0.0,texelSize.y)).rgb; + vec3 albedoCurrent6 = texture2D(colortex3, adjTC + vec2(0.0,-texelSize.y)).rgb; + vec3 albedoCurrent7 = texture2D(colortex3, adjTC + vec2(-texelSize.x,0.0)).rgb; + vec3 albedoCurrent8 = texture2D(colortex3, adjTC + vec2(texelSize.x,0.0)).rgb; + //Assuming the history color is a blend of the 3x3 neighborhood, we clamp the history to the min and max of each channel in the 3x3 neighborhood + vec3 cMax = max(max(max(albedoCurrent0,albedoCurrent1),albedoCurrent2),max(albedoCurrent3,max(albedoCurrent4,max(albedoCurrent5,max(albedoCurrent6,max(albedoCurrent7,albedoCurrent8)))))); + vec3 cMin = min(min(min(albedoCurrent0,albedoCurrent1),albedoCurrent2),min(albedoCurrent3,min(albedoCurrent4,min(albedoCurrent5,min(albedoCurrent6,min(albedoCurrent7,albedoCurrent8)))))); + albedoCurrent0 = smoothfilter(colortex3, adjTC + offsets[framemod8]*texelSize*0.5).rgb; + #endif + + #ifndef NO_CLIP + vec3 albedoPrev = max(FastCatmulRom(colortex5, previousPosition.xy,vec4(texelSize, 1.0/texelSize), 0.75).xyz, 0.0); + vec3 finalcAcc = clamp(albedoPrev,cMin,cMax); + + //Increases blending factor when far from AABB and in motion, reduces ghosting + float isclamped = distance(albedoPrev,finalcAcc)/luma(albedoPrev) * 0.5; + float movementRejection = (0.12+isclamped)*clamp(length(velocity/texelSize),0.0,1.0); + + float test = 0.05; + + bool isEntities = texture2D(colortex10,texcoord).x > 0.0; + // if(isEntities) test = 0.15; + // if(istranslucent) test = 0.1; + + //Blend current pixel with clamped history, apply fast tonemap beforehand to reduce flickering + // vec3 supersampled = invTonemap(mix(tonemap(finalcAcc),tonemap(albedoCurrent0),clamp(BLEND_FACTOR + movementRejection, min(luma(motionVector) *255,1.0),1.))); + + vec3 supersampled = invTonemap(mix(tonemap(finalcAcc),tonemap(albedoCurrent0),clamp(BLEND_FACTOR + movementRejection, test,1.))); + #endif + + + #ifdef NO_CLIP + vec3 albedoPrev = texture2D(colortex5, previousPosition.xy).xyz; + vec3 supersampled = mix(albedoPrev,albedoCurrent0,clamp(0.05,0.,1.)); + #endif + + //De-tonemap + return supersampled; +} + +void main() { + +/* DRAWBUFFERS:5 */ + gl_FragData[0].a = 1.0; + + #ifdef TAA + vec3 color = TAA_hq(); + gl_FragData[0].rgb = clamp(fp10Dither(color,triangularize(interleaved_gradientNoise())),6.11*1e-5,65000.0); + #endif + + #ifndef TAA + vec3 color = clamp(fp10Dither(texture2D(colortex3,texcoord).rgb,triangularize(interleaved_gradientNoise())),0.,65000.); + gl_FragData[0].rgb = color; + #endif + + + + + +} diff --git a/shaders/world1/composite4.vsh b/shaders/world1/composite4.vsh new file mode 100644 index 0000000..372c136 --- /dev/null +++ b/shaders/world1/composite4.vsh @@ -0,0 +1,20 @@ +#version 120 +#extension GL_EXT_gpu_shader4 : enable + + +varying vec2 texcoord; +flat varying float exposureA; +flat varying float tempOffsets; +uniform sampler2D colortex4; +uniform int frameCounter; + + +#include "/lib/util.glsl" + +void main() { + + tempOffsets = HaltonSeq2(frameCounter%10000); + gl_Position = ftransform(); + texcoord = gl_MultiTexCoord0.xy; + exposureA = texelFetch2D(colortex4,ivec2(10,37),0).r; +} diff --git a/shaders/world1/composite5.fsh b/shaders/world1/composite5.fsh index 48345fb..a4b6244 100644 --- a/shaders/world1/composite5.fsh +++ b/shaders/world1/composite5.fsh @@ -1,259 +1,45 @@ #version 120 -//Volumetric fog rendering -#extension GL_EXT_gpu_shader4 : enable +//downsample 1st pass (half res) for bloom -#define VL_SAMPLES 8 //[4 6 8 10 12 14 16 20 24 30 40 50] -#define Ambient_Mult 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0 5.0 6.0 10.0] -#define SEA_LEVEL 70 //[0 10 20 30 40 50 60 70 80 90 100 110 120 130 150 170 190] //The volumetric light uses an altitude-based fog density, this is where fog density is the highest, adjust this value according to your world. -#define ATMOSPHERIC_DENSITY 1.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 4.0 5.0 7.5 10.0 12.5 15.0 20.] -#define fog_mieg1 0.40 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0] -#define fog_mieg2 0.10 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0] -#define fog_coefficientRayleighR 5.8 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientRayleighG 1.35 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientRayleighB 3.31 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] - -#define fog_coefficientMieR 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientMieG 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientMieB 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] - -#define Underwater_Fog_Density 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0] - -flat varying vec4 lightCol; -flat varying vec3 ambientUp; -flat varying vec3 ambientLeft; -flat varying vec3 ambientRight; -flat varying vec3 ambientB; -flat varying vec3 ambientF; -flat varying vec3 ambientDown; -flat varying float tempOffsets; -flat varying float fogAmount; -flat varying float VFAmount; -uniform sampler2D noisetex; -uniform sampler2D depthtex0; - - -uniform sampler2D colortex2; -uniform sampler2D colortex3; -// uniform sampler2D colortex4; - -uniform vec3 sunVec; -uniform float far; -uniform int frameCounter; -uniform float rainStrength; -uniform float sunElevation; -uniform ivec2 eyeBrightnessSmooth; -uniform float frameTimeCounter; -uniform int isEyeInWater; +uniform sampler2D colortex5; uniform vec2 texelSize; - - -uniform float isWastes; -uniform float isWarpedForest; -uniform float isCrimsonForest; -uniform float isSoulValley; -uniform float isBasaltDelta; - - -#include "lib/waterOptions.glsl" -#include "lib/color_transforms.glsl" -#include "lib/color_dither.glsl" -#include "lib/projections.glsl" -#include "lib/sky_gradient.glsl" -#include "lib/volumetricClouds.glsl" -#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) - -float interleaved_gradientNoise(){ - return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+tempOffsets); -} - -float densityAtPosFog(in vec3 pos){ - pos /= 18.; - pos.xz *= 0.5; - - vec3 p = floor(pos); - vec3 f = fract(pos); - - f = (f*f) * (3.-2.*f); - vec2 uv = p.xz + f.xz + p.y * vec2(0.0,193.0); - vec2 coord = uv / 512.0; - vec2 xy = texture2D(noisetex, coord).yx; - return mix(xy.r,xy.g, f.y); -} - - -float cloudVol(in vec3 pos){ - - vec3 samplePos = pos*vec3(1.0,1./24.,1.0) ; - vec3 samplePos2 = pos*vec3(1.0,1./48.,1.0) + vec3(frameTimeCounter,0,frameTimeCounter); - - float fog_shape = 1-densityAtPosFog(samplePos * 16.0 ); - float fog_eroded = densityAtPosFog( samplePos2 * 255.0 ); - - return max( (fog_shape*2.0 - fog_eroded*0.2) - 1.5, 0.0) * 255*255 ; -} -float phaseRayleigh(float cosTheta) { - const vec2 mul_add = vec2(0.1, 0.28) /acos(-1.0); - return cosTheta * mul_add.x + mul_add.y; // optimized version from [Elek09], divided by 4 pi for energy conservation -} -mat2x3 getVolumetricRays(float dither,vec3 fragpos, vec3 fragpos_ALT) { - - //project pixel position into projected shadowmap space - vec3 wpos = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - vec3 fragposition = mat3(shadowModelView) * wpos + shadowModelView[3].xyz; - fragposition = diagonal3(shadowProjection) * fragposition + shadowProjection[3].xyz; - - - //project view origin into projected shadowmap space - vec3 start = toShadowSpaceProjected(vec3(0.)); - - //rayvector into projected shadow map space - //we can use a projected vector because its orthographic projection - //however we still have to send it to curved shadow map space every step - vec3 dV = (fragposition-start); - vec3 dVWorld = (wpos-gbufferModelViewInverse[3].xyz); - - float maxLength = min(length(dVWorld),far*4)/length(dVWorld); - dV *= maxLength; - dVWorld *= maxLength; - - //apply dither - vec3 progress = start.xyz; - vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; - vec3 vL = vec3(0.); - float dL = length(dVWorld); - - vec3 lightSource = normalize(WsunVec); - vec3 viewspace_sunvec = mat3(gbufferModelView) * lightSource; - float SdotV = dot(normalize(viewspace_sunvec), normalize(fragpos)); - - float mie = phaseg(SdotV,0.8); - float rayL = phaseRayleigh(SdotV); - - float mu = 1.0; - vec3 absorbance = vec3(1.0); - float expFactor = 11.0; - - vec3 fogColor = gl_Fog.color.rgb * 0.5 ; - vec3 lightning = SunCol ; - - vec3 rC = vec3(fogColor.r*1e-6, fogColor.g*1e-5, fogColor.b*1e-5); - vec3 mC = vec3(fogColor.r*1e-6, fogColor.g*1e-6, fogColor.b*1e-6); - - for (int i=0;i 1.0 - 3.5*texelSize.x || quarterResTC.y > 1.0 -3.5*texelSize.y || quarterResTC.x < 3.5*texelSize.x || quarterResTC.y < 3.5*texelSize.y) gl_FragData[0].rgb = vec3(0.0); + } diff --git a/shaders/world1/composite5.vsh b/shaders/world1/composite5.vsh index 1de7145..386f006 100644 --- a/shaders/world1/composite5.vsh +++ b/shaders/world1/composite5.vsh @@ -1,32 +1,7 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define BASE_FOG_AMOUNT 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0 10.0 20.0 30.0 50.0 100.0 150.0 200.0] Base fog amount amount (does not change the "cloudy" fog) -#define CLOUDY_FOG_AMOUNT 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0] -#define FOG_TOD_MULTIPLIER 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0] //Influence of time of day on fog amount -#define FOG_RAIN_MULTIPLIER 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0] //Influence of rain on fog amount - -flat varying vec4 lightCol; -flat varying vec3 ambientUp; -flat varying vec3 ambientLeft; -flat varying vec3 ambientRight; -flat varying vec3 ambientB; -flat varying vec3 ambientF; -flat varying vec3 ambientDown; -flat varying float tempOffsets; -flat varying float fogAmount; -flat varying float VFAmount; - -uniform sampler2D colortex4; -uniform float sunElevation; -uniform float rainStrength; -uniform int isEyeInWater; -uniform int frameCounter; -uniform int worldTime; -#include "/lib/util.glsl" -float luma(vec3 color) { - return dot(color,vec3(0.21, 0.72, 0.07)); -} +uniform float viewWidth; +uniform float viewHeight; //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -34,16 +9,9 @@ float luma(vec3 color) { //////////////////////////////VOID MAIN////////////////////////////// void main() { - tempOffsets = HaltonSeq2(frameCounter%10000); + //Improves performances and makes sure bloom radius stays the same at high resolution (>1080p) + vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); gl_Position = ftransform(); - gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.51*2.0-1.0; - vec3 avgAmbient = texelFetch2D(colortex4,ivec2(11,37),0).rgb; - ambientUp = texelFetch2D(colortex4,ivec2(0,37),0).rgb; - ambientDown = texelFetch2D(colortex4,ivec2(1,37),0).rgb; - ambientLeft = texelFetch2D(colortex4,ivec2(2,37),0).rgb; - ambientRight = texelFetch2D(colortex4,ivec2(3,37),0).rgb; - ambientB = texelFetch2D(colortex4,ivec2(4,37),0).rgb; - ambientF = texelFetch2D(colortex4,ivec2(5,37),0).rgb; - - + //*0.51 to avoid errors when sampling outside since clearing is disabled + gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.51/clampedRes*vec2(1920.0,1080.)*2.0-1.0; } diff --git a/shaders/world1/composite6.fsh b/shaders/world1/composite6.fsh index cf835db..25c81c0 100644 --- a/shaders/world1/composite6.fsh +++ b/shaders/world1/composite6.fsh @@ -1,210 +1,45 @@ #version 120 -//Horizontal bilateral blur for volumetric fog + Forward rendered objects + Draw volumetric fog -#extension GL_EXT_gpu_shader4 : enable +//downsample 1st pass (half res) for bloom -#define Cave_fog // cave fog.... -#define CaveFogFallOff 1.3 // [0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 ] - -#define CaveFogColor_R 0.1 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define CaveFogColor_G 0.2 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define CaveFogColor_B 0.5 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] - -// #define display_LUT // aaaaaaaaaaaaaaaaaaaaaaa - -varying vec2 texcoord; -flat varying vec3 zMults; -uniform sampler2D depthtex0; -uniform sampler2D depthtex1; -uniform sampler2D colortex7; uniform sampler2D colortex3; -// uniform sampler2D colortex4; -uniform sampler2D colortex2; -uniform sampler2D colortex0; -uniform sampler2D noisetex; - -uniform float frameTimeCounter; -uniform int frameCounter; -uniform float far; -uniform float near; -uniform mat4 gbufferModelViewInverse; -uniform mat4 gbufferProjectionInverse; uniform vec2 texelSize; -uniform vec3 cameraPosition; +uniform float viewWidth; +uniform float viewHeight; +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// -uniform mat4 gbufferModelView; - -uniform float isWastes; -uniform float isWarpedForest; -uniform float isCrimsonForest; -uniform float isSoulValley; -uniform float isBasaltDelta; - -uniform int isEyeInWater; -uniform ivec2 eyeBrightnessSmooth; -uniform float rainStrength; -uniform float blindness; -uniform float darknessFactor; -uniform float darknessLightFactor; -uniform float nightVision; - - - -#include "lib/waterBump.glsl" -#include "lib/waterOptions.glsl" -#include "lib/volumetricClouds.glsl" -float ld(float depth) { - return 1.0 / (zMults.y - depth * zMults.z); // (-depth * (far - near)) = (2.0 * near)/ld - far - near -} -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -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; -} -vec4 BilateralUpscale(sampler2D tex, sampler2D depth,vec2 coord,float frDepth){ - vec4 vl = vec4(0.0); - float sum = 0.0; - mat3x3 weights; - ivec2 posD = ivec2(coord/2.0)*2; - ivec2 posVl = ivec2(coord/2.0); - float dz = zMults.x; - ivec2 pos = (ivec2(gl_FragCoord.xy+frameCounter) % 2 )*2; - //pos = ivec2(1,-1); - - ivec2 tcDepth = posD + ivec2(-4,-4) + pos*2; - float dsample = ld(texelFetch2D(depth,tcDepth,0).r); - float w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(-2)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(-4,0) + pos*2; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(-2,0)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(0) + pos*2; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(0)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(0,-4) + pos*2; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(0,-2)+pos,0)*w; - sum += w; - - return vl/sum; -} -float luma(vec3 color) { - return dot(color,vec3(0.21, 0.72, 0.07)); -} -vec3 normVec (vec3 vec){ - return vec*inversesqrt(dot(vec,vec)); -} void main() { - /* DRAWBUFFERS:73 */ - //3x3 bilateral upscale from half resolution - float z = texture2D(depthtex0,texcoord).x; - float z2 = texture2D(depthtex1,texcoord).x; - float frDepth = ld(z); - vec4 vl = BilateralUpscale(colortex0,depthtex0,gl_FragCoord.xy,frDepth); + +/* DRAWBUFFERS:6 */ +vec2 resScale = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))/vec2(1920.,1080.); +vec2 quarterResTC = gl_FragCoord.xy*2.*texelSize; + + //0.5 + gl_FragData[0] = texture2D(colortex3,quarterResTC-1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; + gl_FragData[0] += texture2D(colortex3,quarterResTC+1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; + gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(-1.0*texelSize.x,1.0*texelSize.y))/4.*0.5; + gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(1.0*texelSize.x,-1.0*texelSize.y))/4.*0.5; + + //0.25 + gl_FragData[0] += texture2D(colortex3,quarterResTC-2.0*vec2(texelSize.x,0.0))/2.*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(0.0,texelSize.y))/2.*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(0,-texelSize.y))/2*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(-texelSize.x,0.0))/2*0.125; + + //0.125 + gl_FragData[0] += texture2D(colortex3,quarterResTC-2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(-2.0*texelSize.x,2.0*texelSize.y))/4.*0.125; + gl_FragData[0] += texture2D(colortex3,quarterResTC+vec2(2.0*texelSize.x,-2.0*texelSize.y))/4.*0.125; + + //0.125 + gl_FragData[0] += texture2D(colortex3,quarterResTC)*0.125; + + gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); - vec4 transparencies = texture2D(colortex2,texcoord); - vec4 trpData = texture2D(colortex7,texcoord); - bool iswater = trpData.a > 0.99; - vec2 refractedCoord = texcoord; - - vec3 fragpos = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z)); - vec3 fragpos2 = toScreenSpace(vec3(texcoord-vec2(0.0)*texelSize*0.5,z2)); - // vec3 np3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition; - - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos; - vec3 np3 = normVec(p3); - - - if (iswater){ - float norm = getWaterHeightmap(np3.xz*1.71, 4.0, 0.25, 1.0); - float displ = norm/(length(fragpos)/far)/35.; - refractedCoord += displ; - - if (texture2D(colortex7,refractedCoord).a < 0.99) - refractedCoord = texcoord; - - } - - - vec3 color = texture2D(colortex3,refractedCoord).rgb; - if (frDepth > 2.5/far || transparencies.a < 0.99) // Discount fix for transparencies through hand - color = color*(1.0-transparencies.a)+transparencies.rgb*10.; - - float dirtAmount = Dirt_Amount; - vec3 waterEpsilon = vec3(Water_Absorb_R, Water_Absorb_G, Water_Absorb_B); - vec3 dirtEpsilon = vec3(Dirt_Absorb_R, Dirt_Absorb_G, Dirt_Absorb_B); - vec3 totEpsilon = dirtEpsilon*dirtAmount + waterEpsilon; - - color *= vl.a; - - - // vec3 fogColor = clamp(gl_Fog.color.rgb*pow(luma(gl_Fog.color.rgb),-0.75)*0.65,0.0,1.0)*0.05; - - /// lightnign flashes fog - // if (isEyeInWater == 0){ - - // vec3 lightSource = normalize(WsunVec); - // vec3 viewspace_sunvec = mat3(gbufferModelView) * lightSource; - // float SdotV = dot(normalize(viewspace_sunvec), normalize(fragpos)); - // float lightning_shine = clamp(phaseg(SdotV, 0.35) ,0,1); - - // vec3 flashingfogCol = SunCol * 0.25; - // float flashingfogdist = clamp(pow(length(fragpos)/far,5.), 0.0, 1.0) ; - // color.rgb += flashingfogCol * lightning_shine * flashingfogdist; - // // vl.a *= 1.0 - sqrt(flashingfogdist); - // } - - - - - // underwater fog - if (isEyeInWater == 1){ - // color.rgb *= exp(-length(fragpos)/2*totEpsilon); - // vl.a *= (dot(exp(-length(fragpos)/1.2*totEpsilon),vec3(0.2,0.7,0.1)))*0.5+0.5; - - float fogfade = clamp(exp(-length(fragpos) /12 ) ,0.0,1.0); - float fogcolfade = clamp(exp(np3.y*1.5 - 1.5),0.0,1.0); - color.rgb *= fogfade; - color.rgb = color.rgb * (1.0 + vec3(0.0,0.1,0.2) * 12 * (1.0 - fogfade)) + (vec3(0.0,0.1,0.2) * 0.5 * (1.0 - fogfade))*fogcolfade; - - vl.a *= fogfade*0.75 +0.25; - } - /// lava. - if (isEyeInWater == 2){ - color.rgb = vec3(4.0,0.5,0.1); - } - /// powdered snow - if (isEyeInWater == 3){ - color.rgb = mix(color.rgb,vec3(10,15,20),clamp(length(fragpos)*0.5,0.,1.)); - vl.a = 0.0; - } - // blidnesss - color.rgb *= mix(1.0, clamp(1.5-pow(length(fragpos2)*(blindness*0.2),2.0),0.0,1.0), blindness); - // darkness effect - color.rgb *= mix(1.0, (1.0-darknessLightFactor*2.0) * clamp(1.0-pow(length(fragpos2)*(darknessFactor*0.07),2.0),0.0,1.0), darknessFactor); - - - // float BiomeParams = isWastes + isWarpedForest + isCrimsonForest + isSoulValley + isBasaltDelta ; - - color += vl.rgb; - gl_FragData[0].r = vl.a; - gl_FragData[1].rgb = clamp(color.rgb,0.0,68000.0); - gl_FragData[1].rgb = clamp(color,6.11*1e-5,65000.0); - - #ifdef display_LUT - gl_FragData[1].rgb = texture2D(colortex4,texcoord*0.45).rgb * 0.000035; - #endif } diff --git a/shaders/world1/composite6.vsh b/shaders/world1/composite6.vsh index 05cecb7..8d47d5c 100644 --- a/shaders/world1/composite6.vsh +++ b/shaders/world1/composite6.vsh @@ -1,10 +1,7 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -varying vec2 texcoord; -flat varying vec3 zMults; -uniform float far; -uniform float near; +uniform float viewWidth; +uniform float viewHeight; //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -12,8 +9,9 @@ uniform float near; //////////////////////////////VOID MAIN////////////////////////////// void main() { - zMults = vec3(1.0/(far * near),far+near,far-near); + //Improves performances and makes sure bloom radius stays the same at high resolution (>1080p) + vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); gl_Position = ftransform(); - texcoord = gl_MultiTexCoord0.xy; - + //*0.51 to avoid errors when sampling outside since clearing is disabled + gl_Position.xy = (gl_Position.xy*0.5+0.5)*0.26/clampedRes*vec2(1920.0,1080.)*2-1.0; } diff --git a/shaders/world1/composite11.fsh b/shaders/world1/composite7.fsh similarity index 100% rename from shaders/world1/composite11.fsh rename to shaders/world1/composite7.fsh diff --git a/shaders/world1/composite11.vsh b/shaders/world1/composite7.vsh similarity index 100% rename from shaders/world1/composite11.vsh rename to shaders/world1/composite7.vsh diff --git a/shaders/world1/composite8.fsh b/shaders/world1/composite8.fsh index dd85629..dd63b74 100644 --- a/shaders/world1/composite8.fsh +++ b/shaders/world1/composite8.fsh @@ -1,320 +1,61 @@ #version 120 -//Temporal Anti-Aliasing + Dynamic exposure calculations (vertex shader) - -#extension GL_EXT_gpu_shader4 : enable - -#define TAA //if disabled you should increase most samples counts as I rely on TAA to filter noise - -//#define FAST_TAA //disables bicubic resampling and closest velocity, improves fps especially at high resolutions - -//TAA OPTIONS -//#define NO_CLIP //Removes all anti-ghosting techniques used and creates a sharp image (good for still screenshots) -#define BLEND_FACTOR 0.05 //[0.01 0.02 0.03 0.04 0.05 0.06 0.08 0.1 0.12 0.14 0.16] higher values = more flickering but sharper image, lower values = less flickering but the image will be blurrier -#define MOTION_REJECTION 0.5 //[0.0 0.05 0.1 0.15 0.2 0.25 0.3 0.35 0.4 0.5] //Higher values=sharper image in motion at the cost of flickering -#define ANTI_GHOSTING 1.0 //[0.0 0.25 0.5 0.75 1.0] High values reduce ghosting but may create flickering -#define FLICKER_REDUCTION 0.75 //[0.0 0.25 0.5 0.75 1.0] High values reduce flickering but may reduce sharpness -#define CLOSEST_VELOCITY //improves edge quality in motion at the cost of performance +//6 Vertical gaussian blurs and vertical downsampling -const int noiseTextureResolution = 32; - - -/* -const int colortex0Format = RGBA16F; // low res clouds (deferred->composite2) + low res VL (composite5->composite15) -const int colortex1Format = RGBA16; //terrain gbuffer (gbuffer->composite2) -const int colortex2Format = RGBA16F; //forward + transparencies (gbuffer->composite4) -const int colortex3Format = R11F_G11F_B10F; //frame buffer + bloom (deferred6->final) -const int colortex4Format = RGBA16F; //light values and skyboxes (everything) -const int colortex5Format = R11F_G11F_B10F; //TAA buffer (everything) -const int colortex6Format = R11F_G11F_B10F; //additionnal buffer for bloom (composite3->final) -const int colortex7Format = RGBA8; //Final output, transparencies id (gbuffer->composite4) -*/ -//no need to clear the buffers, saves a few fps -const bool colortex0Clear = false; -const bool colortex1Clear = false; -const bool colortex2Clear = true; -const bool colortex3Clear = false; -const bool colortex4Clear = false; -const bool colortex5Clear = false; -const bool colortex6Clear = false; -const bool colortex7Clear = false; - -varying vec2 texcoord; -flat varying float exposureA; -flat varying float tempOffsets; -uniform sampler2D colortex3; -uniform sampler2D colortex5; -uniform sampler2D depthtex0; +uniform sampler2D colortex6; uniform vec2 texelSize; -uniform float frameTimeCounter; -uniform float viewHeight; +varying vec2 texcoord; uniform float viewWidth; -uniform vec3 previousCameraPosition; -uniform mat4 gbufferPreviousModelView; -#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) -#include "lib/projections.glsl" - - -float luma(vec3 color) { - return dot(color,vec3(0.21, 0.72, 0.07)); -} -float interleaved_gradientNoise(){ - return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+tempOffsets); -} -float triangularize(float dither) -{ - float center = dither*2.0-1.0; - dither = center*inversesqrt(abs(center)); - return clamp(dither-fsign(center),0.0,1.0); -} -vec3 fp10Dither(vec3 color,float dither){ - const vec3 mantissaBits = vec3(6.,6.,5.); - vec3 exponent = floor(log2(color)); - return color + dither*exp2(-mantissaBits)*exp2(exponent); -} - - -//returns the projected coordinates of the closest point to the camera in the 3x3 neighborhood -vec3 closestToCamera3x3() -{ - vec2 du = vec2(texelSize.x, 0.0); - vec2 dv = vec2(0.0, texelSize.y); - - vec3 dtl = vec3(texcoord,0.) + vec3(-texelSize, texture2D(depthtex0, texcoord - dv - du).x); - vec3 dtc = vec3(texcoord,0.) + vec3( 0.0, -texelSize.y, texture2D(depthtex0, texcoord - dv).x); - vec3 dtr = vec3(texcoord,0.) + vec3( texelSize.x, -texelSize.y, texture2D(depthtex0, texcoord - dv + du).x); - - vec3 dml = vec3(texcoord,0.) + vec3(-texelSize.x, 0.0, texture2D(depthtex0, texcoord - du).x); - vec3 dmc = vec3(texcoord,0.) + vec3( 0.0, 0.0, texture2D(depthtex0, texcoord).x); - vec3 dmr = vec3(texcoord,0.) + vec3( texelSize.x, 0.0, texture2D(depthtex0, texcoord + du).x); - - vec3 dbl = vec3(texcoord,0.) + vec3(-texelSize.x, texelSize.y, texture2D(depthtex0, texcoord + dv - du).x); - vec3 dbc = vec3(texcoord,0.) + vec3( 0.0, texelSize.y, texture2D(depthtex0, texcoord + dv).x); - vec3 dbr = vec3(texcoord,0.) + vec3( texelSize.x, texelSize.y, texture2D(depthtex0, texcoord + dv + du).x); - - vec3 dmin = dmc; - - dmin = dmin.z > dtc.z? dtc : dmin; - dmin = dmin.z > dtr.z? dtr : dmin; - - dmin = dmin.z > dml.z? dml : dmin; - dmin = dmin.z > dtl.z? dtl : dmin; - dmin = dmin.z > dmr.z? dmr : dmin; - - dmin = dmin.z > dbl.z? dbl : dmin; - dmin = dmin.z > dbc.z? dbc : dmin; - dmin = dmin.z > dbr.z? dbr : dmin; - - return dmin; -} - -//Modified texture interpolation from inigo quilez -vec4 smoothfilter(in sampler2D tex, in vec2 uv) -{ - vec2 textureResolution = vec2(viewWidth,viewHeight); - uv = uv*textureResolution + 0.5; - vec2 iuv = floor( uv ); - vec2 fuv = fract( uv ); - #ifndef SMOOTHESTSTEP_INTERPOLATION - uv = iuv + (fuv*fuv)*(3.0-2.0*fuv); - #endif - #ifdef SMOOTHESTSTEP_INTERPOLATION - uv = iuv + fuv*fuv*fuv*(fuv*(fuv*6.0-15.0)+10.0); - #endif - uv = (uv - 0.5)/textureResolution; - return texture2D( tex, uv); -} -//Due to low sample count we "tonemap" the inputs to preserve colors and smoother edges -vec3 weightedSample(sampler2D colorTex, vec2 texcoord){ - vec3 wsample = texture2D(colorTex,texcoord).rgb*exposureA; - return wsample/(1.0+luma(wsample)); - -} - - -//from : https://gist.github.com/TheRealMJP/c83b8c0f46b63f3a88a5986f4fa982b1 -vec4 SampleTextureCatmullRom(sampler2D tex, vec2 uv, vec2 texSize ) -{ - // We're going to sample a a 4x4 grid of texels surrounding the target UV coordinate. We'll do this by rounding - // down the sample location to get the exact center of our "starting" texel. The starting texel will be at - // location [1, 1] in the grid, where [0, 0] is the top left corner. - vec2 samplePos = uv * texSize; - vec2 texPos1 = floor(samplePos - 0.5) + 0.5; - - // Compute the fractional offset from our starting texel to our original sample location, which we'll - // feed into the Catmull-Rom spline function to get our filter weights. - vec2 f = samplePos - texPos1; - - // Compute the Catmull-Rom weights using the fractional offset that we calculated earlier. - // These equations are pre-expanded based on our knowledge of where the texels will be located, - // which lets us avoid having to evaluate a piece-wise function. - vec2 w0 = f * ( -0.5 + f * (1.0 - 0.5*f)); - vec2 w1 = 1.0 + f * f * (-2.5 + 1.5*f); - vec2 w2 = f * ( 0.5 + f * (2.0 - 1.5*f) ); - vec2 w3 = f * f * (-0.5 + 0.5 * f); - - // Work out weighting factors and sampling offsets that will let us use bilinear filtering to - // simultaneously evaluate the middle 2 samples from the 4x4 grid. - vec2 w12 = w1 + w2; - vec2 offset12 = w2 / (w1 + w2); - - // Compute the final UV coordinates we'll use for sampling the texture - vec2 texPos0 = texPos1 - vec2(1.0); - vec2 texPos3 = texPos1 + vec2(2.0); - vec2 texPos12 = texPos1 + offset12; - - texPos0 *= texelSize; - texPos3 *= texelSize; - texPos12 *= texelSize; - - vec4 result = vec4(0.0); - result += texture2D(tex, vec2(texPos0.x, texPos0.y)) * w0.x * w0.y; - result += texture2D(tex, vec2(texPos12.x, texPos0.y)) * w12.x * w0.y; - result += texture2D(tex, vec2(texPos3.x, texPos0.y)) * w3.x * w0.y; - - result += texture2D(tex, vec2(texPos0.x, texPos12.y)) * w0.x * w12.y; - result += texture2D(tex, vec2(texPos12.x, texPos12.y)) * w12.x * w12.y; - result += texture2D(tex, vec2(texPos3.x, texPos12.y)) * w3.x * w12.y; - - result += texture2D(tex, vec2(texPos0.x, texPos3.y)) * w0.x * w3.y; - result += texture2D(tex, vec2(texPos12.x, texPos3.y)) * w12.x * w3.y; - result += texture2D(tex, vec2(texPos3.x, texPos3.y)) * w3.x * w3.y; - - return result; -} -//approximation from SMAA presentation from siggraph 2016 -vec3 FastCatmulRom(sampler2D colorTex, vec2 texcoord, vec4 rtMetrics, float sharpenAmount) -{ - vec2 position = rtMetrics.zw * texcoord; - vec2 centerPosition = floor(position - 0.5) + 0.5; - vec2 f = position - centerPosition; - vec2 f2 = f * f; - vec2 f3 = f * f2; - - float c = sharpenAmount; - vec2 w0 = -c * f3 + 2.0 * c * f2 - c * f; - vec2 w1 = (2.0 - c) * f3 - (3.0 - c) * f2 + 1.0; - vec2 w2 = -(2.0 - c) * f3 + (3.0 - 2.0 * c) * f2 + c * f; - vec2 w3 = c * f3 - c * f2; - - vec2 w12 = w1 + w2; - vec2 tc12 = rtMetrics.xy * (centerPosition + w2 / w12); - vec3 centerColor = texture2D(colorTex, vec2(tc12.x, tc12.y)).rgb; - - vec2 tc0 = rtMetrics.xy * (centerPosition - 1.0); - vec2 tc3 = rtMetrics.xy * (centerPosition + 2.0); - vec4 color = vec4(texture2D(colorTex, vec2(tc12.x, tc0.y )).rgb, 1.0) * (w12.x * w0.y ) + - vec4(texture2D(colorTex, vec2(tc0.x, tc12.y)).rgb, 1.0) * (w0.x * w12.y) + - vec4(centerColor, 1.0) * (w12.x * w12.y) + - vec4(texture2D(colorTex, vec2(tc3.x, tc12.y)).rgb, 1.0) * (w3.x * w12.y) + - vec4(texture2D(colorTex, vec2(tc12.x, tc3.y )).rgb, 1.0) * (w12.x * w3.y ); - return color.rgb/color.a; - -} - -vec3 clip_aabb(vec3 q,vec3 aabb_min, vec3 aabb_max) - { - vec3 p_clip = 0.5 * (aabb_max + aabb_min); - vec3 e_clip = 0.5 * (aabb_max - aabb_min) + 0.00000001; - - vec3 v_clip = q - vec3(p_clip); - vec3 v_unit = v_clip.xyz / e_clip; - vec3 a_unit = abs(v_unit); - float ma_unit = max(a_unit.x, max(a_unit.y, a_unit.z)); - - if (ma_unit > 1.0) - return vec3(p_clip) + v_clip / ma_unit; - else - return q; +uniform float viewHeight; +vec2 resScale = vec2(1920.,1080.)/max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); +vec3 gauss1D(vec2 coord,vec2 dir,float alpha,int maxIT){ + vec4 tot = vec4(0.); + float maxTC = 0.25*resScale.y; + float minTC = 0.; + for (int i = -maxIT;i minTC && spCoord.y < maxTC); } -vec3 toClipSpace3Prev(vec3 viewSpacePosition) { - return projMAD(gbufferPreviousProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; + return tot.rgb/max(1.0,tot.a); } -vec3 TAA_hq(){ - //use velocity from the nearest texel from camera in a 3x3 box in order to improve edge quality in motion - #ifdef CLOSEST_VELOCITY - vec3 closestToCamera = closestToCamera3x3(); - #endif - - #ifndef CLOSEST_VELOCITY - vec3 closestToCamera = vec3(texcoord,texture2D(depthtex0,texcoord).x); - #endif - - //reproject previous frame - vec3 fragposition = toScreenSpace(closestToCamera); - fragposition = mat3(gbufferModelViewInverse) * fragposition + gbufferModelViewInverse[3].xyz + (cameraPosition - previousCameraPosition); - vec3 previousPosition = mat3(gbufferPreviousModelView) * fragposition + gbufferPreviousModelView[3].xyz; - previousPosition = toClipSpace3Prev(previousPosition); - vec2 velocity = previousPosition.xy - closestToCamera.xy; - previousPosition.xy = texcoord + velocity; - - //to reduce error propagation caused by interpolation during history resampling, we will introduce back some aliasing in motion - vec2 d = 0.5-abs(fract(previousPosition.xy*vec2(viewWidth,viewHeight)-texcoord*vec2(viewWidth,viewHeight))-0.5); - float mixFactor = dot(d,d); - float rej = mixFactor*MOTION_REJECTION; - //reject history if off-screen and early exit - if (previousPosition.x < 0.0 || previousPosition.y < 0.0 || previousPosition.x > 1.0 || previousPosition.y > 1.0) return texture2D(colortex3, texcoord).rgb; - - //Samples current frame 3x3 neighboorhood - vec3 albedoCurrent0 = texture2D(colortex3, texcoord).rgb; - vec3 albedoCurrent1 = texture2D(colortex3, texcoord + vec2(texelSize.x,texelSize.y)).rgb; - vec3 albedoCurrent2 = texture2D(colortex3, texcoord + vec2(texelSize.x,-texelSize.y)).rgb; - vec3 albedoCurrent3 = texture2D(colortex3, texcoord + vec2(-texelSize.x,-texelSize.y)).rgb; - vec3 albedoCurrent4 = texture2D(colortex3, texcoord + vec2(-texelSize.x,texelSize.y)).rgb; - vec3 albedoCurrent5 = texture2D(colortex3, texcoord + vec2(0.0,texelSize.y)).rgb; - vec3 albedoCurrent6 = texture2D(colortex3, texcoord + vec2(0.0,-texelSize.y)).rgb; - vec3 albedoCurrent7 = texture2D(colortex3, texcoord + vec2(-texelSize.x,0.0)).rgb; - vec3 albedoCurrent8 = texture2D(colortex3, texcoord + vec2(texelSize.x,0.0)).rgb; - - #ifndef NO_CLIP - //Assuming the history color is a blend of the 3x3 neighborhood, we clamp the history to the min and max of each channel in the 3x3 neighborhood - vec3 cMax = max(max(max(albedoCurrent0,albedoCurrent1),albedoCurrent2),max(albedoCurrent3,max(albedoCurrent4,max(albedoCurrent5,max(albedoCurrent6,max(albedoCurrent7,albedoCurrent8)))))); - vec3 cMin = min(min(min(albedoCurrent0,albedoCurrent1),albedoCurrent2),min(albedoCurrent3,min(albedoCurrent4,min(albedoCurrent5,min(albedoCurrent6,min(albedoCurrent7,albedoCurrent8)))))); - - - vec3 albedoPrev = FastCatmulRom(colortex5, previousPosition.xy,vec4(texelSize, 1.0/texelSize), 0.82).xyz; - vec3 finalcAcc = clamp(albedoPrev,cMin,cMax); - - - - //increases blending factor if history is far away from aabb, reduces ghosting at the cost of some flickering - float isclamped = distance(albedoPrev,finalcAcc)/luma(albedoPrev); - - //reduces blending factor if current texel is far from history, reduces flickering - float lumDiff2 = distance(albedoPrev,albedoCurrent0)/luma(albedoPrev); - lumDiff2 = 1.0-clamp(lumDiff2*lumDiff2,0.,1.)*FLICKER_REDUCTION; - - //Blend current pixel with clamped history - vec3 supersampled = mix(finalcAcc,albedoCurrent0,clamp(BLEND_FACTOR*lumDiff2+rej+isclamped*ANTI_GHOSTING+0.01,0.,1.)); - #endif - - - #ifdef NO_CLIP - vec3 albedoPrev = texture2D(colortex5, previousPosition.xy).xyz; - vec3 supersampled = mix(albedoPrev,albedoCurrent0,clamp(0.05,0.,1.)); - #endif - - //De-tonemap - return supersampled; -} +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// void main() { +/* DRAWBUFFERS:6 */ +vec2 texcoord = (gl_FragCoord.xy*vec2(2.0,4.0))*texelSize; -/* DRAWBUFFERS:5 */ -gl_FragData[0].a = 1.0; - #ifdef TAA - vec3 color = TAA_hq(); - gl_FragData[0].rgb = clamp(fp10Dither(color,triangularize(interleaved_gradientNoise())),6.11*1e-5,65000.0); - #endif - #ifndef TAA - vec3 color = clamp(fp10Dither(texture2D(colortex3,texcoord).rgb,triangularize(interleaved_gradientNoise())),0.,65000.); - gl_FragData[0].rgb = color; - #endif +vec2 gaussDir = vec2(0.0,1.0); +gl_FragData[0].rgb = vec3(0.0); +vec2 tc2 = texcoord*vec2(2.0,1.); +if (tc2.x < 1.0*resScale.x && tc2.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord/vec2(2.0,4.0),gaussDir,0.16,0); +vec2 tc4 = texcoord*vec2(4.0,2.)-vec2(0.5*resScale.x+4.0*texelSize.x,0.)*4.0; +if (tc4.x > 0.0 && tc4.y > 0.0 && tc4.x < 1.0*resScale.x && tc4.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord/vec2(2.0,2.0),gaussDir,0.16,3); +vec2 tc8 = texcoord*vec2(8.0,4.)-vec2(0.75*resScale.x+8.*texelSize.x,0.)*8.0; +if (tc8.x > 0.0 && tc8.y > 0.0 && tc8.x < 1.0*resScale.x && tc8.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,2.0)/vec2(2.0,2.0),gaussDir,0.035,6); +vec2 tc16 = texcoord*vec2(16.0,8.)-vec2(0.875*resScale.x+12.*texelSize.x,0.)*16.0; +if (tc16.x > 0.0 && tc16.y > 0.0 && tc16.x < 1.0*resScale.x && tc16.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,4.0)/vec2(2.0,2.0),gaussDir,0.0085,12); +vec2 tc32 = texcoord*vec2(32.0,16.)-vec2(0.9375*resScale.x+16.*texelSize.x,0.)*32.0; +if (tc32.x > 0.0 && tc32.y > 0.0 && tc32.x < 1.0*resScale.x && tc32.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,8.0)/vec2(2.0,2.0),gaussDir,0.002,30); +vec2 tc64 = texcoord*vec2(64.0,32.)-vec2(0.96875*resScale.x+20.*texelSize.x,0.)*64.0; +if (tc64.x > 0.0 && tc64.y > 0.0 && tc64.x < 1.0*resScale.x && tc64.y <1.0*resScale.y) +gl_FragData[0].xyz = gauss1D(texcoord*vec2(1.0,16.0)/vec2(2.0,2.0),gaussDir,0.0005,60); + +gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); } diff --git a/shaders/world1/composite8.vsh b/shaders/world1/composite8.vsh index 24ef8ce..56683b4 100644 --- a/shaders/world1/composite8.vsh +++ b/shaders/world1/composite8.vsh @@ -1,17 +1,21 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable - +uniform float viewWidth; +uniform float viewHeight; varying vec2 texcoord; -flat varying float exposureA; -flat varying float tempOffsets; -uniform sampler2D colortex4; -uniform int frameCounter; -#include "/lib/util.glsl" -void main() { +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// - tempOffsets = HaltonSeq2(frameCounter%10000); +void main() { + vec2 clampedRes = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.0)); gl_Position = ftransform(); - texcoord = gl_MultiTexCoord0.xy; - exposureA = texelFetch2D(colortex4,ivec2(10,37),0).r; + //0-0.25 + gl_Position.y = (gl_Position.y*0.5+0.5)*0.25/clampedRes.y*1080.0*2.0-1.0; + //0-0.5 + gl_Position.x = (gl_Position.x*0.5+0.5)*0.5/clampedRes.x*1920.0*2.0-1.0; + texcoord = gl_MultiTexCoord0.xy/clampedRes*vec2(1920.,1080.); + } diff --git a/shaders/world1/composite9.fsh b/shaders/world1/composite9.fsh index 517bfe5..6bfa802 100644 --- a/shaders/world1/composite9.fsh +++ b/shaders/world1/composite9.fsh @@ -1,11 +1,78 @@ #version 120 -//downsample 1st pass (half res) for bloom +//Merge and upsample the blurs into a 1/4 res bloom buffer + +uniform sampler2D colortex3; +uniform sampler2D colortex6; -uniform sampler2D colortex5; -uniform sampler2D colortex8; uniform vec2 texelSize; uniform float viewWidth; uniform float viewHeight; + +float w0(float a) +{ + return (1.0/6.0)*(a*(a*(-a + 3.0) - 3.0) + 1.0); +} + +float w1(float a) +{ + return (1.0/6.0)*(a*a*(3.0*a - 6.0) + 4.0); +} + +float w2(float a) +{ + return (1.0/6.0)*(a*(a*(-3.0*a + 3.0) + 3.0) + 1.0); +} + +float w3(float a) +{ + return (1.0/6.0)*(a*a*a); +} + +float g0(float a) +{ + return w0(a) + w1(a); +} + +float g1(float a) +{ + return w2(a) + w3(a); +} + +float h0(float a) +{ + return -1.0 + w1(a) / (w0(a) + w1(a)); +} + +float h1(float a) +{ + return 1.0 + w3(a) / (w2(a) + w3(a)); +} + +vec4 texture2D_bicubic(sampler2D tex, vec2 uv) +{ + vec4 texelSize = vec4(texelSize,1.0/texelSize); + uv = uv*texelSize.zw; + vec2 iuv = floor( uv ); + vec2 fuv = fract( uv ); + + float g0x = g0(fuv.x); + float g1x = g1(fuv.x); + float h0x = h0(fuv.x); + float h1x = h1(fuv.x); + float h0y = h0(fuv.y); + float h1y = h1(fuv.y); + + vec2 p0 = (vec2(iuv.x + h0x, iuv.y + h0y) - 0.5) * texelSize.xy; + vec2 p1 = (vec2(iuv.x + h1x, iuv.y + h0y) - 0.5) * texelSize.xy; + vec2 p2 = (vec2(iuv.x + h0x, iuv.y + h1y) - 0.5) * texelSize.xy; + vec2 p3 = (vec2(iuv.x + h1x, iuv.y + h1y) - 0.5) * texelSize.xy; + + return g0(fuv.y) * (g0x * texture2D(tex, p0) + + g1x * texture2D(tex, p1)) + + g1(fuv.y) * (g0x * texture2D(tex, p2) + + g1x * texture2D(tex, p3)); +} + //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -13,41 +80,24 @@ uniform float viewHeight; //////////////////////////////VOID MAIN////////////////////////////// void main() { - /* DRAWBUFFERS:3 */ -vec2 resScale = max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.))/vec2(1920.,1080.); -vec2 quarterResTC = gl_FragCoord.xy*2.*resScale*texelSize; +vec2 resScale = vec2(1920.,1080.)/max(vec2(viewWidth,viewHeight),vec2(1920.0,1080.)); +vec2 texcoord = ((gl_FragCoord.xy)*2.+0.5)*texelSize; +vec3 bloom = texture2D_bicubic(colortex3,texcoord/2.0).rgb; //1/4 res -float emissives = texture2D(colortex8,quarterResTC).a; -if(emissives == 1.0) emissives = 0.0; -emissives *= 5; - //0.5 - gl_FragData[0] = texture2D(colortex5,quarterResTC-1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex5,quarterResTC+1.0*vec2(texelSize.x,texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(-1.0*texelSize.x,1.0*texelSize.y))/4.*0.5; - gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(1.0*texelSize.x,-1.0*texelSize.y))/4.*0.5; +bloom += texture2D_bicubic(colortex6,texcoord/4.).rgb; //1/8 res - //0.25 - gl_FragData[0] += texture2D(colortex5,quarterResTC-2.0*vec2(texelSize.x,0.0))/2.*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(0.0,texelSize.y))/2.*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(0,-texelSize.y))/2*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(-texelSize.x,0.0))/2*0.125; +bloom += texture2D_bicubic(colortex6,texcoord/8.+vec2(0.25*resScale.x+2.5*texelSize.x,.0)).rgb; //1/16 res - //0.125 - gl_FragData[0] += texture2D(colortex5,quarterResTC-2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+2.0*vec2(texelSize.x,texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(-2.0*texelSize.x,2.0*texelSize.y))/4.*0.125; - gl_FragData[0] += texture2D(colortex5,quarterResTC+vec2(2.0*texelSize.x,-2.0*texelSize.y))/4.*0.125; +bloom += texture2D_bicubic(colortex6,texcoord/16.+vec2(0.375*resScale.x+4.5*texelSize.x,.0)).rgb; //1/32 res - //0.125 - gl_FragData[0] += texture2D(colortex5,quarterResTC)*0.125; +bloom += texture2D_bicubic(colortex6,texcoord/32.+vec2(0.4375*resScale.x+6.5*texelSize.x,.0)).rgb*1.0; //1/64 res +bloom += texture2D_bicubic(colortex6,texcoord/64.+vec2(0.46875*resScale.x+8.5*texelSize.x,.0)).rgb*1.0; //1/128 res +bloom += texture2D_bicubic(colortex6,texcoord/128.+vec2(0.484375*resScale.x+10.5*texelSize.x,.0)).rgb*1.0; //1/256 res - gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); - - // gl_FragData[0].rgb += gl_FragData[0].rgb*emissives; - - - if (quarterResTC.x > 1.0 - 3.5*texelSize.x || quarterResTC.y > 1.0 -3.5*texelSize.y || quarterResTC.x < 3.5*texelSize.x || quarterResTC.y < 3.5*texelSize.y) gl_FragData[0].rgb = vec3(0.0); +//bloom = texture2D_bicubic(colortex6,texcoord).rgb*6.; //1/8 res +gl_FragData[0].rgb = bloom*2.; +gl_FragData[0].rgb = clamp(gl_FragData[0].rgb,0.0,65000.); } diff --git a/shaders/world1/deferred.fsh b/shaders/world1/deferred.fsh index 34b9358..abb060a 100644 --- a/shaders/world1/deferred.fsh +++ b/shaders/world1/deferred.fsh @@ -2,14 +2,7 @@ #extension GL_EXT_gpu_shader4 : enable -//Prepares sky textures (2 * 256 * 256), computes light values and custom lightmaps -#define Ambient_Mult 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0 5.0 6.0 10.0] -#define Sky_Brightness 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0 5.0 6.0 10.0] -#define MIN_LIGHT_AMOUNT 1.0 //[0.0 0.5 1.0 1.5 2.0 3.0 4.0 5.0] -#define TORCH_AMOUNT 1.0 //[0.0 0.5 0.75 1. 1.2 1.4 1.6 1.8 2.0] -#define TORCH_R 1.0 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define TORCH_G 0.75 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define TORCH_B 0.5 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] +#include "/lib/settings.glsl" flat varying vec3 ambientUp; @@ -53,8 +46,12 @@ uniform float sunElevation; uniform vec3 cameraPosition; uniform float far; uniform ivec2 eyeBrightnessSmooth; + + #include "/lib/util.glsl" #include "/lib/ROBOBO_sky.glsl" + + vec3 toShadowSpaceProjected(vec3 p3){ p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; p3 = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; @@ -73,59 +70,29 @@ float blueNoise(){ vec4 lightCol = vec4(lightSourceColor, float(sunElevation > 1e-5)*2-1.); const float[17] Slightmap = float[17](14.0,17.,19.0,22.0,24.0,28.0,31.0,40.0,60.0,79.0,93.0,110.0,132.0,160.0,197.0,249.0,249.0); +#include "/lib/end_fog.glsl" + void main() { /* DRAWBUFFERS:4 */ + gl_FragData[0] = vec4(0.0); -//Lightmap for forward shading (contains average integrated sky color across all faces + torch + min ambient) -vec3 avgAmbient = (ambientUp + ambientLeft + ambientRight + ambientB + ambientF + ambientDown)/6.; -if (gl_FragCoord.x < 17. && gl_FragCoord.y < 17.){ - float torchLut = clamp(16.0-gl_FragCoord.x,0.5,15.5); - torchLut = torchLut+0.712; - float torch_lightmap = max(1.0/torchLut/torchLut - 1/16.21/16.21,0.0); - torch_lightmap = torch_lightmap*TORCH_AMOUNT*5.0; - float sky_lightmap = 0.5*150.0; - vec3 ambient = avgAmbient*sky_lightmap+torch_lightmap*vec3(TORCH_R,TORCH_G,TORCH_B)*TORCH_AMOUNT+MIN_LIGHT_AMOUNT*0.005/(exposureF+clamp(rodExposure*exposureF/10.,0.0,10000.0)); - gl_FragData[0] = vec4(ambient*Ambient_Mult,1.0); -} -//Lightmap for deferred shading (contains only torch + min ambient) -if (gl_FragCoord.x < 17. && gl_FragCoord.y > 19. && gl_FragCoord.y < 19.+17. ){ - float torchLut = clamp(16.0-gl_FragCoord.x,0.5,15.5); - torchLut = torchLut+0.712; - float torch_lightmap = max(1.0/torchLut/torchLut - 1/16.21/16.21,0.0); - float ambient = torch_lightmap*TORCH_AMOUNT*5.; - float sky_lightmap = 0.5; - gl_FragData[0] = vec4(sky_lightmap,ambient,MIN_LIGHT_AMOUNT*0.005/(exposureF+clamp(rodExposure*exposureF/10.,0.0,10000.0)),1.0)*Ambient_Mult; -} +//Fog for reflections +if (gl_FragCoord.x > 18.+257. && gl_FragCoord.y > 1. && gl_FragCoord.x < 18+257+257.){ + vec2 p = clamp(floor(gl_FragCoord.xy-vec2(18.+257,1.))/256.+tempOffsets/256.,0.0,1.0); + vec3 viewVector = cartToSphere(p); -//Save light values -if (gl_FragCoord.x < 1. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientUp,1.0); -if (gl_FragCoord.x > 1. && gl_FragCoord.x < 2. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientDown,1.0); -if (gl_FragCoord.x > 2. && gl_FragCoord.x < 3. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientLeft,1.0); -if (gl_FragCoord.x > 3. && gl_FragCoord.x < 4. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientRight,1.0); -if (gl_FragCoord.x > 4. && gl_FragCoord.x < 5. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientB,1.0); -if (gl_FragCoord.x > 5. && gl_FragCoord.x < 6. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(ambientF,1.0); -if (gl_FragCoord.x > 6. && gl_FragCoord.x < 7. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(lightSourceColor,1.0); -if (gl_FragCoord.x > 7. && gl_FragCoord.x < 8. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) -gl_FragData[0] = vec4(avgAmbient,1.0); + mat2x3 vL = getVolumetricRays(fract(frameCounter/1.6180339887),mat3(gbufferModelView)*viewVector*1024.,fract(frameCounter/2.6180339887)); + float absorbance = dot(vL[1],vec3(0.22,0.71,0.07)); -//Sky gradient (no clouds) -const float pi = 3.141592653589793238462643383279502884197169; -if (gl_FragCoord.x > 18. && gl_FragCoord.y > 1. && gl_FragCoord.x < 18+257){ - gl_FragData[0] = vec4(vec3(1.0,0.4,0.12)*100.,1.0); + + gl_FragData[0] = vec4(vL[0].rgb * (1.0-absorbance),1.0); } //Temporally accumulate sky and light values vec3 temp = texelFetch2D(colortex4,ivec2(gl_FragCoord.xy),0).rgb; vec3 curr = gl_FragData[0].rgb*150.; -gl_FragData[0].rgb = clamp(mix(temp,curr,0.06),0.0,65000.); +gl_FragData[0].rgb = clamp(mix(temp,curr,0.07),0.0,65000.); //Exposure values if (gl_FragCoord.x > 10. && gl_FragCoord.x < 11. && gl_FragCoord.y > 19.+18. && gl_FragCoord.y < 19.+18.+1 ) diff --git a/shaders/world1/deferred.vsh b/shaders/world1/deferred.vsh index 2ff914b..4fa6840 100644 --- a/shaders/world1/deferred.vsh +++ b/shaders/world1/deferred.vsh @@ -1,14 +1,8 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable -#define EXPOSURE_MULTIPLIER 1.0 //[0.25 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.1 1.2 1.3 1.4 1.5 2.0 3.0 4.0] -#define AUTO_EXPOSURE //Highly recommended to keep it on unless you want to take screenshots -#define Manual_exposure_value 1.0 // [0.000553 0.000581 0.000611 0.000642 0.000675 0.000710 0.000746 0.000784 0.000825 0.000867 0.000911 0.000958 0.001007 0.001059 0.001113 0.001170 0.001230 0.001294 0.001360 0.001430 0.001503 0.001580 0.001661 0.001746 0.001836 0.001930 0.002029 0.002133 0.002242 0.002357 0.002478 0.002605 0.002739 0.002879 0.003027 0.003182 0.003345 0.003517 0.003697 0.003887 0.004086 0.004296 0.004516 0.004748 0.004991 0.005247 0.005516 0.005799 0.006096 0.006409 0.006737 0.007083 0.007446 0.007828 0.008229 0.008651 0.009095 0.009561 0.010051 0.010567 0.011108 0.011678 0.012277 0.012906 0.013568 0.014264 0.014995 0.015764 0.016572 0.017422 0.018315 0.019254 0.020241 0.021279 0.022370 0.023517 0.024723 0.025991 0.027323 0.028724 0.030197 0.031745 0.033373 0.035084 0.036883 0.038774 0.040762 0.042852 0.045049 0.047358 0.049787 0.052339 0.055023 0.057844 0.060810 0.063927 0.067205 0.070651 0.074273 0.078081 0.082084 0.086293 0.090717 0.095369 0.100258 0.105399 0.110803 0.116484 0.122456 0.128734 0.135335 0.142274 0.149568 0.157237 0.165298 0.173773 0.182683 0.192049 0.201896 0.212247 0.223130 0.234570 0.246596 0.259240 0.272531 0.286504 0.301194 0.316636 0.332871 0.349937 0.367879 0.386741 0.406569 0.427414 0.449328 0.472366 0.496585 0.522045 0.548811 0.576949 0.606530 0.637628 0.670320 0.704688 0.740818 0.778800 0.818730 0.860707 0.904837 0.951229 1.0 1.051271 1.105170 1.161834 1.221402 1.284025 1.349858 1.419067 1.491824 1.568312 1.648721 1.733253 1.822118 1.915540 2.013752 2.117000 2.225540 2.339646 2.459603 2.585709 2.718281 2.857651 3.004166 3.158192 3.320116 3.490342 3.669296 3.857425 4.055199 4.263114 4.481689 4.711470 4.953032 5.206979 5.473947 5.754602 6.049647 6.359819 6.685894 7.028687 7.389056 7.767901 8.166169 8.584858 9.025013 9.487735 9.974182 10.48556 11.02317 11.58834 12.18249 ] -#define Exposure_Speed 1.0 //[0.25 0.5 0.75 1.0 1.25 1.5 1.75 2.0 2.25 2.5 2.75 3.0 4.0 5.0] -#define CLOUDS_SHADOWS -#define BASE_FOG_AMOUNT 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0 10.0 20.0 30.0 50.0 100.0 150.0 200.0] Base fog amount amount (does not change the "cloudy" fog) -#define CLOUDY_FOG_AMOUNT 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0] -#define FOG_TOD_MULTIPLIER 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0] //Influence of time of day on fog amount -#define FOG_RAIN_MULTIPLIER 1.0 //[0.0 0.2 0.4 0.6 0.8 1.0 1.25 1.5 1.75 2.0 3.0 4.0 5.0] //Influence of rain on fog amount + +#include "/lib/settings.glsl" + flat varying vec3 ambientUp; flat varying vec3 ambientLeft; flat varying vec3 ambientRight; @@ -43,12 +37,15 @@ uniform float frameTime; uniform float eyeAltitude; uniform int frameCounter; uniform int worldTime; -vec3 sunVec = -normalize(vec3(0.8,0.8,0.2)); +vec3 sunVec = vec3(0.0,1.0,0.0); -#include "lib/sky_gradient.glsl" + +#include "/lib/sky_gradient.glsl" #include "/lib/util.glsl" #include "/lib/ROBOBO_sky.glsl" + + vec3 rodSample(vec2 Xi) { float r = sqrt(1.0f - Xi.x*Xi.y); @@ -70,6 +67,10 @@ vec3 cosineHemisphereSample(vec2 Xi) float luma(vec3 color) { return dot(color,vec3(0.21, 0.72, 0.07)); } +vec3 toLinear(vec3 sRGB){ + return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); +} + vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter) { @@ -95,107 +96,101 @@ void main() { gl_Position.xy = gl_Position.xy*vec2(18.+258*2,258.)*texelSize; gl_Position.xy = gl_Position.xy*2.-1.0; - tempOffsets = R2_samples(frameCounter%10000); +// tempOffsets = R2_samples(frameCounter%10000); - ambientUp = vec3(0.0); - ambientDown = vec3(0.0); - ambientLeft = vec3(0.0); - ambientRight = vec3(0.0); - ambientB = vec3(0.0); - ambientF = vec3(0.0); - avgSky = vec3(0.0); +// ambientUp = vec3(0.0); +// ambientDown = vec3(0.0); +// ambientLeft = vec3(0.0); +// ambientRight = vec3(0.0); +// ambientB = vec3(0.0); +// ambientF = vec3(0.0); +// avgSky = vec3(0.0); - //Fake bounced sunlight - vec3 bouncedSun = 0.3 * vec3(1.0,0.7,0.85)/4000; - ambientUp += bouncedSun*clamp(-sunVec.y+1.,0.,4.0); - ambientLeft += bouncedSun*clamp(sunVec.x+1.,0.0,4.); - ambientRight += bouncedSun*clamp(-sunVec.x+1.,0.0,4.); - ambientB += bouncedSun*clamp(-sunVec.z+1.,0.0,4.); - ambientF += bouncedSun*clamp(sunVec.z+1.,0.0,4.); - ambientDown += bouncedSun*clamp(sunVec.y+1.,0.0,4.); +// //Fake bounced sunlight +// vec3 bouncedSun = clamp(gl_Fog.color.rgb*pow(luma(gl_Fog.color.rgb),-0.75)*0.65,0.0,1.0)/4000.*0.08; +// ambientUp += bouncedSun*clamp(-sunVec.y+5.,0.,6.0); +// ambientLeft += bouncedSun*clamp(sunVec.x+5.,0.0,6.); +// ambientRight += bouncedSun*clamp(-sunVec.x+5.,0.0,6.); +// ambientB += bouncedSun*clamp(-sunVec.z+5.,0.0,6.); +// ambientF += bouncedSun*clamp(sunVec.z+5.,0.0,6.); +// ambientDown += bouncedSun*clamp(sunVec.y+5.,0.0,6.); - float avgLuma = 0.0; - float m2 = 0.0; - int n=100; - vec2 clampedRes = max(1.0/texelSize,vec2(1920.0,1080.)); - float avgExp = 0.0; - vec2 resScale = vec2(1920.,1080.)/clampedRes; - float v[25]; - float temp; - // 5x5 Median filter by morgan mcguire - // We take the median value of the most blurred bloom buffer - #define s2(a, b) temp = a; a = min(a, b); b = max(temp, b); - #define t2(a, b) s2(v[a], v[b]); - #define t24(a, b, c, d, e, f, g, h) t2(a, b); t2(c, d); t2(e, f); t2(g, h); - #define t25(a, b, c, d, e, f, g, h, i, j) t24(a, b, c, d, e, f, g, h); t2(i, j); - for (int i = 0; i < 5; i++){ - for (int j = 0; j < 5; j++){ - vec2 tc = 0.5 + vec2(i-2,j-2)/2.0 * 0.35; - v[i+j*5] = luma(texture2D(colortex6,tc/128. * resScale+vec2(0.484375*resScale.x+10.5*texelSize.x,.0)).rgb); - } - } - t25(0, 1, 3, 4, 2, 4, 2, 3, 6, 7); - t25(5, 7, 5, 6, 9, 7, 1, 7, 1, 4); - t25(12, 13, 11, 13, 11, 12, 15, 16, 14, 16); - t25(14, 15, 18, 19, 17, 19, 17, 18, 21, 22); - t25(20, 22, 20, 21, 23, 24, 2, 5, 3, 6); - t25(0, 6, 0, 3, 4, 7, 1, 7, 1, 4); - t25(11, 14, 8, 14, 8, 11, 12, 15, 9, 15); - t25(9, 12, 13, 16, 10, 16, 10, 13, 20, 23); - t25(17, 23, 17, 20, 21, 24, 18, 24, 18, 21); - t25(19, 22, 8, 17, 9, 18, 0, 18, 0, 9); - t25(10, 19, 1, 19, 1, 10, 11, 20, 2, 20); - t25(2, 11, 12, 21, 3, 21, 3, 12, 13, 22); - t25(4, 22, 4, 13, 14, 23, 5, 23, 5, 14); - t25(15, 24, 6, 24, 6, 15, 7, 16, 7, 19); - t25(3, 11, 5, 17, 11, 17, 9, 17, 4, 10); - t25(6, 12, 7, 14, 4, 6, 4, 7, 12, 14); - t25(10, 14, 6, 7, 10, 12, 6, 10, 6, 17); - t25(12, 17, 7, 17, 7, 10, 12, 18, 7, 12); - t24(10, 18, 12, 20, 10, 20, 10, 12); - avgExp = v[12]; // Median value +// float avgLuma = 0.0; +// float m2 = 0.0; +// int n=100; +// vec2 clampedRes = max(1.0/texelSize,vec2(1920.0,1080.)); +// float avgExp = 0.0; +// vec2 resScale = vec2(1920.,1080.)/clampedRes; +// float v[25]; +// float temp; +// // 5x5 Median filter by morgan mcguire +// // We take the median value of the most blurred bloom buffer +// #define s2(a, b) temp = a; a = min(a, b); b = max(temp, b); +// #define t2(a, b) s2(v[a], v[b]); +// #define t24(a, b, c, d, e, f, g, h) t2(a, b); t2(c, d); t2(e, f); t2(g, h); +// #define t25(a, b, c, d, e, f, g, h, i, j) t24(a, b, c, d, e, f, g, h); t2(i, j); +// for (int i = 0; i < 5; i++){ +// for (int j = 0; j < 5; j++){ +// vec2 tc = 0.5 + vec2(i-2,j-2)/2.0 * 0.35; +// v[i+j*5] = luma(texture2D(colortex6,tc/128. * resScale+vec2(0.484375*resScale.x+10.5*texelSize.x,.0)).rgb); +// } +// } +// t25(0, 1, 3, 4, 2, 4, 2, 3, 6, 7); +// t25(5, 7, 5, 6, 9, 7, 1, 7, 1, 4); +// t25(12, 13, 11, 13, 11, 12, 15, 16, 14, 16); +// t25(14, 15, 18, 19, 17, 19, 17, 18, 21, 22); +// t25(20, 22, 20, 21, 23, 24, 2, 5, 3, 6); +// t25(0, 6, 0, 3, 4, 7, 1, 7, 1, 4); +// t25(11, 14, 8, 14, 8, 11, 12, 15, 9, 15); +// t25(9, 12, 13, 16, 10, 16, 10, 13, 20, 23); +// t25(17, 23, 17, 20, 21, 24, 18, 24, 18, 21); +// t25(19, 22, 8, 17, 9, 18, 0, 18, 0, 9); +// t25(10, 19, 1, 19, 1, 10, 11, 20, 2, 20); +// t25(2, 11, 12, 21, 3, 21, 3, 12, 13, 22); +// t25(4, 22, 4, 13, 14, 23, 5, 23, 5, 14); +// t25(15, 24, 6, 24, 6, 15, 7, 16, 7, 19); +// t25(3, 11, 5, 17, 11, 17, 9, 17, 4, 10); +// t25(6, 12, 7, 14, 4, 6, 4, 7, 12, 14); +// t25(10, 14, 6, 7, 10, 12, 6, 10, 6, 17); +// t25(12, 17, 7, 17, 7, 10, 12, 18, 7, 12); +// t24(10, 18, 12, 20, 10, 20, 10, 12); +// avgExp = v[12]; // Median value - avgBrightness = clamp(mix(avgExp,texelFetch2D(colortex4,ivec2(10,37),0).g,0.95),0.00003051757,65000.0); +// avgBrightness = clamp(mix(avgExp,texelFetch2D(colortex4,ivec2(10,37),0).g,0.95),0.00003051757,65000.0); - float currentExposure = texelFetch2D(colortex4,ivec2(10,37),0).b; - float L = max(avgBrightness,1e-8); - float keyVal = 1.03-2.0/(log(L+1.0)/log(10.0)+2.0); - float targetExposure = 1.0*keyVal/L; +// float currentExposure = texelFetch2D(colortex4,ivec2(10,37),0).b; +// float L = max(avgBrightness,1e-8); +// float keyVal = 1.03-2.0/(log(L+1.0)/log(10.0)+2.0); +// float targetExposure = 1.0*keyVal/L; - float targetrodExposure = clamp(log(targetExposure*2.0+1.0)-0.1,0.0,2.0); - float currentrodExposure = texelFetch2D(colortex4,ivec2(14,37),0).r; +// float targetrodExposure = clamp(log(targetExposure*2.0+1.0)-0.1,0.0,2.0); +// float currentrodExposure = texelFetch2D(colortex4,ivec2(14,37),0).r; - targetExposure = clamp(targetExposure,2.0,3.0); - float rad = sqrt(currentExposure); - float rtarget = sqrt(targetExposure); - float dir = sign(rtarget-rad); - float dist = abs(rtarget-rad); - float maxApertureChange = 0.0032*frameTime/0.016666*Exposure_Speed * exp2(max(rad,rtarget)*0.5); +// targetExposure = clamp(targetExposure,2.0,3.0); +// float rad = sqrt(currentExposure); +// float rtarget = sqrt(targetExposure); +// float dir = sign(rtarget-rad); +// float dist = abs(rtarget-rad); +// float maxApertureChange = 0.0032*frameTime/0.016666*Exposure_Speed * exp2(max(rad,rtarget)*0.5); - maxApertureChange *= 1.0+nightVision*4.; - rad = rad+dir*min(dist,maxApertureChange); +// maxApertureChange *= 1.0+nightVision*4.; +// rad = rad+dir*min(dist,maxApertureChange); - exposureF = rad*rad; - exposure=exposureF*EXPOSURE_MULTIPLIER; +// exposureF = rad*rad; +// exposure=exposureF*EXPOSURE_MULTIPLIER; - dir = sign(targetrodExposure-currentrodExposure); - dist = abs(targetrodExposure-currentrodExposure); - maxApertureChange = 0.0032*frameTime/0.016666*Exposure_Speed * exp2(max(rad,rtarget)*0.5); +// dir = sign(targetrodExposure-currentrodExposure); +// dist = abs(targetrodExposure-currentrodExposure); +// maxApertureChange = 0.0032*frameTime/0.016666*Exposure_Speed * exp2(max(rad,rtarget)*0.5); - rodExposure = currentrodExposure + dir * min(dist,maxApertureChange); +// rodExposure = currentrodExposure + dir * min(dist,maxApertureChange); - #ifndef AUTO_EXPOSURE - exposure = Manual_exposure_value; - rodExposure = clamp(log(Manual_exposure_value*2.0+1.0)-0.1,0.0,2.0); - #endif - float modWT = (worldTime%24000)*1.0; + exposure = 1.0; + rodExposure = clamp(log(1.0*2.0+1.0)-0.1,0.0,2.0); - float fogAmount0 = 1/3000.+FOG_TOD_MULTIPLIER*(1/180.*(clamp(modWT-11000.,0.,2000.0)/2000.+(1.0-clamp(modWT,0.,3000.0)/3000.))*(clamp(modWT-11000.,0.,2000.0)/2000.+(1.0-clamp(modWT,0.,3000.0)/3000.)) + 1/200.*clamp(modWT-13000.,0.,1000.0)/1000.*(1.0-clamp(modWT-23000.,0.,1000.0)/1000.)); - VFAmount = CLOUDY_FOG_AMOUNT*(fogAmount0*fogAmount0+FOG_RAIN_MULTIPLIER*1.8/20000.*rainStrength); - fogAmount = BASE_FOG_AMOUNT*(fogAmount0+max(FOG_RAIN_MULTIPLIER*1/15.*rainStrength , FOG_TOD_MULTIPLIER*1/50.*clamp(modWT-13000.,0.,1000.0)/1000.*(1.0-clamp(modWT-23000.,0.,1000.0)/1000.))); } diff --git a/shaders/world1/deferred1.fsh b/shaders/world1/deferred1.fsh deleted file mode 100644 index 24db38d..0000000 --- a/shaders/world1/deferred1.fsh +++ /dev/null @@ -1,87 +0,0 @@ -#version 120 -#extension GL_EXT_gpu_shader4 : enable - -//Computes volumetric clouds at variable resolution (default 1/4 res) -#define HQ_CLOUDS //Renders detailled clouds for viewport -#define CLOUDS_QUALITY 0.5 //[0.1 0.125 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.9 1.0] -#define TAA - -flat varying vec3 sunColor; -flat varying vec3 moonColor; -flat varying vec3 avgAmbient; -flat varying float tempOffsets; - -uniform sampler2D depthtex0; -uniform sampler2D noisetex; - -// uniform vec3 sunVec; -// uniform vec3 sunPosition; -uniform vec2 texelSize; -uniform float frameTimeCounter; -uniform float rainStrength; -uniform int frameCounter; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferModelViewInverse; -uniform mat4 gbufferModelView; -uniform vec3 cameraPosition; - -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; -} - - -#include "lib/volumetricClouds.glsl" - - -float interleaved_gradientNoise(){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+frameCounter/1.6180339887); - return noise; -} -float interleaved_gradientNoise2(){ - vec2 coord = gl_FragCoord.xy; - float noise = 1-fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+frameCounter/1.6180339887); - return noise; -} -float blueNoise(){ - return fract(texelFetch2D(noisetex, ivec2(1.0-gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); -} -float blueNoise2(){ - return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); -} -float R2_dither(){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y + 1.0/1.6180339887 * frameCounter); -} -float R2_dither2(){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha.x * (1.0-gl_FragCoord.x) + alpha.y * (1.0-gl_FragCoord.y) + 1.0/1.6180339887 * frameCounter); -} -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { -/* DRAWBUFFERS:0 */ - - - - #ifdef VOLUMETRIC_CLOUDS - vec2 halfResTC = vec2(floor(gl_FragCoord.xy)/CLOUDS_QUALITY+0.5); - - vec3 fragpos = toScreenSpace(vec3(halfResTC*texelSize,1.0)); - // vec4 currentClouds = renderClouds(fragpos,vec3(0.),R2_dither(),sunColor/150.,moonColor/150.,avgAmbient/150., blueNoise()); - - // gl_FragData[0] = currentClouds; - - - #else - gl_FragData[0] = vec4(0.0,0.0,0.0,1.0); - #endif - -} diff --git a/shaders/world1/deferred1.vsh b/shaders/world1/deferred1.vsh deleted file mode 100644 index 1afd63f..0000000 --- a/shaders/world1/deferred1.vsh +++ /dev/null @@ -1,21 +0,0 @@ -#version 120 -#extension GL_EXT_gpu_shader4 : enable -#define CLOUDS_QUALITY 0.5 //[0.1 0.125 0.15 0.2 0.25 0.3 0.35 0.4 0.45 0.5 0.55 0.6 0.65 0.7 0.75 0.8 0.9 1.0] - -flat varying vec3 sunColor; -flat varying vec3 moonColor; -flat varying vec3 avgAmbient; -flat varying float tempOffsets; - - -uniform sampler2D colortex4; -uniform int frameCounter; -#include "/lib/util.glsl" - -void main() { - tempOffsets = HaltonSeq2(frameCounter%10000); - gl_Position = ftransform(); - gl_Position.xy = (gl_Position.xy*0.5+0.5)*clamp(CLOUDS_QUALITY+0.01,0.0,1.0)*2.0-1.0; - avgAmbient = texelFetch2D(colortex4,ivec2(7,37),0).rgb; - -} diff --git a/shaders/world1/deferred2.fsh b/shaders/world1/deferred2.fsh new file mode 100644 index 0000000..f59c069 --- /dev/null +++ b/shaders/world1/deferred2.fsh @@ -0,0 +1,30 @@ +#version 120 +#extension GL_EXT_gpu_shader4 : enable +#include "/lib/settings.glsl" + +uniform sampler2D colortex4; +uniform sampler2D depthtex1; + +uniform float near; +uniform float far; + + +float linZ(float depth) { + return (2.0 * near) / (far + near - depth * (far - near)); +} +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// +//////////////////////////////VOID MAIN////////////////////////////// + +void main() { +/* DRAWBUFFERS:4 */ + vec3 oldTex = texelFetch2D(colortex4, ivec2(gl_FragCoord.xy), 0).xyz; + float newTex = texelFetch2D(depthtex1, ivec2(gl_FragCoord.xy*4), 0).x; + + if (newTex < 1.0) + gl_FragData[0] = vec4(oldTex, linZ(newTex)*linZ(newTex)*65000.0); + else + gl_FragData[0] = vec4(oldTex, 2.0); +} diff --git a/shaders/world1/deferred2.vsh b/shaders/world1/deferred2.vsh new file mode 100644 index 0000000..8f06db4 --- /dev/null +++ b/shaders/world1/deferred2.vsh @@ -0,0 +1,11 @@ +#version 120 +#extension GL_EXT_gpu_shader4 : enable +#include "/lib/settings.glsl" + +uniform vec2 texelSize; +#include "/lib/res_params.glsl" +void main() { + gl_Position = ftransform(); + vec2 scaleRatio = max(vec2(0.25), vec2(18.+258*2,258.)*texelSize); + gl_Position.xy = (gl_Position.xy*0.5+0.5)*clamp(scaleRatio+0.01,0.0,1.0)*2.0-1.0; +} diff --git a/shaders/world1/final.fsh b/shaders/world1/final.fsh index 2388d11..90041c9 100644 --- a/shaders/world1/final.fsh +++ b/shaders/world1/final.fsh @@ -1,11 +1,10 @@ #version 120 //Vignetting, applies bloom, applies exposure and tonemaps the final image #extension GL_EXT_gpu_shader4 : enable -//#define BICUBIC_UPSCALING //Provides a better interpolation when using a render quality different of 1.0, slower -#define CONTRAST_ADAPTATIVE_SHARPENING -#define SHARPENING 0.35 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define SATURATION 0.00 // Negative values desaturates colors, Positive values saturates color, 0 is no change [-1.0 -0.98 -0.96 -0.94 -0.92 -0.9 -0.88 -0.86 -0.84 -0.82 -0.8 -0.78 -0.76 -0.74 -0.72 -0.7 -0.68 -0.66 -0.64 -0.62 -0.6 -0.58 -0.56 -0.54 -0.52 -0.5 -0.48 -0.46 -0.44 -0.42 -0.4 -0.38 -0.36 -0.34 -0.32 -0.3 -0.28 -0.26 -0.24 -0.22 -0.2 -0.18 -0.16 -0.14 -0.12 -0.1 -0.08 -0.06 -0.04 -0.02 0.0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2 0.22 0.24 0.26 0.28 0.3 0.32 0.34 0.36 0.38 0.4 0.42 0.44 0.46 0.48 0.5 0.52 0.54 0.56 0.58 0.6 0.62 0.64 0.66 0.68 0.7 0.72 0.74 0.76 0.78 0.8 0.82 0.84 0.86 0.88 0.9 0.92 0.94 0.96 0.98 1.0 ] -#define CROSSTALK 0.0 // Desaturates bright colors and preserves saturation in darker areas (inverted if negative). Helps avoiding almsost fluorescent colors [-1.0 -0.98 -0.96 -0.94 -0.92 -0.9 -0.88 -0.86 -0.84 -0.82 -0.8 -0.78 -0.76 -0.74 -0.72 -0.7 -0.68 -0.66 -0.64 -0.62 -0.6 -0.58 -0.56 -0.54 -0.52 -0.5 -0.48 -0.46 -0.44 -0.42 -0.4 -0.38 -0.36 -0.34 -0.32 -0.3 -0.28 -0.26 -0.24 -0.22 -0.2 -0.18 -0.16 -0.14 -0.12 -0.1 -0.08 -0.06 -0.04 -0.02 0.0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2 0.22 0.24 0.26 0.28 0.3 0.32 0.34 0.36 0.38 0.4 0.42 0.44 0.46 0.48 0.5 0.52 0.54 0.56 0.58 0.6 0.62 0.64 0.66 0.68 0.7 0.72 0.74 0.76 0.78 0.8 0.82 0.84 0.86 0.88 0.9 0.92 0.94 0.96 0.98 1.0 ] + +#include "/lib/settings.glsl" + + varying vec2 texcoord; uniform sampler2D colortex7; @@ -15,9 +14,11 @@ uniform float viewHeight; uniform float frameTimeCounter; uniform int frameCounter; uniform int isEyeInWater; -#include "lib/color_transforms.glsl" -#include "lib/color_dither.glsl" + +#include "/lib/color_transforms.glsl" +#include "/lib/color_dither.glsl" #include "/lib/res_params.glsl" + vec4 SampleTextureCatmullRom(sampler2D tex, vec2 uv, vec2 texSize ) { // We're going to sample a a 4x4 grid of texels surrounding the target UV coordinate. We'll do this by rounding diff --git a/shaders/world1/final.vsh b/shaders/world1/final.vsh index 7aeb51b..88b6076 100644 --- a/shaders/world1/final.vsh +++ b/shaders/world1/final.vsh @@ -1,9 +1,7 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable -#define FinalR 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] -#define FinalG 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] -#define FinalB 1.0 //[0.0 0.025315 0.051271 0.077884 0.105170 0.133148 0.161834 0.191246 0.221402 0.252322 0.284025 0.316530 0.349858 0.384030 0.419067 0.454991 0.491824 0.529590 0.568312 0.608014 0.648721 0.690458 0.733253 0.777130 0.822118 0.868245 0.915540 0.964032 1.013752 1.064731 1.117000 1.170592 1.225540 1.281880 1.339646 1.398875 1.459603 1.521868 1.585709 1.651167 1.718281 1.787095 1.857651 1.929992 2.004166 2.080216 2.158192 2.238142 2.320116 2.404166 2.490342 2.578701 2.669296 2.762185 2.857425 2.955076 3.055199 3.157857 3.263114 3.371035 3.481689 3.595143 3.711470 3.830741 3.953032 4.078419 4.206979 4.338795 4.473947 4.612521 4.754602 4.900281 5.049647 5.202795 5.359819 5.520819 5.685894 5.855148 6.028687 6.206619 6.389056 6.576110 6.767901 6.964546 7.166169 7.372897 7.584858 7.802185 8.025013 8.253482 8.487735 8.727919 8.974182 9.226680 9.485569 9.751013 10.02317 10.30222 10.58834 10.88170 11.18249 ] +#include "/lib/settings.glsl" varying vec2 texcoord; flat varying vec4 exposure; diff --git a/shaders/world1/gbuffers_all_solid.fsh b/shaders/world1/gbuffers_all_solid.fsh deleted file mode 100644 index 76e3e6c..0000000 --- a/shaders/world1/gbuffers_all_solid.fsh +++ /dev/null @@ -1,411 +0,0 @@ -#extension GL_EXT_gpu_shader4 : enable -#extension GL_ARB_shader_texture_lod : enable -//#define Specular_Reflections // reflections on blocks. REQUIRES A PBR RESOURCEPACK. -//#define POM -#define POM_MAP_RES 128.0 // [16.0 32.0 64.0 128.0 256.0 512.0 1024.0] Increase to improve POM quality -#define POM_DEPTH 0.1 // [0.025 0.05 0.075 0.1 0.125 0.15 0.20 0.25 0.30 0.50 0.75 1.0] //Increase to increase POM strength -#define MAX_ITERATIONS 50 // [5 10 15 20 25 30 40 50 60 70 80 90 100 125 150 200 400] //Improves quality at grazing angles (reduces performance) -#define MAX_DIST 25.0 // [5.0 10.0 15.0 20.0 25.0 30.0 40.0 50.0 60.0 70.0 80.0 90.0 100.0 125.0 150.0 200.0 400.0] //Increases distance at which POM is calculated -//#define USE_LUMINANCE_AS_HEIGHTMAP //Can generate POM on any texturepack (may look weird in some cases) -#define Texture_MipMap_Bias -1.00 // Uses a another mip level for textures. When reduced will increase texture detail but may induce a lot of shimmering. [-5.00 -4.75 -4.50 -4.25 -4.00 -3.75 -3.50 -3.25 -3.00 -2.75 -2.50 -2.25 -2.00 -1.75 -1.50 -1.25 -1.00 -0.75 -0.50 -0.25 0.00 0.25 0.50 0.75 1.00 1.25 1.50 1.75 2.00 2.25 2.50 2.75 3.00 3.25 3.50 3.75 4.00 4.25 4.50 4.75 5.00] -#define DISABLE_ALPHA_MIPMAPS //Disables mipmaps on the transparency of alpha-tested things like foliage, may cost a few fps in some cases - - -#define SSAO // screen-space ambient occlusion. -#define texture_ao // ambient occlusion on the texture - -#define Puddle_Size 1.0 // [0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5] -#ifdef Specular_Reflections - #define Puddles // yes -#else - // #define Puddles // yes -#endif -// #define Porosity - -#ifndef USE_LUMINANCE_AS_HEIGHTMAP -#ifndef MC_NORMAL_MAP -#undef POM -#endif -#endif - -#ifdef POM -#define MC_NORMAL_MAP -#endif - -const float mincoord = 1.0/4096.0; -const float maxcoord = 1.0-mincoord; -const vec3 intervalMult = vec3(1.0, 1.0, 1.0/POM_DEPTH)/POM_MAP_RES * 1.0; - -const float MAX_OCCLUSION_DISTANCE = MAX_DIST; -const float MIX_OCCLUSION_DISTANCE = MAX_DIST*0.9; -const int MAX_OCCLUSION_POINTS = MAX_ITERATIONS; - -uniform vec2 texelSize; -uniform int framemod8; - -#ifdef POM -varying vec4 vtexcoordam; // .st for add, .pq for mul -varying vec4 vtexcoord; - -#endif -#include "/lib/res_params.glsl" -varying vec4 lmtexcoord; -varying vec4 color; -uniform float far; -varying vec4 normalMat; -#ifdef MC_NORMAL_MAP -varying vec4 tangent; -uniform float wetness; -uniform sampler2D normals; -uniform sampler2D specular; -#endif - -#ifdef POM - vec2 dcdx = dFdx(vtexcoord.st*vtexcoordam.pq)*exp2(Texture_MipMap_Bias); - vec2 dcdy = dFdy(vtexcoord.st*vtexcoordam.pq)*exp2(Texture_MipMap_Bias); -#endif - -flat varying int lightningBolt; -uniform sampler2D texture; -uniform sampler2D colortex1;//albedo(rgb),material(alpha) RGBA16 -uniform float frameTimeCounter; -uniform int frameCounter; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferModelView; -uniform mat4 gbufferProjection; -uniform mat4 gbufferModelViewInverse; -uniform vec3 cameraPosition; -uniform float rainStrength; -uniform sampler2D noisetex;//depth -uniform sampler2D depthtex0; -in vec3 test_motionVectors; - -varying vec4 materialMask; - -flat varying vec4 TESTMASK; - -// float interleaved_gradientNoise(){ -// return fract(52.9829189*fract(0.06711056*gl_FragCoord.x + 0.00583715*gl_FragCoord.y)+frameTimeCounter*51.9521); -// } -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; -} - -float blueNoise(){ - return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); -} -float R2_dither(){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y + 1.0/1.6180339887 * frameCounter) ; -} -vec2 decodeVec2(float a){ - const vec2 constant1 = 65535. / vec2( 256., 65536.); - const float constant2 = 256. / 255.; - return fract( a * constant1 ) * constant2 ; -} -mat3 inverse(mat3 m) { - float a00 = m[0][0], a01 = m[0][1], a02 = m[0][2]; - float a10 = m[1][0], a11 = m[1][1], a12 = m[1][2]; - float a20 = m[2][0], a21 = m[2][1], a22 = m[2][2]; - - float b01 = a22 * a11 - a12 * a21; - float b11 = -a22 * a10 + a12 * a20; - float b21 = a21 * a10 - a11 * a20; - - float det = a00 * b01 + a01 * b11 + a02 * b21; - - return mat3(b01, (-a22 * a01 + a02 * a21), (a12 * a01 - a02 * a11), - b11, (a22 * a00 - a02 * a20), (-a12 * a00 + a02 * a10), - b21, (-a21 * a00 + a01 * a20), (a11 * a00 - a01 * a10)) / det; -} - -vec3 viewToWorld(vec3 viewPosition) { - vec4 pos; - pos.xyz = viewPosition; - pos.w = 0.0; - pos = gbufferModelViewInverse * pos; - return pos.xyz; -} -vec3 worldToView(vec3 worldPos) { - vec4 pos = vec4(worldPos, 0.0); - pos = gbufferModelView * pos; - return pos.xyz; -} -vec4 encode (vec3 n, vec2 lightmaps){ - n.xy = n.xy / dot(abs(n), vec3(1.0)); - n.xy = n.z <= 0.0 ? (1.0 - abs(n.yx)) * sign(n.xy) : n.xy; - vec2 encn = clamp(n.xy * 0.5 + 0.5,-1.0,1.0); - - return vec4(encn,vec2(lightmaps.x,lightmaps.y)); -} - - -#ifdef MC_NORMAL_MAP - // vec3 applyBump(mat3 tbnMatrix, vec3 bump){ - // float bumpmult = 1.0; - // bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); - // return normalize(bump*tbnMatrix); - // } - vec3 applyBump(mat3 tbnMatrix, vec3 bump, float puddle_values){ - float bumpmult = clamp(puddle_values,0.0,1.0); - bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); - return normalize(bump*tbnMatrix); - } -#endif - -//encoding by jodie -float encodeVec2(vec2 a){ - const vec2 constant1 = vec2( 1., 256.) / 65535.; - vec2 temp = floor( a * 255. ); - return temp.x*constant1.x+temp.y*constant1.y; -} -float encodeVec2(float x,float y){ - return encodeVec2(vec2(x,y)); -} - -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) - -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; -} -vec3 toClipSpace3(vec3 viewSpacePosition) { - return projMAD(gbufferProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; -} -#ifdef POM -vec4 readNormal(in vec2 coord) -{ - return texture2DGradARB(normals,fract(coord)*vtexcoordam.pq+vtexcoordam.st,dcdx,dcdy); -} -vec4 readTexture(in vec2 coord) -{ - return texture2DGradARB(texture,fract(coord)*vtexcoordam.pq+vtexcoordam.st,dcdx,dcdy); -} -#endif -float luma(vec3 color) { - return dot(color,vec3(0.21, 0.72, 0.07)); -} - - -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} - - -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 getPuddleCoverage(vec3 samplePos){ -// float puddle = texture2D(noisetex, samplePos.xz/25000).b ; - -// return max(puddle,0.0); -// } - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -/* RENDERTARGETS: 1,7,8,13 */ -void main() { - - #ifdef BLOCK_ENT - gl_FragData[3] = TESTMASK; - #endif - - float phi = 2 * 3.14159265359; - float noise = fract(fract(frameCounter * (1.0 / phi)) + interleaved_gradientNoise() ) ; - - vec3 normal = normalMat.xyz; - - #ifdef MC_NORMAL_MAP - vec3 tangent2 = normalize(cross(tangent.rgb,normal)*tangent.w); - mat3 tbnMatrix = mat3(tangent.x, tangent2.x, normal.x, - tangent.y, tangent2.y, normal.y, - tangent.z, tangent2.z, normal.z); - #endif - vec2 tempOffset=offsets[framemod8]; - - vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize/RENDER_SCALE,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); - - - - vec3 worldpos = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition; - float lightmap = clamp( (lmtexcoord.w-0.66) * 5.0,0.,1.); - - float rainfall = 0. ; - float Puddle_shape = 0.; - float puddle_shiny = 1.; - float puddle_normal = 0.; - - #ifndef ENTITIES - #ifdef WORLD - #ifdef Puddles - rainfall = rainStrength ; - Puddle_shape = 1.0 - max(texture2D(noisetex, worldpos.xz * (0.015 * Puddle_Size)).b - (1.0-lightmap) ,0.0); - puddle_shiny = clamp( pow(1.0-Puddle_shape,2.0)*2,0.5,1.) ; - puddle_normal = clamp( pow(Puddle_shape,5.0) * 50. ,0.,1.) ; - #endif - #endif - #endif - - #ifdef POM - // vec2 tempOffset=offsets[framemod8]; - vec2 adjustedTexCoord = fract(vtexcoord.st)*vtexcoordam.pq+vtexcoordam.st; - // vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize/RENDER_SCALE,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); - vec3 viewVector = normalize(tbnMatrix*fragpos); - float dist = length(fragpos); - - gl_FragDepth = gl_FragCoord.z; - - #ifdef WORLD - if (dist < MAX_OCCLUSION_DISTANCE) { - - if ( viewVector.z < 0.0 && readNormal(vtexcoord.st).a < 0.9999 && readNormal(vtexcoord.st).a > 0.00001) { - - vec3 interval = viewVector.xyz /-viewVector.z/MAX_OCCLUSION_POINTS*POM_DEPTH; - vec3 coord = vec3(vtexcoord.st, 1.0); - coord += noise*interval; - float sumVec = noise; - for (int loopCount = 0; (loopCount < MAX_OCCLUSION_POINTS) && (1.0 - POM_DEPTH + POM_DEPTH*readNormal(coord.st).a < coord.p) && coord.p >= 0.0; ++loopCount) { coord = coord+interval; sumVec += 1.0; } - - if (coord.t < mincoord) { - if (readTexture(vec2(coord.s,mincoord)).a == 0.0) { - coord.t = mincoord; - discard; - } - } - adjustedTexCoord = mix(fract(coord.st)*vtexcoordam.pq+vtexcoordam.st, adjustedTexCoord, max(dist-MIX_OCCLUSION_DISTANCE,0.0)/(MAX_OCCLUSION_DISTANCE-MIX_OCCLUSION_DISTANCE)); - - vec3 truePos = fragpos + sumVec*inverse(tbnMatrix)*interval; - // #ifdef Depth_Write_POM - gl_FragDepth = toClipSpace3(truePos).z; - // #endif - } - } - #endif - - // color - vec4 data0 = texture2DGradARB(texture, adjustedTexCoord.xy,dcdx,dcdy); - - #ifdef DISABLE_ALPHA_MIPMAPS - data0.a = texture2DGradARB(texture, adjustedTexCoord.xy,vec2(0.),vec2(0.0)).a; - #endif - - data0.rgb *= color.rgb; - float avgBlockLum = luma(texture2DLod(texture, lmtexcoord.xy,128).rgb*color.rgb); - data0.rgb = clamp(data0.rgb*pow(avgBlockLum,-0.33)*0.85,0.0,1.0); - - - #ifdef WORLD - if (data0.a > 0.1) data0.a = normalMat.a; - else data0.a = 0.0; - #endif - - #ifdef HAND - if (data0.a > 0.1) data0.a = 0.75; - else data0.a = 0.0; - #endif - - // normal - #ifdef MC_NORMAL_MAP - vec3 normalTex = texture2DGradARB(normals, adjustedTexCoord.xy, dcdx,dcdy).rgb; - normalTex.xy = normalTex.xy*2.0-1.0; - normalTex.z = clamp(sqrt(1.0 - dot(normalTex.xy, normalTex.xy)),0.0,1.0); - normal = applyBump(tbnMatrix,normalTex, mix(1.0,puddle_normal,rainfall)); - #endif - - // specular - gl_FragData[2] = texture2DGradARB(specular, adjustedTexCoord.xy,dcdx,dcdy); - - // finalize - vec4 data1 = clamp(encode(viewToWorld(normal), lmtexcoord.zw),0.,1.0); - gl_FragData[0] = vec4(encodeVec2(data0.x,data1.x),encodeVec2(data0.y,data1.y),encodeVec2(data0.z,data1.z),encodeVec2(data1.w,data0.w)); - - gl_FragData[1].a = 0.0; - - #else - // specular - vec4 specular = texture2D(specular, lmtexcoord.xy, Texture_MipMap_Bias).rgba; - vec4 specular_modded = vec4( max(specular.r,puddle_shiny), max(specular.g, puddle_shiny*0.1),specular.ba); - gl_FragData[2].rgba = mix(specular, specular_modded, rainfall); - - float porosity = specular.z >= 64.5/255.0 ? 0.0 : (specular.z*255.0/64.0)*0.65; - #ifndef Porosity - porosity = 0.4; - #endif - // normal - #ifdef MC_NORMAL_MAP - vec4 normalTex = texture2D(normals, lmtexcoord.xy, Texture_MipMap_Bias).rgba; - normalTex.xy = normalTex.xy*2.0-1.0; - normalTex.z = clamp(sqrt(1.0 - dot(normalTex.xy, normalTex.xy)),0.0,1.0) ; - normal = applyBump(tbnMatrix, normalTex.xyz, mix(1.0,puddle_normal, rainfall) ); - #endif - - // color - vec4 data0 = texture2D(texture, lmtexcoord.xy, Texture_MipMap_Bias) ; - - data0.rgb *= mix(color.rgb, vec3(0.0), max((puddle_shiny*porosity)*0.5,0) * rainfall ); - - - - float avgBlockLum = luma(texture2DLod(texture, lmtexcoord.xy,128).rgb*color.rgb); - data0.rgb = clamp(data0.rgb*pow(avgBlockLum,-0.33)*0.85,0.0,1.0); - - #ifndef ENTITIES - if(TESTMASK.r==255) data0.rgb = vec3(0); - #endif - - #ifdef DISABLE_ALPHA_MIPMAPS - data0.a = texture2DLod(texture,lmtexcoord.xy,0).a; - #endif - #ifdef WORLD - if (data0.a > 0.1) data0.a = normalMat.a; - else data0.a = 0.0; - - #endif - #ifdef HAND - if (data0.a > 0.1) data0.a = 0.75; - else data0.a = 0.0; - #endif - - // finalize - vec4 data1 = clamp(blueNoise()/255.0 + encode(viewToWorld(normal), lmtexcoord.zw),0.0,1.0); - gl_FragData[0] = vec4(encodeVec2(data0.x,data1.x), encodeVec2(data0.y,data1.y), encodeVec2(data0.z,data1.z), encodeVec2(data1.w,data0.w)); - - #ifdef WORLD - gl_FragData[1].a = 0.0; - #endif - - #endif - - - - #ifdef ENTITIES - #ifdef WORLD - gl_FragData[3].xyz = test_motionVectors; - #endif - #endif - // float z = texture2D(depthtex0,texcoord).x; - // vec3 fragpos = toScreenSpace(vec3(texcoord,z)); - // gl_FragData[0].rgb *= vec3(1- clamp( pow( length(fragpos)/far, 1), 0, 1)) ; - - - -} \ No newline at end of file diff --git a/shaders/world1/gbuffers_all_solid.vsh b/shaders/world1/gbuffers_all_solid.vsh deleted file mode 100644 index 179d57f..0000000 --- a/shaders/world1/gbuffers_all_solid.vsh +++ /dev/null @@ -1,213 +0,0 @@ -#extension GL_EXT_gpu_shader4 : enable -#include "/lib/res_params.glsl" -#define WAVY_PLANTS -#define WAVY_STRENGTH 1.0 //[0.1 0.25 0.5 0.75 1.0 1.25 1.5 1.75 2.0] -#define WAVY_SPEED 1.0 //[0.001 0.01 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 1.0 1.25 1.5 2.0 3.0 4.0] -#define SEPARATE_AO -//#define POM -//#define USE_LUMINANCE_AS_HEIGHTMAP //Can generate POM on any texturepack (may look weird in some cases) -// #define RTAO // I recommend turning ambientOcclusionLevel to zero with this on. like ssao, but rt, nicer, noiser, and slower. SSAO will turn OFF when this is ON -#define indirect_effect 1 // Choose what effect is applied to indirect light. [0 1 2 3] - -#define Variable_Penumbra_Shadows //Makes the shadows more blurry the more distant they are to objects (costs fps) -#define mob_SSS - -#ifndef USE_LUMINANCE_AS_HEIGHTMAP -#ifndef MC_NORMAL_MAP -#undef POM -#endif -#endif - -#ifdef POM -#define MC_NORMAL_MAP -#endif - -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -#ifdef POM -varying vec4 vtexcoordam; // .st for add, .pq for mul -varying vec4 vtexcoord; -#endif - -#ifdef MC_NORMAL_MAP - varying vec4 tangent; - attribute vec4 at_tangent; -#endif - -out vec3 test_motionVectors; -in vec3 at_velocity; - -uniform float frameTimeCounter; -const float PI48 = 150.796447372*WAVY_SPEED; -float pi2wt = PI48*frameTimeCounter; -attribute vec4 mc_Entity; -uniform int blockEntityId; -uniform int entityId; -varying vec4 materialMask; -flat varying vec4 TESTMASK; -flat varying int lightningBolt; - -uniform mat4 gbufferModelView; -uniform mat4 gbufferModelViewInverse; -attribute vec4 mc_midTexCoord; -uniform vec3 cameraPosition; -uniform vec2 texelSize; -uniform int framemod8; -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.); -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -vec4 toClipSpace3(vec3 viewSpacePosition) { - return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); -} - -vec2 calcWave(in vec3 pos) { - - float magnitude = abs(sin(dot(vec4(frameTimeCounter, pos),vec4(1.0,0.005,0.005,0.005)))*0.5+0.72)*0.013; - vec2 ret = (sin(pi2wt*vec2(0.0063,0.0015)*4. - pos.xz + pos.y*0.05)+0.1)*magnitude; - - return ret; -} - -vec3 calcMovePlants(in vec3 pos) { - vec2 move1 = calcWave(pos ); - float move1y = -length(move1); - return vec3(move1.x,move1y,move1.y)*5.*WAVY_STRENGTH; -} - -vec3 calcWaveLeaves(in vec3 pos, in float fm, in float mm, in float ma, in float f0, in float f1, in float f2, in float f3, in float f4, in float f5) { - - float magnitude = abs(sin(dot(vec4(frameTimeCounter, pos),vec4(1.0,0.005,0.005,0.005)))*0.5+0.72)*0.013; - vec3 ret = (sin(pi2wt*vec3(0.0063,0.0224,0.0015)*1.5 - pos))*magnitude; - - return ret; -} - -vec3 calcMoveLeaves(in vec3 pos, in float f0, in float f1, in float f2, in float f3, in float f4, in float f5, in vec3 amp1, in vec3 amp2) { - vec3 move1 = calcWaveLeaves(pos , 0.0054, 0.0400, 0.0400, 0.0127, 0.0089, 0.0114, 0.0063, 0.0224, 0.0015) * amp1; - return move1*5.*WAVY_STRENGTH; -} -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - - TESTMASK = vec4(normalize(gl_NormalMatrix * gl_Normal), 1.0); - - TESTMASK.r = blockEntityId == 222 ? 255 : TESTMASK.r; - - - #ifdef ENTITIES - test_motionVectors = at_velocity; - #endif - - #ifdef POM - vec2 midcoord = (gl_TextureMatrix[0] * mc_midTexCoord).st; - vec2 texcoordminusmid = lmtexcoord.xy-midcoord; - vtexcoordam.pq = abs(texcoordminusmid)*2; - vtexcoordam.st = min(lmtexcoord.xy,midcoord-texcoordminusmid); - vtexcoord.xy = sign(texcoordminusmid)*0.5+0.5; - #endif - - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; - color = gl_Color; - bool istopv = gl_MultiTexCoord0.t < mc_midTexCoord.t; - - #ifdef MC_NORMAL_MAP - tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); - #endif - - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal), 1.0); - -#ifdef ENTITIES - - #ifdef mob_SSS - #ifdef Variable_Penumbra_Shadows - normalMat.a = entityId == 1100 ? 1.0 : normalMat.a; - normalMat.a = entityId == 1200 ? 1.0 : normalMat.a; - normalMat.a = entityId == 1400 ? 1.0 : normalMat.a; - #endif - #endif - - - gl_Position = ftransform(); - -#endif - - - -#ifdef WORLD - - - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),mc_Entity.x == 10004 || mc_Entity.x == 10003 ? 0.5 : mc_Entity.x == 10001 ? 0.6 : 1.0); - normalMat.a = (mc_Entity.x == 10006 || mc_Entity.x == 100061) ? 0.6 : normalMat.a; - normalMat.a = (mc_Entity.x == 10007 || mc_Entity.x == 10008) ? 0.55 : normalMat.a; - - normalMat.a = mc_Entity.x == 10005 ? 0.8 : normalMat.a; - normalMat.a = mc_Entity.x == 99 ? 0.65 : normalMat.a; - - - #ifdef WAVY_PLANTS - if ((mc_Entity.x == 10001 && istopv) && abs(position.z) < 64.0) { - vec3 worldpos = mat3(gbufferModelViewInverse) * position + gbufferModelViewInverse[3].xyz + cameraPosition; - worldpos.xyz += calcMovePlants(worldpos.xyz)*lmtexcoord.w - cameraPosition; - position = mat3(gbufferModelView) * worldpos + gbufferModelView[3].xyz; - } - - if (mc_Entity.x == 10003 && abs(position.z) < 64.0) { - vec3 worldpos = mat3(gbufferModelViewInverse) * position + gbufferModelViewInverse[3].xyz + cameraPosition; - worldpos.xyz += calcMoveLeaves(worldpos.xyz, 0.0040, 0.0064, 0.0043, 0.0035, 0.0037, 0.0041, vec3(1.0,0.2,1.0), vec3(0.5,0.1,0.5))*lmtexcoord.w - cameraPosition; - position = mat3(gbufferModelView) * worldpos + gbufferModelView[3].xyz; - } - #endif - - if (mc_Entity.x == 100 ){ - color.rgb = normalize(color.rgb)*sqrt(3.0); - normalMat.a = 0.9; - } - - gl_Position = toClipSpace3(position); - - if (color.a < 0.3) color.a = 1.0; - - #ifdef SEPARATE_AO - - #if indirect_effect == 1 || indirect_effect == 0 - lmtexcoord.z *= sqrt(color.a); - lmtexcoord.w *= color.a; - #endif - - #else - color.rgb *= color.a; - #endif - -#endif - - - #ifdef TAA_UPSCALING - gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; - #endif - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w * texelSize; - #endif -} diff --git a/shaders/world1/gbuffers_all_translucent.fsh b/shaders/world1/gbuffers_all_translucent.fsh deleted file mode 100644 index d89e204..0000000 --- a/shaders/world1/gbuffers_all_translucent.fsh +++ /dev/null @@ -1,624 +0,0 @@ -// #version 120 -#extension GL_EXT_gpu_shader4 : enable - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -varying vec3 binormal; -uniform sampler2D normals; -varying vec3 tangent; -varying vec4 tangent_other; -varying vec3 viewVector; -varying float dist; -#include "/lib/res_params.glsl" - -#define CLOUDS_SHADOWS -#define VL_CLOUDS_SHADOWS // Casts shadows from clouds on VL (slow) -#define SCREENSPACE_REFLECTIONS //can be really expensive at high resolutions/render quality, especially on ice -#define SSR_STEPS 30 //[10 15 20 25 30 35 40 50 100 200 400] -#define SUN_MICROFACET_SPECULAR // If enabled will use realistic rough microfacet model, else will just reflect the sun. No performance impact. -#define USE_QUARTER_RES_DEPTH // Uses a quarter resolution depth buffer to raymarch screen space reflections, improves performance but may introduce artifacts -#define saturate(x) clamp(x,0.0,1.0) -#define Dirt_Amount 0.14 //How much dirt there is in water [0.0 0.04 0.08 0.12 0.16 0.2 0.24 0.28 0.32 0.36 0.4 0.44 0.48 0.52 0.56 0.6 0.64 0.68 0.72 0.76 0.8 0.84 0.88 0.92 0.96 1.0 1.04 1.08 1.12 1.16 1.2 1.24 1.28 1.32 1.36 1.4 1.44 1.48 1.52 1.56 1.6 1.64 1.68 1.72 1.76 1.8 1.84 1.88 1.92 1.96 2.0 ] - -#define Dirt_Scatter_R 0.6 //How much dirt diffuses red [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 ] -#define Dirt_Scatter_G 0.6 //How much dirt diffuses green [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 ] -#define Dirt_Scatter_B 0.6 //How much dirt diffuses blue [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 ] - -#define Dirt_Absorb_R 1.65 //How much dirt absorbs red [0.0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2 0.22 0.24 0.26 0.28 0.3 0.32 0.34 0.36 0.38 0.4 0.42 0.44 0.46 0.48 0.5 0.52 0.54 0.56 0.58 0.6 0.62 0.64 0.66 0.68 0.7 0.72 0.74 0.76 0.78 0.8 0.82 0.84 0.86 0.88 0.9 0.92 0.94 0.96 0.98 1.0 1.02 1.04 1.06 1.08 1.1 1.12 1.14 1.16 1.18 1.2 1.22 1.24 1.26 1.28 1.3 1.32 1.34 1.36 1.38 1.4 1.42 1.44 1.46 1.48 1.5 1.52 1.54 1.56 1.58 1.6 1.62 1.64 1.66 1.68 1.7 1.72 1.74 1.76 1.78 1.8 1.82 1.84 1.86 1.88 1.9 1.92 1.94 1.96 1.98 2.0 ] -#define Dirt_Absorb_G 1.85 //How much dirt absorbs green [0.0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2 0.22 0.24 0.26 0.28 0.3 0.32 0.34 0.36 0.38 0.4 0.42 0.44 0.46 0.48 0.5 0.52 0.54 0.56 0.58 0.6 0.62 0.64 0.66 0.68 0.7 0.72 0.74 0.76 0.78 0.8 0.82 0.84 0.86 0.88 0.9 0.92 0.94 0.96 0.98 1.0 1.02 1.04 1.06 1.08 1.1 1.12 1.14 1.16 1.18 1.2 1.22 1.24 1.26 1.28 1.3 1.32 1.34 1.36 1.38 1.4 1.42 1.44 1.46 1.48 1.5 1.52 1.54 1.56 1.58 1.6 1.62 1.64 1.66 1.68 1.7 1.72 1.74 1.76 1.78 1.8 1.82 1.84 1.86 1.88 1.9 1.92 1.94 1.96 1.98 2.0 ] -#define Dirt_Absorb_B 2.05 //How much dirt absorbs blue [0.0 0.02 0.04 0.06 0.08 0.1 0.12 0.14 0.16 0.18 0.2 0.22 0.24 0.26 0.28 0.3 0.32 0.34 0.36 0.38 0.4 0.42 0.44 0.46 0.48 0.5 0.52 0.54 0.56 0.58 0.6 0.62 0.64 0.66 0.68 0.7 0.72 0.74 0.76 0.78 0.8 0.82 0.84 0.86 0.88 0.9 0.92 0.94 0.96 0.98 1.0 1.02 1.04 1.06 1.08 1.1 1.12 1.14 1.16 1.18 1.2 1.22 1.24 1.26 1.28 1.3 1.32 1.34 1.36 1.38 1.4 1.42 1.44 1.46 1.48 1.5 1.52 1.54 1.56 1.58 1.6 1.62 1.64 1.66 1.68 1.7 1.72 1.74 1.76 1.78 1.8 1.82 1.84 1.86 1.88 1.9 1.92 1.94 1.96 1.98 2.0 ] - -#define Water_Absorb_R 0.2629 //How much water absorbs red [0.0 0.0025 0.005 0.0075 0.01 0.0125 0.015 0.0175 0.02 0.0225 0.025 0.0275 0.03 0.0325 0.035 0.0375 0.04 0.0425 0.045 0.0475 0.05 0.0525 0.055 0.0575 0.06 0.0625 0.065 0.0675 0.07 0.0725 0.075 0.0775 0.08 0.0825 0.085 0.0875 0.09 0.0925 0.095 0.0975 0.1 0.1025 0.105 0.1075 0.11 0.1125 0.115 0.1175 0.12 0.1225 0.125 0.1275 0.13 0.1325 0.135 0.1375 0.14 0.1425 0.145 0.1475 0.15 0.1525 0.155 0.1575 0.16 0.1625 0.165 0.1675 0.17 0.1725 0.175 0.1775 0.18 0.1825 0.185 0.1875 0.19 0.1925 0.195 0.1975 0.2 0.2025 0.205 0.2075 0.21 0.2125 0.215 0.2175 0.22 0.2225 0.225 0.2275 0.23 0.2325 0.235 0.2375 0.24 0.2425 0.245 0.2475 0.25 ] -#define Water_Absorb_G 0.0565 //How much water absorbs green [0.0 0.0025 0.005 0.0075 0.01 0.0125 0.015 0.0175 0.02 0.0225 0.025 0.0275 0.03 0.0325 0.035 0.0375 0.04 0.0425 0.045 0.0475 0.05 0.0525 0.055 0.0575 0.06 0.0625 0.065 0.0675 0.07 0.0725 0.075 0.0775 0.08 0.0825 0.085 0.0875 0.09 0.0925 0.095 0.0975 0.1 0.1025 0.105 0.1075 0.11 0.1125 0.115 0.1175 0.12 0.1225 0.125 0.1275 0.13 0.1325 0.135 0.1375 0.14 0.1425 0.145 0.1475 0.15 0.1525 0.155 0.1575 0.16 0.1625 0.165 0.1675 0.17 0.1725 0.175 0.1775 0.18 0.1825 0.185 0.1875 0.19 0.1925 0.195 0.1975 0.2 0.2025 0.205 0.2075 0.21 0.2125 0.215 0.2175 0.22 0.2225 0.225 0.2275 0.23 0.2325 0.235 0.2375 0.24 0.2425 0.245 0.2475 0.25 ] -#define Water_Absorb_B 0.01011 //How much water absorbs blue [0.0 0.0025 0.005 0.0075 0.01 0.0125 0.015 0.0175 0.02 0.0225 0.025 0.0275 0.03 0.0325 0.035 0.0375 0.04 0.0425 0.045 0.0475 0.05 0.0525 0.055 0.0575 0.06 0.0625 0.065 0.0675 0.07 0.0725 0.075 0.0775 0.08 0.0825 0.085 0.0875 0.09 0.0925 0.095 0.0975 0.1 0.1025 0.105 0.1075 0.11 0.1125 0.115 0.1175 0.12 0.1225 0.125 0.1275 0.13 0.1325 0.135 0.1375 0.14 0.1425 0.145 0.1475 0.15 0.1525 0.155 0.1575 0.16 0.1625 0.165 0.1675 0.17 0.1725 0.175 0.1775 0.18 0.1825 0.185 0.1875 0.19 0.1925 0.195 0.1975 0.2 0.2025 0.205 0.2075 0.21 0.2125 0.215 0.2175 0.22 0.2225 0.225 0.2275 0.23 0.2325 0.235 0.2375 0.24 0.2425 0.245 0.2475 0.25 ] -#define Texture_MipMap_Bias -1.00 // Uses a another mip level for textures. When reduced will increase texture detail but may induce a lot of shimmering. [-5.00 -4.75 -4.50 -4.25 -4.00 -3.75 -3.50 -3.25 -3.00 -2.75 -2.50 -2.25 -2.00 -1.75 -1.50 -1.25 -1.00 -0.75 -0.50 -0.25 0.00 0.25 0.50 0.75 1.00 1.25 1.50 1.75 2.00 2.25 2.50 2.75 3.00 3.25 3.50 3.75 4.00 4.25 4.50 4.75 5.00] - -#define ambient_colortype 0 // Toggle which method you want to change the color of ambient light with. [0 1] -#define ambient_temp 9000 // [1000 2000 3000 4000 5000 6000 7000 8000 9000 10000 15000 50000] - -#define AmbientLight_R 0.91 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define AmbientLight_G 0.86 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] -#define AmbientLight_B 1.0 // [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0] - - - -#define MIN_LIGHT_AMOUNT 1.0 //[0.0 0.5 1.0 1.5 2.0 3.0 4.0 5.0] -//#define Vanilla_like_water // vanilla water texture along with shader water stuff -uniform sampler2D texture; -uniform sampler2D noisetex; -uniform sampler2DShadow shadow; -uniform sampler2D gaux2; -uniform sampler2D gaux1; -uniform sampler2D depthtex1; - -uniform vec4 lightCol; -uniform float nightVision; - -uniform vec3 sunVec; -uniform float frameTimeCounter; -uniform float lightSign; -uniform float near; -uniform float far; -uniform float moonIntensity; -uniform float sunIntensity; -uniform vec3 sunColor; -uniform vec3 nsunColor; -uniform vec3 upVec; -uniform float sunElevation; -uniform float fogAmount; -uniform vec2 texelSize; -uniform float rainStrength; -uniform float skyIntensityNight; -uniform float skyIntensity; -flat varying vec3 WsunVec; -uniform mat4 gbufferPreviousModelView; -uniform vec3 previousCameraPosition; -uniform int framemod8; -uniform sampler2D specular; -uniform int frameCounter; -uniform int isEyeInWater; - - - - - -#include "lib/Shadow_Params.glsl" -#include "lib/color_transforms.glsl" -#include "lib/projections.glsl" -#include "lib/sky_gradient.glsl" -#include "lib/waterBump.glsl" -#include "lib/clouds.glsl" -#include "lib/stars.glsl" -#include "lib/volumetricClouds.glsl" - - 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 interleaved_gradientNoise(float temporal){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+temporal); - return noise; -} -vec3 srgbToLinear2(vec3 srgb){ - return mix( - srgb / 12.92, - pow(.947867 * srgb + .0521327, vec3(2.4) ), - step( .04045, srgb ) - ); -} -vec3 blackbody2(float Temp) -{ - float t = pow(Temp, -1.5); - float lt = log(Temp); - - vec3 col = vec3(0.0); - col.x = 220000.0 * t + 0.58039215686; - col.y = 0.39231372549 * lt - 2.44549019608; - col.y = Temp > 6500. ? 138039.215686 * t + 0.72156862745 : col.y; - col.z = 0.76078431372 * lt - 5.68078431373; - col = clamp(col,0.0,1.0); - col = Temp < 1000. ? col * Temp * 0.001 : col; - - return srgbToLinear2(col); -} - -float blueNoise(){ - return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); -} -float invLinZ (float lindepth){ - return -((2.0*near/lindepth)-far-near)/(far-near); -} -float ld(float dist) { - return (2.0 * near) / (far + near - dist * (far - near)); -} -vec3 nvec3(vec4 pos){ - return pos.xyz/pos.w; -} - -vec4 nvec4(vec3 pos){ - return vec4(pos.xyz, 1.0); -} -vec3 rayTrace(vec3 dir,vec3 position,float dither, float fresnel, bool inwater){ - - float quality = mix(15,SSR_STEPS,fresnel); - vec3 clipPosition = toClipSpace3(position); - float rayLength = ((position.z + dir.z * far*sqrt(3.)) > -near) ? - (-near -position.z) / dir.z : far*sqrt(3.); - vec3 direction = normalize(toClipSpace3(position+dir*rayLength)-clipPosition); //convert to clip space - direction.xy = normalize(direction.xy); - - //get at which length the ray intersects with the edge of the screen - vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; - float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z); - - - vec3 stepv = direction * mult / quality*vec3(RENDER_SCALE,1.0); - - - - - vec3 spos = clipPosition*vec3(RENDER_SCALE,1.0) + stepv*dither; - float minZ = clipPosition.z; - float maxZ = spos.z+stepv.z*0.5; - - spos.xy += offsets[framemod8]*texelSize*0.5/RENDER_SCALE; - - for (int i = 0; i <= int(quality); i++) { - #ifdef USE_QUARTER_RES_DEPTH - // decode depth buffer - float sp = sqrt(texelFetch2D(gaux1,ivec2(spos.xy/texelSize/4),0).w/65000.0); - sp = invLinZ(sp); - if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ)){ - return vec3(spos.xy/RENDER_SCALE,sp); - } - spos += stepv; - #else - float sp = texelFetch2D(depthtex1,ivec2(spos.xy/texelSize),0).r; - if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ)){ - return vec3(spos.xy/RENDER_SCALE,sp); - } - spos += stepv; - #endif - //small bias - minZ = maxZ-0.00004/ld(spos.z); - if(inwater) minZ = maxZ-0.0004/ld(spos.z); - maxZ += stepv.z; - } - - return vec3(1.1); -} - - -float facos(float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : pi - a; -} - - - - - float bayer2(vec2 a){ - a = floor(a); - return fract(dot(a,vec2(0.5,a.y*0.75))); -} - -float cdist(vec2 coord) { - return max(abs(coord.s-0.5),abs(coord.t-0.5))*2.0; -} - - #define PW_DEPTH 1.0 //[0.5 1.0 1.5 2.0 2.5 3.0] - #define PW_POINTS 1 //[2 4 6 8 16 32] - #define bayer4(a) (bayer2( .5*(a))*.25+bayer2(a)) -#define bayer8(a) (bayer4( .5*(a))*.25+bayer2(a)) -#define bayer16(a) (bayer8( .5*(a))*.25+bayer2(a)) -#define bayer32(a) (bayer16(.5*(a))*.25+bayer2(a)) -#define bayer64(a) (bayer32(.5*(a))*.25+bayer2(a)) -#define bayer128(a) fract(bayer64(.5*(a))*.25+bayer2(a)) -vec3 getParallaxDisplacement(vec3 posxz, float iswater,float bumpmult,vec3 viewVec) { - float waveZ = mix(20.0,0.25,iswater); - float waveM = mix(0.0,4.0,iswater); - - vec3 parallaxPos = posxz; - vec2 vec = viewVector.xy * (1.0 / float(PW_POINTS)) * 22.0 * PW_DEPTH; - float waterHeight = getWaterHeightmap(posxz.xz, waveM, waveZ, iswater) ; - - parallaxPos.xz += waterHeight * vec; - - return parallaxPos; - -} -vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter,float distort) -{ - float alpha = (sampleNumber+jitter)/nb; - float angle = jitter*6.28 + alpha * nbRot * 6.28; - - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*sqrt(alpha); -} -//Low discrepancy 2D sequence, integration error is as low as sobol but easier to compute : http://extremelearning.com.au/unreasonable-effectiveness-of-quasirandom-sequences/ -vec2 R2_samples(int n){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha * n); -} -vec4 hash44(vec4 p4) -{ - p4 = fract(p4 * vec4(.1031, .1030, .0973, .1099)); - p4 += dot(p4, p4.wzxy+33.33); - return fract((p4.xxyz+p4.yzzw)*p4.zywx); -} -vec3 TangentToWorld(vec3 N, vec3 H) -{ - vec3 UpVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0); - vec3 T = normalize(cross(UpVector, N)); - vec3 B = cross(N, T); - - return vec3((T * H.x) + (B * H.y) + (N * H.z)); -} -float GGX (vec3 n, vec3 v, vec3 l, float r, float F0) { - r*=r;r*=r; - - vec3 h = l + v; - float hn = inversesqrt(dot(h, h)); - - float dotLH = clamp(dot(h,l)*hn,0.,1.); - float dotNH = clamp(dot(h,n)*hn,0.,1.); - float dotNL = clamp(dot(n,l),0.,1.); - float dotNHsq = dotNH*dotNH; - - float denom = dotNHsq * r - dotNHsq + 1.; - float D = r / (3.141592653589793 * denom * denom); - float F = F0 + (1. - F0) * exp2((-5.55473*dotLH-6.98316)*dotLH); - float k2 = .25 * r; - - return dotNL * D * F / (dotLH*dotLH*(1.0-k2)+k2); -} - - vec3 applyBump(mat3 tbnMatrix, vec3 bump){ - float bumpmult = 1.0; - bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); - return normalize(bump*tbnMatrix); - } - -#define fsign(a) (clamp((a)*1e35,0.,1.)*2.-1.) -float triangularize(float dither) -{ - float center = dither*2.0-1.0; - dither = center*inversesqrt(abs(center)); - return clamp(dither-fsign(center),0.0,1.0); -} -vec3 fp10Dither(vec3 color,float dither){ - const vec3 mantissaBits = vec3(6.,6.,5.); - vec3 exponent = floor(log2(color)); - return color + dither*exp2(-mantissaBits)*exp2(exponent); -} -float R2_dither(){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha.x * gl_FragCoord.x + alpha.y * gl_FragCoord.y + 1.0/1.6180339887 * frameCounter) ; -} -//encoding by jodie -float encodeVec2(vec2 a){ - const vec2 constant1 = vec2( 1., 256.) / 65535.; - vec2 temp = floor( a * 255. ); - return temp.x*constant1.x+temp.y*constant1.y; -} -float encodeVec2(float x,float y){ - return encodeVec2(vec2(x,y)); -} -vec3 viewToWorld(vec3 viewPosition) { - vec4 pos; - pos.xyz = viewPosition; - pos.w = 0.0; - pos = gbufferModelViewInverse * pos; - return pos.xyz; -} -vec3 worldToView(vec3 worldPos) { - vec4 pos = vec4(worldPos, 0.0); - pos = gbufferModelView * pos; - return pos.xyz; -} -vec4 encode (vec3 n, vec2 lightmaps){ - n.xy = n.xy / dot(abs(n), vec3(1.0)); - n.xy = n.z <= 0.0 ? (1.0 - abs(n.yx)) * sign(n.xy) : n.xy; - vec2 encn = clamp(n.xy * 0.5 + 0.5,-1.0,1.0); - - return vec4(encn,vec2(lightmaps.x,lightmaps.y)); -} - - - - -float square(float x){ - return x*x; -} -float g(float NdotL, float roughness){ - float alpha = square(max(roughness, 0.02)); - return 2.0 * NdotL / (NdotL + sqrt(square(alpha) + (1.0 - square(alpha)) * square(NdotL))); -} -float gSimple(float dp, float roughness){ - float k = roughness + 1; - k *= k/8.0; - return dp / (dp * (1.0-k) + k); -} - -vec3 GGX2(vec3 n, vec3 v, vec3 l, float r, vec3 F0) { - - float roughness = r + 1.0/255.0; // when roughness is zero it fucks up - - float alpha = square(roughness); - - - vec3 h = normalize(l + v); - - float dotLH = clamp(dot(h,l),0.,1.); - float dotNH = clamp(dot(h,n),0.,1.); - float dotNL = clamp(dot(n,l),0.,1.); - float dotNV = clamp(dot(n,v),0.,1.); - float dotVH = clamp(dot(h,v),0.,1.); - - - float D = alpha / (3.141592653589793*square(square(dotNH) * (alpha - 1.0) + 1.0)); - float G = gSimple(dotNV, roughness) * gSimple(dotNL, roughness); - vec3 F = F0 + (1. - F0) * exp2((-5.55473*dotVH-6.98316)*dotVH); - - return dotNL * F * (G * D / (4 * dotNV * dotNL + 1e-7)); -} - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -/* RENDERTARGETS:2,7,1,11 */ -void main() { - if (gl_FragCoord.x * texelSize.x < RENDER_SCALE.x && gl_FragCoord.y * texelSize.y < RENDER_SCALE.y ) { - vec2 tempOffset=offsets[framemod8]; - float iswater = normalMat.w; - vec3 fragC = gl_FragCoord.xyz*vec3(texelSize,1.0); - vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize/RENDER_SCALE,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); - gl_FragData[0] = texture2D(texture, lmtexcoord.xy)*color; - float avgBlockLum = luma(texture2DLod(texture, lmtexcoord.xy,128).rgb*color.rgb); - gl_FragData[0].rgb = clamp((gl_FragData[0].rgb)*pow(avgBlockLum,-0.33)*0.85,0.0,1.0); - - vec3 albedo = toLinear(gl_FragData[0].rgb); - - #ifndef Vanilla_like_water - if (iswater > 0.4) { - albedo = vec3(0.42,0.6,0.7); - gl_FragData[0] = vec4(0.42,0.6,0.7,0.7); - } - if (iswater > 0.9) { - gl_FragData[0] = vec4(0.0); - } - #endif - - #ifdef Vanilla_like_water - if (iswater > 0.5) { - gl_FragData[0].a = luma(albedo.rgb); - albedo = color.rgb; - } - #endif - vec2 specularstuff = texture2D(specular, lmtexcoord.xy, Texture_MipMap_Bias).rg; - - vec3 normal = normalMat.xyz; - - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - mat3 tbnMatrix = mat3(tangent.x, binormal.x, normal.x, - tangent.y, binormal.y, normal.y, - tangent.z, binormal.z, normal.z); - if (iswater > 0.4){ - float bumpmult = 1.; - if (iswater > 0.9) - bumpmult = 1.; - float parallaxMult = bumpmult; - vec3 posxz = p3+cameraPosition; - posxz.xz-=posxz.y; - if (iswater < 0.9) - posxz.xz *= 3.0; - vec3 bump; - - - posxz.xyz = getParallaxDisplacement(posxz,iswater,bumpmult,normalize(tbnMatrix*fragpos)); - - bump = normalize(getWaveHeight(posxz.xz,iswater)); - - - - bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); - - normal = normalize(bump * tbnMatrix); - }else { - vec3 normalTex = texture2D(normals, lmtexcoord.xy, Texture_MipMap_Bias).rgb; - - normalTex.xy = normalTex.xy*2.0-1.0; - normalTex.z = clamp(sqrt(1.0 - dot(normalTex.xy, normalTex.xy)),0.0,1.0); - normal = applyBump(tbnMatrix,normalTex); - } - vec4 data0 = vec4(1); - vec4 data1 = clamp( encode(viewToWorld(normal), lmtexcoord.zw),0.0,1.0); - gl_FragData[3] = vec4(encodeVec2(data0.x,data1.x), encodeVec2(data0.y,data1.y), encodeVec2(data0.z,data1.z), encodeVec2(data1.w,data0.w)); - // gl_FragData[3].a = 0.0; - - - float NdotL = lightSign*dot(normal,sunVec); - float NdotU = dot(upVec,normal); - float diffuseSun = clamp(NdotL,0.0f,1.0f); - - vec3 direct = texelFetch2D(gaux1,ivec2(6,37),0).rgb/3.1415; - - float shading = 1.0; - float cloudShadow = 1.0; - //compute shadows only if not backface - if (diffuseSun > 0.001) { - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - vec3 projectedShadowPosition = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; - projectedShadowPosition = diagonal3(shadowProjection) * projectedShadowPosition + shadowProjection[3].xyz; - - //apply distortion - float distortFactor = calcDistort(projectedShadowPosition.xy); - projectedShadowPosition.xy *= distortFactor; - //do shadows only if on shadow map - if (abs(projectedShadowPosition.x) < 1.0-1.5/shadowMapResolution && abs(projectedShadowPosition.y) < 1.0-1.5/shadowMapResolution){ - const float threshMul = max(2048.0/shadowMapResolution*shadowDistance/128.0,0.95); - float distortThresh = (sqrt(1.0-diffuseSun*diffuseSun)/diffuseSun+0.7)/distortFactor; - float diffthresh = distortThresh/6000.0*threshMul; - - projectedShadowPosition = projectedShadowPosition * vec3(0.5,0.5,0.5/6.0) + vec3(0.5,0.5,0.5); - - shading = 0.0; - float noise = blueNoise(); - float rdMul = 4.0/shadowMapResolution; - for(int i = 0; i < 9; i++){ - vec2 offsetS = tapLocation(i,9, 1.618,noise,0.0); - - float weight = 1.0+(i+noise)*rdMul/9.0*shadowMapResolution; - shading += shadow2D(shadow,vec3(projectedShadowPosition + vec3(rdMul*offsetS,-diffthresh*weight))).x/9.0; - } - direct *= shading; - } - - - #ifdef VOLUMETRIC_CLOUDS - #ifdef CLOUDS_SHADOWS - vec3 campos = (p3 + cameraPosition)-319 ; - // get cloud position - vec3 cloudPos = campos*Cloud_Size + WsunVec/abs(WsunVec.y) * (2250 - campos.y*Cloud_Size); - // get the cloud density and apply it - cloudShadow = getCloudDensity(cloudPos, 1); - // cloudShadow = exp(-cloudShadow*sqrt(cloudDensity)*25); - - cloudShadow = clamp(exp(-cloudShadow*10),0,1); - - // make these turn to zero when occluded by the cloud shadow - direct *= cloudShadow; - #endif - #endif - } - - - - - #if ambient_colortype == 0 - vec3 colortype = blackbody2(ambient_temp); - #else - vec3 colortype = vec3(AmbientLight_R,AmbientLight_G,AmbientLight_B) ; - #endif - - vec3 ambientLight = texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb * colortype; - - direct *= (iswater > 0.9 ? 0.2: 1.0)*diffuseSun*lmtexcoord.w; - - - vec3 diffuseLight = (direct*1.5) + (ambientLight*2.5); - vec3 color = diffuseLight * albedo * 8./150./3.0 ; - - - - if (iswater > 0.0){ - - float roughness = iswater > 0.4 ? 0.0 : specularstuff.r > 0.0 ? pow(1.0-specularstuff.r,2.0) : 0.05*(1.0-gl_FragData[0].a ); - float f0 = iswater > 0.4 ? 0.02 : specularstuff.g; - if(f0 > 0.9) f0 = 0.02; - float F0 = f0; - - // float f0 = iswater > 0.1 ? 0.02 : 0.05*(1.0-gl_FragData[0].a); - // float roughness = 0.02; - // float F0 = f0; - - vec3 reflectedVector = reflect(normalize(fragpos), normal); - - - float normalDotEye = dot(normal, normalize(fragpos)); - float fresnel = pow(clamp(1.0 + normalDotEye,0.0,1.0), 5.0); - float fresnel2 = pow(clamp(1.0 + normalDotEye,0.0,1.0), 1.0); - - // gl_FragData[3].a = fresnel2; - - // snells window looking thing - if(isEyeInWater == 1 && iswater > 0.99) fresnel = clamp(pow(1.66 + normalDotEye,25),0.02,1.0); - - fresnel = mix(F0,1.0,fresnel); - - // adjust the amount of sunlight based on f0. max f0 should - color = mix(color, (ambientLight*2.5) * albedo * 8./150./3.0 , mix(1.0-roughness, F0, 0.5)); - - vec3 wrefl = mat3(gbufferModelViewInverse)*reflectedVector; - vec3 sky_c = mix(skyCloudsFromTex(wrefl,gaux1).rgb,texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb*0.5,isEyeInWater); - sky_c.rgb *= lmtexcoord.w*lmtexcoord.w*255*255/240./240./150.*8./3.; - - vec4 reflection = vec4(sky_c.rgb,0.); - #ifdef SCREENSPACE_REFLECTIONS - vec3 rtPos = rayTrace(reflectedVector,fragpos.xyz, blueNoise(), fresnel, isEyeInWater == 0); - if (rtPos.z <1.){ - vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rtPos) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; - previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; - previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; - if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) { - reflection.a = 1.0; - reflection.rgb = texture2D(gaux2,previousPosition.xy).rgb; - } - } - #endif - - - if(isEyeInWater ==1 ) sky_c.rgb = color.rgb*lmtexcoord.y; - - reflection.rgb = mix(sky_c.rgb, reflection.rgb, reflection.a); - - #ifdef SUN_MICROFACET_SPECULAR - vec3 sunSpec = GGX2(normal, -normalize(fragpos), lightSign*sunVec ,roughness, vec3(f0)) * direct; - - // vec3 sunSpec = GGX(normal,-normalize(fragpos), lightSign*sunVec, rainStrength*0.2+roughness+0.05+clamp(-lightSign*0.15,0.0,1.0), f0) * texelFetch2D(gaux1,ivec2(6,37),0).rgb*8./3./150.0/3.1415 * (1.0-rainStrength*0.9); - #else - vec3 sunSpec = drawSun(dot(lightSign * sunVec,reflectedVector), 0.0,texelFetch2D(gaux1,ivec2(6,37),0).rgb,vec3(0.0))*8./3./150.0*fresnel/3.1415 * (1.0-rainStrength*0.9); - #endif - - - // vec3 albedoTint = F0 >= (230.0/255.0) ? clamp(color.rgb + fresnel,0.0,1.0) : vec3(1.0); - // reflection.rgb *= albedoTint; - // sunSpec.rgb *= albedoTint; - sunSpec *= max(cloudShadow-0.5,0.0); - - vec3 reflected = reflection.rgb*fresnel+shading*sunSpec; - - float alpha0 = gl_FragData[0].a; - - vec3 np3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition; - - float borderfog = clamp( pow( length(fragpos)/far, 5), 0, 1); - vec3 bordercolor = skyFromTex(np3,colortex4)/150.; - vec3 finalborderfog = clamp(fp10Dither(bordercolor*8./3.,triangularize(R2_dither())),0.0,65000.); - - // alpha0 = mix(0.0, alpha0, borderfog); - - //correct alpha channel with fresnel - gl_FragData[0].a = -gl_FragData[0].a*fresnel+gl_FragData[0].a+fresnel; - - gl_FragData[0].rgb = clamp(color/gl_FragData[0].a*alpha0*(1.0-fresnel)*0.1+reflected/gl_FragData[0].a*0.1,0.0,65100.0); - if (gl_FragData[0].r > 65000.) gl_FragData[0].rgba = vec4(0.); - - - } - else - gl_FragData[0].rgb = color*.1; - - gl_FragData[1] = vec4(albedo,iswater); - - // vec3 np3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz + cameraPosition; - - // float borderfog = clamp( pow( length(fragpos)/far, 5), 0, 1); - // vec3 bordercolor = skyFromTex(np3,colortex4)/150.; - // vec3 finalborderfog = clamp(fp10Dither(bordercolor*8./3.,triangularize(R2_dither())),0.0,65000.); - - } -} diff --git a/shaders/world1/gbuffers_all_translucent.vsh b/shaders/world1/gbuffers_all_translucent.vsh deleted file mode 100644 index 13986e0..0000000 --- a/shaders/world1/gbuffers_all_translucent.vsh +++ /dev/null @@ -1,112 +0,0 @@ -// #version 120 -#extension GL_EXT_gpu_shader4 : enable - -#include "/lib/res_params.glsl" - - -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -varying vec3 binormal; -varying vec3 tangent; -varying float dist; -uniform mat4 gbufferModelViewInverse; -varying vec3 viewVector; -attribute vec4 at_tangent; -attribute vec4 mc_Entity; - -uniform sampler2D colortex4; -uniform vec3 sunPosition; -flat varying vec3 WsunVec; -uniform float sunElevation; - -varying vec4 tangent_other; -#define SHADOW_MAP_BIAS 0.8 - -flat varying vec4 lightCol; //main light source color (rgb),used light source(1=sun,-1=moon) - - - -uniform vec2 texelSize; -uniform int framemod8; - 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.); -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -vec4 toClipSpace3(vec3 viewSpacePosition) { - return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); -} -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - - vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; - gl_Position = toClipSpace3(position); - color = gl_Color; - float mat = 0.0; - if(mc_Entity.x == 8.0 || mc_Entity.x == 9.0) { - mat = 1.0; - - gl_Position.z -= 1e-4; - } - - - if (mc_Entity.x == 10002) mat = 0.01; - if (mc_Entity.x == 72) mat = 0.5; - // if (mc_Entity.x == 8) mat = 0.1; - - normalMat = vec4(normalize( gl_NormalMatrix*gl_Normal),mat); - - - - tangent_other = vec4(normalize(gl_NormalMatrix * at_tangent.rgb),normalMat.a); - - tangent = normalize( gl_NormalMatrix *at_tangent.rgb); - binormal = normalize(cross(tangent.rgb,normalMat.xyz)*at_tangent.w); - - mat3 tbnMatrix = mat3(tangent.x, binormal.x, normalMat.x, - tangent.y, binormal.y, normalMat.y, - tangent.z, binormal.z, normalMat.z); - - dist = length(gl_ModelViewMatrix * gl_Vertex); - - viewVector = ( gl_ModelViewMatrix * gl_Vertex).xyz; - viewVector = normalize(tbnMatrix * viewVector); - - - - #ifdef TAA_UPSCALING - gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; - #endif - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif - - vec3 sc = texelFetch2D(colortex4,ivec2(6,37),0).rgb; - - - lightCol.a = float(sunElevation > 1e-5)*2-1.; - lightCol.rgb = sc; - - WsunVec = lightCol.a*normalize(mat3(gbufferModelViewInverse) *sunPosition); -} diff --git a/shaders/world1/gbuffers_armor_glint.fsh b/shaders/world1/gbuffers_armor_glint.fsh index c931e5f..d2a0cfd 100644 --- a/shaders/world1/gbuffers_armor_glint.fsh +++ b/shaders/world1/gbuffers_armor_glint.fsh @@ -8,7 +8,7 @@ varying vec4 normalMat; uniform sampler2D texture; - +uniform sampler2D gaux1; uniform vec4 lightCol; uniform vec3 sunVec; @@ -66,34 +66,15 @@ void main() { gl_FragData[0] = texture2D(texture, lmtexcoord.xy); + vec3 albedo = toLinear(gl_FragData[0].rgb*color.rgb); - vec3 albedo = toLinear(gl_FragData[0].rgb*color.rgb); + float exposure = texelFetch2D(gaux1,ivec2(10,37),0).r; - vec3 normal = normalMat.xyz; - vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize,1.0)); + vec3 col = albedo*exp(-exposure*3.); - - float NdotL = lightCol.a*dot(normal,sunVec); - - float diffuseSun = clamp(NdotL,0.0f,1.0f); - - vec3 direct = lightCol.rgb; - - - direct *= (diffuseSun*lmtexcoord.w)*10.; - - float torch_lightmap = ((lmtexcoord.z*lmtexcoord.z)*(lmtexcoord.z*lmtexcoord.z))*(lmtexcoord.z*20.)+lmtexcoord.z; - - vec3 ambient = (lightCol.a*sunElevation)*(-NdotL*0.45+0.9)*lightCol.rgb*0.6 + (1.2*skyIntensity)*vec3(0.65,0.7,1.)*30. + skyIntensityNight*vec3(0.09,0.1,0.15)/1.5; - - vec3 diffuseLight = (lmtexcoord.w)*ambient + vec3(1.,0.4,0.1)*torch_lightmap*0.08*1.0 + 0.0006; - - vec3 col = dot(diffuseLight,vec3(1.0/3))*albedo; - - - gl_FragData[0].rgb = col*color.a; - gl_FragData[0].a = 0.0; + gl_FragData[0].rgb = col*color.a; + gl_FragData[0].a = gl_FragData[0].a*0.1; diff --git a/shaders/world1/gbuffers_armor_glint.vsh b/shaders/world1/gbuffers_armor_glint.vsh index 40823aa..ab59388 100644 --- a/shaders/world1/gbuffers_armor_glint.vsh +++ b/shaders/world1/gbuffers_armor_glint.vsh @@ -1,6 +1,6 @@ #version 120 #extension GL_EXT_gpu_shader4 : enable -#define TAA +#include "/lib/res_params.glsl" /* !! DO NOT REMOVE !! @@ -14,7 +14,7 @@ varying vec4 color; varying vec4 normalMat; #ifdef MC_NORMAL_MAP varying vec4 tangent; -attribute vec4 at_tangent; +attribute vec4 at_tangent; #endif uniform vec2 texelSize; uniform int framemod8; @@ -26,6 +26,12 @@ uniform int framemod8; vec2(-7.,-1.)/8., vec2(3,7.)/8., vec2(7.,-7.)/8.); +#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) +#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) +vec4 toClipSpace3(vec3 viewSpacePosition) { + return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); +} + //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// //////////////////////////////VOID MAIN////////////////////////////// @@ -38,16 +44,20 @@ void main() { vec2 lmcoord = gl_MultiTexCoord1.xy/255.; lmtexcoord.zw = lmcoord*lmcoord; - gl_Position = ftransform(); - color = gl_Color; - - + vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; + color = gl_Color; + gl_Position = toClipSpace3(position); + + #ifdef MC_NORMAL_MAP tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); #endif - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),1.0); + normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),1.0); + #ifdef TAA_UPSCALING + gl_Position.xy = gl_Position.xy * RENDER_SCALE + RENDER_SCALE * gl_Position.w - gl_Position.w; + #endif #ifdef TAA gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; #endif -} \ No newline at end of file +} diff --git a/shaders/world1/gbuffers_basic.fsh b/shaders/world1/gbuffers_basic.fsh index 97072f6..7bb4bf0 100644 --- a/shaders/world1/gbuffers_basic.fsh +++ b/shaders/world1/gbuffers_basic.fsh @@ -1,4 +1,6 @@ #version 120 +// #define ENTITIES +#define BLOCKENTITIES #define WORLD -#include "gbuffers_all_solid.fsh" \ No newline at end of file +#include "/programs/all_solid.fsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_basic.vsh b/shaders/world1/gbuffers_basic.vsh index 5078151..2577f65 100644 --- a/shaders/world1/gbuffers_basic.vsh +++ b/shaders/world1/gbuffers_basic.vsh @@ -1,4 +1,7 @@ #version 120 +// #define ENTITIES +// #define LINE +#define BLOCKENTITIES #define WORLD -#include "gbuffers_all_solid.vsh" \ No newline at end of file +#include "/programs/all_solid.vsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_block.fsh b/shaders/world1/gbuffers_block.fsh index 95943b4..34cbade 100644 --- a/shaders/world1/gbuffers_block.fsh +++ b/shaders/world1/gbuffers_block.fsh @@ -1,5 +1,5 @@ #version 120 -#define BLOCK_ENT #define WORLD -#include "gbuffers_all_solid.fsh" \ No newline at end of file +#define BLOCKENTITIES +#include "/gbuffers_all_solid.fsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_block.vsh b/shaders/world1/gbuffers_block.vsh index 9974256..31749b9 100644 --- a/shaders/world1/gbuffers_block.vsh +++ b/shaders/world1/gbuffers_block.vsh @@ -1,5 +1,5 @@ #version 120 -#define BLOCK_ENT #define WORLD -#include "gbuffers_all_solid.vsh" \ No newline at end of file +#define BLOCKENTITIES +#include "/gbuffers_all_solid.vsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_clouds.fsh b/shaders/world1/gbuffers_clouds.fsh deleted file mode 100644 index 563a191..0000000 --- a/shaders/world1/gbuffers_clouds.fsh +++ /dev/null @@ -1,9 +0,0 @@ -#version 120 - -/* DRAWBUFFERS:3 */ - - - -void main() { - -} diff --git a/shaders/world1/gbuffers_clouds.vsh b/shaders/world1/gbuffers_clouds.vsh deleted file mode 100644 index 90c4b9e..0000000 --- a/shaders/world1/gbuffers_clouds.vsh +++ /dev/null @@ -1,14 +0,0 @@ -#version 120 -#extension GL_EXT_gpu_shader4 : enable - - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - - gl_Position.w = -1.0; -} diff --git a/shaders/world1/gbuffers_entities.fsh b/shaders/world1/gbuffers_entities.fsh index 0cd3e0d..234213a 100644 --- a/shaders/world1/gbuffers_entities.fsh +++ b/shaders/world1/gbuffers_entities.fsh @@ -2,4 +2,5 @@ #define WORLD #define ENTITIES -#include "gbuffers_all_solid.fsh" \ No newline at end of file + +#include "/programs/all_solid.fsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_entities.vsh b/shaders/world1/gbuffers_entities.vsh index f4f07a4..460f566 100644 --- a/shaders/world1/gbuffers_entities.vsh +++ b/shaders/world1/gbuffers_entities.vsh @@ -3,4 +3,4 @@ // #define WORLD #define ENTITIES -#include "gbuffers_all_solid.vsh" \ No newline at end of file +#include "/programs/all_solid.vsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_hand.fsh b/shaders/world1/gbuffers_hand.fsh index 21ac244..8350290 100644 --- a/shaders/world1/gbuffers_hand.fsh +++ b/shaders/world1/gbuffers_hand.fsh @@ -1,4 +1,4 @@ #version 120 #define HAND -#include "gbuffers_all_solid.fsh" \ No newline at end of file +#include "/programs/all_solid.fsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_hand.vsh b/shaders/world1/gbuffers_hand.vsh index 39504ed..a2820e6 100644 --- a/shaders/world1/gbuffers_hand.vsh +++ b/shaders/world1/gbuffers_hand.vsh @@ -2,4 +2,5 @@ #define WORLD #define HAND -#include "gbuffers_all_solid.vsh" \ No newline at end of file + +#include "/programs/all_solid.vsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_hand_water.fsh b/shaders/world1/gbuffers_hand_water.fsh index 2225473..59a7bed 100644 --- a/shaders/world1/gbuffers_hand_water.fsh +++ b/shaders/world1/gbuffers_hand_water.fsh @@ -1,116 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define PCF - - - - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; - - -uniform sampler2D texture; -uniform sampler2D gaux1; -uniform vec4 lightCol; -uniform vec3 sunVec; -uniform vec3 upVec; - -uniform vec2 texelSize; -uniform float skyIntensityNight; -uniform float skyIntensity; -uniform float sunElevation; -uniform float rainStrength; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferModelViewInverse; -uniform mat4 shadowModelView; -uniform mat4 shadowProjection; - -//faster and actually more precise than pow 2.2 -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} - -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -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; -} -float interleaved_gradientNoise(float temporal){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+temporal); - return noise; -} - -#ifdef PCF -const vec2 shadowOffsets[4] = vec2[4](vec2( 0.1250, 0.0000 ), -vec2( -0.1768, -0.1768 ), -vec2( -0.0000, 0.3750 ), -vec2( 0.3536, -0.3536 ) -); -#endif -float facos(float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : 3.14159265359 - a; -} - - -vec2 tapLocation(int sampleNumber, float spinAngle,int nb, float nbRot) -{ - float startJitter = (spinAngle/6.28); - float alpha = sqrt(sampleNumber + startJitter/nb ); - float angle = alpha * (nbRot * 6.28) + spinAngle*2.; - - float ssR = alpha; - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*ssR; -} -uniform int framemod8; -uniform int framecouter; - 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.); - - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -/* DRAWBUFFERS:2 */ -void main() { - - gl_FragData[0] = texture2D(texture, lmtexcoord.xy)*color; - vec2 tempOffset=offsets[framemod8]; - - if (gl_FragData[0].a>0.1){ - vec3 albedo = toLinear(gl_FragData[0].rgb); - - vec3 normal = normalMat.xyz; - - - vec3 ambient = texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb; - - vec3 diffuseLight = ambient; - - - gl_FragData[0].rgb = diffuseLight*albedo*8./1500.*0.1; - } - - - -} +#include "/programs/all_translucent.fsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_hand_water.vsh b/shaders/world1/gbuffers_hand_water.vsh index 68dc1b7..afcff5d 100644 --- a/shaders/world1/gbuffers_hand_water.vsh +++ b/shaders/world1/gbuffers_hand_water.vsh @@ -1,56 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define TAA -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -#ifdef MC_NORMAL_MAP -varying vec4 tangent; -attribute vec4 at_tangent; -#endif - - - -uniform vec2 texelSize; -uniform int framemod8; - 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.); -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - - gl_Position = ftransform(); - color = gl_Color; - - - #ifdef MC_NORMAL_MAP - tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); - #endif - - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),1.0); - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif -} +#include "/programs/all_translucent.vsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_terrain.fsh b/shaders/world1/gbuffers_terrain.fsh index 97072f6..d9afdd3 100644 --- a/shaders/world1/gbuffers_terrain.fsh +++ b/shaders/world1/gbuffers_terrain.fsh @@ -1,4 +1,5 @@ #version 120 #define WORLD -#include "gbuffers_all_solid.fsh" \ No newline at end of file + +#include "/programs/all_solid.fsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_terrain.vsh b/shaders/world1/gbuffers_terrain.vsh index 5078151..d18fc18 100644 --- a/shaders/world1/gbuffers_terrain.vsh +++ b/shaders/world1/gbuffers_terrain.vsh @@ -1,4 +1,5 @@ #version 120 #define WORLD -#include "gbuffers_all_solid.vsh" \ No newline at end of file + +#include "/programs/all_solid.vsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_textured.fsh b/shaders/world1/gbuffers_textured.fsh index 2225473..0f62590 100644 --- a/shaders/world1/gbuffers_textured.fsh +++ b/shaders/world1/gbuffers_textured.fsh @@ -1,116 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define PCF - - - - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; - - -uniform sampler2D texture; -uniform sampler2D gaux1; -uniform vec4 lightCol; -uniform vec3 sunVec; -uniform vec3 upVec; - -uniform vec2 texelSize; -uniform float skyIntensityNight; -uniform float skyIntensity; -uniform float sunElevation; -uniform float rainStrength; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferModelViewInverse; -uniform mat4 shadowModelView; -uniform mat4 shadowProjection; - -//faster and actually more precise than pow 2.2 -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} - -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -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; -} -float interleaved_gradientNoise(float temporal){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+temporal); - return noise; -} - -#ifdef PCF -const vec2 shadowOffsets[4] = vec2[4](vec2( 0.1250, 0.0000 ), -vec2( -0.1768, -0.1768 ), -vec2( -0.0000, 0.3750 ), -vec2( 0.3536, -0.3536 ) -); -#endif -float facos(float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : 3.14159265359 - a; -} - - -vec2 tapLocation(int sampleNumber, float spinAngle,int nb, float nbRot) -{ - float startJitter = (spinAngle/6.28); - float alpha = sqrt(sampleNumber + startJitter/nb ); - float angle = alpha * (nbRot * 6.28) + spinAngle*2.; - - float ssR = alpha; - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*ssR; -} -uniform int framemod8; -uniform int framecouter; - 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.); - - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -/* DRAWBUFFERS:2 */ -void main() { - - gl_FragData[0] = texture2D(texture, lmtexcoord.xy)*color; - vec2 tempOffset=offsets[framemod8]; - - if (gl_FragData[0].a>0.1){ - vec3 albedo = toLinear(gl_FragData[0].rgb); - - vec3 normal = normalMat.xyz; - - - vec3 ambient = texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb; - - vec3 diffuseLight = ambient; - - - gl_FragData[0].rgb = diffuseLight*albedo*8./1500.*0.1; - } - - - -} +#include "/programs/all_particles.fsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_textured.vsh b/shaders/world1/gbuffers_textured.vsh index 51f3fd7..a6d1cbf 100644 --- a/shaders/world1/gbuffers_textured.vsh +++ b/shaders/world1/gbuffers_textured.vsh @@ -1,74 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define TAA -#define WAVY_PLANTS -#define WAVY_STRENGTH 1.0 //[0.1 0.25 0.5 0.75 1.0 1.25 1.5 1.75 2.0] -#define WAVY_SPEED 1.0 //[0.001 0.01 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 1.0 1.25 1.5 2.0 3.0 4.0] -#define SEPARATE_AO -//#define POM -//#define USE_LUMINANCE_AS_HEIGHTMAP //Can generate POM on any texturepack (may look weird in some cases) - -#ifndef USE_LUMINANCE_AS_HEIGHTMAP -#ifndef MC_NORMAL_MAP -#undef POM -#endif -#endif - -#ifdef POM -#define MC_NORMAL_MAP -#endif - -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; - - -uniform vec2 texelSize; -uniform int framemod8; - 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.); -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -vec4 toClipSpace3(vec3 viewSpacePosition) { - return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); -} - - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - - vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; - - color = gl_Color; - - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),0.0); - - gl_Position = toClipSpace3(position); - - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif -} +#include "/programs/all_particles.vsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_textured_lit.fsh b/shaders/world1/gbuffers_textured_lit.fsh index 2225473..0f62590 100644 --- a/shaders/world1/gbuffers_textured_lit.fsh +++ b/shaders/world1/gbuffers_textured_lit.fsh @@ -1,116 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define PCF - - - - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; - - -uniform sampler2D texture; -uniform sampler2D gaux1; -uniform vec4 lightCol; -uniform vec3 sunVec; -uniform vec3 upVec; - -uniform vec2 texelSize; -uniform float skyIntensityNight; -uniform float skyIntensity; -uniform float sunElevation; -uniform float rainStrength; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferModelViewInverse; -uniform mat4 shadowModelView; -uniform mat4 shadowProjection; - -//faster and actually more precise than pow 2.2 -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} - -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -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; -} -float interleaved_gradientNoise(float temporal){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+temporal); - return noise; -} - -#ifdef PCF -const vec2 shadowOffsets[4] = vec2[4](vec2( 0.1250, 0.0000 ), -vec2( -0.1768, -0.1768 ), -vec2( -0.0000, 0.3750 ), -vec2( 0.3536, -0.3536 ) -); -#endif -float facos(float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : 3.14159265359 - a; -} - - -vec2 tapLocation(int sampleNumber, float spinAngle,int nb, float nbRot) -{ - float startJitter = (spinAngle/6.28); - float alpha = sqrt(sampleNumber + startJitter/nb ); - float angle = alpha * (nbRot * 6.28) + spinAngle*2.; - - float ssR = alpha; - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*ssR; -} -uniform int framemod8; -uniform int framecouter; - 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.); - - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -/* DRAWBUFFERS:2 */ -void main() { - - gl_FragData[0] = texture2D(texture, lmtexcoord.xy)*color; - vec2 tempOffset=offsets[framemod8]; - - if (gl_FragData[0].a>0.1){ - vec3 albedo = toLinear(gl_FragData[0].rgb); - - vec3 normal = normalMat.xyz; - - - vec3 ambient = texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb; - - vec3 diffuseLight = ambient; - - - gl_FragData[0].rgb = diffuseLight*albedo*8./1500.*0.1; - } - - - -} +#include "/programs/all_particles.fsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_textured_lit.vsh b/shaders/world1/gbuffers_textured_lit.vsh index 68dc1b7..c9e7eab 100644 --- a/shaders/world1/gbuffers_textured_lit.vsh +++ b/shaders/world1/gbuffers_textured_lit.vsh @@ -1,56 +1,5 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define TAA -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -#ifdef MC_NORMAL_MAP -varying vec4 tangent; -attribute vec4 at_tangent; -#endif - - - -uniform vec2 texelSize; -uniform int framemod8; - 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.); -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - - gl_Position = ftransform(); - color = gl_Color; - - - #ifdef MC_NORMAL_MAP - tangent = vec4(normalize(gl_NormalMatrix *at_tangent.rgb),at_tangent.w); - #endif - - normalMat = vec4(normalize(gl_NormalMatrix *gl_Normal),1.0); - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif -} +// #define WEATHER +#define PARTICLES +#include "/programs/all_particles.vsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_water.fsh b/shaders/world1/gbuffers_water.fsh index 5d6f344..59a7bed 100644 --- a/shaders/world1/gbuffers_water.fsh +++ b/shaders/world1/gbuffers_water.fsh @@ -1,334 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -varying vec4 lmtexcoord; -varying vec4 color; -varying vec4 normalMat; -varying vec3 binormal; -varying vec3 tangent; -varying vec3 viewVector; -varying float dist; -#define SCREENSPACE_REFLECTIONS //can be really expensive at high resolutions/render quality, especially on ice -#define SSR_STEPS 30 //[10 15 20 25 30 35 40 50 100 200 400] -#define SUN_MICROFACET_SPECULAR // If enabled will use realistic rough microfacet model, else will just reflect the sun. No performance impact. -#define saturate(x) clamp(x,0.0,1.0) - -uniform sampler2D texture; -uniform sampler2D noisetex; -uniform sampler2D gaux2; -uniform sampler2D gaux1; -uniform sampler2D depthtex1; - -uniform vec4 lightCol; -uniform vec3 sunVec; -uniform float frameTimeCounter; -uniform float lightSign; -uniform float near; -uniform float far; -uniform float moonIntensity; -uniform float sunIntensity; -uniform vec3 sunColor; -uniform vec3 nsunColor; -uniform vec3 upVec; -uniform float sunElevation; -uniform float fogAmount; -uniform vec2 texelSize; -uniform float rainStrength; -uniform float skyIntensityNight; -uniform float skyIntensity; -uniform mat4 gbufferPreviousModelView; -uniform vec3 previousCameraPosition; -uniform int framemod8; -uniform int frameCounter; -uniform int isEyeInWater; -#include "lib/color_transforms.glsl" -#include "lib/projections.glsl" -#include "lib/sky_gradient.glsl" -#include "lib/waterBump.glsl" -#include "lib/clouds.glsl" -#include "lib/stars.glsl" - 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 interleaved_gradientNoise(float temporal){ - vec2 coord = gl_FragCoord.xy; - float noise = fract(52.9829189*fract(0.06711056*coord.x + 0.00583715*coord.y)+temporal); - return noise; -} -float blueNoise(){ - return fract(texelFetch2D(noisetex, ivec2(gl_FragCoord.xy)%512, 0).a + 1.0/1.6180339887 * frameCounter); -} -float invLinZ (float lindepth){ - return -((2.0*near/lindepth)-far-near)/(far-near); -} -float ld(float dist) { - return (2.0 * near) / (far + near - dist * (far - near)); -} -vec3 nvec3(vec4 pos){ - return pos.xyz/pos.w; -} - -vec4 nvec4(vec3 pos){ - return vec4(pos.xyz, 1.0); -} -vec3 rayTrace(vec3 dir,vec3 position,float dither, float fresnel){ - - float quality = mix(15,SSR_STEPS,fresnel); - vec3 clipPosition = toClipSpace3(position); - float rayLength = ((position.z + dir.z * far*sqrt(3.)) > -near) ? - (-near -position.z) / dir.z : far*sqrt(3.); - vec3 direction = normalize(toClipSpace3(position+dir*rayLength)-clipPosition); //convert to clip space - direction.xy = normalize(direction.xy); - - //get at which length the ray intersects with the edge of the screen - vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; - float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z); - - - vec3 stepv = direction * mult / quality; - - - - - vec3 spos = clipPosition + stepv*dither; - float minZ = clipPosition.z; - float maxZ = spos.z+stepv.z*0.5; - spos.xy+=offsets[framemod8]*texelSize*0.5; - //raymarch on a quarter res depth buffer for improved cache coherency - - - for (int i = 0; i < int(quality+1); i++) { - - float sp=texelFetch2D(depthtex1,ivec2(spos.xy/texelSize),0).x; - - if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ)){ - return vec3(spos.xy,sp); - - } - spos += stepv; - //small bias - minZ = maxZ-0.00004/ld(spos.z); - maxZ += stepv.z; - } - - return vec3(1.1); -} - - -float facos(float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : pi - a; -} - - - - - float bayer2(vec2 a){ - a = floor(a); - return fract(dot(a,vec2(0.5,a.y*0.75))); -} - -float cdist(vec2 coord) { - return max(abs(coord.s-0.5),abs(coord.t-0.5))*2.0; -} - - #define PW_DEPTH 1.0 //[0.5 1.0 1.5 2.0 2.5 3.0] - #define PW_POINTS 1 //[2 4 6 8 16 32] - #define bayer4(a) (bayer2( .5*(a))*.25+bayer2(a)) -#define bayer8(a) (bayer4( .5*(a))*.25+bayer2(a)) -#define bayer16(a) (bayer8( .5*(a))*.25+bayer2(a)) -#define bayer32(a) (bayer16(.5*(a))*.25+bayer2(a)) -#define bayer64(a) (bayer32(.5*(a))*.25+bayer2(a)) -#define bayer128(a) fract(bayer64(.5*(a))*.25+bayer2(a)) -vec3 getParallaxDisplacement(vec3 posxz, float iswater,float bumpmult,vec3 viewVec) { - float waveZ = mix(20.0,0.25,iswater); - float waveM = mix(0.0,4.0,iswater); - - vec3 parallaxPos = posxz; - vec2 vec = viewVector.xy * (1.0 / float(PW_POINTS)) * 22.0 * PW_DEPTH; - float waterHeight = getWaterHeightmap(posxz.xz, waveM, waveZ, iswater) * 0.5; -parallaxPos.xz += waterHeight * vec; - - return parallaxPos; - -} -vec2 tapLocation(int sampleNumber,int nb, float nbRot,float jitter,float distort) -{ - float alpha = (sampleNumber+jitter)/nb; - float angle = jitter*6.28 + alpha * nbRot * 6.28; - - float sin_v, cos_v; - - sin_v = sin(angle); - cos_v = cos(angle); - - return vec2(cos_v, sin_v)*sqrt(alpha); -} -//Low discrepancy 2D sequence, integration error is as low as sobol but easier to compute : http://extremelearning.com.au/unreasonable-effectiveness-of-quasirandom-sequences/ -vec2 R2_samples(int n){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha * n); -} -vec4 hash44(vec4 p4) -{ - p4 = fract(p4 * vec4(.1031, .1030, .0973, .1099)); - p4 += dot(p4, p4.wzxy+33.33); - return fract((p4.xxyz+p4.yzzw)*p4.zywx); -} -vec3 TangentToWorld(vec3 N, vec3 H) -{ - vec3 UpVector = abs(N.z) < 0.999 ? vec3(0.0, 0.0, 1.0) : vec3(1.0, 0.0, 0.0); - vec3 T = normalize(cross(UpVector, N)); - vec3 B = cross(N, T); - - return vec3((T * H.x) + (B * H.y) + (N * H.z)); -} -float GGX (vec3 n, vec3 v, vec3 l, float r, float F0) { - r*=r;r*=r; - - vec3 h = l + v; - float hn = inversesqrt(dot(h, h)); - - float dotLH = clamp(dot(h,l)*hn,0.,1.); - float dotNH = clamp(dot(h,n)*hn,0.,1.); - float dotNL = clamp(dot(n,l),0.,1.); - float dotNHsq = dotNH*dotNH; - - float denom = dotNHsq * r - dotNHsq + 1.; - float D = r / (3.141592653589793 * denom * denom); - float F = F0 + (1. - F0) * exp2((-5.55473*dotLH-6.98316)*dotLH); - float k2 = .25 * r; - - return dotNL * D * F / (dotLH*dotLH*(1.0-k2)+k2); -} - -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -/* DRAWBUFFERS:27 */ -void main() { - - vec2 tempOffset=offsets[framemod8]; - float iswater = normalMat.w; - vec3 fragC = gl_FragCoord.xyz*vec3(texelSize,1.0); - vec3 fragpos = toScreenSpace(gl_FragCoord.xyz*vec3(texelSize,1.0)-vec3(vec2(tempOffset)*texelSize*0.5,0.0)); - gl_FragData[0] = texture2D(texture, lmtexcoord.xy)*color; - vec3 albedo = toLinear(gl_FragData[0].rgb); - if (iswater > 0.4) { - albedo = vec3(0.42,0.6,0.7); - gl_FragData[0] = vec4(0.42,0.6,0.7,0.7); - } - if (iswater > 0.9) { - gl_FragData[0] = vec4(0.0); - } - - - - - vec3 normal = normalMat.xyz; - - vec3 p3 = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - mat3 tbnMatrix = mat3(tangent.x, binormal.x, normal.x, - tangent.y, binormal.y, normal.y, - tangent.z, binormal.z, normal.z); - if (iswater > 0.4){ - float bumpmult = 1.; - if (iswater > 0.9) - bumpmult = 1.; - float parallaxMult = bumpmult; - vec3 posxz = p3+cameraPosition; - posxz.xz-=posxz.y; - if (iswater < 0.9) - posxz.xz *= 3.0; - vec3 bump; - - - posxz.xyz = getParallaxDisplacement(posxz,iswater,bumpmult,normalize(tbnMatrix*fragpos)); - - bump = normalize(getWaveHeight(posxz.xz,iswater)); - - - - bump = bump * vec3(bumpmult, bumpmult, bumpmult) + vec3(0.0f, 0.0f, 1.0f - bumpmult); - - normal = normalize(bump * tbnMatrix); - } - - - vec3 diffuseLight = texture2D(gaux1,(lmtexcoord.zw*15.+0.5)*texelSize).rgb; - vec3 color = diffuseLight*albedo*8./150./3.; - - - if (iswater > 0.0){ - float f0 = iswater > 0.1? 0.02 : 0.05*(1.0-gl_FragData[0].a); - - float roughness = 0.02; - - float emissive = 0.0; - float F0 = f0; - - vec3 reflectedVector = reflect(normalize(fragpos), normal); - float normalDotEye = dot(normal, normalize(fragpos)); - float fresnel = pow(clamp(1.0 + normalDotEye,0.0,1.0), 5.0); - fresnel = mix(F0,1.0,fresnel); - if (iswater > 0.4){ - fresnel = fresnel*0.87+0.04; //faking additionnal roughness to the water - roughness = 0.1; - } - - - - vec3 wrefl = mat3(gbufferModelViewInverse)*reflectedVector; - vec4 sky_c = skyCloudsFromTex(wrefl,gaux1)*(1.0-isEyeInWater); - sky_c.rgb *= lmtexcoord.w*lmtexcoord.w*255*255/240./240./150.*8./3.; - - - - - - vec4 reflection = vec4(sky_c.rgb,0.); - #ifdef SCREENSPACE_REFLECTIONS - vec3 rtPos = rayTrace(reflectedVector,fragpos.xyz,blueNoise(), fresnel); - if (rtPos.z <1.){ - - vec4 fragpositionPrev = gbufferProjectionInverse * vec4(rtPos*2.-1.,1.); - fragpositionPrev /= fragpositionPrev.w; - - vec3 sampleP = fragpositionPrev.xyz; - fragpositionPrev = gbufferModelViewInverse * fragpositionPrev; - - - - vec4 previousPosition = fragpositionPrev + vec4(cameraPosition-previousCameraPosition,0.); - previousPosition = gbufferPreviousModelView * previousPosition; - previousPosition = gbufferPreviousProjection * previousPosition; - previousPosition.xy = previousPosition.xy/previousPosition.w*0.5+0.5; - reflection.a = 1.0; - reflection.rgb = texture2D(gaux2,previousPosition.xy).rgb; - } - #endif - reflection.rgb = mix(sky_c.rgb, reflection.rgb, reflection.a); - vec3 reflected= reflection.rgb*fresnel; - - - float alpha0 = gl_FragData[0].a; - - //correct alpha channel with fresnel - gl_FragData[0].a = -gl_FragData[0].a*fresnel+gl_FragData[0].a+fresnel; - gl_FragData[0].rgb =clamp(color/gl_FragData[0].a*alpha0*(1.0-fresnel)*0.1+reflected/gl_FragData[0].a*0.1,0.0,65100.0); - if (gl_FragData[0].r > 65000.) gl_FragData[0].rgba = vec4(0.); - } - else - gl_FragData[0].rgb = color*0.1; - - gl_FragData[1] = vec4(albedo,iswater); - -} +#include "/programs/all_translucent.fsh" \ No newline at end of file diff --git a/shaders/world1/gbuffers_water.vsh b/shaders/world1/gbuffers_water.vsh index ec64b46..afcff5d 100644 --- a/shaders/world1/gbuffers_water.vsh +++ b/shaders/world1/gbuffers_water.vsh @@ -1,89 +1,3 @@ #version 120 -#extension GL_EXT_gpu_shader4 : enable -#define TAA - - -/* -!! DO NOT REMOVE !! -This code is from Chocapic13' shaders -Read the terms of modification and sharing before changing something below please ! -!! DO NOT REMOVE !! -*/ - -varying vec4 lmtexcoord; -varying vec4 color; - varying vec4 normalMat; -varying vec3 binormal; -varying vec3 tangent; -varying float dist; -uniform mat4 gbufferModelViewInverse; -varying vec3 viewVector; -attribute vec4 at_tangent; -attribute vec4 mc_Entity; - -#define SHADOW_MAP_BIAS 0.8 - - -uniform vec2 texelSize; -uniform int framemod8; - 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.); -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) -vec4 toClipSpace3(vec3 viewSpacePosition) { - return vec4(projMAD(gl_ProjectionMatrix, viewSpacePosition),-viewSpacePosition.z); -} -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// -//////////////////////////////VOID MAIN////////////////////////////// - -void main() { - lmtexcoord.xy = (gl_MultiTexCoord0).xy; - vec2 lmcoord = gl_MultiTexCoord1.xy/255.; - lmtexcoord.zw = lmcoord; - - vec3 position = mat3(gl_ModelViewMatrix) * vec3(gl_Vertex) + gl_ModelViewMatrix[3].xyz; - gl_Position = toClipSpace3(position); - color = gl_Color; - float mat = 0.0; - if(mc_Entity.x == 8.0 || mc_Entity.x == 9.0) { - mat = 1.0; - gl_Position.z -= 1e-4; - } - - - if(mc_Entity.x == 79.0) mat = 0.5; - if (mc_Entity.x == 10002) mat = 0.0001; - normalMat = vec4(normalize( gl_NormalMatrix*gl_Normal),mat); - - - - - tangent = normalize( gl_NormalMatrix *at_tangent.rgb); - binormal = normalize(cross(tangent.rgb,normalMat.xyz)*at_tangent.w); - - mat3 tbnMatrix = mat3(tangent.x, binormal.x, normalMat.x, - tangent.y, binormal.y, normalMat.y, - tangent.z, binormal.z, normalMat.z); - - dist = length(gl_ModelViewMatrix * gl_Vertex); - - viewVector = ( gl_ModelViewMatrix * gl_Vertex).xyz; - viewVector = normalize(tbnMatrix * viewVector); - - - - #ifdef TAA - gl_Position.xy += offsets[framemod8] * gl_Position.w*texelSize; - #endif - -} +#include "/programs/all_translucent.vsh" \ No newline at end of file diff --git a/shaders/world1/lib/ACES.glsl b/shaders/world1/lib/ACES.glsl deleted file mode 100644 index d9d6ce7..0000000 --- a/shaders/world1/lib/ACES.glsl +++ /dev/null @@ -1,382 +0,0 @@ -#define log10(x) log(x) / log(10.0) - - struct ColorCorrection { - float saturation; - float vibrance; - vec3 lum; - float contrast; - float contrastMidpoint; - - vec3 gain; - vec3 lift; - vec3 InvGamma; -} m; - - -float sigmoid_shaper(float x) { // Sigmoid function in the range 0 to 1 spanning -2 to +2. - float t = max(1.0 - abs(0.5 * x), 0.0); - float y = 1.0 + sign(x) * (1.0 - t * t); - - return 0.5 * y; -} - -float rgb_2_saturation(vec3 rgb) { - float minrgb = min(min(rgb.r, rgb.g), rgb.b); - float maxrgb = max(max(rgb.r, rgb.g), rgb.b); - - return (max(maxrgb, 1e-10) - max(minrgb, 1e-10)) / max(maxrgb, 1e-2); -} - -float rgb_2_yc(vec3 rgb) { // Converts RGB to a luminance proxy, here called YC. YC is ~ Y + K * Chroma. - float ycRadiusWeight = 1.75; - float r = rgb[0]; float g = rgb[1]; float b = rgb[2]; - float chroma = sqrt(b * (b - g) + g * (g - r) + r * (r - b)); - - return (b + g + r + ycRadiusWeight * chroma) / 3.0; -} - -float glow_fwd(float ycIn, float glowGainIn, float glowMid) { - float glowGainOut; - - if (ycIn <= 2.0 / 3.0 * glowMid) { - glowGainOut = glowGainIn; - } else if ( ycIn >= 2.0 * glowMid) { - glowGainOut = 0; - } else { - glowGainOut = glowGainIn * (glowMid / ycIn - 0.5); - } - - return glowGainOut; -} - -float rgb_2_hue(vec3 rgb) { // Returns a geometric hue angle in degrees (0-360) based on RGB values. - float hue; - if (rgb[0] == rgb[1] && rgb[1] == rgb[2]) { // For neutral colors, hue is undefined and the function will return a quiet NaN value. - hue = 0; - } else { - hue = (180.0 / 3.1415) * atan(2.0 * rgb[0] - rgb[1] - rgb[2], sqrt(3.0) * (rgb[1] - rgb[2])); // flip due to opengl spec compared to hlsl - } - - if (hue < 0.0) - hue = hue + 360.0; - - return clamp(hue, 0.0, 360.0); -} - -float center_hue(float hue, float centerH) { - float hueCentered = hue - centerH; - - if (hueCentered < -180.0) { - hueCentered += 360.0; - } else if (hueCentered > 180.0) { - hueCentered -= 360.0; - } - - return hueCentered; -} - -// Transformations between CIE XYZ tristimulus values and CIE x,y -// chromaticity coordinates -vec3 XYZ_2_xyY( vec3 XYZ ) { - float divisor = max(XYZ[0] + XYZ[1] + XYZ[2], 1e-10); - - vec3 xyY = XYZ.xyy; - xyY.rg = XYZ.rg / divisor; - - return xyY; -} - -vec3 xyY_2_XYZ(vec3 xyY) { - vec3 XYZ = vec3(0.0); - XYZ.r = xyY.r * xyY.b / max(xyY.g, 1e-10); - XYZ.g = xyY.b; - XYZ.b = (1.0 - xyY.r - xyY.g) * xyY.b / max(xyY.g, 1e-10); - - return XYZ; -} - -mat3 ChromaticAdaptation( vec2 src_xy, vec2 dst_xy ) { - // Von Kries chromatic adaptation - - // Bradford - const mat3 ConeResponse = mat3( - vec3(0.8951, 0.2664, -0.1614), - vec3(-0.7502, 1.7135, 0.0367), - vec3(0.0389, -0.0685, 1.0296) - ); - const mat3 InvConeResponse = mat3( - vec3(0.9869929, -0.1470543, 0.1599627), - vec3(0.4323053, 0.5183603, 0.0492912), - vec3(-0.0085287, 0.0400428, 0.9684867) - ); - - vec3 src_XYZ = xyY_2_XYZ( vec3( src_xy, 1 ) ); - vec3 dst_XYZ = xyY_2_XYZ( vec3( dst_xy, 1 ) ); - - vec3 src_coneResp = src_XYZ * ConeResponse; - vec3 dst_coneResp = dst_XYZ * ConeResponse; - - mat3 VonKriesMat = mat3( - vec3(dst_coneResp[0] / src_coneResp[0], 0.0, 0.0), - vec3(0.0, dst_coneResp[1] / src_coneResp[1], 0.0), - vec3(0.0, 0.0, dst_coneResp[2] / src_coneResp[2]) - ); - - return (ConeResponse * VonKriesMat) * InvConeResponse; -} - -/******************************************************************************* - - Color CorrectionUE4 Style - ******************************************************************************/ - - // Accurate for 1000K < Temp < 15000K -// [Krystek 1985, "An algorithm to calculate correlated colour temperature"] -vec2 PlanckianLocusChromaticity(float Temp) { - float u = ( 0.860117757f + 1.54118254e-4f * Temp + 1.28641212e-7f * Temp*Temp ) / ( 1.0f + 8.42420235e-4f * Temp + 7.08145163e-7f * Temp*Temp ); - float v = ( 0.317398726f + 4.22806245e-5f * Temp + 4.20481691e-8f * Temp*Temp ) / ( 1.0f - 2.89741816e-5f * Temp + 1.61456053e-7f * Temp*Temp ); - - float x = 3.0*u / ( 2.0*u - 8.0*v + 4.0 ); - float y = 2.0*v / ( 2.0*u - 8.0*v + 4.0 ); - - return vec2(x, y); -} - - vec2 D_IlluminantChromaticity(float Temp) { - // Accurate for 4000K < Temp < 25000K - // in: correlated color temperature - // out: CIE 1931 chromaticity - // Correct for revision of Plank's law - // This makes 6500 == D65 - Temp *= 1.4388 / 1.438; - - float x = Temp <= 7000 ? - 0.244063 + ( 0.09911e3 + ( 2.9678e6 - 4.6070e9 / Temp ) / Temp ) / Temp : - 0.237040 + ( 0.24748e3 + ( 1.9018e6 - 2.0064e9 / Temp ) / Temp ) / Temp; - - float y = -3 * x*x + 2.87 * x - 0.275; - - return vec2(x,y); -} - -vec2 PlanckianIsothermal( float Temp, float Tint ) { - float u = ( 0.860117757f + 1.54118254e-4f * Temp + 1.28641212e-7f * Temp*Temp ) / ( 1.0f + 8.42420235e-4f * Temp + 7.08145163e-7f * Temp*Temp ); - float v = ( 0.317398726f + 4.22806245e-5f * Temp + 4.20481691e-8f * Temp*Temp ) / ( 1.0f - 2.89741816e-5f * Temp + 1.61456053e-7f * Temp*Temp ); - - float ud = ( -1.13758118e9f - 1.91615621e6f * Temp - 1.53177f * Temp*Temp ) / pow( 1.41213984e6f + 1189.62f * Temp + Temp*Temp, 2.0 ); - float vd = ( 1.97471536e9f - 705674.0f * Temp - 308.607f * Temp*Temp ) / pow( 6.19363586e6f - 179.456f * Temp + Temp*Temp , 2.0); //don't pow2 this - - vec2 uvd = normalize( vec2( u, v ) ); - - // Correlated color temperature is meaningful within +/- 0.05 - u += -uvd.y * Tint * 0.05; - v += uvd.x * Tint * 0.05; - - float x = 3*u / ( 2*u - 8*v + 4 ); - float y = 2*v / ( 2*u - 8*v + 4 ); - - return vec2(x,y); -} - -vec3 WhiteBalance(vec3 LinearColor) { - const float WhiteTemp = float(WHITE_BALANCE); - const float WhiteTint = 0.0; - vec2 SrcWhiteDaylight = D_IlluminantChromaticity( WhiteTemp ); - vec2 SrcWhitePlankian = PlanckianLocusChromaticity( WhiteTemp ); - - vec2 SrcWhite = WhiteTemp < 4000 ? SrcWhitePlankian : SrcWhiteDaylight; - const vec2 D65White = vec2(0.31270, 0.32900); - - // Offset along isotherm - vec2 Isothermal = PlanckianIsothermal( WhiteTemp, WhiteTint ) - SrcWhitePlankian; - SrcWhite += Isothermal; - - mat3x3 WhiteBalanceMat = ChromaticAdaptation( SrcWhite, D65White ); - WhiteBalanceMat = (sRGB_2_XYZ_MAT * WhiteBalanceMat) * XYZ_2_sRGB_MAT; - - return LinearColor * WhiteBalanceMat * 1.0; -} - -/******************************************************************************* - - ACES Fimic Curve Approx. - ******************************************************************************/ - -// ACES settings -const float FilmSlope = Film_Slope; //0.90 -const float FilmToe = Film_Toe; //0.55 -const float FilmShoulder = Film_Shoulder; //0.25 -const float FilmBlackClip = Black_Clip; -const float FilmWhiteClip = White_Clip; -const float BlueCorrection = Blue_Correction; -const float ExpandGamut = Gamut_Expansion; - -vec3 FilmToneMap(vec3 LinearColor) { - const mat3 AP0_2_sRGB = (AP0_2_XYZ_MAT * D60_2_D65_CAT) * XYZ_2_sRGB_MAT; - const mat3 AP1_2_sRGB = (AP1_2_XYZ_MAT * D60_2_D65_CAT) * XYZ_2_sRGB_MAT; - - const mat3 AP0_2_AP1 = AP0_2_XYZ_MAT * XYZ_2_AP1_MAT; - const mat3 AP1_2_AP0 = AP1_2_XYZ_MAT * XYZ_2_AP0_MAT; - - vec3 ColorAP1 = LinearColor * AP0_2_AP1; - float LumaAP1 = dot( ColorAP1, AP1_RGB2Y ); - - vec3 ChromaAP1 = ColorAP1 / LumaAP1; - - float ChromaDistSqr = dot( ChromaAP1 - 1, ChromaAP1 - 1 ); - float ExpandAmount = ( 1 - exp2( -4 * ChromaDistSqr ) ) * ( 1 - exp2( -4 * ExpandGamut * LumaAP1*LumaAP1 ) ); - - const mat3 Wide_2_XYZ_MAT = mat3( - vec3(0.5441691, 0.2395926, 0.1666943), - vec3(0.2394656, 0.7021530, 0.0583814), - vec3(-0.0023439, 0.0361834, 1.0552183) - ); - - const mat3 Wide_2_AP1 = Wide_2_XYZ_MAT * XYZ_2_AP1_MAT; - const mat3 ExpandMat = AP1_2_sRGB * Wide_2_AP1; - - vec3 ColorExpand = ColorAP1 * ExpandMat; - ColorAP1 = mix(ColorAP1, ColorExpand, ExpandAmount); - - const mat3 BlueCorrect = mat3( - vec3(0.9404372683, -0.0183068787, 0.0778696104), - vec3(0.0083786969, 0.8286599939, 0.1629613092), - vec3(0.0005471261, -0.0008833746, 1.0003362486) - ); - const mat3 BlueCorrectInv = mat3( - vec3(1.06318, 0.0233956, -0.0865726), - vec3(-0.0106337, 1.20632, -0.19569), - vec3(-0.000590887, 0.00105248, 0.999538) - ); - - const mat3 BlueCorrectAP1 = (AP1_2_AP0 * BlueCorrect) * AP0_2_AP1; - const mat3 BlueCorrectInvAP1 = (AP1_2_AP0 * BlueCorrectInv) * AP0_2_AP1; - - // Blue correction - ColorAP1 = mix(ColorAP1, ColorAP1 * BlueCorrectAP1, BlueCorrection); - - vec3 ColorAP0 = LinearColor * AP1_2_AP0; - - // "Glow" module constants - const float RRT_GLOW_GAIN = 0.05; - const float RRT_GLOW_MID = 0.08; - - float saturation = rgb_2_saturation(ColorAP0); - float ycIn = rgb_2_yc(ColorAP0); - float s = sigmoid_shaper((saturation - 0.4) * 5.0); - float addedGlow = 1.0 + glow_fwd(ycIn, RRT_GLOW_GAIN * s, RRT_GLOW_MID) * 3; - ColorAP0 *= addedGlow; - - // --- Red modifier --- // - const float RRT_RED_SCALE = 0.99; - const float RRT_RED_PIVOT = 0.22; - const float RRT_RED_HUE = 0.15; - const float RRT_RED_WIDTH = 135.0; - float hue = rgb_2_hue(ColorAP0); - float centeredHue = center_hue(hue, RRT_RED_HUE); - float hueWeight = pow(smoothstep(0.0, 1.0, 1.0 - abs(2.0 * centeredHue / RRT_RED_WIDTH)), 2.0); - - ColorAP0.r += hueWeight * saturation * (RRT_RED_PIVOT - ColorAP0.r) * (1.0 - RRT_RED_SCALE); - - // Use ACEScg primaries as working space - vec3 WorkingColor = ColorAP0 * AP0_2_AP1_MAT * 1.2; - WorkingColor = max(vec3(0.0), WorkingColor) * 1.1; - WorkingColor = mix(vec3(dot(WorkingColor, AP1_RGB2Y)), WorkingColor, 0.96); // Pre desaturate - - const float ToeScale = 1.0 + FilmBlackClip - FilmToe; - const float ShoulderScale = 1.0 + FilmWhiteClip - FilmShoulder; - - const float InMatch = in_Match; - const float OutMatch = Out_Match; - - float ToeMatch = 0.0; - if(FilmToe > 0.8) { - // 0.18 will be on straight segment - ToeMatch = (1.0 - FilmToe - OutMatch) / FilmSlope + log10(InMatch); - } else { - // 0.18 will be on toe segment - // Solve for ToeMatch such that input of InMatch gives output of OutMatch. - const float bt = (OutMatch + FilmBlackClip) / ToeScale - 1.0; - ToeMatch = log10(InMatch) - 0.5 * log((1.0 + bt) / (1.0 - bt)) * (ToeScale / FilmSlope); - } - - float StraightMatch = (1.0 - FilmToe) / FilmSlope - ToeMatch; - float ShoulderMatch = FilmShoulder / FilmSlope - StraightMatch; - - vec3 LogColor = log10(WorkingColor); - vec3 StraightColor = FilmSlope * (LogColor + StraightMatch); - - vec3 ToeColor = (-FilmBlackClip) + (2.0 * ToeScale) / (1.0 + exp((-2.0 * FilmSlope / ToeScale) * (LogColor - ToeMatch))); - vec3 ShoulderColor = (1.0 + FilmWhiteClip) - (2.0 * ShoulderScale) / (1.0 + exp(( 2.0 * FilmSlope / ShoulderScale) * (LogColor - ShoulderMatch))); - - for(int i = 0; i < 1; ++i) { - ToeColor[i] = LogColor[i] < ToeMatch ? ToeColor[i] : StraightColor[i]; - ShoulderColor[i] = LogColor[i] > ShoulderMatch ? ShoulderColor[i] : StraightColor[i]; - } - - vec3 t = clamp((LogColor - ToeMatch) / (ShoulderMatch - ToeMatch), 0.0, 1.0); - t = ShoulderMatch < ToeMatch ? 1.0 - t : t; - t = (3.0 - 2.0 * t) * t * t; - - vec3 ToneColor = mix(ToeColor, ShoulderColor, t); - ToneColor = mix(vec3(dot(ToneColor, AP1_RGB2Y)), ToneColor, 0.93); // Post desaturate - - ToneColor = mix(ToneColor, ToneColor * BlueCorrectInvAP1, BlueCorrection); - - // Returning positive AP1 values - return max(vec3(0.0), ToneColor * AP1_2_sRGB); -} - -vec3 Saturation(vec3 color, ColorCorrection m) { - float grey = dot(color, m.lum); - return grey + m.saturation * (color - grey); -} - -vec3 Vibrance(vec3 color, ColorCorrection m) { - float maxColor = max(color.r, max(color.g, color.b)); - float minColor = min(color.r, min(color.g, color.b)); - - float colorSaturation = maxColor - minColor; - - float grey = dot(color, m.lum); - color = mix(vec3(grey), color, 1.0 + m.vibrance * (1.0 - sign(m.vibrance) * colorSaturation)); - - return color; -} - -vec3 LiftGammaGain(vec3 v, ColorCorrection m) { - vec3 lerpV = clamp(pow(v, m.InvGamma), 0.0, 1.0); - return m.gain * lerpV + m.lift * (1.0 - lerpV); -} - -float LogContrast(float x, const float eps, float logMidpoint, float contrast) { - float logX = log2(x + eps); - float adjX = (logX - logMidpoint) / contrast + logMidpoint; - - return max(exp2(adjX) - eps, 0.0); -} - -vec3 Contrast(vec3 color, ColorCorrection m) { - const float contrastEpsilon = 1e-5; - - vec3 ret; - ret.x = LogContrast(color.x, contrastEpsilon, log2(0.18), m.contrast); - ret.y = LogContrast(color.y, contrastEpsilon, log2(0.18), m.contrast); - ret.z = LogContrast(color.z, contrastEpsilon, log2(0.18), m.contrast); - - return ret; -} - -vec3 srgbToLinear(vec3 srgb) { - return mix( - srgb * 0.07739938080495356, // 1.0 / 12.92 = ~0.07739938080495356 - pow(0.947867 * srgb + 0.0521327, vec3(2.4)), - step(0.04045, srgb) - ); -} - -vec3 linearToSrgb(vec3 linear) { - return mix( - linear * 12.92, - pow(linear, vec3(0.416666666667)) * 1.055 - 0.055, // 1.0 / 2.4 = ~0.416666666667 - step(0.0031308, linear) - ); -} diff --git a/shaders/world1/lib/ACESSPL.glsl b/shaders/world1/lib/ACESSPL.glsl deleted file mode 100644 index 81c4ffd..0000000 --- a/shaders/world1/lib/ACESSPL.glsl +++ /dev/null @@ -1,115 +0,0 @@ -#define log10(x) log(x) / log(10.0) - - -struct SegmentedSplineParams_c5 { - float coefsLow[6]; // coefs for B-spline between minPoint and midPoint (units of log luminance) - float coefsHigh[6]; // coefs for B-spline between midPoint and maxPoint (units of log luminance) - vec2 minPoint; // {luminance, luminance} linear extension below this - vec2 midPoint; // {luminance, luminance} - vec2 maxPoint; // {luminance, luminance} linear extension above this - float slopeLow; // log-log slope of low linear extension - float slopeHigh; // log-log slope of high linear extension -}; - -struct SegmentedSplineParams_c9 { - float coefsLow[10]; // coefs for B-spline between minPoint and midPoint (units of log luminance) - float coefsHigh[10]; // coefs for B-spline between midPoint and maxPoint (units of log luminance) - float slopeLow; // log-log slope of low linear extension - float slopeHigh; // log-log slope of high linear extension -}; - -const mat3 M = mat3( - 0.5, -1.0, 0.5, - -1.0, 1.0, 0.5, - 0.5, 0.0, 0.0 -); - -float segmented_spline_c5_fwd(float x) { - const SegmentedSplineParams_c5 C = SegmentedSplineParams_c5( - float[6] ( -4.0000000000, -4.0000000000, -3.1573765773, -0.4852499958, 1.8477324706, 1.8477324706 ), - float[6] ( -0.7185482425, 2.0810307172, 3.6681241237, 4.0000000000, 4.0000000000, 4.0000000000 ), - vec2(0.18*exp2(-15.0), 0.0001), - vec2(0.18, 4.8), - vec2(0.18*exp2(18.0), 10000.), - 0.0, - 0.0 - ); - - const int N_KNOTS_LOW = 4; - const int N_KNOTS_HIGH = 4; - - // Check for negatives or zero before taking the log. If negative or zero, - // set to ACESMIN.1 - float xCheck = x <= 0 ? exp2(-14.0) : x; - - float logx = log10( xCheck); - float logy; - - if (logx <= log10(C.minPoint.x)) { - logy = logx * C.slopeLow + (log10(C.minPoint.y) - C.slopeLow * log10(C.minPoint.x)); - } else if ((logx > log10(C.minPoint.x)) && (logx < log10(C.midPoint.x))) { - float knot_coord = (N_KNOTS_LOW-1) * (logx-log10(C.minPoint.x))/(log10(C.midPoint.x)-log10(C.minPoint.x)); - int j = int(knot_coord); - float t = knot_coord - float(j); - - vec3 cf = vec3( C.coefsLow[ j], C.coefsLow[ j + 1], C.coefsLow[ j + 2]); - - vec3 monomials = vec3(t * t, t, 1.0); - logy = dot( monomials, M * cf); - } else if ((logx >= log10(C.midPoint.x)) && (logx < log10(C.maxPoint.x))) { - float knot_coord = (N_KNOTS_HIGH - 1) * (logx - log10(C.midPoint.x)) / (log10(C.maxPoint.x) - log10(C.midPoint.x)); - int j = int(knot_coord); - float t = knot_coord - float(j); - - vec3 cf = vec3(C.coefsHigh[j], C.coefsHigh[j + 1], C.coefsHigh[j + 2]); - vec3 monomials = vec3(t * t, t, 1.0); - - logy = dot(monomials, M * cf); - } else { - logy = logx * C.slopeHigh + (log10(C.maxPoint.y) - C.slopeHigh * log10(C.maxPoint.x)); - } - - return pow(10.0, logy); -} - -float segmented_spline_c9_fwd( float x, const SegmentedSplineParams_c9 C, const mat3x2 toningPoints) { - const int N_KNOTS_LOW = 8; - const int N_KNOTS_HIGH = 8; - - // Check for negatives or zero before taking the log. If negative or zero, - // set to OCESMIN. - float xCheck = x <= 0 ? 1e-4 : x; - - vec2 minPoint = toningPoints[0]; - vec2 midPoint = toningPoints[1]; - vec2 maxPoint = toningPoints[2]; - - float logx = log10(xCheck); - float logy; - - if (logx <= log10(minPoint.x)) { - logy = logx * C.slopeLow + (log10(minPoint.y) - C.slopeLow * log10(minPoint.x)); - } else if ((logx > log10(minPoint.x)) && (logx < log10(midPoint.x))) { - float knot_coord = (N_KNOTS_LOW - 1) * (logx - log10(minPoint.x)) / (log10(midPoint.x) - log10(minPoint.x)); - int j = int(knot_coord); - float t = knot_coord - float(j); - - vec3 cf = vec3(C.coefsLow[j], C.coefsLow[j + 1], C.coefsLow[j + 2]); - vec3 monomials = vec3(t * t, t, 1.0); - - logy = dot(monomials, M * cf); - } else if ((logx >= log10(midPoint.x)) && (logx < log10(maxPoint.x))) { - float knot_coord = (N_KNOTS_HIGH - 1) * (logx - log10(midPoint.x)) / (log10(maxPoint.x) - log10(midPoint.x)); - int j = int(knot_coord); - float t = knot_coord - float(j); - - vec3 cf = vec3(C.coefsHigh[j], C.coefsHigh[j + 1], C.coefsHigh[j + 2]); - vec3 monomials = vec3(t * t, t, 1.0); - - logy = dot(monomials, M * cf); - } else { - logy = logx * C.slopeHigh + (log10(maxPoint.y) - C.slopeHigh * log10(maxPoint.x)); - } - - return pow(10.0, logy); -} \ No newline at end of file diff --git a/shaders/world1/lib/ACEST.glsl b/shaders/world1/lib/ACEST.glsl deleted file mode 100644 index f8693d7..0000000 --- a/shaders/world1/lib/ACEST.glsl +++ /dev/null @@ -1,63 +0,0 @@ - -const mat3 sRGB_2_XYZ_MAT = mat3( // Linear sRGB to XYZ color space - vec3(0.4124564, 0.3575761, 0.1804375), - vec3(0.2126729, 0.7151522, 0.0721750), - vec3(0.0193339, 0.1191920, 0.9503041) -); - -const mat3 XYZ_2_sRGB_MAT = mat3( //XYZ to linear sRGB Color Space - vec3(3.2409699419, -1.5373831776, -0.4986107603), - vec3(-0.9692436363, 1.8759675015, 0.0415550574), - vec3(0.0556300797, -0.2039769589, 1.0569715142) -); - -const mat3 D65_2_D60_CAT = mat3( // D65 to D60 White Point - vec3(1.01303, 0.00610531, -0.014971), - vec3(0.00769823, 0.998165, -0.00503203), - vec3(-0.00284131, 0.00468516, 0.924507) -); - -const mat3 D60_2_D65_CAT = mat3( //D60 to D65 White Point - vec3(0.987224, -0.00611327, 0.0159533), - vec3(-0.00759836, 1.00186, 0.00533002), - vec3(0.00307257, -0.00509595, 1.08168) -); - -const mat3 XYZ_2_AP0_MAT = mat3( // XYZ to ACEScg Color Space - vec3(1.0498110175, 0.0000000000,-0.0000974845), - vec3(-0.4959030231, 1.3733130458, 0.0982400361), - vec3(0.0000000000, 0.0000000000, 0.9912520182) -); - -const mat3 AP0_2_XYZ_MAT = mat3( // ACEScg to XYZ Color Space - vec3(0.9525523959, 0.0000000000, 0.0000936786), - vec3(0.3439664498, 0.7281660966,-0.0721325464), - vec3(0.0000000000, 0.0000000000, 1.0088251844) -); - -const mat3 XYZ_2_AP1_MAT = mat3( // XYZ to ACEStoning Color Space - vec3(1.6410233797, -0.3248032942, -0.2364246952), - vec3(-0.6636628587, 1.6153315917, 0.0167563477), - vec3(0.0117218943, -0.0082844420, 0.9883948585) -); - -const mat3 AP1_2_XYZ_MAT = mat3( // ACEStoning to XYZ Color Space - vec3(0.6624541811, 0.1340042065, 0.1561876870), - vec3(0.2722287168, 0.6740817658, 0.0536895174), - vec3(-0.0055746495, 0.0040607335, 1.0103391003) -); - -const mat3 AP0_2_AP1_MAT = mat3( // ACEScg to ACEStoneing Color Space - vec3(1.4514393161, -0.2365107469, -0.2149285693), - vec3(-0.0765537734, 1.1762296998, -0.0996759264), - vec3(0.0083161484, -0.0060324498, 0.9977163014) -); - -const mat3 AP1_2_AP0_MAT = mat3( // ACEStoning to ACEScg Color Space - vec3(0.6954522414, 0.1406786965, 0.1638690622), - vec3(0.0447945634, 0.8596711185, 0.0955343182), - vec3(-0.0055258826, 0.0040252103, 1.0015006723) -); - -const vec3 AP1_RGB2Y = vec3(0.2722287168, 0.6740817658, 0.0536895174); // Desaturation Coeff -const mat3 sRGB_2_AP0 = (sRGB_2_XYZ_MAT * D65_2_D60_CAT) * XYZ_2_AP0_MAT; \ No newline at end of file diff --git a/shaders/world1/lib/ROBOBO_sky.glsl b/shaders/world1/lib/ROBOBO_sky.glsl deleted file mode 100644 index ef8fcfd..0000000 --- a/shaders/world1/lib/ROBOBO_sky.glsl +++ /dev/null @@ -1,157 +0,0 @@ -const float sunAngularSize = 0.533333; -const float moonAngularSize = 0.516667; - -//Sky coefficients and heights - -#define airNumberDensity 2.5035422e25 -#define ozoneConcentrationPeak 8e-6 -const float ozoneNumberDensity = airNumberDensity * ozoneConcentrationPeak; -#define ozoneCrossSection vec3(4.51103766177301e-21, 3.2854797958699e-21, 1.96774621921165e-22) - -#define sky_planetRadius 6731e3 - -#define sky_atmosphereHeight 110e3 -#define sky_scaleHeights vec2(8.0e3, 1.2e3) - -#define sky_mieg 0.80 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define sky_coefficientRayleighR 5.8 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] -#define sky_coefficientRayleighG 1.35 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] -#define sky_coefficientRayleighB 3.31 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] - -#define sky_coefficientRayleigh vec3(sky_coefficientRayleighR*1e-6, sky_coefficientRayleighG*1e-5, sky_coefficientRayleighB*1e-5) - - -#define sky_coefficientMieR 3.0 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] -#define sky_coefficientMieG 3.0 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] -#define sky_coefficientMieB 3.0 //[0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 3.1 3.2 3.3 3.4 3.5 3.6 3.7 3.8 3.9 4.0 4.1 4.2 4.3 4.4 4.5 4.6 4.7 4.8 4.9 5.0 5.1 5.2 5.3 5.4 5.5 5.6 5.7 5.8 5.9 6.0 6.1 6.2 6.3 6.4 6.5 6.6 6.7 6.8 6.9 7.0 7.1 7.2 7.3 7.4 7.5 7.6 7.7 7.8 7.9 8.0 8.1 8.2 8.3 8.4 8.5 8.6 8.7 8.8 8.9 9.0 9.1 9.2 9.3 9.4 9.5 9.6 9.7 9.8 9.9 10.0 ] - -#define sky_coefficientMie vec3(sky_coefficientMieR*1e-6, sky_coefficientMieG*1e-6, sky_coefficientMieB*1e-6) // Should be >= 2e-6 -const vec3 sky_coefficientOzone = (ozoneCrossSection * (ozoneNumberDensity * 1.e-6)); // ozone cross section * (ozone number density * (cm ^ 3)) - -const vec2 sky_inverseScaleHeights = 1.0 / sky_scaleHeights; -const vec2 sky_scaledPlanetRadius = sky_planetRadius * sky_inverseScaleHeights; -const float sky_atmosphereRadius = sky_planetRadius + sky_atmosphereHeight; -const float sky_atmosphereRadiusSquared = sky_atmosphereRadius * sky_atmosphereRadius; - -#define sky_coefficientsScattering mat2x3(sky_coefficientRayleigh, sky_coefficientMie) -const mat3 sky_coefficientsAttenuation = mat3(sky_coefficientRayleigh, sky_coefficientMie * 1.11, sky_coefficientOzone); // commonly called the extinction coefficient - -#define sun_illuminance 128000.0 //[10000.0 20000.0 30000.0 40000.0 50000.0 60000.0 70000.0 80000.0 90000.0 100000.0 110000.0 120000.0 130000.0 140000.0 160000.0] -#define moon_illuminance 60.0 //[0.0 10.0 20.0 30.0 40.0 50.0 60.0 70.0 80.0 90.0 100.0 1000.0 10000.0 100000.0] - -#define sunColorR 1.0 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define sunColorG 0.9 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define sunColorB 0.81 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] - -#define sunColorBase (vec3(sunColorR,sunColorG,sunColorB) * sun_illuminance) -//#define sunColorBase blackbody(5778) * sun_illuminance -#define moonColorR 1.0 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define moonColorG 0.9 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -#define moonColorB 0.81 //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] - -#define moonColorBase (vec3(moonColorR, moonColorG, moonColorB) * moon_illuminance ) //Fake Purkinje effect - -float sky_rayleighPhase(float cosTheta) { - const vec2 mul_add = vec2(0.1, 0.28) * rPI; - return cosTheta * mul_add.x + mul_add.y; // optimized version from [Elek09], divided by 4 pi for energy conservation -} - -float sky_miePhase(float cosTheta, const float g) { - float gg = g * g; - return (gg * -0.25 + 0.25) * rPI * pow(-(2.0 * g) * cosTheta + (gg + 1.0), -1.5); -} - -vec2 sky_phase(float cosTheta, const float g) { - return vec2(sky_rayleighPhase(cosTheta), sky_miePhase(cosTheta, g)); -} - -vec3 sky_density(float centerDistance) { - vec2 rayleighMie = exp(centerDistance * -sky_inverseScaleHeights + sky_scaledPlanetRadius); - - // Ozone distribution curve by Sergeant Sarcasm - https://www.desmos.com/calculator/j0wozszdwa - float ozone = exp(-max(0.0, (35000.0 - centerDistance) - sky_planetRadius) * (1.0 / 5000.0)) - * exp(-max(0.0, (centerDistance - 35000.0) - sky_planetRadius) * (1.0 / 15000.0)); - return vec3(rayleighMie, ozone); -} - -vec3 sky_airmass(vec3 position, vec3 direction, float rayLength, const float steps) { - float stepSize = rayLength * (1.0 / steps); - vec3 increment = direction * stepSize; - position += increment * 0.5; - - vec3 airmass = vec3(0.0); - for (int i = 0; i < steps; ++i, position += increment) { - airmass += sky_density(length(position)); - } - - return airmass * stepSize; -} -vec3 sky_airmass(vec3 position, vec3 direction, const float steps) { - float rayLength = dot(position, direction); - rayLength = rayLength * rayLength + sky_atmosphereRadiusSquared - dot(position, position); - if (rayLength < 0.0) return vec3(0.0); - rayLength = sqrt(rayLength) - dot(position, direction); - - return sky_airmass(position, direction, rayLength, steps); -} - -vec3 sky_opticalDepth(vec3 position, vec3 direction, float rayLength, const float steps) { - return sky_coefficientsAttenuation * sky_airmass(position, direction, rayLength, steps); -} -vec3 sky_opticalDepth(vec3 position, vec3 direction, const float steps) { - return sky_coefficientsAttenuation * sky_airmass(position, direction, steps); -} - -vec3 sky_transmittance(vec3 position, vec3 direction, const float steps) { - return exp2(-sky_opticalDepth(position, direction, steps) * rLOG2); -} - - - -vec3 calculateAtmosphere(vec3 background, vec3 viewVector, vec3 upVector, vec3 sunVector, vec3 moonVector, out vec2 pid, out vec3 transmittance, const int iSteps, float noise) { - const int jSteps = 4; - - vec3 viewPosition = (sky_planetRadius + eyeAltitude) * upVector; - - vec2 aid = rsi(viewPosition, viewVector, sky_atmosphereRadius); - if (aid.y < 0.0) {transmittance = vec3(1.0); return vec3(0.0);} - - pid = rsi(viewPosition, viewVector, sky_planetRadius * 0.998); - bool planetIntersected = pid.y >= 0.0; - - vec2 sd = vec2((planetIntersected && pid.x < 0.0) ? pid.y : max(aid.x, 0.0), (planetIntersected && pid.x > 0.0) ? pid.x : aid.y); - - float stepSize = (sd.y - sd.x) * (1.0 / iSteps); - vec3 increment = viewVector * stepSize; - vec3 position = viewVector * sd.x + viewPosition; - position += increment * (0.34*noise); - vec2 phaseSun = sky_phase(dot(viewVector, sunVector ), sky_mieg); - vec2 phaseMoon = sky_phase(dot(viewVector, moonVector), sky_mieg); - - vec3 scatteringSun = vec3(0.0); - vec3 scatteringMoon = vec3(0.0); - vec3 scatteringAmbient = vec3(0.0); - transmittance = vec3(1.0); - - for (int i = 0; i < iSteps; ++i, position += increment) { - vec3 density = sky_density(length(position)); - if (density.y > 1e35) break; - vec3 stepAirmass = density * stepSize; - vec3 stepOpticalDepth = sky_coefficientsAttenuation * stepAirmass; - - vec3 stepTransmittance = exp2(-stepOpticalDepth * rLOG2); - vec3 stepTransmittedFraction = clamp01((stepTransmittance - 1.0) / -stepOpticalDepth); - vec3 stepScatteringVisible = transmittance * stepTransmittedFraction; - - scatteringSun += sky_coefficientsScattering * (stepAirmass.xy * phaseSun ) * stepScatteringVisible * sky_transmittance(position, sunVector, jSteps); - scatteringMoon += sky_coefficientsScattering * (stepAirmass.xy * phaseMoon) * stepScatteringVisible * sky_transmittance(position, moonVector, jSteps); - // Nice way to fake multiple scattering. - scatteringAmbient += sky_coefficientsScattering * stepAirmass.xy * stepScatteringVisible; - - transmittance *= stepTransmittance; - } - - vec3 scattering = scatteringSun * sunColorBase + scatteringAmbient * background + scatteringMoon*moonColorBase; - - return scattering; -} diff --git a/shaders/world1/lib/Shadow_Params.glsl b/shaders/world1/lib/Shadow_Params.glsl deleted file mode 100644 index 7556167..0000000 --- a/shaders/world1/lib/Shadow_Params.glsl +++ /dev/null @@ -1,22 +0,0 @@ -const float ambientOcclusionLevel = 0.3; //[0.0 0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 1.0 ] -const float sunPathRotation = -35; //[-90 -89 -88 -87 -86 -85 -84 -83 -82 -81 -80 -79 -78 -77 -76 -75 -74 -73 -72 -71 -70 -69 -68 -67 -66 -65 -64 -63 -62 -61 -60 -59 -58 -57 -56 -55 -54 -53 -52 -51 -50 -49 -48 -47 -46 -45 -44 -43 -42 -41 -40 -39 -38 -37 -36 -35 -34 -33 -32 -31 -30 -29 -28 -27 -26 -25 -24 -23 -22 -21 -20 -19 -18 -17 -16 -15 -14 -13 -12 -11 -10 -9 -8 -7 -6 -5 -4 -3 -2 -1 0 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 ] - -const int shadowMapResolution = 3172; //Will probably crash at 16 384 [512 768 1024 1536 2048 3172 4096 8192 16384] -const float shadowDistance = 150; //[32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 ] Not linear at all when shadowDistanceRenderMul is set to -1.0, 175.0 is enough for 40 render distance -const float shadowDistanceRenderMul = -1.0; //[-1.0 1.0] Can help to increase shadow draw distance when set to -1.0, at the cost of performance - - -const float k = 1.8; -const float d0 = 0.04; -const float d1 = 0.61; -float a = exp(d0); -float b = (exp(d1)-a)*shadowDistance/128.0; - -vec4 BiasShadowProjection(in vec4 projectedShadowSpacePosition) { - float distortFactor = log(length(projectedShadowSpacePosition.xy)*b+a)*k; - projectedShadowSpacePosition.xy /= distortFactor; - return projectedShadowSpacePosition; -} -float calcDistort(vec2 worldpos){ - return 1.0/(log(length(worldpos)*b+a)*k); -} diff --git a/shaders/world1/lib/clouds.glsl b/shaders/world1/lib/clouds.glsl deleted file mode 100644 index abd35ef..0000000 --- a/shaders/world1/lib/clouds.glsl +++ /dev/null @@ -1,16 +0,0 @@ -vec3 cloud2D(vec3 fragpos,vec3 col){ - vec3 wpos = fragpos; - float wind = frameTimeCounter/200.; - vec2 intersection = ((2000.0-cameraPosition.y)*wpos.xz*inversesqrt(wpos.y+cameraPosition.y/512.-50./512.) + cameraPosition.xz+wind)/40000.; - - - float phase = pow(clamp(dot(fragpos,sunVec),0.,1.),2.)*0.5+0.5; - - float fbm = clamp((texture2D(noisetex,intersection*vec2(1.,1.5)).a + texture2D(noisetex,intersection*vec2(2.,7.)+wind*0.4).a/2.)-0.5*(1.0-rainStrength),0.,1.) ; - - - - - return mix(col,6.*(vec3(0.9,1.2,1.5)*skyIntensityNight*0.02*(1.0-rainStrength*0.9)+17.*phase*nsunColor*skyIntensity*0.7*(1.0-rainStrength*0.9)),0.0*(fbm*fbm)*(fbm*fbm)*(fbm*clamp(wpos.y*0.9,0.,1.))); - -} \ No newline at end of file diff --git a/shaders/world1/lib/color_dither.glsl b/shaders/world1/lib/color_dither.glsl deleted file mode 100644 index 73c4960..0000000 --- a/shaders/world1/lib/color_dither.glsl +++ /dev/null @@ -1,46 +0,0 @@ -//using white noise for color dithering : gives a somewhat more "filmic" look when noise is visible -float nrand( vec2 n ) -{ - return fract(sin(dot(n.xy, vec2(12.9898, 78.233)))* 43758.5453); -} - -float triangWhiteNoise( vec2 n ) -{ - - float t = fract( frameTimeCounter ); - float rnd = nrand( n + 0.07*t ); - - float center = rnd*2.0-1.0; - rnd = center*inversesqrt(abs(center)); - rnd = max(-1.0,rnd); - return rnd-sign(center); -} - -vec3 fp10Dither(vec3 color,vec2 tc01){ - float dither = triangWhiteNoise(tc01); - const vec3 mantissaBits = vec3(6.,6.,5.); - vec3 exponent = floor(log2(color)); - return color + dither*exp2(-mantissaBits)*exp2(exponent); -} - -vec3 fp16Dither(vec3 color,vec2 tc01){ - float dither = triangWhiteNoise(tc01); - const vec3 mantissaBits = vec3(10.); - vec3 exponent = floor(log2(color)); - return color + dither*exp2(-mantissaBits)*exp2(exponent); -} - -vec3 int8Dither(vec3 color,vec2 tc01){ - float dither = triangWhiteNoise(tc01); - return color + dither*exp2(-8.0); -} - -vec3 int10Dither(vec3 color,vec2 tc01){ - float dither = triangWhiteNoise(tc01); - return color + dither*exp2(-10.0); -} - -vec3 int16Dither(vec3 color,vec2 tc01){ - float dither = triangWhiteNoise(tc01); - return color + dither*exp2(-16.0); -} \ No newline at end of file diff --git a/shaders/world1/lib/color_transforms.glsl b/shaders/world1/lib/color_transforms.glsl deleted file mode 100644 index 4813ff4..0000000 --- a/shaders/world1/lib/color_transforms.glsl +++ /dev/null @@ -1,131 +0,0 @@ -//faster and actually more precise than pow 2.2 -vec3 toLinear(vec3 sRGB){ - return sRGB * (sRGB * (sRGB * 0.305306011 + 0.682171111) + 0.012522878); -} - -float luma(vec3 color) { - return dot(color,vec3(0.299, 0.587, 0.114)); -} -vec3 ToneMap_Hejl2015(in vec3 hdr) -{ - vec4 vh = vec4(hdr*0.85, 3.0); //0 - vec4 va = (1.75 * vh) + 0.05; //0.05 - vec4 vf = ((vh * va + 0.004f) / ((vh * (va + 0.55f) + 0.0491f))) - 0.0821f+0.000633604888; //((0+0.004)/((0*(0.05+0.55)+0.0491)))-0.0821 - return vf.xyz / vf.www; -} -const mat3 ACESInputMat = -mat3(0.59719, 0.35458, 0.04823, - 0.07600, 0.90834, 0.01566, - 0.02840, 0.13383, 0.83777 -); - -// ODT_SAT => XYZ => D60_2_D65 => sRGB -const mat3 ACESOutputMat = -mat3( 1.60475, -0.53108, -0.07367, - -0.10208, 1.10813, -0.00605, - -0.00327, -0.07276, 1.07602 -); -vec3 LinearTosRGB(in vec3 color) -{ - vec3 x = color * 12.92f; - vec3 y = 1.055f * pow(clamp(color,0.0,1.0), vec3(1.0f / 2.4f)) - 0.055f; - - vec3 clr = color; - clr.r = color.r < 0.0031308f ? x.r : y.r; - clr.g = color.g < 0.0031308f ? x.g : y.g; - clr.b = color.b < 0.0031308f ? x.b : y.b; - - return clr; -} -vec3 HableTonemap(vec3 linearColor) { - // A = shoulder strength - const float A = 0.22; - // B = linear strength - const float B = 0.3; - // C = linear angle - const float C = 0.1; - // D = toe strength - const float D = 0.4; - // E = toe numerator - const float E = 0.025; - // F = toe denominator - const float F = 0.30; - // Note: E / F = toe angle - // linearWhite = linear white point value - - vec3 x = linearColor*2.8; - vec3 color = ((x * (A * x + C * B) + D * E) / (x * (A * x + B) + D * F)) - E / F; - - const float W = 11.2; - const float white = ((W * (A * W + C * B) + D * E) / (W * (A * W + B) + D * F)) - E / F; - - return color / white; -} - -vec3 reinhard(vec3 x){ -x *= 1.66; -return x/(1.0+x); -} -vec3 ACESFilm( vec3 x ) -{ - x *= 0.23/0.267; - float a = 2.51f; - float b = 0.03f; - float c = 2.43f; - float d = 0.59f; - float e = 0.14f; - return (x*(a*x+b))/(x*(c*x+d)+e); -} - -// From https://www.shadertoy.com/view/WdjSW3 -vec3 Tonemap_Lottes(vec3 x) { - // Lottes 2016, "Advanced Techniques and Optimization of HDR Color Pipelines" - const float a = 1.7; - const float d = 0.92; - const float hdrMax = 3.0; - const float midIn = 0.2475; - const float midOut = 0.267; - - // Can be precomputed - const float b = - (-pow(midIn, a) + pow(hdrMax, a) * midOut) / - ((pow(hdrMax, a * d) - pow(midIn, a * d)) * midOut); - const float c = - (pow(hdrMax, a * d) * pow(midIn, a) - pow(hdrMax, a) * pow(midIn, a * d) * midOut) / - ((pow(hdrMax, a * d) - pow(midIn, a * d)) * midOut); - - return pow(x,vec3(a)) / (pow(x, vec3(a * d)) * b + c); -} -// From https://www.shadertoy.com/view/WdjSW3 -vec3 Tonemap_Uchimura(vec3 x, float P, float a, float m, float l, float c, float b) { - // Uchimura 2017, "HDR theory and practice" - // Math: https://www.desmos.com/calculator/gslcdxvipg - // Source: https://www.slideshare.net/nikuque/hdr-theory-and-practicce-jp - float l0 = ((P - m) * l) / a; - float L0 = m - m / a; - float L1 = m + (1.0 - m) / a; - float S0 = m + l0; - float S1 = m + a * l0; - float C2 = (a * P) / (P - S1); - float CP = -C2 / P; - - vec3 w0 = 1.0 - smoothstep(0.0, m, x); - vec3 w2 = step(m + l0, x); - vec3 w1 = 1.0 - w0 - w2; - - vec3 T = m * pow(x / m, vec3(c)) + b; - vec3 S = P - (P - S1) * exp(CP * (x - S0)); - vec3 L = m + a * (x - m); - - return T * w0 + L * w1 + S * w2; -} - -vec3 Tonemap_Uchimura(vec3 x) { - const float P = 1.0; // max display brightness - const float a = 1.0; // contrast - const float m = 0.22; // linear section start - const float l = 0.4; // linear section length - const float c = 1.33; // black - const float b = 0.0; // pedestal - return Tonemap_Uchimura(x, P, a, m, l, c, b); -} diff --git a/shaders/world1/lib/composite3.fsh b/shaders/world1/lib/composite3.fsh deleted file mode 100644 index cb2a2ba..0000000 --- a/shaders/world1/lib/composite3.fsh +++ /dev/null @@ -1,78 +0,0 @@ -#version 120 -//Horizontal bilateral blur for volumetric fog + Forward rendered objects + Draw volumetric fog -#extension GL_EXT_gpu_shader4 : enable - - - -varying vec2 texcoord; -flat varying vec3 zMults; -uniform sampler2D depthtex0; -uniform sampler2D colortex3; -uniform sampler2D colortex2; -uniform sampler2D colortex0; - -uniform int frameCounter; -uniform float far; -uniform float near; -uniform int isEyeInWater; - -uniform vec2 texelSize; -float ld(float depth) { - return 1.0 / (zMults.y - depth * zMults.z); // (-depth * (far - near)) = (2.0 * near)/ld - far - near -} - -vec4 BilateralUpscale(sampler2D tex, sampler2D depth,vec2 coord,float frDepth){ - vec4 vl = vec4(0.0); - float sum = 0.0; - mat3x3 weights; - ivec2 posD = ivec2(coord/2.0)*2; - ivec2 posVl = ivec2(coord/2.0); - float dz = zMults.x; - ivec2 pos = (ivec2(gl_FragCoord.xy+frameCounter) % 3 ); - //pos = ivec2(1,-1); - - ivec2 tcDepth = posD + ivec2(-2,-2) + pos*2; - float dsample = ld(texelFetch2D(depth,tcDepth,0).r); - float w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(-1)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(-2,0) + pos*2; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(-1,0)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(0) + pos*2; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(0)+pos,0)*w; - sum += w; - - tcDepth = posD + ivec2(0,-2) + pos*2; - dsample = ld(texelFetch2D(depth,tcDepth,0).r); - w = abs(dsample-frDepth) < dz ? 1.0 : 1e-5; - vl += texelFetch2D(tex,posVl+ivec2(0,-1)+pos,0)*w; - sum += w; - - return vl/sum; -} - -void main() { -/* DRAWBUFFERS:0 */ - - //3x3 bilateral upscale from half resolution - float frDepth = ld(texture2D(depthtex0,texcoord).x); - vec4 vl = BilateralUpscale(colortex0,depthtex0,gl_FragCoord.xy,frDepth); - - vec3 color = texture2D(colortex3,texcoord).rgb; - vec4 transparencies = texture2D(colortex2,texcoord); - color = color*(1.0-transparencies.a)+transparencies.rgb*10.; - - color *= vl.a; - color += vl.rgb; - - gl_FragData[0].rgb = clamp(color,6.11*1e-5,65000.0); - - gl_FragData[0].a = vl.a; -} diff --git a/shaders/world1/lib/projections.glsl b/shaders/world1/lib/projections.glsl deleted file mode 100644 index 72ab381..0000000 --- a/shaders/world1/lib/projections.glsl +++ /dev/null @@ -1,55 +0,0 @@ -uniform mat4 gbufferProjection; -uniform mat4 gbufferProjectionInverse; -uniform mat4 gbufferPreviousProjection; -uniform mat4 gbufferModelViewInverse; -uniform mat4 gbufferModelView; -uniform mat4 shadowModelView; -uniform mat4 shadowProjection; - -uniform vec3 cameraPosition; - - -#define diagonal3(m) vec3((m)[0].x, (m)[1].y, m[2].z) -#define projMAD(m, v) (diagonal3(m) * (v) + (m)[3].xyz) - -vec3 toClipSpace3(vec3 viewSpacePosition) { - return projMAD(gbufferProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; -} - -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; -} - -vec3 toScreenSpaceVector(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 normalize(fragposition.xyz); -} - -vec3 toWorldSpace(vec3 p3){ - p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; - return p3; -} - -vec3 toWorldSpaceCamera(vec3 p3){ - p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; - return p3 + cameraPosition; -} - -vec3 toShadowSpace(vec3 p3){ - p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; - p3 = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; - return p3; -} - -vec3 toShadowSpaceProjected(vec3 p3){ - p3 = mat3(gbufferModelViewInverse) * p3 + gbufferModelViewInverse[3].xyz; - p3 = mat3(shadowModelView) * p3 + shadowModelView[3].xyz; - p3 = diagonal3(shadowProjection) * p3 + shadowProjection[3].xyz; - - return p3; -} diff --git a/shaders/world1/lib/sky_gradient.glsl b/shaders/world1/lib/sky_gradient.glsl deleted file mode 100644 index 559faf3..0000000 --- a/shaders/world1/lib/sky_gradient.glsl +++ /dev/null @@ -1,84 +0,0 @@ -#define DRAW_SUN //if not using custom sky -#define SKY_BRIGHTNESS_DAY 1.0 //[0.0 0.5 0.75 1. 1.2 1.4 1.6 1.8 2.0] -#define SKY_BRIGHTNESS_NIGHT 1.0 //[0.0 0.5 0.75 1. 1.2 1.4 1.6 1.8 2.0] -#define ffstep(x,y) clamp((y - x) * 1e35,0.0,1.0) -vec3 drawSun(float cosY, float sunInt,vec3 nsunlight,vec3 inColor){ - return inColor+nsunlight/0.0008821203*pow(smoothstep(cos(0.0093084168595*3.2),cos(0.0093084168595*1.8),cosY),3.)*0.62; -} -const float pi = 3.141592653589793238462643383279502884197169; -vec2 sphereToCarte(vec3 dir) { - float lonlat = atan(-dir.x, -dir.z); - return vec2(lonlat * (0.5/pi) +0.5,0.5*dir.y+0.5); -} -vec3 skyFromTex(vec3 pos,sampler2D sampler){ - vec2 p = sphereToCarte(pos); - return texture2D(sampler,p*texelSize*256.+vec2(18.5,1.5)*texelSize).rgb; -} -float w0(float a) -{ - return (1.0/6.0)*(a*(a*(-a + 3.0) - 3.0) + 1.0); -} - -float w1(float a) -{ - return (1.0/6.0)*(a*a*(3.0*a - 6.0) + 4.0); -} - -float w2(float a) -{ - return (1.0/6.0)*(a*(a*(-3.0*a + 3.0) + 3.0) + 1.0); -} - -float w3(float a) -{ - return (1.0/6.0)*(a*a*a); -} - -float g0(float a) -{ - return w0(a) + w1(a); -} - -float g1(float a) -{ - return w2(a) + w3(a); -} - -float h0(float a) -{ - return -1.0 + w1(a) / (w0(a) + w1(a)); -} - -float h1(float a) -{ - return 1.0 + w3(a) / (w2(a) + w3(a)); -} - -vec4 texture2D_bicubic(sampler2D tex, vec2 uv) -{ - vec4 texelSize = vec4(texelSize,1.0/texelSize); - uv = uv*texelSize.zw; - vec2 iuv = floor( uv ); - vec2 fuv = fract( uv ); - - float g0x = g0(fuv.x); - float g1x = g1(fuv.x); - float h0x = h0(fuv.x); - float h1x = h1(fuv.x); - float h0y = h0(fuv.y); - float h1y = h1(fuv.y); - - vec2 p0 = (vec2(iuv.x + h0x, iuv.y + h0y) - 0.5) * texelSize.xy; - vec2 p1 = (vec2(iuv.x + h1x, iuv.y + h0y) - 0.5) * texelSize.xy; - vec2 p2 = (vec2(iuv.x + h0x, iuv.y + h1y) - 0.5) * texelSize.xy; - vec2 p3 = (vec2(iuv.x + h1x, iuv.y + h1y) - 0.5) * texelSize.xy; - - return g0(fuv.y) * (g0x * texture2D(tex, p0) + - g1x * texture2D(tex, p1)) + - g1(fuv.y) * (g0x * texture2D(tex, p2) + - g1x * texture2D(tex, p3)); -} -vec4 skyCloudsFromTex(vec3 pos,sampler2D sampler){ - vec2 p = sphereToCarte(pos); - return texture2D(sampler,p*texelSize*256.+vec2(18.5+257.,1.5)*texelSize); -} diff --git a/shaders/world1/lib/specular.glsl b/shaders/world1/lib/specular.glsl deleted file mode 100644 index 2ee4cdb..0000000 --- a/shaders/world1/lib/specular.glsl +++ /dev/null @@ -1,334 +0,0 @@ -//#define Specular_Reflections // reflections on blocks. REQUIRES A PBR RESOURCEPACK. -#define Screen_Space_Reflections // toggle screenspace reflections. if you want normal performance but still want a bit of shiny, the sun reflection stays on when this is turned off. -#define Sky_reflection // just in case you dont want it i guess -// #define Rough_reflections // turns the roughness GGXVNDF ON. sizable performance impact, and introduces alot of noise. - -#define Sun_specular_Strength 3 // increase for more sparkles [1 2 3 4 5 6 7 8 9 10] -#define reflection_quality 30 // adjust the quality of the screenspace reflections. [6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 25 30 35 40 45 50 55 60 65 70 75 80 85 90 95 100 ] -#define Roughness_Threshold 1.5 // using a curve on the roughness, make the reflections more or less visible on rough surfaces. good for hiding noise on rough materials [1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 2.9 3.0 ] - -// #define SCREENSHOT_MODE // go render mode and accumulate frames for as long as you want for max image quality. - -uniform sampler2D gaux1; -uniform int framemod8; - -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.); - - -// sun specular stuff -float square(float x){ - return x*x; -} -float g(float NdotL, float roughness){ - float alpha = square(max(roughness, 0.02)); - return 2.0 * NdotL / (NdotL + sqrt(square(alpha) + (1.0 - square(alpha)) * square(NdotL))); -} -float gSimple(float dp, float roughness){ - float k = roughness + 1; - k *= k/8.0; - return dp / (dp * (1.0-k) + k); -} -vec3 GGX2(vec3 n, vec3 v, vec3 l, float r, vec3 F0) { - - float roughness = r; // when roughness is zero it fucks up - - float alpha = square(roughness) + 1e-4; - - - vec3 h = normalize(l + v); - - float dotLH = clamp(dot(h,l),0.,1.); - float dotNH = clamp(dot(h,n),0.,1.); - float dotNL = clamp(dot(n,l),0.,1.); - float dotNV = clamp(dot(n,v),0.,1.); - float dotVH = clamp(dot(h,v),0.,1.); - - - float D = alpha / (3.141592653589793*square(square(dotNH) * (alpha - 1.0) + 1.0)); - float G = gSimple(dotNV, roughness) * gSimple(dotNL, roughness); - vec3 F = F0 + (1. - F0) * exp2((-5.55473*dotVH-6.98316)*dotVH); - - return dotNL * F * (G * D / (4 * dotNV * dotNL + 1e-7)); -} - - -// other shit -float invLinZ (float lindepth){ - return -((2.0*near/lindepth)-far-near)/(far-near); -} -vec3 toClipSpace3(vec3 viewSpacePosition) { - return projMAD(gbufferProjection, viewSpacePosition) / -viewSpacePosition.z * 0.5 + 0.5; -} -float linZ(float depth) { - return (2.0 * near) / (far + near - depth * (far - near)); - // l = (2*n)/(f+n-d(f-n)) - // f+n-d(f-n) = 2n/l - // -d(f-n) = ((2n/l)-f-n) - // d = -((2n/l)-f-n)/(f-n) - -} -void frisvad(in vec3 n, out vec3 f, out vec3 r){ - if(n.z < -0.9) { - f = vec3(0.,-1,0); - r = vec3(-1, 0, 0); - } else { - float a = 1./(1.+n.z); - float b = -n.x*n.y*a; - f = vec3(1. - n.x*n.x*a, b, -n.x) ; - r = vec3(b, 1. - n.y*n.y*a , -n.y); - } -} -mat3 CoordBase(vec3 n){ - vec3 x,y; - frisvad(n,x,y); - return mat3(x,y,n); -} -float unpackRoughness(float x){ - float r = 1.0 - x; - return clamp(r*r,0,1); -} -vec2 R2_samples_spec(int n){ - vec2 alpha = vec2(0.75487765, 0.56984026); - return fract(alpha * n); -} - -vec3 sampleGGXVNDF(vec3 V_, float alpha_x, float alpha_y, float U1, float U2, bool ishand){ - // stretch view - vec3 V = normalize(vec3(alpha_x * V_.x, alpha_y * V_.y, V_.z)); - // orthonormal basis - vec3 T1 = (V.z < 0.9999) ? normalize(cross(V, vec3(0,0,1))) : vec3(1,0,0); - vec3 T2 = cross(T1, V); - // sample point with polar coordinates (r, phi) - float a = 1.0 / (1.0 + V.z); - float r = sqrt(U1); - float phi = (U2 -near) ? - (-near -position.z) / dir.z : far*sqrt(3.); - vec3 direction = normalize(toClipSpace3(position+dir*rayLength)-clipPosition); //convert to clip space - direction.xy = normalize(direction.xy); - - //get at which length the ray intersects with the edge of the screen - vec3 maxLengths = (step(0.,direction)-clipPosition) / direction; - float mult = min(min(maxLengths.x,maxLengths.y),maxLengths.z); - - vec3 stepv = direction * mult / quality*vec3(1,1,1.0); - // if(hand) dither *= 0.1 ; - vec3 spos = clipPosition*vec3(1,1,1.0) + stepv*dither; - - float minZ = spos.z+stepv.z; - float maxZ = spos.z+stepv.z; - - spos.xy += TAA_Offset*texelSize*0.5/1; - - // for (int i = 0; i <= int(quality); i++) { - - // // decode depth buffer - // vec2 testthing = hand ? spos.xy*texelSize : spos.xy/texelSize/4.0; // fix for ssr on hand - - // float sp = sqrt(texelFetch2D(gaux1,ivec2(spos.xy/texelSize/4.0),0).w/65000.0); - - // sp = invLinZ(sp); - - // if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ) ) return vec3(spos.xy/1,sp); - - // spos += stepv; - - // //small bias - // float biasamount = 0.00015; - // if(hand) biasamount = 0.01; - // // minZ = maxZ-clamp(fres*0.0004 ,0.00004,0.0004) / ld(spos.z); - // minZ = maxZ-biasamount / ld(spos.z); - - // maxZ += stepv.z; - - // } - for (int i = 0; i < int(quality+1); i++) { - - vec2 testthing = hand ? spos.xy : spos.xy/texelSize; // fix for ssr on hand - float sp=texelFetch2D(depthtex1,ivec2(testthing),0).x; - - if(sp <= max(maxZ,minZ) && sp >= min(maxZ,minZ)){ - return vec3(spos.xy,sp); - - } - spos += stepv; - //small bias - float biasamount = 0.00015; - if(hand) biasamount = 0.01; - // minZ = maxZ-clamp(fres*0.0004 ,0.00004,0.0004) / ld(spos.z); - minZ = maxZ-biasamount / ld(spos.z); - maxZ += stepv.z; - } - - return vec3(1.1); -} - -vec3 mix_vec3(vec3 X, vec3 Y, float A){ - return X * (1.0 - A) + Y * A; -} -float mix_float(float X, float Y, float A){ - return X * (1.0 - A) + Y * A; -} - - -// vec3 gaussblur( vec4 colorout, vec2 texcoord ) -// { -// float Pi = 6.28318530718; // Pi*2 - -// // GAUSSIAN BLUR SETTINGS {{{ -// float Directions = 16.0; // BLUR DIRECTIONS (Default 16.0 - More is better but slower) -// float Quality = 3.0; // BLUR QUALITY (Default 4.0 - More is better but slower) -// float Size = 50.0; // BLUR SIZE (Radius) -// // GAUSSIAN BLUR SETTINGS }}} - -// vec2 Radius = Size/vec2(1920,1080); - -// // Normalized pixel coordinates (from 0 to 1) -// vec2 uv = texcoord/vec2(1920,1080); -// // Pixel colour -// vec4 Color = texture2D(colortex3, texcoord); - -// // Blur calculations -// for( float d=0.0; d 0.01; - - if (Roughness_Threshold == 1.0){ hasReflections = roughness > -1; NdotV = -1.0;} - - - vec3 SunReflection = diffuse * GGX2(normal, -np3, sunPos, roughness, f0) * sunCol; - - vec4 Reflections = vec4(0.0); - #ifdef Screen_Space_Reflections - if ( hasReflections && NdotV <= 0.0) { // Skip SSR if ray contribution is low - #ifdef SCREENSHOT_MODE - float rayQuality = reflection_quality; - #else - float rayQuality = mix_float(reflection_quality,0.0,sqrt(roughness)); // Scale quality with ray contribution - #endif - vec3 rtPos = rayTraceSpeculars( mat3(gbufferModelView) * L,fragpos.xyz, noise.b, rayQuality, hand, fresnel); - if (rtPos.z < 1. ){ // Reproject on previous frame - vec3 previousPosition = mat3(gbufferModelViewInverse) * toScreenSpace(rtPos) + gbufferModelViewInverse[3].xyz + cameraPosition-previousCameraPosition; - previousPosition = mat3(gbufferPreviousModelView) * previousPosition + gbufferPreviousModelView[3].xyz; - previousPosition.xy = projMAD(gbufferPreviousProjection, previousPosition).xy / -previousPosition.z * 0.5 + 0.5; - if (previousPosition.x > 0.0 && previousPosition.y > 0.0 && previousPosition.x < 1.0 && previousPosition.x < 1.0) { - Reflections.a = 1.0; - Reflections.rgb = texture2D(colortex5,previousPosition.xy).rgb; - } - } - } - #endif - - // check if the f0 is within the metal ranges, then tint by albedo if it's true. - vec3 Metals = f0.y > 229.5/255.0 ? clamp(albedo + fresnel,0.0,1.0) : vec3(1.0); - Reflections.rgb *= Metals; - - // apply all reflections to the lighting - Reflections_Final += Reflections.rgb * luma(rayContrib); - - // interpolate between the albedos and reflections using the roughness value instead of the sampling. - float visibilityFactor = clamp(exp2((pow(roughness,3.0) / f0.y) * -4),0,1); - #ifdef Rough_reflections - Output = hand ? mix_vec3(Output, Reflections_Final, visibilityFactor) : Reflections_Final; - #else - Output = mix_vec3(Output, Reflections_Final, visibilityFactor); - #endif - Output += SunReflection; -} \ No newline at end of file diff --git a/shaders/world1/lib/stars.glsl b/shaders/world1/lib/stars.glsl deleted file mode 100644 index 38d3cbf..0000000 --- a/shaders/world1/lib/stars.glsl +++ /dev/null @@ -1,48 +0,0 @@ -//Original star code : https://www.shadertoy.com/view/Md2SR3 , optimised - - - -// Return random noise in the range [0.0, 1.0], as a function of x. -float hash12(vec2 p) -{ - vec3 p3 = fract(vec3(p.xyx) * 0.1031); - p3 += dot(p3, p3.yzx + 19.19); - return fract((p3.x + p3.y) * p3.z); -} -// Convert Noise2d() into a "star field" by stomping everthing below fThreshhold to zero. -float NoisyStarField( in vec2 vSamplePos, float fThreshhold ) -{ - float StarVal = hash12( vSamplePos ); - StarVal = clamp(StarVal/(1.0 - fThreshhold) - fThreshhold/(1.0 - fThreshhold),0.0,1.0); - - return StarVal; -} - -// Stabilize NoisyStarField() by only sampling at integer values. -float StableStarField( in vec2 vSamplePos, float fThreshhold ) -{ - // Linear interpolation between four samples. - // Note: This approach has some visual artifacts. - // There must be a better way to "anti alias" the star field. - float fractX = fract( vSamplePos.x ); - float fractY = fract( vSamplePos.y ); - vec2 floorSample = floor( vSamplePos ); - float v1 = NoisyStarField( floorSample, fThreshhold ); - float v2 = NoisyStarField( floorSample + vec2( 0.0, 1.0 ), fThreshhold ); - float v3 = NoisyStarField( floorSample + vec2( 1.0, 0.0 ), fThreshhold ); - float v4 = NoisyStarField( floorSample + vec2( 1.0, 1.0 ), fThreshhold ); - - float StarVal = v1 * ( 1.0 - fractX ) * ( 1.0 - fractY ) - + v2 * ( 1.0 - fractX ) * fractY - + v3 * fractX * ( 1.0 - fractY ) - + v4 * fractX * fractY; - return StarVal; -} - -float stars(vec3 fragpos){ - - float elevation = clamp(fragpos.y,0.,1.); - vec2 uv = fragpos.xz/(1.+elevation); - - return StableStarField(uv*700.,0.999)/4.*(0.3-0.3*rainStrength); -} diff --git a/shaders/world1/lib/texFiltering.glsl b/shaders/world1/lib/texFiltering.glsl deleted file mode 100644 index 7d58676..0000000 --- a/shaders/world1/lib/texFiltering.glsl +++ /dev/null @@ -1,19 +0,0 @@ -vec4 smoothfilter(in sampler2D tex, in vec2 uv, in vec2 textureResolution) -{ - uv = uv*textureResolution + 0.5; - vec2 iuv = floor( uv ); - vec2 fuv = fract( uv ); - uv = iuv + (fuv*fuv)*(3.0-2.0*fuv); - uv = uv/textureResolution - 0.5/textureResolution; - return texture2D( tex, uv); -} - -float shadowsmoothfilter(in sampler2DShadow tex, in vec3 uv,in float textureResolution) -{ - uv.xy = uv.xy*textureResolution + 0.5; - vec2 iuv = floor( uv.xy ); - vec2 fuv = fract( uv.xy ); - uv.xy = iuv + (fuv*fuv)*(3.0-2.0*fuv); - uv.xy = uv.xy/textureResolution - 0.5/textureResolution; - return shadow2D( tex, uv).x; -} diff --git a/shaders/world1/lib/util.glsl b/shaders/world1/lib/util.glsl deleted file mode 100644 index f701920..0000000 --- a/shaders/world1/lib/util.glsl +++ /dev/null @@ -1,196 +0,0 @@ -#define TIME_MULT 1.0 -#define TIME (frameTimeCounter * TIME_MULT) - -const float PI = acos(-1.0); -const float TAU = PI * 2.0; -const float hPI = PI * 0.5; -const float rPI = 1.0 / PI; -const float rTAU = 1.0 / TAU; - -const float PHI = sqrt(5.0) * 0.5 + 0.5; -const float rLOG2 = 1.0 / log(2.0); - -const float goldenAngle = TAU / PHI / PHI; - -#define clamp01(x) clamp(x, 0.0, 1.0) -#define max0(x) max(x, 0.0) -#define min0(x) min(x, 0.0) -#define max3(a) max(max(a.x, a.y), a.z) -#define min3(a) min(min(a.x, a.y), a.z) -#define max4(a, b, c, d) max(max(a, b), max(c, d)) -#define min4(a, b, c, d) min(min(a, b), min(c, d)) - -#define fsign(x) (clamp01(x * 1e35) * 2.0 - 1.0) -#define fstep(x,y) clamp01((y - x) * 1e35) - -#define diagonal2(m) vec2((m)[0].x, (m)[1].y) -#define diagonal3(m) vec3(diagonal2(m), m[2].z) -#define diagonal4(m) vec4(diagonal3(m), m[2].w) - -#define transMAD(mat, v) (mat3(mat) * (v) + (mat)[3].xyz) -#define projMAD(mat, v) (diagonal3(mat) * (v) + (mat)[3].xyz) - -#define encodeColor(x) (x * 0.00005) -#define decodeColor(x) (x * 20000.0) - -#define cubeSmooth(x) (x * x * (3.0 - 2.0 * x)) - -#define lumCoeff vec3(0.2125, 0.7154, 0.0721) - -float facos(const float sx){ - float x = clamp(abs( sx ),0.,1.); - float a = sqrt( 1. - x ) * ( -0.16882 * x + 1.56734 ); - return sx > 0. ? a : PI - a; - //float c = clamp(-sx * 1e35, 0., 1.); - //return c * pi + a * -(c * 2. - 1.); //no conditional version -} - - -vec2 sincos(float x){ - return vec2(sin(x), cos(x)); -} - -vec2 circlemap(float i, float n){ - return sincos(i * n * goldenAngle) * sqrt(i); -} - -vec3 circlemapL(float i, float n){ - return vec3(sincos(i * n * goldenAngle), sqrt(i)); -} - -vec3 calculateRoughSpecular(const float i, const float alpha2, const int steps) { - - float x = (alpha2 * i) / (1.0 - i); - float y = i * float(steps) * 64.0 * 64.0 * goldenAngle; - - float c = inversesqrt(x + 1.0); - float s = sqrt(x) * c; - - return vec3(cos(y) * s, sin(y) * s, c); -} - -vec3 clampNormal(vec3 n, vec3 v){ - float NoV = clamp( dot(n, -v), 0., 1. ); - return normalize( NoV * v + n ); -} - -vec3 srgbToLinear(vec3 srgb){ - return mix( - srgb / 12.92, - pow(.947867 * srgb + .0521327, vec3(2.4) ), - step( .04045, srgb ) - ); -} - -vec3 linearToSRGB(vec3 linear){ - return mix( - linear * 12.92, - pow(linear, vec3(1./2.4) ) * 1.055 - .055, - step( .0031308, linear ) - ); -} - - - -vec3 blackbody(float Temp) -{ - float t = pow(Temp, -1.5); - float lt = log(Temp); - - vec3 col = vec3(0.0); - col.x = 220000.0 * t + 0.58039215686; - col.y = 0.39231372549 * lt - 2.44549019608; - col.y = Temp > 6500. ? 138039.215686 * t + 0.72156862745 : col.y; - col.z = 0.76078431372 * lt - 5.68078431373; - col = clamp01(col); - col = Temp < 1000. ? col * Temp * 0.001 : col; - - return srgbToLinear(col); -} - -float calculateHardShadows(float shadowDepth, vec3 shadowPosition, float bias) { - if(shadowPosition.z >= 1.0) return 1.0; - - return 1.0 - fstep(shadowDepth, shadowPosition.z - bias); -} - -vec3 genUnitVector(vec2 xy) { - xy.x *= TAU; xy.y = xy.y * 2.0 - 1.0; - return vec3(sincos(xy.x) * sqrt(1.0 - xy.y * xy.y), xy.y); -} - -vec2 rotate(vec2 x, float r){ - vec2 sc = sincos(r); - return mat2(sc.x, -sc.y, sc.y, sc.x) * x; -} - -vec3 cartToSphere(vec2 coord) { - coord *= vec2(TAU, PI); - vec2 lon = sincos(coord.x) * sin(coord.y); - return vec3(lon.x, 2.0/PI*coord.y-1.0, lon.y); -} - -vec2 sphereToCart(vec3 dir) { - float lonlat = atan(-dir.x, -dir.z); - return vec2(lonlat * rTAU +0.5,0.5*dir.y+0.5); -} - -mat3 getRotMat(vec3 x,vec3 y){ - float d = dot(x,y); - vec3 cr = cross(y,x); - - float s = length(cr); - - float id = 1.-d; - - vec3 m = cr/s; - - vec3 m2 = m*m*id+d; - vec3 sm = s*m; - - vec3 w = (m.xy*id).xxy*m.yzz; - - return mat3( - m2.x, w.x-sm.z, w.y+sm.y, - w.x+sm.z, m2.y, w.z-sm.x, - w.y-sm.y, w.z+sm.x, m2.z - ); -} - -// No intersection if returned y component is < 0.0 -vec2 rsi(vec3 position, vec3 direction, float radius) { - float PoD = dot(position, direction); - float radiusSquared = radius * radius; - - float delta = PoD * PoD + radiusSquared - dot(position, position); - if (delta < 0.0) return vec2(-1.0); - delta = sqrt(delta); - - return -PoD + vec2(-delta, delta); -} -float HaltonSeq3(int index) - { - float r = 0.; - float f = 1.; - int i = index; - while (i > 0) - { - f /= 3.0; - r += f * (i % 3); - i = int(i / 3.0); - } - return r; - } -float HaltonSeq2(int index) - { - float r = 0.; - float f = 1.; - int i = index; - while (i > 0) - { - f /= 2.0; - r += f * (i % 2); - i = int(i / 2.0); - } - return r; - } diff --git a/shaders/world1/lib/volumetricClouds.glsl b/shaders/world1/lib/volumetricClouds.glsl deleted file mode 100644 index 527c5b2..0000000 --- a/shaders/world1/lib/volumetricClouds.glsl +++ /dev/null @@ -1,342 +0,0 @@ -#define VOLUMETRIC_CLOUDS// if you don't like the noise on the default cloud settings, turn up the cloud samples. if that hurts performance too much, turn down the clouds quality. - -#define cloud_LevelOfDetail 1 // Number of fbm noise iterations for on-screen clouds (-1 is no fbm) [-1 0 1 2 3 4 5 6 7 8] -#define cloud_ShadowLevelOfDetail 0 // Number of fbm noise iterations for the shadowing of on-screen clouds (-1 is no fbm) [-1 0 1 2 3 4 5 6 7 8] -#define cloud_LevelOfDetailLQ 1 // Number of fbm noise iterations for reflected clouds (-1 is no fbm) [-1 0 1 2 3 4 5 6 7 8] -#define cloud_ShadowLevelOfDetailLQ 0 // Number of fbm noise iterations for the shadowing of reflected clouds (-1 is no fbm) [-1 0 1 2 3 4 5 6 7 8] -#define minRayMarchSteps 20 // Number of ray march steps towards zenith for on-screen clouds [20 25 30 35 40 45 50 55 60 65 70 75 80 85 90 95 100 105 110 115 120 125 130 135 140 145 150 155 160 165 170 175 180 185 190 195 200] -#define maxRayMarchSteps 30 // Number of ray march steps towards horizon for on-screen clouds [5 10 15 20 25 30 35 40 45 50 55 60 65 70 75 80 85 90 95 100 105 110 115 120 125 130 135 140 145 150 155 160 165 170 175 180 185 190 195 200] -#define minRayMarchStepsLQ 10 // Number of ray march steps towards zenith for reflected clouds [5 10 15 20 25 30 35 40 45 50 55 60 65 70 75 80 85 90 95 100] -#define maxRayMarchStepsLQ 30 // Number of ray march steps towards horizon for reflected clouds [ 5 10 15 20 25 30 35 40 45 50 55 60 65 70 75 80 85 90 95 100] -#define cloudMieG 0.5 // Values close to 1 will create a strong peak of luminance around the sun and weak elsewhere, values close to 0 means uniform fog. [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 ] -#define cloudMieG2 0.9 // Multiple scattering approximation. Values close to 1 will create a strong peak of luminance around the sun and weak elsewhere, values close to 0 means uniform fog. [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 ] -#define cloudMie2Multiplier 0.7 // Multiplier for multiple scattering approximation [0.01 0.02 0.03 0.04 0.05 0.06 0.07 0.08 0.09 0.1 0.11 0.12 0.13 0.14 0.15 0.16 0.17 0.18 0.19 0.2 0.21 0.22 0.23 0.24 0.25 0.26 0.27 0.28 0.29 0.3 0.31 0.32 0.33 0.34 0.35 0.36 0.37 0.38 0.39 0.4 0.41 0.42 0.43 0.44 0.45 0.46 0.47 0.48 0.49 0.5 0.51 0.52 0.53 0.54 0.55 0.56 0.57 0.58 0.59 0.6 0.61 0.62 0.63 0.64 0.65 0.66 0.67 0.68 0.69 0.7 0.71 0.72 0.73 0.74 0.75 0.76 0.77 0.78 0.79 0.8 0.81 0.82 0.83 0.84 0.85 0.86 0.87 0.88 0.89 0.9 0.91 0.92 0.93 0.94 0.95 0.96 0.97 0.98 0.99 ] - -#define Cloud_top_cutoff 1.0 // the cutoff point on the top part of the cloud. [ 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 2.5 3.0 4 5 6 7 8 9] -#define Cloud_base_cutoff 5.0 // the cutoff point on the base of the cloud. [0.1 1 2 4 6 8 10 12 14 16 18 20] - - -#ifdef HQ_CLOUDS -int maxIT_clouds = minRayMarchSteps; -int maxIT = maxRayMarchSteps; -#else -int maxIT_clouds = minRayMarchStepsLQ; -int maxIT = maxRayMarchStepsLQ; -#endif - - - -uniform vec3 sunPosition; - - -#define cloudCoverage 0.4 // Cloud coverage [ 0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0] -#define Rain_coverage 0.6 // how much the coverage of the clouds change during rain [ 0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 3.0 4.0 5.0] - -/////// shape -#define cloudDensity 0.0514 // Cloud Density, 0.04-0.06 is around irl values [0.0010 0.0011 0.0013 0.0015 0.0017 0.0020 0.0023 0.0026 0.0030 0.0034 0.0039 0.0045 0.0051 0.0058 0.0067 0.0077 0.0088 0.0101 0.0115 0.0132 0.0151 0.0173 0.0199 0.0228 0.0261 0.0299 0.0342 0.0392 0.0449 0.0514 0.0589 0.0675 0.0773 0.0885 0.1014 0.1162 0.1331 0.1524 0.1746 0.2000 0.3 0.35 0.4 0.45 0.5 0.6 0.7 0.8 0.9 1.0] -#define fbmAmount2 1 // Amount of noise added to the cloud shape [0.00 0.02 0.04 0.06 0.08 0.10 0.12 0.14 0.16 0.18 0.20 0.22 0.24 0.26 0.28 0.30 0.32 0.34 0.36 0.38 0.40 0.42 0.44 0.46 0.48 0.50 0.52 0.54 0.56 0.58 0.60 0.62 0.64 0.66 0.68 0.70 0.72 0.74 0.76 0.78 0.80 0.82 0.84 0.86 0.88 0.90 0.92 0.94 0.96 0.98 1.00 1.02 1.04 1.06 1.08 1.10 1.12 1.14 1.16 1.18 1.20 1.22 1.24 1.26 1.28 1.30 1.32 1.34 1.36 1.38 1.40 1.42 1.44 1.46 1.48 1.50 1.52 1.54 1.56 1.58 1.60 1.62 1.64 1.66 1.68 1.70 1.72 1.74 1.76 1.78 1.80 1.82 1.84 1.86 1.88 1.90 1.92 1.94 1.96 1.98 2.00 2.02 2.04 2.06 2.08 2.10 2.12 2.14 2.16 2.18 2.20 2.22 2.24 2.26 2.28 2.30 2.32 2.34 2.36 2.38 2.40 2.42 2.44 2.46 2.48 2.50 2.52 2.54 2.56 2.58 2.60 2.62 2.64 2.66 2.68 2.70 2.72 2.74 2.76 2.78 2.80 2.82 2.84 2.86 2.88 2.90 2.92 2.94 2.96 2.98 3.00] -#define fbmPower1 3.00 // Higher values increases high frequency details of the cloud shape [1.0 1.50 1.52 1.54 1.56 1.58 1.60 1.62 1.64 1.66 1.68 1.70 1.72 1.74 1.76 1.78 1.80 1.82 1.84 1.86 1.88 1.90 1.92 1.94 1.96 1.98 2.00 2.02 2.04 2.06 2.08 2.10 2.12 2.14 2.16 2.18 2.20 2.22 2.24 2.26 2.28 2.30 2.32 2.34 2.36 2.38 2.40 2.42 2.44 2.46 2.48 2.50 2.52 2.54 2.56 2.58 2.60 2.62 2.64 2.66 2.68 2.70 2.72 2.74 2.76 2.78 2.80 2.82 2.84 2.86 2.88 2.90 2.92 2.94 2.96 2.98 3.00 3.02 3.04 3.06 3.08 3.10 3.12 3.14 3.16 3.18 3.20 3.22 3.24 3.26 3.28 3.30 3.32 3.34 3.36 3.38 3.40 3.42 3.44 3.46 3.48 3.50 3.52 3.54 3.56 3.58 3.60 3.62 3.64 3.66 3.68 3.70 3.72 3.74 3.76 3.78 3.80 3.82 3.84 3.86 3.88 3.90 3.92 3.94 3.96 3.98 4.00 5. 6. 7. 8. 9. 10.] -#define fbmPower2 1.50 // Lower values increases high frequency details of the cloud shape [1.00 1.50 1.52 1.54 1.56 1.58 1.60 1.62 1.64 1.66 1.68 1.70 1.72 1.74 1.76 1.78 1.80 1.82 1.84 1.86 1.88 1.90 1.92 1.94 1.96 1.98 2.00 2.02 2.04 2.06 2.08 2.10 2.12 2.14 2.16 2.18 2.20 2.22 2.24 2.26 2.28 2.30 2.32 2.34 2.36 2.38 2.40 2.42 2.44 2.46 2.48 2.50 2.52 2.54 2.56 2.58 2.60 2.62 2.64 2.66 2.68 2.70 2.72 2.74 2.76 2.78 2.80 2.82 2.84 2.86 2.88 2.90 2.92 2.94 2.96 2.98 3.00 3.02 3.04 3.06 3.08 3.10 3.12 3.14 3.16 3.18 3.20 3.22 3.24 3.26 3.28 3.30 3.32 3.34 3.36 3.38 3.40 3.42 3.44 3.46 3.48 3.50 3.52 3.54 3.56 3.58 3.60 3.62 3.64 3.66 3.68 3.70 3.72 3.74 3.76 3.78 3.80 3.82 3.84 3.86 3.88 3.90 3.92 3.94 3.96 3.98 4.00 5. 6. 7. 8. 9. 10.] - -/////// lighting -#define Shadow_brightness 0.5 // how dark / bright you want the shadowed part of the clouds to be. low values can look weird. [ 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 1.1 1.2 1.3 1.4 1.5 1.6 1.7 1.8 1.9 2.0 3.0 4.0 5.0 6.0] -#define self_shadow_samples 3.0 // amount of interations for cloud self shadows. longer/shorter cloud self shadows. [ 2.0 3.0 4.0 5.0 6.0 7.0 8.0 9.0 10.0] - -#define Cloud_Size 35 // [1 5 10 15 20 25 30 35 40 45 50 55 60 65 70 75 80 85 90 95 100] -#define Cloud_Height 319 // [-300 -290 -280 -270 -260 -250 -240 -230 -220 -210 -200 -190 -180 -170 -160 -150 -140 -130 -120 -110 -100 -90 -80 -70 -60 -50 -40 -30 -20 -10 0 10 20 30 40 50 60 70 80 90 100 110 120 130 140 150 160 170 180 190 200 210 220 230 240 250 260 270 280 290 300 310 319 320] - -// #define Dynamic_weather // a - -#define Dynamic_sky_day -1 // -1 MEANS THIS IS OFF. select which day of the 8 to the clouds should take shape in [0 1 2 3 4 5 6 7 ] - -#define Dynamic_Sky // day 1: partly cloudy. day 2: really cloudy, misty. day 3: mostly clear. day 4: cloudy. day 5: cloudy again. day 6: scattered clouds. day 7: partly cloudy. day 8: clear -#define High_Altitude_Clouds // a layer of clouds way up yonder - -/////// other -#define Puddle_size 5 // size of puddles [1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 191 20 21 22 23 24 25] -#define Puddle_Coverage 0.7 // the amount of cround the puddles cover [ 0.50 0.49 0.48 0.47 0.46 0.45 0.44 0.44 0.43 0.42 0.41 0.40 0.39 0.38 0.37 0.36 0.35 0.34 0.33 0.32 0.31 0.30 0.29 0.28 0.27 0.26 0.25 0.24 0.23 0.22 0.21 0.20 0.19 0.18 0.17 0.16 0.15 0.14 0.13 0.12 0.11 0.10 0.09 0.08 0.07 0.06 0.05 0.04 0.03 0.02 0.01 0.0] -#define flip_the_clouds 1 // what was once above is now below [1 -1] -#define cloud_speed 1 // how [ 0.0 0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.8 0.9 1.0 2.0 3.0 5.0 10.0 25.0 50.0 100.0 200.0] - - -#ifdef HQ_CLOUDS -const int cloudLoD = cloud_LevelOfDetail; -const int cloudShadowLoD = cloud_ShadowLevelOfDetail; -#else -const int cloudLoD = cloud_LevelOfDetailLQ; -const int cloudShadowLoD = cloud_ShadowLevelOfDetailLQ; -#endif - - - -uniform sampler2D colortex4;//Skybox - -uniform float wetness; - -uniform vec4 Moon_Weather_properties; - - - -// David Hoskins' Hash without Sine https://www.shadertoy.com/view/4djSRW -vec3 hash31(float p) -{ - vec3 p3 = fract(vec3(p) * vec3(.1031, .1030, .0973)); - p3 += dot(p3, p3.yzx+33.33); - return fract((p3.xxy+p3.yzz)*p3.zyx); -} - - -float speed = floor(frameTimeCounter); -vec3 rand_pos = hash31(speed) * 6.28; - -vec3 lighting_pos = vec3(sin(1.57 + rand_pos.x), sin(rand_pos.y), sin(rand_pos.z)); -// vec3 lighting_pos = vec3(1,3 , 1); - -vec3 lightSource = normalize(lighting_pos); -vec3 viewspace_sunvec = mat3(gbufferModelView) * lightSource; -vec3 WsunVec = normalize(mat3(gbufferModelViewInverse) * viewspace_sunvec); - - -float timing = dot(lighting_pos, vec3(1.0)); -float flash = max(sin(frameTimeCounter*5) * timing,0.0); - -vec3 srgbToLinear(vec3 srgb){ - return mix( - srgb / 12.92, - pow(.947867 * srgb + .0521327, vec3(2.4) ), - step( .04045, srgb ) - ); -} - - -vec3 blackbody(float Temp) -{ - float t = pow(Temp, -1.5); - float lt = log(Temp); - - vec3 col = vec3(0.0); - col.x = 220000.0 * t + 0.58039215686; - col.y = 0.39231372549 * lt - 2.44549019608; - col.y = Temp > 6500. ? 138039.215686 * t + 0.72156862745 : col.y; - col.z = 0.76078431372 * lt - 5.68078431373; - col = clamp(col,0,1); - col = Temp < 1000. ? col * Temp * 0.001 : col; - - return srgbToLinear(col); -} -// vec3 SunCol = vec3(1 ,0.3 ,0.8) ; -vec3 SunCol = vec3(0.25 ,0.5 ,1.0)*flash * blackbody( rand_pos.y* 2000); -// vec3 SunCol = vec3(0.0); - - - - -float cloud_height = 1500.; -float maxHeight = 4000.; - -//3D noise from 2d texture -float densityAtPos(in vec3 pos){ - pos /= 18.; - pos.xz *= 0.5; - vec3 p = floor(pos); - vec3 f = fract(pos); - vec2 uv = p.xz + f.xz + p.y * vec2(0.0,193.0); - vec2 coord = uv / 512.0; - - //Te y channel has an offset to avoid using two textures fetches - vec2 xy = texture2D(noisetex, coord).yx; - - return mix(xy.r,xy.g, f.y); -} - -float CloudLarge = 1.0; -float CloudSmall = 1.0; -float coverage = 1.0; -float cloudshape = 0; - -// vec2 cloud_movement = vec2( sin(frameTimeCounter/2000)*2 ,-cos(frameTimeCounter/2000)*2) * MOVEMENT; -vec3 cloud_movement1 = vec3(frameTimeCounter)*0.1 ; - -//Cloud without 3D noise, is used to exit early lighting calculations if there is no cloud -float cloudCov(in vec3 pos,vec3 samplePos){ - - CloudLarge = texture2D(noisetex, samplePos.xz/22500 + frameTimeCounter/500. ).b*2.0; - - coverage = CloudLarge +0.5; - float mult = max( (4000.0-pos.y) / 1000, 0); - - cloudshape = coverage - mult ; - - return cloudshape; -} - - -//Erode cloud with 3d Perlin-worley noise, actual cloud value -float cloudVol(in vec3 pos,in vec3 samplePos,in float cov, in int LoD){ - float noise = 0.0 ; - float totalWeights = 0.0; - float pw = log(fbmPower1); - float pw2 = log(fbmPower2); - - float swirl = (1-texture2D(noisetex, samplePos.xz/5000 ).b)*8; - - for (int i = 0; i <= LoD; i++){ - float weight = exp(-i*pw2); - - noise += weight - densityAtPos(samplePos *(8. )* exp(i*pw) )*weight ; - totalWeights += weight ; - } - - noise /= totalWeights; - noise = noise*noise; - noise *= clamp(1.0 - cloudshape,0.0,1.0); - float cloud = max(cov-noise*noise*(1.)*fbmAmount2,0.0); - - return cloud; -} - -float getCloudDensity(in vec3 pos, in int LoD){ - vec3 samplePos = pos*vec3(1.0,1./48.,1.0)/4 - frameTimeCounter/2; - float coverageSP = cloudCov(pos,samplePos); - if (coverageSP > 0.001) { - if (LoD < 0) return max(coverageSP - 0.27*fbmAmount2,0.0); - return cloudVol(pos,samplePos,coverageSP, LoD); - } else return 0.0; -} -//Mie phase function -float phaseg(float x, float g){ - float gg = g * g; - return (gg * -0.25 + 0.25) * pow(-2.0 * (g * x) + (gg + 1.0), -1.5) /3.14; -} - - -vec3 startOffset = vec3(0); -vec4 renderClouds(vec3 fragpositi, vec3 color,float dither,vec3 sunColor,vec3 moonColor,vec3 avgAmbient,float dither2) { - - - #ifndef VOLUMETRIC_CLOUDS - return vec4(0.0,0.0,0.0,1.0); - #endif - - //project pixel position into projected shadowmap space - vec4 fragposition = gbufferModelViewInverse*vec4(fragpositi,1.0); - - vec3 worldV = normalize(fragposition.rgb); - float VdotU = worldV.y; - - // worldV.y += 0.1 ; - - - //project view origin into projected shadowmap space - vec4 start = (gbufferModelViewInverse*vec4(0.0,0.0,0.,1.)); - vec3 dV_view = worldV; - - vec3 progress_view = dV_view*dither+cameraPosition; - - float testdither = dither ; - float vL = 0.0; - float total_extinction = 1.0; - - maxIT_clouds = int(clamp( maxIT_clouds /sqrt(exp2(VdotU)),0.0, maxIT*1.0)); - float distW = length(worldV); - worldV = normalize(worldV)*100000. + cameraPosition; //makes max cloud distance not dependant of render distance - dV_view = normalize(dV_view); - // maxHeight = maxHeight * (1+testCloudheight_variation); - - int Flip_clouds = 1; - if (worldV.y < cloud_height) Flip_clouds = -1; - //setup ray to start at the start of the cloud plane and end at the end of the cloud plane - dV_view *= max(maxHeight - cloud_height, 0.0)/dV_view.y/(maxIT_clouds); - startOffset = dV_view*testdither; - - vec3 camPos = Flip_clouds*(cameraPosition); - - progress_view = (startOffset) + camPos + dV_view*((cloud_height)-camPos.y)/dV_view.y ; - - - - - - - float shadowStep = 240.; - vec3 dV_Sun = Flip_clouds * normalize( mat3(gbufferModelViewInverse) * viewspace_sunvec ) * shadowStep; - - - float mult = length(dV_view); - - - color = vec3(0.0); - - total_extinction = 1.0; - float SdotV = dot(normalize(viewspace_sunvec), normalize(fragpositi)); - - float mieDay = phaseg(SdotV, 0.8); - float mie2 = phaseg(SdotV, 0.5); - - - // vec3 SunCol = vec3(1.0,0.5,0.5) * flashing ; - - vec3 sunContribution = mieDay*SunCol*3.14; - - - // float darkness = texture2D(noisetex, progress_view.xz/120500).b; - // vec3 skyCol0 = (avgAmbient*4.0*3.1415*8/3.0 ) ; - vec3 skyCol0 = gl_Fog.color.rgb * 0.01; - - for(int i=0;i 0.0001){ - float muS = cloud*densityofclouds; - float muE = cloud*densityofclouds; - - float muEshD = 0.0; - if (sunContribution.g > 1e-5){ - for (int j=0; j < 3; j++){ - - vec3 shadowSamplePos = progress_view + dV_Sun * ((j+0.5) + (j *2)) ; - // get the cloud density and apply it - if (shadowSamplePos.y < maxHeight){ - float cloudS = getCloudDensity(shadowSamplePos, cloudShadowLoD); - muEshD += cloudS*densityofclouds*shadowStep; - } - } - } - - float powder = muE * 100; // powder.... - - float sunShadow = exp(-muEshD*0.25); // this simulates the direct light, and the scattering of it - - float front_lit = sunShadow; - float back_lit = pow(muS*(cloud+muE), max(1-cloud*2,0.0)*2); - - float innerSeams = mix(front_lit, back_lit*0.5, clamp(mie2,0.,1.) ) ; - - vec3 SunCloud_lighting = sunContribution * innerSeams * mie2; - vec3 AmbientCloud_Lighting = skyCol0 * powder ; - - - - vec3 S = SunCloud_lighting + AmbientCloud_Lighting ; // combine all the combined - - vec3 Sint= (S - S * exp(-mult*muE)) / muE; - color += max(muS*Sint*total_extinction,0.0); - total_extinction *= max(exp(-muE*mult),0); - - if (total_extinction < 1e-5) break; - } - progress_view += dV_view; - } - - // vec3 normView = normalize(dV_view); - // // Assume fog color = sky gradient at long distance - // vec3 fogColor = skyFromTex(normView, colortex4)/150.; - // float dist = (cloud_height - cameraPosition.y)/normalize(dV_view).y; - // float fog = exp(-dist/15000.0*(1.0+rainCloudwetness*8.)); - - float cosY = normalize(dV_view).y; - return mix(vec4(color,clamp(total_extinction*(1.0+1/250.)-1/250.,0.0,1.0)),vec4(0.0,0.0,0.0,1.0), 1-smoothstep(0.02,0.15,cosY)); -} diff --git a/shaders/world1/lib/volumetricFog.glsl b/shaders/world1/lib/volumetricFog.glsl deleted file mode 100644 index 83212d0..0000000 --- a/shaders/world1/lib/volumetricFog.glsl +++ /dev/null @@ -1,118 +0,0 @@ -#define VL_SAMPLES2 6 //[4 6 8 10 12 14 16 20 24 30 40 50] -#define Ambient_Mult 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0 5.0 6.0 10.0] -#define SEA_LEVEL 70 //[0 10 20 30 40 50 60 70 80 90 100 110 120 130 150 170 190] //The volumetric light uses an altitude-based fog density, this is where fog density is the highest, adjust this value according to your world. -#define ATMOSPHERIC_DENSITY 1.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 4.0 5.0 7.5 10.0 12.5 15.0 20.] -#define fog_mieg1 0.40 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0] -#define fog_mieg2 0.10 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0] -#define fog_coefficientRayleighR 5.8 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientRayleighG 1.35 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientRayleighB 3.31 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] - -#define fog_coefficientMieR 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientMieG 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] -#define fog_coefficientMieB 3.0 //[0.0 0.5 1.0 1.5 2.0 2.5 3.0 3.5 4.0 4.5 5.0 5.5 6.0 6.5 7.0 7.5 8.0 8.5 9.0 9.5 10.0] - -#define Underwater_Fog_Density 1.0 //[0.1 0.2 0.3 0.4 0.5 0.6 0.7 0.75 0.8 0.85 0.9 0.95 1.0 1.5 2.0 3.0 4.0] - -float phaseRayleigh(float cosTheta) { - const vec2 mul_add = vec2(0.1, 0.28) /acos(-1.0); - return cosTheta * mul_add.x + mul_add.y; // optimized version from [Elek09], divided by 4 pi for energy conservation -} -float cloudVol2(in vec3 pos){ - - vec3 samplePos = pos*vec3(1.0,1./16.,1.0)+frameTimeCounter*vec3(0.5,0.,0.5)*5.; - float coverage = mix(exp2(-(pos.y-SEA_LEVEL)*(pos.y-SEA_LEVEL)/10000.),1.0,rainStrength*0.5); - float noise = densityAtPos(samplePos*12.); - float unifCov = exp2(-max(pos.y-SEA_LEVEL,0.0)/50.); - - float cloud = pow(clamp(coverage-noise-0.76,0.0,1.0),2.)*1200./0.23/(coverage+0.01)*VFAmount*600+unifCov*60.*fogAmount; - -return cloud; -} - -mat2x3 getVolumetricRays(float dither,vec3 fragpos) { - - //project pixel position into projected shadowmap space - vec3 wpos = mat3(gbufferModelViewInverse) * fragpos + gbufferModelViewInverse[3].xyz; - vec3 fragposition = mat3(shadowModelView) * wpos + shadowModelView[3].xyz; - fragposition = diagonal3(shadowProjection) * fragposition + shadowProjection[3].xyz; - - - - //project view origin into projected shadowmap space - vec3 start = toShadowSpaceProjected(vec3(0.)); - - - //rayvector into projected shadow map space - //we can use a projected vector because its orthographic projection - //however we still have to send it to curved shadow map space every step - vec3 dV = (fragposition-start); - vec3 dVWorld = (wpos-gbufferModelViewInverse[3].xyz); - - float maxLength = min(length(dVWorld),256.0)/length(dVWorld); - dV *= maxLength; - dVWorld *= maxLength; - - //apply dither - vec3 progress = start.xyz; - vec3 progressW = gbufferModelViewInverse[3].xyz+cameraPosition; - vec3 vL = vec3(0.); - - float SdotV = dot(sunVec,normalize(fragpos))*lightCol.a; - float dL = length(dVWorld); - //Mie phase + somewhat simulates multiple scattering (Horizon zero down cloud approx) - float mie = max(phaseg(SdotV,fog_mieg1),1.0/13.0); - float rayL = phaseRayleigh(SdotV); - // wpos.y = clamp(wpos.y,0.0,1.0); - - vec3 ambientCoefs = dVWorld/dot(abs(dVWorld),vec3(1.)); - - vec3 ambientLight = ambientUp*clamp(ambientCoefs.y,0.,1.); - ambientLight += ambientDown*clamp(-ambientCoefs.y,0.,1.); - ambientLight += ambientRight*clamp(ambientCoefs.x,0.,1.); - ambientLight += ambientLeft*clamp(-ambientCoefs.x,0.,1.); - ambientLight += ambientB*clamp(ambientCoefs.z,0.,1.); - ambientLight += ambientF*clamp(-ambientCoefs.z,0.,1.); - - vec3 skyCol0 = ambientLight*2.*eyeBrightnessSmooth.y/vec3(240.)*Ambient_Mult*2.0/PI; - vec3 sunColor = lightCol.rgb; - - vec3 rC = vec3(fog_coefficientRayleighR*1e-6, fog_coefficientRayleighG*1e-5, fog_coefficientRayleighB*1e-5); - vec3 mC = vec3(fog_coefficientMieR*1e-6, fog_coefficientMieG*1e-6, fog_coefficientMieB*1e-6); - - - float mu = 1.0; - float muS = 1.0*mu; - vec3 absorbance = vec3(1.0); - float expFactor = 11.0; - for (int i=0;i FLICKER_REDUCTION BLEND_FACTOR ANTI_GHOSTING MOTION_REJECTION CLOSEST_VELOCITY NO_CLIP - -screen.Lighting= [Torch] [Sky] [Ambient] -screen.Torch = TORCH_R TORCH_G TORCH_B TORCH_AMOUNT -screen.Sky=[Sky_coefficients] [Sun_and_Moon_Colors] sunPathRotation -screen.Sky_coefficients = Sky_Brightness sky_mieg sky_coefficientRayleighR sky_coefficientRayleighG sky_coefficientRayleighB sky_coefficientMieR sky_coefficientMieG sky_coefficientMieB -screen.Sun_and_Moon_Colors = sunColorR sunColorG sunColorB sun_illuminance moonColorR moonColorG moonColorB moon_illuminance -screen.Ambient = MIN_LIGHT_AMOUNT SEPARATE_AO ambientOcclusionLevel Ambient_Mult - -screen.Shading = DISABLE_ALPHA_MIPMAPS [Shadows] [POM] BICUBIC_UPSCALING CONTRAST_ADAPTATIVE_SHARPENING SHARPENING -screen.Shadows = [Filtering] SCREENSPACE_CONTACT_SHADOWS shadowMapResolution CLOUDS_SHADOWS CLOUDS_SHADOWS_STRENGTH shadowDistanceRenderMul shadowDistance SHADOW_FRUSTRUM_CULLING CAVE_LIGHT_LEAK_FIX SSAO SSAO_SAMPLES SHADOW_DISABLE_ALPHA_MIPMAPS Stochastic_Transparent_Shadows -screen.Filtering = Variable_Penumbra_Shadows VPS_Search_Samples Min_Shadow_Filter_Radius Max_Shadow_Filter_Radius Max_Filter_Depth SHADOW_FILTER_SAMPLE_COUNT -screen.POM = POM_MAP_RES POM POM_DEPTH MAX_ITERATIONS MAX_DIST USE_LUMINANCE_AS_HEIGHTMAP -screen.Camera = EXPOSURE_MULTIPLIER Exposure_Speed AUTO_EXPOSURE Manual_exposure_value BLOOM_STRENGTH FinalR FinalG FinalB [Tonemapping] [DepthOfField] [Purkinje_effect] -screen.Purkinje_effect = Purkinje_strength Purkinje_strength Purkinje_R Purkinje_G Purkinje_B Purkinje_Multiplier -screen.Tonemapping = TONEMAP USE_ACES_COLORSPACE_APPROXIMATION SATURATION CROSSTALK -screen.DepthOfField = DOF HQ_DOF HEXAGONAL_BOKEH AUTOFOCUS focal aperture MANUAL_FOCUS FAR_BLUR_ONLY -texture.noise=texture/noises.png - -separateAo=true - - -beacon.beam.depth=true -rain.depth=false - -variable.float.texelSizeX = 1.0/viewWidth -variable.float.texelSizeY = 1.0/viewHeight -uniform.vec2.texelSize=vec2(texelSizeX,texelSizeY) - -uniform.int.framemod8 = frameCounter%8 - -variable.float.normSunVec = sqrt(sunPosition.x*sunPosition.x+sunPosition.y*sunPosition.y+sunPosition.z*sunPosition.z) -variable.float.normUpVec = sqrt(upPosition.x*upPosition.x+upPosition.y*upPosition.y+upPosition.z*upPosition.z) - -variable.float.sunPosX = sunPosition.x/normSunVec -variable.float.sunPosY = sunPosition.y/normSunVec -variable.float.sunPosZ = sunPosition.z/normSunVec - -uniform.vec3.sunVec=vec3(sunPosX,sunPosY,sunPosZ) - -variable.float.upPosX = upPosition.x/normUpVec -variable.float.upPosY = upPosition.y/normUpVec -variable.float.upPosZ = upPosition.z/normUpVec - -uniform.vec3.upVec=vec3(upPosX,upPosY,upPosZ) -uniform.float.sunElevation = sunPosX*upPosX+sunPosY*upPosY+sunPosZ*upPosZ -uniform.float.lightSign = clamp(sunElevation * 1000000000000000000, 0.0, 1.0) * 2.0 - 1.0 - -#Max angle at frustrum diagonal -variable.float.maxAngle = atan(1.0 / gbufferProjection.1.1 * sqrt(1.0+(aspectRatio * aspectRatio))) -uniform.float.cosFov = cos(maxAngle) -variable.float.viewDirX = gbufferModelViewInverse.2.0 -variable.float.viewDirY = gbufferModelViewInverse.2.1 -variable.float.viewDirZ = gbufferModelViewInverse.2.2 -variable.float.normView = sqrt(viewDirX*viewDirX + viewDirY*viewDirY + viewDirZ*viewDirZ) -variable.float.shViewDirX = (shadowModelView.0.0 * viewDirX + shadowModelView.1.0 * viewDirY + shadowModelView.2.0 * viewDirZ)/normView -variable.float.shViewDirY = (shadowModelView.0.1 * viewDirX + shadowModelView.1.1 * viewDirY + shadowModelView.2.1 * viewDirZ)/normView -variable.float.shViewDirZ = (shadowModelView.0.2 * viewDirX + shadowModelView.1.2 * viewDirY + shadowModelView.2.2 * viewDirZ)/normView - -uniform.vec3.shadowViewDir = vec3(shViewDirX, shViewDirY, shViewDirZ) - -variable.float.shStartX = (shadowModelView.0.0 * gbufferModelViewInverse.3.0 + shadowModelView.1.0 * gbufferModelViewInverse.3.1 + shadowModelView.2.0 * gbufferModelViewInverse.3.2) -variable.float.shStartY = (shadowModelView.0.1 * gbufferModelViewInverse.3.0 + shadowModelView.1.1 * gbufferModelViewInverse.3.1 + shadowModelView.2.1 * gbufferModelViewInverse.3.2) -variable.float.shStartZ = (shadowModelView.0.2 * gbufferModelViewInverse.3.0 + shadowModelView.1.2 * gbufferModelViewInverse.3.1 + shadowModelView.2.2 * gbufferModelViewInverse.3.2) - -uniform.vec3.shadowCamera = vec3(shStartX + shadowModelView.3.0 + shViewDirX*2., shStartY + shadowModelView.3.1 + shViewDirY*2., shStartZ + shadowModelView.3.2 + shViewDirZ*2.0) - - -variable.float.wSunX = (gbufferModelViewInverse.0.0 * sunPosX + gbufferModelViewInverse.1.0 * sunPosY + gbufferModelViewInverse.2.0 * sunPosZ) -variable.float.wSunY = (gbufferModelViewInverse.0.1 * sunPosX + gbufferModelViewInverse.1.1 * sunPosY + gbufferModelViewInverse.2.1 * sunPosZ) -variable.float.wSunZ = (gbufferModelViewInverse.0.2 * sunPosX + gbufferModelViewInverse.1.2 * sunPosY + gbufferModelViewInverse.2.2 * sunPosZ) - -variable.float.shSunX = (shadowModelView.0.0 * wSunX + shadowModelView.1.0 * wSunY + shadowModelView.2.0 * wSunZ) -variable.float.shSunY = (shadowModelView.0.1 * wSunX + shadowModelView.1.1 * wSunY + shadowModelView.2.1 * wSunZ) -variable.float.shSunZ = (shadowModelView.0.2 * wSunX + shadowModelView.1.2 * wSunY + shadowModelView.2.2 * wSunZ) - -uniform.vec3.shadowLightVec = vec3(lightSign*shSunX, lightSign*shSunY, lightSign*shSunZ) - -uniform.float.shadowMaxProj = 150.0/abs(sunPosY) diff --git a/shaders/world1/texture/composite4.fsh b/shaders/world1/texture/composite4.fsh deleted file mode 100644 index fccda4b..0000000 --- a/shaders/world1/texture/composite4.fsh +++ /dev/null @@ -1,37 +0,0 @@ -#version 120 -//Horizontal bilateral blur for volumetric fog + Forward rendered objects + Draw volumetric fog -#extension GL_EXT_gpu_shader4 : enable - - - -varying vec2 texcoord; -flat varying vec3 zMults; -uniform sampler2D depthtex0; -uniform sampler2D colortex3; -uniform sampler2D colortex2; -uniform sampler2D colortex0; - -uniform int frameCounter; -uniform float far; -uniform float near; -uniform int isEyeInWater; - -uniform vec2 texelSize; -float ld(float depth) { - return 1.0 / (zMults.y - depth * zMults.z); // (-depth * (far - near)) = (2.0 * near)/ld - far - near -} - - -void main() { -/* DRAWBUFFERS:3 */ - vec3 color = texture2D(colortex3,texcoord).rgb; - vec4 transparencies = texture2D(colortex2,texcoord); - color = color*(1.0-transparencies.a)+transparencies.rgb*10.; - - vec4 vl = texture2D(colortex0,texcoord); - - color *= vl.a; - color += vl.rgb; - - gl_FragData[0].rgb = clamp(color,6.11*1e-5,65000.0); -} diff --git a/shaders/world1/texture/noises.png b/shaders/world1/texture/noises.png deleted file mode 100644 index 6236ff19990bb213e4ec6f6a51df1fc13138e582..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 695035 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 yNUa~SuZo9zB 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Ƴ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℞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

    Yi2^SGZ6h!TfpHNG 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

      r`*%wWjg2o<3!FDJr@VHqPU9k#`#ewcI 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≫vUQb#-F!u*zClQN@?MP)=TWr=6%kyA9OtVAX{4{qPh3q*r z<>#h2R}i0pyacev1Ed$maPHL_ zw}R?Wq7DJ_X+R$XdI|D-kTw{Mzku;R&{+_)8Gz3R<)W~71gZ}Jogb*q+e97(v(sU| zIlVan?mNia4`6jMG5eD`2C%tj;fecRqS}pJ`MN`w7sDpS@vxg7cWPC#Zcf&}5xAbJ zivw6e@@;|g2H=|l!Hy8M^u`!;08q0IP+!8tAYAkqey`0rF_cPWpttWUey zbjq%#{6fj!lkgCs2LNm>VN@nQDVA%AK3?GNN^Zi$VyxWW!&kB7N(TSVg)v1~tH|$l z+0&FiOz}O)ZiVc0Dn`3-Il(t6n`A5px;Sr9b4Jl`K5tMCYoHyS@qtsf(l`g*mJ)G) ziiZbnM6zcvR92#z;k3?Q+?pvxwvT7N;n3hBjx*^a%lwG2yF}gz@LWmbnDxKR-ZdbO z5p$S~XQbspK|3|&%QG>F%%OljQS$ewv8Bkpl zP3NSK05DFT1 zg=-WXd&9IMT&uwF4;c;&!@rVtgjjk-+fjyFWOjoLKc{QgbZwD^w}sh?VRlTKeJA(b z)47FQl=+~vqM)x4Dto5<<&+(lwCB_6@8mN*z3*+6`fE5Y%fhe1c|{mUrL&XtMP)V@ zXgdkqPQ-r&Ob|6WT?@!{xC(ZMV+T3!gLAl94x{Diw7Mp(`&WAV3axvIS>FZDUndv* zdUm7UR~pq{n$!s;^VcH0RDdg;dd-mU8S<}G`@Lmd*s{`UeawO#6E89dL{2240qiQE zSy$o|NP808%0PG3b6j;#GIk)^Z^`cO!0td;9SFm!MlR*1JDlA`9PI@LT|@CYqC7>F zU#ZUJNWV$Rqm}tiX50&55fU#rZT(_Br#0*u(6F3ZP)eh6enHRVMm;YTm0unHpu?s( zb&oNxChP(NAGtW$;j7aH@VsWufmem75&Mm`d zp#BbOCSbclx==il}MGmioL4Cp%(sC@v=2J$vT_aR4I(?ML+ zLHExc#>ftH=Z4t1vAnRczGn;n_cCYSznyuE)Bf0qCpD_md$PM`6ZN=GV3Q_otCHm{ z&mxnz2EIq&SHk~6G^ z$XE^_y`hzJ!Ol0b<{xkllIQ%g_GOvY5u=FuLGbwjI}EUwz­iy+Pg%T8eDLy+%) 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%0A4os% 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 %Xwxw4s#^wgS`JdVVU#(cv} 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 P00000NkvXXu0mjfdVlSA diff --git a/shaders/world1/texture/noises.png.mcmeta b/shaders/world1/texture/noises.png.mcmeta deleted file mode 100644 index 33f3199..0000000 --- a/shaders/world1/texture/noises.png.mcmeta +++ /dev/null @@ -1,7 +0,0 @@ -{ - "texture": - { - "blur": true, - "clamp": false - } -} \ No newline at end of file