2024-05-06 11:54:30 -04:00
|
|
|
#ifdef IS_LPV_ENABLED
|
2024-05-07 10:27:37 -04:00
|
|
|
vec3 GetHandLight(const in int itemId, const in vec3 playerPos, const in vec3 normal) {
|
2024-05-06 15:12:52 -04:00
|
|
|
vec3 lightFinal = vec3(0.0);
|
|
|
|
vec3 lightColor = vec3(0.0);
|
|
|
|
float lightRange = 0.0;
|
|
|
|
|
|
|
|
uvec2 blockData = texelFetch(texBlockData, itemId, 0).rg;
|
|
|
|
vec4 lightColorRange = unpackUnorm4x8(blockData.r);
|
|
|
|
lightColor = srgbToLinear(lightColorRange.rgb);
|
|
|
|
lightRange = lightColorRange.a * 255.0;
|
|
|
|
|
|
|
|
if (lightRange > 0.0) {
|
|
|
|
float lightDist = length(playerPos);
|
2024-05-07 10:27:37 -04:00
|
|
|
vec3 lightDir = playerPos / lightDist;
|
|
|
|
float NoL = 1.0;//max(dot(normal, lightDir), 0.0);
|
2024-05-06 15:12:52 -04:00
|
|
|
float falloff = pow(1.0 - lightDist / lightRange, 3.0);
|
2024-05-07 10:27:37 -04:00
|
|
|
lightFinal = lightColor * NoL * max(falloff, 0.0);
|
2024-05-06 11:54:30 -04:00
|
|
|
}
|
2024-05-06 15:12:52 -04:00
|
|
|
|
|
|
|
return lightFinal;
|
2024-05-06 11:54:30 -04:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2024-06-23 21:43:15 -04:00
|
|
|
vec3 doBlockLightLighting(
|
|
|
|
vec3 lightColor, float lightmap, float exposureValue,
|
|
|
|
vec3 playerPos, vec3 lpvPos
|
2023-10-18 17:43:29 -04:00
|
|
|
){
|
2024-11-15 17:54:18 -05:00
|
|
|
lightmap = clamp(lightmap,0.0,1.0);
|
2024-03-22 22:11:43 -04:00
|
|
|
|
2024-11-15 17:54:18 -05:00
|
|
|
float lightmapBrightspot = min(max(lightmap-0.7,0.0)*3.3333,1.0);
|
|
|
|
lightmapBrightspot *= lightmapBrightspot*lightmapBrightspot;
|
|
|
|
|
|
|
|
float lightmapLight = 1.0-sqrt(1.0-lightmap);
|
|
|
|
lightmapLight *= lightmapLight;
|
|
|
|
|
|
|
|
float lightmapCurve = mix(lightmapLight, 2.0, lightmapBrightspot);
|
|
|
|
|
|
|
|
// lightmapCurve = lightmap*lightmap;
|
|
|
|
|
|
|
|
// float lightmapCurve = (exp(-15.0 * (1.0-lightmap))*10.0 + lightmap*pow(1.0-pow(1.0-lightmap,2.0),2.0))*0.5;
|
|
|
|
// float lightmapCurve = (pow(min(max(lightmap-0.6, 0.0) * 2.5,1.0),4.0) * 10.0 + lightmap*pow(1.0-pow(1.0-lightmap,2.0),2.0))*0.5;
|
|
|
|
// float lightmapCurve = pow(1.0-pow(1.0-lightmap,2.0),2.0);
|
2024-05-04 21:36:06 -04:00
|
|
|
|
2024-11-15 17:54:18 -05:00
|
|
|
vec3 blockLight = lightColor * lightmapCurve;
|
2024-05-04 21:36:06 -04:00
|
|
|
|
2024-05-02 12:43:30 -04:00
|
|
|
#if defined IS_LPV_ENABLED && defined MC_GL_EXT_shader_image_load_store
|
2024-05-02 13:00:51 -04:00
|
|
|
vec4 lpvSample = SampleLpvLinear(lpvPos);
|
2024-11-15 17:54:18 -05:00
|
|
|
#ifdef VANILLA_LIGHTMAP_MASK
|
|
|
|
lpvSample.rgb *= lightmapCurve;
|
|
|
|
#endif
|
2024-06-23 21:43:15 -04:00
|
|
|
vec3 lpvBlockLight = GetLpvBlockLight(lpvSample);
|
2024-03-23 18:29:25 -04:00
|
|
|
|
2024-06-23 21:43:15 -04:00
|
|
|
// create a smooth falloff at the edges of the voxel volume.
|
|
|
|
float fadeLength = 10.0; // in meters
|
2024-05-09 18:24:29 -04:00
|
|
|
vec3 cubicRadius = clamp( min(((LpvSize3-1.0) - lpvPos)/fadeLength, lpvPos/fadeLength) ,0.0,1.0);
|
2024-06-23 21:43:15 -04:00
|
|
|
float voxelRangeFalloff = cubicRadius.x*cubicRadius.y*cubicRadius.z;
|
|
|
|
voxelRangeFalloff = 1.0 - pow(1.0-pow(voxelRangeFalloff,1.5),3.0);
|
2024-05-04 21:36:06 -04:00
|
|
|
|
2024-06-23 21:43:15 -04:00
|
|
|
// outside the voxel volume, lerp to vanilla lighting as a fallback
|
2024-11-15 17:54:18 -05:00
|
|
|
blockLight = mix(blockLight, lpvSample.rgb, voxelRangeFalloff);
|
2024-05-06 11:54:30 -04:00
|
|
|
|
2024-06-23 21:43:15 -04:00
|
|
|
#ifdef Hand_Held_lights
|
|
|
|
// create handheld lightsources
|
|
|
|
const vec3 normal = vec3(0.0); // TODO
|
2024-05-07 10:27:37 -04:00
|
|
|
|
2024-06-23 21:43:15 -04:00
|
|
|
if (heldItemId > 0)
|
|
|
|
blockLight += GetHandLight(heldItemId, playerPos, normal);
|
2024-05-06 11:54:30 -04:00
|
|
|
|
2024-06-23 21:43:15 -04:00
|
|
|
if (heldItemId2 > 0)
|
|
|
|
blockLight += GetHandLight(heldItemId2, playerPos, normal);
|
|
|
|
#endif
|
2024-05-02 12:43:30 -04:00
|
|
|
#endif
|
2024-03-23 18:29:25 -04:00
|
|
|
|
2024-06-23 21:43:15 -04:00
|
|
|
// try to make blocklight have consistent visiblity in different light levels.
|
2024-11-15 17:54:18 -05:00
|
|
|
// float autoBrightness = mix(0.5, 1.0, clamp(exp(-10.0*exposureValue),0.0,1.0));
|
|
|
|
// blockLight *= autoBrightness;
|
2024-06-23 21:43:15 -04:00
|
|
|
|
|
|
|
return blockLight * TORCH_AMOUNT;
|
2023-07-31 23:31:56 -04:00
|
|
|
}
|
2023-10-20 20:26:41 -04:00
|
|
|
|
2024-06-23 21:43:15 -04:00
|
|
|
vec3 doIndirectLighting(
|
|
|
|
vec3 lightColor, vec3 minimumLightColor, float lightmap
|
2023-10-18 17:43:29 -04:00
|
|
|
){
|
2024-05-09 19:14:41 -04:00
|
|
|
|
2024-11-15 17:54:18 -05:00
|
|
|
// float lightmapCurve = pow(1.0-pow(1.0-lightmap,2.0),2.0);
|
|
|
|
// float lightmapCurve = lightmap*lightmap;
|
2024-06-23 21:43:15 -04:00
|
|
|
float lightmapCurve = (pow(lightmap,15.0)*2.0 + pow(lightmap,2.5))*0.5;
|
2024-05-09 19:14:41 -04:00
|
|
|
|
2024-06-23 21:43:15 -04:00
|
|
|
vec3 indirectLight = lightColor * lightmapCurve * ambient_brightness * 0.7;
|
2024-05-09 19:14:41 -04:00
|
|
|
|
2024-11-15 17:54:18 -05:00
|
|
|
// indirectLight = max(indirectLight, minimumLightColor * (MIN_LIGHT_AMOUNT * 0.02 * 0.2 + nightVision));
|
|
|
|
indirectLight += minimumLightColor * (MIN_LIGHT_AMOUNT * 0.02 * 0.2 + nightVision*0.02);
|
2023-04-16 16:18:26 -04:00
|
|
|
|
2024-06-23 21:43:15 -04:00
|
|
|
return indirectLight;
|
2023-10-20 20:26:41 -04:00
|
|
|
}
|