mirror of
https://github.com/minetest-mods/magma_conduits.git
synced 2025-01-22 20:31:42 +01:00
enhance findvolcano, chunk sizes limited to multiples of mapblocks
This commit is contained in:
parent
b2170d10e2
commit
78172cb38b
@ -6,7 +6,8 @@ local radius_vent = 3 -- approximate minimum radius of vent - noise adds a lot t
|
|||||||
local radius_lining = 5 -- the difference between this and the vent radius is about how thick the layer of lining nodes is, though noise will affect it
|
local radius_lining = 5 -- the difference between this and the vent radius is about how thick the layer of lining nodes is, though noise will affect it
|
||||||
local caldera_min = 5 -- minimum radius of caldera
|
local caldera_min = 5 -- minimum radius of caldera
|
||||||
local caldera_max = 20 -- maximum radius of caldera
|
local caldera_max = 20 -- maximum radius of caldera
|
||||||
local chunk_size = 1000
|
local chunk_size = nil
|
||||||
|
local region_mapblocks = 13
|
||||||
|
|
||||||
local snow_line = 120 -- above this elevation snow is added to the dirt type
|
local snow_line = 120 -- above this elevation snow is added to the dirt type
|
||||||
local snow_border = 15 -- transitional zone where there's dirt with snow on it
|
local snow_border = 15 -- transitional zone where there's dirt with snow on it
|
||||||
@ -96,13 +97,22 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local sidelen = maxp.x - minp.x + 1 --length of a mapblock
|
||||||
|
|
||||||
|
if not chunk_size then -- TODO: just look up map block size from settings
|
||||||
|
chunk_size = region_mapblocks * sidelen
|
||||||
|
end
|
||||||
|
|
||||||
local volcano = get_volcano(minp)
|
local volcano = get_volcano(minp)
|
||||||
local depth_peak = volcano.depth_peak
|
local depth_peak = volcano.depth_peak
|
||||||
local base_radius = (depth_peak - depth_maxwidth) * volcano.slope + radius_lining
|
local base_radius = (depth_peak - depth_maxwidth) * volcano.slope + radius_lining
|
||||||
local sidelen = maxp.x - minp.x + 1 --length of a mapblock
|
|
||||||
|
|
||||||
-- early out if the volcano is too far away to matter
|
-- early out if the volcano is too far away to matter
|
||||||
if vector.distance(volcano.location, {x=minp.x+sidelen/2, y=0, z=minp.z+sidelen/2}) > base_radius * 2.5 then
|
if vector.distance(volcano.location, {x=minp.x, y=0, z=minp.z}) > base_radius + 20 and
|
||||||
|
vector.distance(volcano.location, {x=maxp.x, y=0, z=minp.z}) > base_radius + 20 and
|
||||||
|
vector.distance(volcano.location, {x=maxp.x, y=0, z=maxp.z}) > base_radius + 20 and
|
||||||
|
vector.distance(volcano.location, {x=minp.x, y=0, z=maxp.z}) > base_radius + 20
|
||||||
|
then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -225,31 +235,42 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
vm:write_to_map()
|
vm:write_to_map()
|
||||||
end)
|
end)
|
||||||
|
|
||||||
minetest.register_privilege("findvolcano", { description = "Allows players to use a console command to find the nearest volcano", give_to_singleplayer = false})
|
----------------------------------------------------------------------------------------------
|
||||||
|
-- Debugging and sightseeing commands
|
||||||
|
|
||||||
|
minetest.register_privilege("findvolcano", { description = "Allows players to use a console command to find volcanoes", give_to_singleplayer = false})
|
||||||
|
|
||||||
|
local send_volcano_state = function(pos, name)
|
||||||
|
volcano = get_volcano(pos)
|
||||||
|
text = "Nearest volcano is at " .. minetest.pos_to_string(volcano.location, 0)
|
||||||
|
.. "\nHeight: " .. tostring(volcano.depth_peak) .. " Slope: " .. tostring(volcano.slope)
|
||||||
|
.. "\nState: "
|
||||||
|
if volcano.state < state_extinct then
|
||||||
|
text = text .. "Extinct"
|
||||||
|
elseif volcano.state < state_dormant then
|
||||||
|
text = text .. "Dormant"
|
||||||
|
else
|
||||||
|
text = text .. "Active"
|
||||||
|
end
|
||||||
|
minetest.chat_send_player(name, text)
|
||||||
|
end
|
||||||
|
|
||||||
minetest.register_chatcommand("findvolcano", {
|
minetest.register_chatcommand("findvolcano", {
|
||||||
params = "pos", -- Short parameter description
|
params = "pos", -- Short parameter description
|
||||||
description = "find the volcano in the player's map region, or in the map region containing pos if provided",
|
description = "find the volcano in the player's map region, or in the map region containing pos if provided",
|
||||||
func = function(name, param)
|
func = function(name, param)
|
||||||
if minetest.check_player_privs(name, {findvolcano = true}) then
|
if minetest.check_player_privs(name, {findvolcano = true}) then
|
||||||
pos = tonumber(param)
|
local pos = {}
|
||||||
if pos ~= nil then
|
pos.x, pos.y, pos.z = string.match(param, "^([%d.-]+)[, ] *([%d.-]+)[, ] *([%d.-]+)$")
|
||||||
--TODO
|
pos.x = tonumber(pos.x)
|
||||||
|
pos.y = tonumber(pos.y)
|
||||||
|
pos.z = tonumber(pos.z)
|
||||||
|
if pos.x and pos.y and pos.z then
|
||||||
|
send_volcano_state(pos, name)
|
||||||
return true
|
return true
|
||||||
else
|
else
|
||||||
playerobj = minetest.get_player_by_name(name)
|
playerobj = minetest.get_player_by_name(name)
|
||||||
volcano = get_volcano(playerobj:get_pos())
|
send_volcano_state(playerobj:get_pos(), name)
|
||||||
text = "Nearest volcano is at " .. minetest.pos_to_string(volcano.location, 0)
|
|
||||||
.. "\nHeight: " .. tostring(volcano.depth_peak) .. " Slope: " .. tostring(volcano.slope)
|
|
||||||
.. "\nState: "
|
|
||||||
if volcano.state < state_extinct then
|
|
||||||
text = text .. "Extinct"
|
|
||||||
elseif volcano.state < state_dormant then
|
|
||||||
text = text .. "Dormant"
|
|
||||||
else
|
|
||||||
text = text .. "Active"
|
|
||||||
end
|
|
||||||
minetest.chat_send_player(name, text)
|
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
|
Loading…
Reference in New Issue
Block a user