mirror of
https://github.com/minetest-mods/magma_conduits.git
synced 2025-01-22 20:31:42 +01:00
more volcano options, also add soil cooking
This commit is contained in:
parent
78172cb38b
commit
c0ca6ac965
28
config.lua
28
config.lua
@ -23,19 +23,15 @@ local function setting(stype, name, default, description)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
setting("int", "spread", 400, "Approximate spacing between magma conduits")
|
|
||||||
setting("bool", "remove_default_lava", true, "Removes default mapgen lava")
|
setting("bool", "remove_default_lava", true, "Removes default mapgen lava")
|
||||||
setting("bool", "ameliorate_floods", true, "Ameliorate lava floods on the surface")
|
|
||||||
setting("bool", "obsidian_lining", true, "Add an obsidian lining to magma conduits")
|
|
||||||
setting("bool", "glowing_rock", true, "Cause rock adjacent to lava to convert into glowing form")
|
setting("bool", "glowing_rock", true, "Cause rock adjacent to lava to convert into glowing form")
|
||||||
setting("int", "remove_lava_above", 512, "Remove lava above this y level")
|
setting("bool", "cook_soil", true, "Cause soil and carbon-containing ores to be cooked into other forms by lava")
|
||||||
setting("bool", "magma_veins", true, "Enable magma veins")
|
|
||||||
|
|
||||||
setting("bool", "volcanoes", true, "Enable volcanoes")
|
setting("bool", "magma_veins", true, "Enable magma veins")
|
||||||
setting("int", "volcano_min_height", 20, "Minimum volcano peak")
|
setting("int", "spread", 400, "Approximate spacing between magma conduits")
|
||||||
setting("int", "volcano_max_height", 200, "Maximum volcano peak")
|
setting("int", "remove_lava_above", 512, "Remove lava above this y level")
|
||||||
setting("float", "volcano_min_slope", 0.5, "Minimum volcano slope")
|
setting("bool", "obsidian_lining", true, "Add an obsidian lining to magma conduits")
|
||||||
setting("float", "volcano_max_slope", 1.5, "Maximum volcano slope")
|
setting("bool", "ameliorate_floods", true, "Ameliorate lava floods on the surface")
|
||||||
|
|
||||||
-- Removing this setting on account of issue https://github.com/minetest/minetest/issues/7364
|
-- Removing this setting on account of issue https://github.com/minetest/minetest/issues/7364
|
||||||
--setting("int", "upper_limit", 512, "Upper extent of magma conduits")
|
--setting("int", "upper_limit", 512, "Upper extent of magma conduits")
|
||||||
@ -43,3 +39,15 @@ setting("float", "volcano_max_slope", 1.5, "Maximum volcano slope")
|
|||||||
--from settingtypes.txt:
|
--from settingtypes.txt:
|
||||||
--magma_conduits_upper_limit (Upper extent of magma conduits) int 512
|
--magma_conduits_upper_limit (Upper extent of magma conduits) int 512
|
||||||
--magma_conduits_lower_limit (Lower extent of magma conduits) int -31000
|
--magma_conduits_lower_limit (Lower extent of magma conduits) int -31000
|
||||||
|
|
||||||
|
setting("bool", "volcanoes", true, "Enable volcanoes")
|
||||||
|
setting("int", "volcano_min_height", 20, "Minimum volcano peak")
|
||||||
|
setting("int", "volcano_max_height", 200, "Maximum volcano peak")
|
||||||
|
setting("float", "volcano_min_slope", 0.5, "Minimum volcano slope")
|
||||||
|
setting("float", "volcano_max_slope", 1.5, "Maximum volcano slope")
|
||||||
|
setting("int", "volcano_region_mapblocks", 15, "Map blocks per chunk")
|
||||||
|
|
||||||
|
setting("float", "volcano_probability_active", 0.4, "Probability that there's an active volcano in each region")
|
||||||
|
setting("float", "volcano_probability_dormant", 0.2, "Probability that there's a dormant volcano in each region")
|
||||||
|
setting("float", "volcano_probability_extinct", 0.2, "Probability that there's an extinct volcano in each region")
|
||||||
|
|
||||||
|
22
cook_soil.lua
Normal file
22
cook_soil.lua
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
minetest.register_abm{
|
||||||
|
label = "soil burning",
|
||||||
|
nodenames = {"group:soil"},
|
||||||
|
neighbors = {"default:lava_source", "default:lava_flowing"},
|
||||||
|
interval = 10,
|
||||||
|
chance = 5,
|
||||||
|
action = function(pos)
|
||||||
|
minetest.set_node(pos, {name = "default:sand"})
|
||||||
|
minetest.check_for_falling(pos)
|
||||||
|
end,
|
||||||
|
}
|
||||||
|
|
||||||
|
minetest.register_abm{
|
||||||
|
label = "ore burning",
|
||||||
|
nodenames = {"default:stone_with_coal", "default:stone_with_diamond"},
|
||||||
|
neighbors = {"default:lava_source", "default:lava_flowing"},
|
||||||
|
interval = 10,
|
||||||
|
chance = 5,
|
||||||
|
action = function(pos)
|
||||||
|
minetest.set_node(pos, {name = "default:cobble"})
|
||||||
|
end,
|
||||||
|
}
|
3
init.lua
3
init.lua
@ -15,4 +15,7 @@ end
|
|||||||
if magma_conduits.config.volcanoes then
|
if magma_conduits.config.volcanoes then
|
||||||
dofile(modpath.."/volcanoes.lua")
|
dofile(modpath.."/volcanoes.lua")
|
||||||
end
|
end
|
||||||
|
if magma_conduits.config.cook_soil then
|
||||||
|
dofile(modpath.."/cook_soil.lua")
|
||||||
|
end
|
||||||
|
|
||||||
|
@ -1,4 +1,5 @@
|
|||||||
magma_conduits_glowing_rock (Cause rock adjacent to lava to convert into "glowing" form) bool true
|
magma_conduits_glowing_rock (Cause rock adjacent to lava to convert into "glowing" form) bool true
|
||||||
|
magma_conduits_cook_soil (Cause soil and carbonaceous ores adjacent to lava to cook) bool true
|
||||||
magma_conduits_remove_default_lava (Remove default mapgen lava) bool true
|
magma_conduits_remove_default_lava (Remove default mapgen lava) bool true
|
||||||
|
|
||||||
[Magma Veins]
|
[Magma Veins]
|
||||||
@ -23,3 +24,12 @@ magma_conduits_volcano_min_slope (Minimum volcano slope) float 0.5
|
|||||||
#above 1.5 and the mountain becomes more of a shield volcano,
|
#above 1.5 and the mountain becomes more of a shield volcano,
|
||||||
#taking up a lot of map area.
|
#taking up a lot of map area.
|
||||||
magma_conduits_volcano_max_slope (Maximum volcano slope) float 1.5
|
magma_conduits_volcano_max_slope (Maximum volcano slope) float 1.5
|
||||||
|
#The size of the region within which each volcano is randomly placed
|
||||||
|
#measured in mapblocks, which is usually 80 nodes on a side.
|
||||||
|
#Eg, the default of 15 means that one volcano is placed in each
|
||||||
|
#1200x1200 node region.
|
||||||
|
magma_conduits_volcano_region_mapblocks (Region mapblocks) int 15
|
||||||
|
|
||||||
|
magma_conduits_volcano_probability_active (Probability of active volcano in region) float 0.4
|
||||||
|
magma_conduits_volcano_probability_dormant (Probability of dormant volcano in region) float 0.2
|
||||||
|
magma_conduits_volcano_probability_extinct (Probability of extinct volcano in region) float 0.2
|
||||||
|
@ -6,20 +6,31 @@ 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 = 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
|
||||||
|
|
||||||
local state_extinct = 0.25
|
|
||||||
local state_dormant = 0.5
|
|
||||||
|
|
||||||
local depth_maxpeak = magma_conduits.config.volcano_max_height
|
local depth_maxpeak = magma_conduits.config.volcano_max_height
|
||||||
local depth_minpeak = magma_conduits.config.volcano_min_height
|
local depth_minpeak = magma_conduits.config.volcano_min_height
|
||||||
local slope_min = magma_conduits.config.volcano_min_slope
|
local slope_min = magma_conduits.config.volcano_min_slope
|
||||||
local slope_max = magma_conduits.config.volcano_max_slope
|
local slope_max = magma_conduits.config.volcano_max_slope
|
||||||
|
|
||||||
|
local region_mapblocks = magma_conduits.config.volcano_region_mapblocks
|
||||||
|
local mapgen_chunksize = tonumber(minetest.get_mapgen_setting("chunksize"))
|
||||||
|
local volcano_region_size = region_mapblocks * mapgen_chunksize * 16
|
||||||
|
|
||||||
|
|
||||||
|
local p_active = magma_conduits.config.volcano_probability_active
|
||||||
|
local p_dormant = magma_conduits.config.volcano_probability_dormant
|
||||||
|
local p_extinct = magma_conduits.config.volcano_probability_extinct
|
||||||
|
|
||||||
|
if p_active + p_dormant + p_extinct > 1.0 then
|
||||||
|
minetest.log("error", "[magma_conduits] probabilities of various volcano types adds up to more than 1")
|
||||||
|
end
|
||||||
|
|
||||||
|
local state_dormant = 1 - p_active
|
||||||
|
local state_extinct = 1 - p_active - p_dormant
|
||||||
|
local state_none = 1 - p_active - p_dormant - p_extinct
|
||||||
|
|
||||||
local c_air = minetest.get_content_id("air")
|
local c_air = minetest.get_content_id("air")
|
||||||
local c_lava = minetest.get_content_id("default:lava_source")
|
local c_lava = minetest.get_content_id("default:lava_source")
|
||||||
@ -62,20 +73,24 @@ local scatter_2d = function(min_xz, gridscale, border_width)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local get_volcano = function(pos)
|
local get_volcano = function(pos)
|
||||||
local corner_xz = {x = math.floor(pos.x / chunk_size) * chunk_size, z = math.floor(pos.z / chunk_size) * chunk_size}
|
local corner_xz = {x = math.floor(pos.x / volcano_region_size) * volcano_region_size, z = math.floor(pos.z / volcano_region_size) * volcano_region_size}
|
||||||
|
|
||||||
local next_seed = math.random(1, 1000000000)
|
local next_seed = math.random(1, 1000000000)
|
||||||
math.randomseed(corner_xz.x + corner_xz.z * 2 ^ 8 + mapgen_seed)
|
math.randomseed(corner_xz.x + corner_xz.z * 2 ^ 8 + mapgen_seed)
|
||||||
|
|
||||||
local location = scatter_2d(corner_xz, chunk_size, radius_cone_max)
|
local state = math.random()
|
||||||
--local location = {x=corner_xz.x+chunk_size/2, z = corner_xz.z+chunk_size/2} -- For testing, puts volcanoes in a consistent grid
|
if state < state_none then
|
||||||
|
math.randomseed(next_seed)
|
||||||
|
return nil
|
||||||
|
end
|
||||||
|
|
||||||
|
local location = scatter_2d(corner_xz, volcano_region_size, radius_cone_max)
|
||||||
|
--local location = {x=corner_xz.x+volcano_region_size/2, z = corner_xz.z+volcano_region_size/2} -- For testing, puts volcanoes in a consistent grid
|
||||||
local depth_peak = math.random(depth_minpeak, depth_maxpeak)
|
local depth_peak = math.random(depth_minpeak, depth_maxpeak)
|
||||||
local depth_lava = math.random(depth_peak - 25, depth_peak)
|
local depth_lava = math.random(depth_peak - 25, depth_peak)
|
||||||
local slope = math.random() * (slope_max - slope_min) + slope_min
|
local slope = math.random() * (slope_max - slope_min) + slope_min
|
||||||
local caldera = math.random() * (caldera_max - caldera_min) + caldera_min
|
local caldera = math.random() * (caldera_max - caldera_min) + caldera_min
|
||||||
|
|
||||||
local state = math.random() -- 0-0.25 = extinct, 0.25-0.5 = dormant, 0.5-1.0 active
|
|
||||||
|
|
||||||
math.randomseed(next_seed)
|
math.randomseed(next_seed)
|
||||||
return {location = location, depth_peak = depth_peak, depth_lava = depth_lava, slope = slope, state = state, caldera = caldera}
|
return {location = location, depth_peak = depth_peak, depth_lava = depth_lava, slope = slope, state = state, caldera = caldera}
|
||||||
end
|
end
|
||||||
@ -99,11 +114,12 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
|
|
||||||
local sidelen = maxp.x - minp.x + 1 --length of a mapblock
|
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
|
local volcano = get_volcano(minp)
|
||||||
chunk_size = region_mapblocks * sidelen
|
|
||||||
|
if volcano == nil then
|
||||||
|
return -- no volcano in this map region
|
||||||
end
|
end
|
||||||
|
|
||||||
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
|
||||||
|
|
||||||
@ -241,8 +257,19 @@ end)
|
|||||||
minetest.register_privilege("findvolcano", { description = "Allows players to use a console command to find volcanoes", give_to_singleplayer = false})
|
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)
|
local send_volcano_state = function(pos, name)
|
||||||
|
|
||||||
|
local xmin = math.floor(pos.x / volcano_region_size) * volcano_region_size
|
||||||
|
local zmin = math.floor(pos.z / volcano_region_size) * volcano_region_size
|
||||||
|
|
||||||
|
local text = "In region (" .. tostring(xmin) .. ", 0, " .. tostring(zmin) ..") to ("
|
||||||
|
.. tostring(xmin+volcano_region_size) .. ", 0, " .. tostring(zmin+volcano_region_size) ..")\n"
|
||||||
|
|
||||||
volcano = get_volcano(pos)
|
volcano = get_volcano(pos)
|
||||||
text = "Nearest volcano is at " .. minetest.pos_to_string(volcano.location, 0)
|
if volcano == nil then
|
||||||
|
minetest.chat_send_player(name, text.."No volcano present")
|
||||||
|
return
|
||||||
|
end
|
||||||
|
text = text .. "Nearest volcano is at " .. minetest.pos_to_string(volcano.location, 0)
|
||||||
.. "\nHeight: " .. tostring(volcano.depth_peak) .. " Slope: " .. tostring(volcano.slope)
|
.. "\nHeight: " .. tostring(volcano.depth_peak) .. " Slope: " .. tostring(volcano.slope)
|
||||||
.. "\nState: "
|
.. "\nState: "
|
||||||
if volcano.state < state_extinct then
|
if volcano.state < state_extinct then
|
||||||
|
Loading…
Reference in New Issue
Block a user