forked from mtcontrib/weather_pack
minor code cleanup
This commit is contained in:
parent
1f07735c44
commit
e90133b30a
12
init.lua
12
init.lua
@ -2,13 +2,13 @@ local modpath = minetest.get_modpath("weather_pack");
|
|||||||
|
|
||||||
-- If skylayer mod not located then embeded version will be loaded.
|
-- If skylayer mod not located then embeded version will be loaded.
|
||||||
if minetest.get_modpath("skylayer") == nil then
|
if minetest.get_modpath("skylayer") == nil then
|
||||||
dofile(modpath.."/embedded_sky_layer_api.lua")
|
dofile(modpath.."/embedded_sky_layer_api.lua")
|
||||||
end
|
end
|
||||||
|
|
||||||
-- If happy_weather_api mod not located then embeded version will be loaded.
|
-- If happy_weather_api mod not located then embeded version will be loaded.
|
||||||
if minetest.get_modpath("happy_weather_api") == nil then
|
if minetest.get_modpath("happy_weather_api") == nil then
|
||||||
dofile(modpath.."/embedded_happy_weather_api.lua")
|
dofile(modpath.."/embedded_happy_weather_api.lua")
|
||||||
dofile(modpath.."/commands.lua")
|
dofile(modpath.."/commands.lua")
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Happy Weather utilities
|
-- Happy Weather utilities
|
||||||
@ -20,10 +20,10 @@ dofile(modpath.."/heavy_rain.lua")
|
|||||||
dofile(modpath.."/snow.lua")
|
dofile(modpath.."/snow.lua")
|
||||||
|
|
||||||
if minetest.get_modpath("lightning") ~= nil then
|
if minetest.get_modpath("lightning") ~= nil then
|
||||||
dofile(modpath.."/thunder.lua")
|
dofile(modpath.."/thunder.lua")
|
||||||
|
|
||||||
-- Turn off lightning mod 'auto mode'
|
-- Turn off lightning mod 'auto mode'
|
||||||
lightning.auto = false
|
lightning.auto = false
|
||||||
end
|
end
|
||||||
|
|
||||||
dofile(modpath.."/abm.lua")
|
dofile(modpath.."/abm.lua")
|
||||||
|
@ -9,6 +9,7 @@
|
|||||||
local light_rain = {}
|
local light_rain = {}
|
||||||
light_rain.last_check = 0
|
light_rain.last_check = 0
|
||||||
light_rain.check_interval = 200
|
light_rain.check_interval = 200
|
||||||
|
light_rain.chance = 0.15
|
||||||
|
|
||||||
-- Weather identification code
|
-- Weather identification code
|
||||||
light_rain.code = "light_rain"
|
light_rain.code = "light_rain"
|
||||||
@ -26,7 +27,7 @@ local SKYCOLOR_LAYER = "happy_weather_light_rain_sky"
|
|||||||
light_rain.is_starting = function(dtime, position)
|
light_rain.is_starting = function(dtime, position)
|
||||||
if light_rain.last_check + light_rain.check_interval < os.time() then
|
if light_rain.last_check + light_rain.check_interval < os.time() then
|
||||||
light_rain.last_check = os.time()
|
light_rain.last_check = os.time()
|
||||||
if math.random() < 0.15 then
|
if math.random() < light_rain.chance then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -83,7 +84,7 @@ local remove_rain_sound = function(player)
|
|||||||
if sound ~= nil then
|
if sound ~= nil then
|
||||||
minetest.sound_stop(sound)
|
minetest.sound_stop(sound)
|
||||||
sound_handlers[player:get_player_name()] = nil
|
sound_handlers[player:get_player_name()] = nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
light_rain.add_player = function(player)
|
light_rain.add_player = function(player)
|
||||||
@ -98,16 +99,10 @@ end
|
|||||||
|
|
||||||
-- Random texture getter
|
-- Random texture getter
|
||||||
local choice_random_rain_drop_texture = function()
|
local choice_random_rain_drop_texture = function()
|
||||||
local texture_name
|
local base_name = "happy_weather_light_rain_raindrop_"
|
||||||
local random_number = math.random()
|
local number = math.random(1, 4)
|
||||||
if random_number > 0.33 then
|
local extension = ".png"
|
||||||
texture_name = "happy_weather_light_rain_raindrop_1.png"
|
return base_name .. number .. extension
|
||||||
elseif random_number > 0.66 then
|
|
||||||
texture_name = "happy_weather_light_rain_raindrop_2.png"
|
|
||||||
else
|
|
||||||
texture_name = "happy_weather_light_rain_raindrop_3.png"
|
|
||||||
end
|
|
||||||
return texture_name;
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local add_rain_particle = function(player)
|
local add_rain_particle = function(player)
|
||||||
@ -121,16 +116,16 @@ local add_rain_particle = function(player)
|
|||||||
|
|
||||||
if hw_utils.is_outdoor(random_pos) then
|
if hw_utils.is_outdoor(random_pos) then
|
||||||
minetest.add_particle({
|
minetest.add_particle({
|
||||||
pos = {x=random_pos.x, y=random_pos.y, z=random_pos.z},
|
pos = {x=random_pos.x, y=random_pos.y, z=random_pos.z},
|
||||||
velocity = {x=0, y=-10, z=0},
|
velocity = {x=0, y=-10, z=0},
|
||||||
acceleration = {x=0, y=-30, z=0},
|
acceleration = {x=0, y=-30, z=0},
|
||||||
expirationtime = 2,
|
expirationtime = 2,
|
||||||
size = math.random(0.5, 3),
|
size = math.random(0.5, 3),
|
||||||
collisiondetection = true,
|
collisiondetection = true,
|
||||||
collision_removal = true,
|
collision_removal = true,
|
||||||
vertical = true,
|
vertical = true,
|
||||||
texture = choice_random_rain_drop_texture(),
|
texture = choice_random_rain_drop_texture(),
|
||||||
playername = player:get_player_name()
|
playername = player:get_player_name()
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
75
rain.lua
75
rain.lua
@ -9,6 +9,7 @@
|
|||||||
local rain = {}
|
local rain = {}
|
||||||
rain.last_check = 0
|
rain.last_check = 0
|
||||||
rain.check_interval = 300
|
rain.check_interval = 300
|
||||||
|
rain.chance = 0.1
|
||||||
|
|
||||||
-- Weather identification code
|
-- Weather identification code
|
||||||
rain.code = "rain"
|
rain.code = "rain"
|
||||||
@ -24,14 +25,14 @@ local manual_trigger_end = false
|
|||||||
local SKYCOLOR_LAYER = "happy_weather_rain_sky"
|
local SKYCOLOR_LAYER = "happy_weather_rain_sky"
|
||||||
|
|
||||||
rain.is_starting = function(dtime, position)
|
rain.is_starting = function(dtime, position)
|
||||||
if rain.last_check + rain.check_interval < os.time() then
|
if rain.last_check + rain.check_interval < os.time() then
|
||||||
rain.last_check = os.time()
|
rain.last_check = os.time()
|
||||||
if math.random() < 0.1 then
|
if math.random() < rain.chance then
|
||||||
happy_weather.request_to_end("light_rain")
|
happy_weather.request_to_end("light_rain")
|
||||||
happy_weather.request_to_end("heavy_rain")
|
happy_weather.request_to_end("heavy_rain")
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if manual_trigger_start then
|
if manual_trigger_start then
|
||||||
manual_trigger_start = false
|
manual_trigger_start = false
|
||||||
@ -42,13 +43,13 @@ rain.is_starting = function(dtime, position)
|
|||||||
end
|
end
|
||||||
|
|
||||||
rain.is_ending = function(dtime)
|
rain.is_ending = function(dtime)
|
||||||
if rain.last_check + rain.check_interval < os.time() then
|
if rain.last_check + rain.check_interval < os.time() then
|
||||||
rain.last_check = os.time()
|
rain.last_check = os.time()
|
||||||
if math.random() < 0.6 then
|
if math.random() < 0.6 then
|
||||||
happy_weather.request_to_start("light_rain")
|
happy_weather.request_to_start("light_rain")
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if manual_trigger_end then
|
if manual_trigger_end then
|
||||||
manual_trigger_end = false
|
manual_trigger_end = false
|
||||||
@ -86,7 +87,7 @@ local remove_rain_sound = function(player)
|
|||||||
if sound ~= nil then
|
if sound ~= nil then
|
||||||
minetest.sound_stop(sound)
|
minetest.sound_stop(sound)
|
||||||
sound_handlers[player:get_player_name()] = nil
|
sound_handlers[player:get_player_name()] = nil
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
rain.add_player = function(player)
|
rain.add_player = function(player)
|
||||||
@ -101,16 +102,10 @@ end
|
|||||||
|
|
||||||
-- Random texture getter
|
-- Random texture getter
|
||||||
local choice_random_rain_drop_texture = function()
|
local choice_random_rain_drop_texture = function()
|
||||||
local texture_name
|
local base_name = "happy_weather_light_rain_raindrop_"
|
||||||
local random_number = math.random()
|
local number = math.random(1, 4)
|
||||||
if random_number > 0.33 then
|
local extension = ".png"
|
||||||
texture_name = "happy_weather_light_rain_raindrop_1.png"
|
return base_name .. number .. extension
|
||||||
elseif random_number > 0.66 then
|
|
||||||
texture_name = "happy_weather_light_rain_raindrop_2.png"
|
|
||||||
else
|
|
||||||
texture_name = "happy_weather_light_rain_raindrop_3.png"
|
|
||||||
end
|
|
||||||
return texture_name;
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local add_rain_particle = function(player)
|
local add_rain_particle = function(player)
|
||||||
@ -124,16 +119,16 @@ local add_rain_particle = function(player)
|
|||||||
|
|
||||||
if hw_utils.is_outdoor(random_pos) then
|
if hw_utils.is_outdoor(random_pos) then
|
||||||
minetest.add_particle({
|
minetest.add_particle({
|
||||||
pos = {x=random_pos.x, y=random_pos.y, z=random_pos.z},
|
pos = {x=random_pos.x, y=random_pos.y, z=random_pos.z},
|
||||||
velocity = {x=0, y=-15, z=0},
|
velocity = {x=0, y=-15, z=0},
|
||||||
acceleration = {x=0, y=-35, z=0},
|
acceleration = {x=0, y=-35, z=0},
|
||||||
expirationtime = 2,
|
expirationtime = 2,
|
||||||
size = math.random(1, 6),
|
size = math.random(1, 4),
|
||||||
collisiondetection = true,
|
collisiondetection = true,
|
||||||
collision_removal = true,
|
collision_removal = true,
|
||||||
vertical = true,
|
vertical = true,
|
||||||
texture = choice_random_rain_drop_texture(),
|
texture = choice_random_rain_drop_texture(),
|
||||||
playername = player:get_player_name()
|
playername = player:get_player_name()
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -147,10 +142,10 @@ local display_rain_particles = function(player)
|
|||||||
end
|
end
|
||||||
|
|
||||||
rain.in_area = function(position)
|
rain.in_area = function(position)
|
||||||
if hw_utils.is_biome_frozen(position) or
|
if hw_utils.is_biome_frozen(position) or
|
||||||
hw_utils.is_biome_dry(position) then
|
hw_utils.is_biome_dry(position) then
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
if position.y > -10 then
|
if position.y > -10 then
|
||||||
return true
|
return true
|
||||||
|
63
snow.lua
63
snow.lua
@ -9,6 +9,7 @@
|
|||||||
local snow = {}
|
local snow = {}
|
||||||
snow.last_check = 0
|
snow.last_check = 0
|
||||||
snow.check_interval = 200
|
snow.check_interval = 200
|
||||||
|
snow.chance = 0.2
|
||||||
|
|
||||||
-- Weather identification code
|
-- Weather identification code
|
||||||
snow.code = "snow"
|
snow.code = "snow"
|
||||||
@ -21,12 +22,12 @@ local manual_trigger_end = false
|
|||||||
local SKYCOLOR_LAYER = "happy_weather_snow_sky"
|
local SKYCOLOR_LAYER = "happy_weather_snow_sky"
|
||||||
|
|
||||||
snow.is_starting = function(dtime, position)
|
snow.is_starting = function(dtime, position)
|
||||||
if snow.last_check + snow.check_interval < os.time() then
|
if snow.last_check + snow.check_interval < os.time() then
|
||||||
snow.last_check = os.time()
|
snow.last_check = os.time()
|
||||||
if math.random() < 0.2 then
|
if math.random() < snow.chance then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if manual_trigger_start then
|
if manual_trigger_start then
|
||||||
manual_trigger_start = false
|
manual_trigger_start = false
|
||||||
@ -37,12 +38,12 @@ snow.is_starting = function(dtime, position)
|
|||||||
end
|
end
|
||||||
|
|
||||||
snow.is_ending = function(dtime)
|
snow.is_ending = function(dtime)
|
||||||
if snow.last_check + snow.check_interval < os.time() then
|
if snow.last_check + snow.check_interval < os.time() then
|
||||||
snow.last_check = os.time()
|
snow.last_check = os.time()
|
||||||
if math.random() < 0.5 then
|
if math.random() < 0.5 then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if manual_trigger_end then
|
if manual_trigger_end then
|
||||||
manual_trigger_end = false
|
manual_trigger_end = false
|
||||||
@ -59,7 +60,7 @@ local set_sky_box = function(player_name)
|
|||||||
sl.data = {gradient_data={}}
|
sl.data = {gradient_data={}}
|
||||||
sl.data.gradient_data.colors = {
|
sl.data.gradient_data.colors = {
|
||||||
{r=0, g=0, b=0},
|
{r=0, g=0, b=0},
|
||||||
{r=241, g=244, b=249},
|
{r=231, g=234, b=239},
|
||||||
{r=0, g=0, b=0}
|
{r=0, g=0, b=0}
|
||||||
}
|
}
|
||||||
skylayer.add_layer(player_name, sl)
|
skylayer.add_layer(player_name, sl)
|
||||||
@ -75,16 +76,10 @@ end
|
|||||||
|
|
||||||
-- Random texture getter
|
-- Random texture getter
|
||||||
local choice_random_rain_drop_texture = function()
|
local choice_random_rain_drop_texture = function()
|
||||||
local texture_name
|
local base_name = "happy_weather_light_snow_snowflake_"
|
||||||
local random_number = math.random()
|
local number = math.random(1, 3)
|
||||||
if random_number > 0.33 then
|
local extension = ".png"
|
||||||
texture_name = "happy_weather_light_snow_snowflake_1.png"
|
return base_name .. number .. extension
|
||||||
elseif random_number > 0.66 then
|
|
||||||
texture_name = "happy_weather_light_snow_snowflake_2.png"
|
|
||||||
else
|
|
||||||
texture_name = "happy_weather_light_snow_snowflake_3.png"
|
|
||||||
end
|
|
||||||
return texture_name;
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local add_particle = function(player)
|
local add_particle = function(player)
|
||||||
@ -100,9 +95,9 @@ local add_particle = function(player)
|
|||||||
minetest.add_particle({
|
minetest.add_particle({
|
||||||
pos = {x=random_pos.x, y=random_pos.y, z=random_pos.z},
|
pos = {x=random_pos.x, y=random_pos.y, z=random_pos.z},
|
||||||
velocity = {x = math.random(-1,-0.5), y = math.random(-2,-1), z = math.random(-1,-0.5)},
|
velocity = {x = math.random(-1,-0.5), y = math.random(-2,-1), z = math.random(-1,-0.5)},
|
||||||
acceleration = {x = math.random(-1,-0.5), y=-0.5, z = math.random(-1,-0.5)},
|
acceleration = {x = math.random(-1,-0.5), y=-0.5, z = math.random(-1,-0.5)},
|
||||||
expirationtime = 2.0,
|
expirationtime = 2.0,
|
||||||
size = math.random(0.5, 2),
|
size = math.random(0.5, 2),
|
||||||
collisiondetection = true,
|
collisiondetection = true,
|
||||||
collision_removal = true,
|
collision_removal = true,
|
||||||
vertical = true,
|
vertical = true,
|
||||||
@ -123,19 +118,19 @@ end
|
|||||||
local particles_number_per_update = 10
|
local particles_number_per_update = 10
|
||||||
snow.render = function(dtime, player)
|
snow.render = function(dtime, player)
|
||||||
for i=particles_number_per_update, 1,-1 do
|
for i=particles_number_per_update, 1,-1 do
|
||||||
display_particles(player)
|
display_particles(player)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
snow.in_area = function(position)
|
snow.in_area = function(position)
|
||||||
if hw_utils.is_biome_frozen(position) == false then
|
if hw_utils.is_biome_frozen(position) == false then
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
if position.y > -10 then
|
if position.y > -10 then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
snow.start = function()
|
snow.start = function()
|
||||||
|
BIN
textures/happy_weather_light_rain_raindrop_4.png
Normal file
BIN
textures/happy_weather_light_rain_raindrop_4.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 256 B |
@ -11,6 +11,7 @@
|
|||||||
local thunder = {}
|
local thunder = {}
|
||||||
thunder.last_check = 0
|
thunder.last_check = 0
|
||||||
thunder.check_interval = 100
|
thunder.check_interval = 100
|
||||||
|
thunder.chance = 0.8
|
||||||
|
|
||||||
-- Weather identification code
|
-- Weather identification code
|
||||||
thunder.code = "thunder"
|
thunder.code = "thunder"
|
||||||
@ -33,7 +34,7 @@ thunder.is_starting = function(dtime)
|
|||||||
|
|
||||||
if thunder.last_check + thunder.check_interval < os.time() then
|
if thunder.last_check + thunder.check_interval < os.time() then
|
||||||
thunder.last_check = os.time()
|
thunder.last_check = os.time()
|
||||||
if math.random() < 0.8 and happy_weather.is_weather_active("heavy_rain") then
|
if math.random() < thunder.chance and happy_weather.is_weather_active("heavy_rain") then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -68,8 +69,8 @@ local calculate_thunder_strike_delay = function()
|
|||||||
end
|
end
|
||||||
|
|
||||||
thunder.render = function(dtime, player)
|
thunder.render = function(dtime, player)
|
||||||
if happy_weather.is_player_in_weather_area(player:get_player_name(),
|
local player_name = player:get_player_name()
|
||||||
"heavy_rain") == false then
|
if happy_weather.is_player_in_weather_area(player_name, "heavy_rain") == false then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
191
utils.lua
191
utils.lua
@ -25,129 +25,128 @@ end
|
|||||||
-- checks if player is undewater. This is needed in order to
|
-- checks if player is undewater. This is needed in order to
|
||||||
-- turn off weather particles generation.
|
-- turn off weather particles generation.
|
||||||
hw_utils.is_underwater = function(player)
|
hw_utils.is_underwater = function(player)
|
||||||
local ppos = player:getpos()
|
local ppos = player:getpos()
|
||||||
local offset = player:get_eye_offset()
|
local offset = player:get_eye_offset()
|
||||||
local player_eye_pos = {x = ppos.x + offset.x,
|
local player_eye_pos = {
|
||||||
y = ppos.y + offset.y + 1.5,
|
x = ppos.x + offset.x,
|
||||||
z = ppos.z + offset.z}
|
y = ppos.y + offset.y + 1.5,
|
||||||
local node_level = minetest.get_node_level(player_eye_pos)
|
z = ppos.z + offset.z}
|
||||||
if node_level == 8 or node_level == 7 then
|
local node_level = minetest.get_node_level(player_eye_pos)
|
||||||
return true
|
if node_level == 8 or node_level == 7 then
|
||||||
end
|
return true
|
||||||
return false
|
end
|
||||||
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
-- trying to locate position for particles by player look direction for performance reason.
|
-- trying to locate position for particles by player look direction for performance reason.
|
||||||
-- it is costly to generate many particles around player so goal is focus mainly on front view.
|
-- it is costly to generate many particles around player so goal is focus mainly on front view.
|
||||||
hw_utils.get_random_pos = function(player, offset)
|
hw_utils.get_random_pos = function(player, offset)
|
||||||
local look_dir = player:get_look_dir()
|
local look_dir = player:get_look_dir()
|
||||||
local player_pos = player:getpos()
|
local player_pos = player:getpos()
|
||||||
|
|
||||||
local random_pos_x = 0
|
local random_pos_x = 0
|
||||||
local random_pos_y = 0
|
local random_pos_y = 0
|
||||||
local random_pos_z = 0
|
local random_pos_z = 0
|
||||||
|
|
||||||
if look_dir.x > 0 then
|
if look_dir.x > 0 then
|
||||||
if look_dir.z > 0 then
|
if look_dir.z > 0 then
|
||||||
random_pos_x = math.random(player_pos.x - offset.back, player_pos.x + offset.front) + math.random()
|
random_pos_x = math.random(player_pos.x - offset.back, player_pos.x + offset.front) + math.random()
|
||||||
random_pos_z = math.random(player_pos.z - offset.back, player_pos.z + offset.front) + math.random()
|
random_pos_z = math.random(player_pos.z - offset.back, player_pos.z + offset.front) + math.random()
|
||||||
else
|
else
|
||||||
random_pos_x = math.random(player_pos.x - offset.back, player_pos.x + offset.front) + math.random()
|
random_pos_x = math.random(player_pos.x - offset.back, player_pos.x + offset.front) + math.random()
|
||||||
random_pos_z = math.random(player_pos.z - offset.front, player_pos.z + offset.back) + math.random()
|
random_pos_z = math.random(player_pos.z - offset.front, player_pos.z + offset.back) + math.random()
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if look_dir.z > 0 then
|
if look_dir.z > 0 then
|
||||||
random_pos_x = math.random(player_pos.x - offset.front, player_pos.x + offset.back) + math.random()
|
random_pos_x = math.random(player_pos.x - offset.front, player_pos.x + offset.back) + math.random()
|
||||||
random_pos_z = math.random(player_pos.z - offset.back, player_pos.z + offset.front) + math.random()
|
random_pos_z = math.random(player_pos.z - offset.back, player_pos.z + offset.front) + math.random()
|
||||||
else
|
else
|
||||||
random_pos_x = math.random(player_pos.x - offset.front, player_pos.x + offset.back) + math.random()
|
random_pos_x = math.random(player_pos.x - offset.front, player_pos.x + offset.back) + math.random()
|
||||||
random_pos_z = math.random(player_pos.z - offset.front, player_pos.z + offset.back) + math.random()
|
random_pos_z = math.random(player_pos.z - offset.front, player_pos.z + offset.back) + math.random()
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if offset.bottom ~= nil then
|
if offset.bottom ~= nil then
|
||||||
random_pos_y = math.random(player_pos.y - offset.bottom, player_pos.y + offset.top)
|
random_pos_y = math.random(player_pos.y - offset.bottom, player_pos.y + offset.top)
|
||||||
else
|
else
|
||||||
random_pos_y = player_pos.y + offset.top
|
random_pos_y = player_pos.y + offset.top
|
||||||
end
|
end
|
||||||
|
|
||||||
|
return {x=random_pos_x, y=random_pos_y, z=random_pos_z}
|
||||||
return {x=random_pos_x, y=random_pos_y, z=random_pos_z}
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local np_temp = {
|
local np_temp = {
|
||||||
offset = 50,
|
offset = 50,
|
||||||
scale = 50,
|
scale = 50,
|
||||||
spread = {x = 1000, y = 1000, z = 1000},
|
spread = {x = 1000, y = 1000, z = 1000},
|
||||||
seed = 5349,
|
seed = 5349,
|
||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.5,
|
persist = 0.5,
|
||||||
lacunarity = 2.0
|
lacunarity = 2.0
|
||||||
}
|
}
|
||||||
|
|
||||||
local np_humid = {
|
local np_humid = {
|
||||||
offset = 50,
|
offset = 50,
|
||||||
scale = 50,
|
scale = 50,
|
||||||
spread = {x = 1000, y = 1000, z = 1000},
|
spread = {x = 1000, y = 1000, z = 1000},
|
||||||
seed = 842,
|
seed = 842,
|
||||||
octaves = 3,
|
octaves = 3,
|
||||||
persist = 0.5,
|
persist = 0.5,
|
||||||
lacunarity = 2.0
|
lacunarity = 2.0
|
||||||
}
|
}
|
||||||
|
|
||||||
hw_utils.is_biome_frozen = function(position)
|
local is_biome_frozen_v7 = function(position)
|
||||||
local mg_name = minetest.get_mapgen_setting("mg_name")
|
local posx = math.floor(position.x)
|
||||||
if mg_name == "v6" then
|
local posz = math.floor(position.z)
|
||||||
return false -- v6 not supported yet.
|
local noise_obj = minetest.get_perlin(np_temp)
|
||||||
end
|
local noise_temp = noise_obj:get2d({x = posx, y = posz})
|
||||||
return hw_utils.is_biome_frozen_v7(position)
|
|
||||||
|
-- below 35 heat biome considered to be frozen type
|
||||||
|
return noise_temp < 35
|
||||||
end
|
end
|
||||||
|
|
||||||
hw_utils.is_biome_frozen_v7 = function(position)
|
hw_utils.is_biome_frozen = function(position)
|
||||||
local posx = math.floor(position.x)
|
local mg_name = minetest.get_mapgen_setting("mg_name")
|
||||||
local posz = math.floor(position.z)
|
if mg_name == "v6" then
|
||||||
local noise_obj = minetest.get_perlin(np_temp)
|
return false -- v6 not supported yet.
|
||||||
local noise_temp = noise_obj:get2d({x = posx, y = posz})
|
end
|
||||||
|
return is_biome_frozen_v7(position)
|
||||||
|
end
|
||||||
|
|
||||||
-- below 35 heat biome considered to be frozen type
|
local is_biome_dry_v7 = function(position)
|
||||||
return noise_temp < 35
|
local posx = math.floor(position.x)
|
||||||
|
local posz = math.floor(position.z)
|
||||||
|
local noise_obj = minetest.get_perlin(np_humid)
|
||||||
|
local noise_humid = noise_obj:get2d({x = posx, y = posz})
|
||||||
|
|
||||||
|
-- below 50 humid biome considered to be dry type (at least by this mod)
|
||||||
|
return noise_humid < 50
|
||||||
end
|
end
|
||||||
|
|
||||||
hw_utils.is_biome_dry = function(position)
|
hw_utils.is_biome_dry = function(position)
|
||||||
local mg_name = minetest.get_mapgen_setting("mg_name")
|
local mg_name = minetest.get_mapgen_setting("mg_name")
|
||||||
if mg_name == "v6" then
|
if mg_name == "v6" then
|
||||||
return false -- v6 not supported yet.
|
return false -- v6 not supported yet.
|
||||||
end
|
end
|
||||||
return hw_utils.is_biome_dry_v7(position)
|
return is_biome_dry_v7(position)
|
||||||
end
|
end
|
||||||
|
|
||||||
hw_utils.is_biome_dry_v7 = function(position)
|
local is_biome_tropic_v7 = function(position)
|
||||||
local posx = math.floor(position.x)
|
local posx = math.floor(position.x)
|
||||||
local posz = math.floor(position.z)
|
local posz = math.floor(position.z)
|
||||||
local noise_obj = minetest.get_perlin(np_humid)
|
local noise_obj = minetest.get_perlin(np_humid)
|
||||||
local noise_humid = noise_obj:get2d({x = posx, y = posz})
|
local noise_humid = noise_obj:get2d({x = posx, y = posz})
|
||||||
|
noise_obj = minetest.get_perlin(np_temp)
|
||||||
|
local noise_temp = noise_obj:get2d({x = posx, y = posz})
|
||||||
|
|
||||||
-- below 50 humid biome considered to be dry type (at least by this mod)
|
-- humid and temp values are taked by testing flying around world (not sure actually)
|
||||||
return noise_humid < 50
|
return noise_humid > 55 and noise_temp > 80
|
||||||
end
|
end
|
||||||
|
|
||||||
hw_utils.is_biome_tropic = function(position)
|
hw_utils.is_biome_tropic = function(position)
|
||||||
local mg_name = minetest.get_mapgen_setting("mg_name")
|
local mg_name = minetest.get_mapgen_setting("mg_name")
|
||||||
if mg_name == "v6" then
|
if mg_name == "v6" then
|
||||||
return false -- v6 not supported yet.
|
return false -- v6 not supported yet.
|
||||||
end
|
end
|
||||||
return hw_utils.is_biome_tropic_v7(position)
|
return is_biome_tropic_v7(position)
|
||||||
end
|
end
|
||||||
|
|
||||||
hw_utils.is_biome_tropic_v7 = function(position)
|
|
||||||
local posx = math.floor(position.x)
|
|
||||||
local posz = math.floor(position.z)
|
|
||||||
local noise_obj = minetest.get_perlin(np_humid)
|
|
||||||
local noise_humid = noise_obj:get2d({x = posx, y = posz})
|
|
||||||
noise_obj = minetest.get_perlin(np_temp)
|
|
||||||
local noise_temp = noise_obj:get2d({x = posx, y = posz})
|
|
||||||
|
|
||||||
-- humid and temp values are taked by testing flying around world (not sure actually)
|
|
||||||
return noise_humid > 55 and noise_temp > 80
|
|
||||||
end
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user