forked from mtcontrib/weather_pack
		
	minor code cleanup
This commit is contained in:
		
							
								
								
									
										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 |  | ||||||
|  |  | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user