minetest/src/light.cpp

206 lines
2.4 KiB
C++
Raw Normal View History

/*
Minetest-c55
Copyright (C) 2010 celeron55, Perttu Ahola <celeron55@gmail.com>
This program is free software; you can redistribute it and/or modify
it under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2 of the License, or
(at your option) any later version.
This program is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU General Public License for more details.
You should have received a copy of the GNU General Public License along
with this program; if not, write to the Free Software Foundation, Inc.,
51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*/
2010-11-27 01:02:21 +02:00
#include "light.h"
2011-02-04 01:22:07 +02:00
// a_n+1 = a_n * 0.786
// Length of LIGHT_MAX+1 means LIGHT_MAX is the last value.
// LIGHT_SUN is read as LIGHT_MAX from here.
u8 light_decode_table[LIGHT_MAX+1] =
{
8,
11,
14,
18,
22,
29,
37,
47,
60,
76,
97,
123,
157,
200,
255,
};
// As in minecraft, a_n+1 = a_n * 0.8
// NOTE: This doesn't really work that well because this defines
// LIGHT_MAX as dimmer than LIGHT_SUN
// NOTE: Uh, this has had 34 left out; forget this.
/*u8 light_decode_table[LIGHT_MAX+1] =
2010-12-19 16:51:45 +02:00
{
2011-02-04 01:22:07 +02:00
8,
11,
14,
17,
21,
27,
42,
53,
66,
83,
104,
130,
163,
204,
255,
2010-12-19 16:51:45 +02:00
};*/
2011-02-04 01:22:07 +02:00
// This was a quick try of more light, manually quickly made
/*u8 light_decode_table[LIGHT_MAX+1] =
2010-11-27 01:02:21 +02:00
{
0,
2011-02-02 18:46:14 +02:00
7,
11,
15,
21,
29,
42,
53,
69,
85,
109,
135,
167,
205,
255,
2011-02-04 01:22:07 +02:00
};*/
// This was used for a long time, manually made
2011-02-02 18:46:14 +02:00
/*u8 light_decode_table[LIGHT_MAX+1] =
{
0,
2010-12-19 16:51:45 +02:00
6,
8,
11,
14,
2010-12-19 16:51:45 +02:00
19,
26,
34,
45,
61,
81,
108,
143,
191,
2010-11-27 01:02:21 +02:00
255,
2011-02-02 18:46:14 +02:00
};*/
2011-02-04 01:22:07 +02:00
2010-12-19 16:51:45 +02:00
/*u8 light_decode_table[LIGHT_MAX+1] =
{
0,
3,
6,
10,
18,
25,
35,
50,
75,
95,
120,
150,
185,
215,
255,
2010-11-27 01:02:21 +02:00
};*/
2010-12-19 16:51:45 +02:00
/*u8 light_decode_table[LIGHT_MAX+1] =
{
0,
5,
12,
22,
35,
50,
65,
85,
100,
120,
140,
160,
185,
215,
255,
2010-12-19 16:51:45 +02:00
};*/
// LIGHT_MAX is 14, 0-14 is 15 values
/*u8 light_decode_table[LIGHT_MAX+1] =
{
0,
9,
12,
14,
16,
20,
26,
34,
45,
61,
81,
108,
143,
191,
255,
};*/
2010-11-27 01:02:21 +02:00
#if 0
2010-11-27 01:02:21 +02:00
/*
#!/usr/bin/python
from math import *
from sys import stdout
# We want 0 at light=0 and 255 at light=LIGHT_MAX
LIGHT_MAX = 14
#FACTOR = 0.69
FACTOR = 0.75
L = []
for i in range(1,LIGHT_MAX+1):
L.append(int(round(255.0 * FACTOR ** (i-1))))
L.append(0)
L.reverse()
for i in L:
stdout.write(str(i)+",\n")
*/
u8 light_decode_table[LIGHT_MAX+1] =
{
0,
6,
8,
11,
14,
19,
26,
34,
45,
61,
81,
108,
143,
191,
255,
};
#endif
2010-12-13 03:19:12 +02:00
2010-11-27 01:02:21 +02:00