should disable falling snow in deserts

This commit is contained in:
HybridDog 2015-05-01 19:37:29 +02:00
parent 46cf4e907a
commit c8c2fbd013

View File

@ -40,188 +40,192 @@ near torches and lava.
--============================================================= --=============================================================
if snow.enable_snowfall then if not snow.enable_snowfall then
return
end
local weather_legacy local weather_legacy
local read_weather_legacy = function () local read_weather_legacy = function ()
local file = io.open(minetest.get_worldpath().."/weather_v6", "r") local file = io.open(minetest.get_worldpath().."/weather_v6", "r")
if not file then return end if not file then return end
local readweather = file:read() local readweather = file:read()
file:close() file:close()
return readweather return readweather
end end
--Weather for legacy versions of minetest. --Weather for legacy versions of minetest.
local save_weather_legacy = function () local save_weather_legacy = function ()
local file = io.open(minetest.get_worldpath().."/weather_v6", "w+") local file = io.open(minetest.get_worldpath().."/weather_v6", "w+")
file:write(weather_legacy) file:write(weather_legacy)
file:close() file:close()
end end
weather_legacy = read_weather_legacy() or "" weather_legacy = read_weather_legacy() or ""
minetest.register_globalstep(function(dtime) minetest.register_globalstep(function(dtime)
if weather_legacy == "snow" then
if math.random(1, 10000) == 1 then
weather_legacy = "none"
save_weather_legacy()
end
else
if math.random(1, 50000) == 2 then
weather_legacy = "snow"
save_weather_legacy()
end
end
end)
--Get snow at position.
local get_snow = function(pos)
--Legacy support.
if weather_legacy == "snow" then if weather_legacy == "snow" then
local perlin1 = minetest.env:get_perlin(112,3, 0.5, 150) if math.random(1, 10000) == 1 then
if perlin1:get2d( {x=pos.x, y=pos.z} ) > 0.53 then weather_legacy = "none"
return true save_weather_legacy()
else
return false
end end
else else
if math.random(1, 50000) == 2 then
weather_legacy = "snow"
save_weather_legacy()
end
end
end)
-- copied from meru mod
local SEEDDIFF3 = 9130 -- 9130 -- Values should match minetest mapgen desert perlin.
local OCTAVES3 = 3 -- 3
local PERSISTENCE3 = 0.5 -- 0.5
local SCALE3 = 250 -- 250
--Get snow at position.
local get_snow = function(pos)
--Legacy support.
if weather_legacy == "snow" then
local perlin1 = minetest.get_perlin(112,3, 0.5, 150)
if perlin1:get2d({x=pos.x, y=pos.z}) <= 0.53 then
return false return false
end end
end
local addvectors = vector and vector.add -- disable falling snow in desert
local desert_perlin = minetest.get_perlin(SEEDDIFF3, OCTAVES3, PERSISTENCE3, SCALE3)
--Returns a random position between minp and maxp. local noise3 = desert_perlin:get2d({x=x+150,y=z+50}) -- Offsets must match minetest mapgen desert perlin.
local randpos = function (minp, maxp) if noise3 > 0.35 then -- Smooth transition 0.35 to 0.45.
local x,y,z return false
if minp.x > maxp.x then
x = math.random(maxp.x,minp.x) else x = math.random(minp.x,maxp.x) end
y = minp.y
if minp.z > maxp.z then
z = math.random(maxp.z,minp.z) else z = math.random(minp.z,maxp.z) end
return {x=x,y=y,z=z}
end
local default_snow_particle = {
amount = 3,
time = 0.5,
exptime = 5,
size = 50,
collisiondetection = false,
vertical = false,
}
local function get_snow_particledef(data)
for n,i in pairs(default_snow_particle) do
data[n] = data[n] or i
end end
for _,i in pairs({"vel", "acc", "exptime", "size"}) do return true
data["min"..i] = data[i] end
data["max"..i] = data[i] return false
end
local addvectors = vector and vector.add
--Returns a random position between minp and maxp.
local randpos = function (minp, maxp)
local x,y,z
if minp.x > maxp.x then
x = math.random(maxp.x,minp.x) else x = math.random(minp.x,maxp.x) end
y = minp.y
if minp.z > maxp.z then
z = math.random(maxp.z,minp.z) else z = math.random(minp.z,maxp.z) end
return {x=x,y=y,z=z}
end
local default_snow_particle = {
amount = 3,
time = 0.5,
exptime = 5,
size = 50,
collisiondetection = false,
vertical = false,
}
local function get_snow_particledef(data)
for n,i in pairs(default_snow_particle) do
data[n] = data[n] or i
end
for _,i in pairs({"vel", "acc", "exptime", "size"}) do
data["min"..i] = data[i]
data["max"..i] = data[i]
end
data.texture = "weather_snow.png^[transform"..math.random(0,7)
return data
end
local function snow_fall(pos, player, animate)
local ground_y = nil
for y=pos.y+10,pos.y+20,1 do
local n = minetest.get_node({x=pos.x,y=y,z=pos.z}).name
if n ~= "air" and n ~= "ignore" then
return
end end
data.texture = "weather_snow.png^[transform"..math.random(0,7)
return data
end end
for y=pos.y+10,pos.y-15,-1 do
local snow_fall=function (pos, player, animate) local n = minetest.get_node({x=pos.x,y=y,z=pos.z}).name
local ground_y = nil if n ~= "air" and n ~= "ignore" then
for y=pos.y+10,pos.y+20,1 do ground_y = y
local n = minetest.env:get_node({x=pos.x,y=y,z=pos.z}).name break
if n ~= "air" and n ~= "ignore" then end
return
end
end
for y=pos.y+10,pos.y-15,-1 do
local n = minetest.env:get_node({x=pos.x,y=y,z=pos.z}).name
if n ~= "air" and n ~= "ignore" then
ground_y = y
break
end
end
if not ground_y then return end
pos = {x=pos.x, y=ground_y, z=pos.z}
local spos = {x=pos.x, y=ground_y+10, z=pos.z}
if get_snow(pos) then
if animate then
local minp = addvectors(spos, {x=-9, y=3, z=-9})
local maxp = addvectors(spos, {x= 9, y=5, z= 9})
local vel = {x=0, y= -1, z=-1}
local acc = {x=0, y= 0, z=0}
minetest.add_particlespawner(get_snow_particledef({
minpos = minp,
maxpos = maxp,
vel = vel,
acc = acc,
playername = player:get_player_name()
}))
end
snow.place(pos, true)
--minetest.place_node({x=pos.x, y=pos.y+2, z=pos.z}, {name="default:snow"}) -- LazyJ
end
end end
if not ground_y then return end
pos = {x=pos.x, y=ground_y, z=pos.z}
local spos = {x=pos.x, y=ground_y+10, z=pos.z}
-- Snow
minetest.register_globalstep(function(dtime)
for _, player in pairs(minetest.get_connected_players()) do
local ppos = player:getpos()
local sminp = addvectors(ppos, {x=-20, y=0, z=-20}) if get_snow(pos) then
local smaxp = addvectors(ppos, {x= 20, y=0, z= 20}) if animate then
local minp = addvectors(spos, {x=-9, y=3, z=-9})
local maxp = addvectors(spos, {x= 9, y=5, z= 9})
local vel = {x=0, y= -1, z=-1}
local acc = {x=0, y= 0, z=0}
minetest.add_particlespawner(get_snow_particledef({
minpos = minp,
maxpos = maxp,
vel = vel,
acc = acc,
playername = player:get_player_name()
}))
end
snow.place(pos, true)
--minetest.place_node({x=pos.x, y=pos.y+2, z=pos.z}, {name="default:snow"}) -- LazyJ
end
end
-- Make sure player is not in a cave/house... -- Snow
if get_snow(ppos) and minetest.env:get_node_light(ppos, 0.5) == 15 then minetest.register_globalstep(function(dtime)
for _, player in pairs(minetest.get_connected_players()) do
local ppos = player:getpos()
local minp = addvectors(ppos, {x=-9, y=3, z=-9}) local sminp = addvectors(ppos, {x=-20, y=0, z=-20})
local maxp = addvectors(ppos, {x= 9, y=5, z= 9}) local smaxp = addvectors(ppos, {x= 20, y=0, z= 20})
local minp_deep = addvectors(ppos, {x=-5, y=3.2, z=-5}) -- Make sure player is not in a cave/house...
local maxp_deep = addvectors(ppos, {x= 5, y=1.6, z= 5}) if get_snow(ppos) and minetest.get_node_light(ppos, 0.5) == 15 then
local vel = {x=0, y= -1, z=-1} local minp = addvectors(ppos, {x=-9, y=3, z=-9})
local acc = {x=0, y= 0, z=0} local maxp = addvectors(ppos, {x= 9, y=5, z= 9})
if not snow.lighter_snowfall then local minp_deep = addvectors(ppos, {x=-5, y=3.2, z=-5})
minetest.add_particlespawner(get_snow_particledef({ local maxp_deep = addvectors(ppos, {x= 5, y=1.6, z= 5})
amount = 5,
minpos = minp,
maxpos = maxp,
vel = vel,
acc = acc,
size = 25,
playername = player:get_player_name()
}))
minetest.add_particlespawner(get_snow_particledef({ local vel = {x=0, y= -1, z=-1}
amount = 4, local acc = {x=0, y= 0, z=0}
minpos = minp_deep,
maxpos = maxp_deep,
vel = vel,
acc = acc,
exptime = 4,
size = 25,
playername = player:get_player_name()
}))
if math.random(1,5) == 4 then if not snow.lighter_snowfall then
snow_fall(randpos(sminp, smaxp), player) minetest.add_particlespawner(get_snow_particledef({
end amount = 5,
else minpos = minp,
if math.random(1,5) == 4 then maxpos = maxp,
snow_fall(randpos(sminp, smaxp), player, true) vel = vel,
end acc = acc,
size = 25,
playername = player:get_player_name()
}))
minetest.add_particlespawner(get_snow_particledef({
amount = 4,
minpos = minp_deep,
maxpos = maxp_deep,
vel = vel,
acc = acc,
exptime = 4,
size = 25,
playername = player:get_player_name()
}))
if math.random(1,5) == 4 then
snow_fall(randpos(sminp, smaxp), player)
end end
else else
if math.random(1,5) == 4 then if math.random(1,5) == 4 then
snow_fall(randpos(sminp, smaxp), player, true) snow_fall(randpos(sminp, smaxp), player, true)
end end
end end
end end
end) end
end)
end