diff options
author | Perttu Ahola <celeron55@gmail.com> | 2012-12-02 18:02:04 +0200 |
---|---|---|
committer | Perttu Ahola <celeron55@gmail.com> | 2012-12-02 18:02:45 +0200 |
commit | 804a7875a2018f3d8cb3fbe917c11ecc1666d25a (patch) | |
tree | 8f730c91a9461d512e785e76a3a5f99e52e910d3 /src/light.h | |
parent | 041585a78e7eeabd23d92435a8dd6fd39d329b07 (diff) | |
download | minetest-804a7875a2018f3d8cb3fbe917c11ecc1666d25a.tar.gz minetest-804a7875a2018f3d8cb3fbe917c11ecc1666d25a.tar.bz2 minetest-804a7875a2018f3d8cb3fbe917c11ecc1666d25a.zip |
Smooth day-night transitions
Diffstat (limited to 'src/light.h')
-rw-r--r-- | src/light.h | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/src/light.h b/src/light.h index 218af348e..f1c458ad8 100644 --- a/src/light.h +++ b/src/light.h @@ -85,6 +85,24 @@ inline u8 decode_light(u8 light) return light_decode_table[light]; } +// 0.0 <= light <= 1.0 +// 0.0 <= return value <= 1.0 +inline float decode_light_f(float light_f) +{ + s32 i = (u32)(light_f * LIGHT_MAX + 0.5); + + if(i <= 0) + return (float)light_decode_table[0] / 255.0; + if(i >= LIGHT_MAX) + return (float)light_decode_table[LIGHT_MAX] / 255.0; + + float v1 = (float)light_decode_table[i-1] / 255.0; + float v2 = (float)light_decode_table[i] / 255.0; + float f0 = (float)i - 0.5; + float f = light_f * LIGHT_MAX - f0; + return f * v2 + (1.0 - f) * v1; +} + // 0 <= daylight_factor <= 1000 // 0 <= lightday, lightnight <= LIGHT_SUN // 0 <= return value <= LIGHT_SUN @@ -97,5 +115,15 @@ inline u8 blend_light(u32 daylight_factor, u8 lightday, u8 lightnight) return l; } +// 0.0 <= daylight_factor <= 1.0 +// 0 <= lightday, lightnight <= LIGHT_SUN +// 0 <= return value <= 255 +inline u8 blend_light_f1(float daylight_factor, u8 lightday, u8 lightnight) +{ + u8 l = ((daylight_factor * decode_light(lightday) + + (1.0-daylight_factor) * decode_light(lightnight))); + return l; +} + #endif |