forked from mtcontrib/minetest-mod-snow
dont generate every snow node with the same height, use the weierstraß function
This commit is contained in:
parent
32b08f6738
commit
0443994f06
@ -31,6 +31,31 @@ local function biome_to_string(num,num2)
|
|||||||
return biome
|
return biome
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function do_ws_func(a, x)
|
||||||
|
local n = x/(16000)
|
||||||
|
local y = 0
|
||||||
|
for k=1,1000 do
|
||||||
|
y = y + 1000*(math.sin(math.pi * k^a * n)/(math.pi * k^a))
|
||||||
|
end
|
||||||
|
return y
|
||||||
|
end
|
||||||
|
|
||||||
|
local ws_lists = {}
|
||||||
|
local function get_ws_list(a,x)
|
||||||
|
ws_lists[a] = ws_lists[a] or {}
|
||||||
|
local v = ws_lists[a][x]
|
||||||
|
if v then
|
||||||
|
return v
|
||||||
|
end
|
||||||
|
v = {}
|
||||||
|
for x=x,x + (80 - 1) do
|
||||||
|
local y = do_ws_func(a, x)
|
||||||
|
v[x] = y
|
||||||
|
end
|
||||||
|
ws_lists[a][x] = v
|
||||||
|
return v
|
||||||
|
end
|
||||||
|
|
||||||
-- On generated function
|
-- On generated function
|
||||||
|
|
||||||
minetest.register_on_generated(function(minp, maxp, seed)
|
minetest.register_on_generated(function(minp, maxp, seed)
|
||||||
@ -68,6 +93,8 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
local area = VoxelArea:new({MinEdge=emin, MaxEdge=emax})
|
local area = VoxelArea:new({MinEdge=emin, MaxEdge=emax})
|
||||||
local data = vm:get_data()
|
local data = vm:get_data()
|
||||||
|
|
||||||
|
local snow_tab,num = {},1
|
||||||
|
|
||||||
local sidelen = x1 - x0 + 1
|
local sidelen = x1 - x0 + 1
|
||||||
local chulens = {x=sidelen, y=sidelen, z=sidelen}
|
local chulens = {x=sidelen, y=sidelen, z=sidelen}
|
||||||
local nvals_cold = minetest.get_perlin_map(np_cold, chulens):get2dMap_flat({x=x0, y=z0})
|
local nvals_cold = minetest.get_perlin_map(np_cold, chulens):get2dMap_flat({x=x0, y=z0})
|
||||||
@ -157,7 +184,8 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
|
|
||||||
if ground_y and data[node] == c_dirt_with_grass then
|
if ground_y and data[node] == c_dirt_with_grass then
|
||||||
if alpine and test > 0.53 then
|
if alpine and test > 0.53 then
|
||||||
data[abovenode] = c_snow
|
snow_tab[num] = {abovenode, z, x, test}
|
||||||
|
num = num+1
|
||||||
for y = ground_y, -6, -1 do
|
for y = ground_y, -6, -1 do
|
||||||
local vi = area:index(x, y, z)
|
local vi = area:index(x, y, z)
|
||||||
if data[vi] == c_stone then
|
if data[vi] == c_stone then
|
||||||
@ -176,18 +204,21 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
data[abovenode] = c_snow_block
|
data[abovenode] = c_snow_block
|
||||||
else
|
else
|
||||||
data[node] = c_dirt_with_snow
|
data[node] = c_dirt_with_snow
|
||||||
data[abovenode] = c_snow
|
snow_tab[num] = {abovenode, z, x, test}
|
||||||
|
num = num+1
|
||||||
end
|
end
|
||||||
elseif ground_y and data[node] == c_sand then
|
elseif ground_y and data[node] == c_sand then
|
||||||
if not icy then
|
if not icy then
|
||||||
data[abovenode] = c_snow
|
snow_tab[num] = {abovenode, z, x, test}
|
||||||
|
num = num+1
|
||||||
else
|
else
|
||||||
data[node] = c_ice
|
data[node] = c_ice
|
||||||
end
|
end
|
||||||
elseif ground_y and data[node] == c_leaves
|
elseif ground_y and data[node] == c_leaves
|
||||||
or data[node] == c_jungleleaves or data[node] == c_apple then
|
or data[node] == c_jungleleaves or data[node] == c_apple then
|
||||||
if alpine then
|
if alpine then
|
||||||
data[abovenode] = c_snow
|
snow_tab[num] = {abovenode, z, x, test}
|
||||||
|
num = num+1
|
||||||
for y = ground_y, -6, -1 do
|
for y = ground_y, -6, -1 do
|
||||||
local stone = area:index(x, y, z)
|
local stone = area:index(x, y, z)
|
||||||
if data[stone] == c_stone then
|
if data[stone] == c_stone then
|
||||||
@ -197,7 +228,8 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
data[abovenode] = c_snow
|
snow_tab[num] = {abovenode, z, x, test}
|
||||||
|
num = num+1
|
||||||
end
|
end
|
||||||
elseif ground_y
|
elseif ground_y
|
||||||
and data[node] == c_junglegrass then
|
and data[node] == c_junglegrass then
|
||||||
@ -207,8 +239,8 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
for y = ground_y, ground_y-4, -1 do
|
for y = ground_y, ground_y-4, -1 do
|
||||||
local vi = area:index(x, y, z)
|
local vi = area:index(x, y, z)
|
||||||
if data[vi] == c_papyrus then
|
if data[vi] == c_papyrus then
|
||||||
local via = area:index(x, ground_y, z)
|
snow_tab[num] = {area:index(x, ground_y, z), z, x, test}
|
||||||
data[via] = c_snow
|
num = num+1
|
||||||
data[vi] = c_snow_block
|
data[vi] = c_snow_block
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -274,7 +306,32 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local param2s
|
||||||
|
if num ~= 1 then
|
||||||
|
local wsz, wsx
|
||||||
|
for _,i in pairs(snow_tab) do
|
||||||
|
data[i[1]] = c_snow
|
||||||
|
if i[4] > 0.75 then
|
||||||
|
if not wsz then
|
||||||
|
wsz = get_ws_list(5, z0)
|
||||||
|
wsx = get_ws_list(2, x0)
|
||||||
|
param2s = vm:get_param2_data()
|
||||||
|
end
|
||||||
|
local id = math.floor(wsx[i[3]]+wsz[i[2]]*5)%9+1
|
||||||
|
if id ~= 1 then
|
||||||
|
if id == 9 then
|
||||||
|
id = 4
|
||||||
|
end
|
||||||
|
param2s[i[1]] = id*7
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
vm:set_data(data)
|
vm:set_data(data)
|
||||||
|
if param2s then
|
||||||
|
vm:set_param2_data(param2s)
|
||||||
|
end
|
||||||
vm:set_lighting({day=0, night=0})
|
vm:set_lighting({day=0, night=0})
|
||||||
vm:calc_lighting()
|
vm:calc_lighting()
|
||||||
vm:write_to_map()
|
vm:write_to_map()
|
||||||
|
Loading…
Reference in New Issue
Block a user