Make caldera conical, randomized size a bit

This commit is contained in:
FaceDeer 2018-11-04 16:44:04 -07:00
parent bf6f683211
commit c32ae7d384
2 changed files with 21 additions and 14 deletions

@ -9,6 +9,10 @@ if magma_conduits.config.remove_default_lava then
minetest.register_alias_force("mapgen_lava_source", "air") minetest.register_alias_force("mapgen_lava_source", "air")
end end
dofile(modpath.."/magma_veins.lua") if magma_conduits.config.magma_veins then
dofile(modpath.."/volcanoes.lua") dofile(modpath.."/magma_veins.lua")
end
if magma_conduits.config.volcanoes then
dofile(modpath.."/volcanoes.lua")
end

@ -3,12 +3,14 @@ local depth_base = -50
local depth_maxwidth = -10 local depth_maxwidth = -10
local depth_maxpeak = 200 local depth_maxpeak = 200
local depth_minpeak = 20 local depth_minpeak = 20
local radius_vent = 5 local radius_vent = 3
local radius_lining = 7 local radius_lining = 5
local slope_min = 0.25 local caldera_min = 5
local slope_max = 1.75 local caldera_max = 20
local slope_min = 0.5
local slope_max = 1.5
local chunk_size = 1000 local chunk_size = 1000
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")
local c_lining = minetest.get_content_id("default:obsidian") local c_lining = minetest.get_content_id("default:obsidian")
@ -52,11 +54,12 @@ local get_volcano = function(pos)
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 - 50, depth_peak) local depth_lava = math.random(depth_peak - 50, 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 state = math.random() local state = math.random()
math.randomseed(next_seed) math.randomseed(next_seed)
return {location = location, depth_peak = depth_peak, depth_lava = depth_lava, slope = slope, state = state} return {location = location, depth_peak = depth_peak, depth_lava = depth_lava, slope = slope, state = state, caldera = caldera}
end end
local perlin_params = { local perlin_params = {
@ -72,11 +75,10 @@ local nobj_perlin = nil
local data = {} local data = {}
minetest.register_on_generated(function(minp, maxp, seed) minetest.register_on_generated(function(minp, maxp, seed)
if minp.y > depth_maxpeak then if minp.y > depth_maxpeak then
return return
end end
local vm, emin, emax = minetest.get_mapgen_object("voxelmanip") local vm, emin, emax = minetest.get_mapgen_object("voxelmanip")
local area = VoxelArea:new{MinEdge=emin, MaxEdge=emax} local area = VoxelArea:new{MinEdge=emin, MaxEdge=emax}
vm:get_data(data) vm:get_data(data)
@ -99,6 +101,7 @@ minetest.register_on_generated(function(minp, maxp, seed)
local z_coord = volcano.location.z local z_coord = volcano.location.z
local depth_lava = volcano.depth_lava local depth_lava = volcano.depth_lava
local depth_peak = volcano.depth_peak local depth_peak = volcano.depth_peak
local caldera = volcano.caldera
local base_radius = (depth_peak - depth_maxwidth) * volcano.slope + radius_lining local base_radius = (depth_peak - depth_maxwidth) * volcano.slope + radius_lining
local state = volcano.state local state = volcano.state
@ -145,7 +148,7 @@ minetest.register_on_generated(function(minp, maxp, seed)
if distance < radius_vent then if distance < radius_vent then
data[vi] = pipestuff data[vi] = pipestuff
elseif distance < radius_lining then elseif distance < radius_lining then
if data[vi] == c_stone or data[vi] == c_water then if data[vi] ~= c_air then
data[vi] = liningstuff data[vi] = liningstuff
end end
end end
@ -156,9 +159,9 @@ minetest.register_on_generated(function(minp, maxp, seed)
data[vi] = liningstuff data[vi] = liningstuff
elseif distance < radius_lining + ((y - depth_base)/depth_maxwidth_dist) * base_radius then elseif distance < radius_lining + ((y - depth_base)/depth_maxwidth_dist) * base_radius then
data[vi] = c_cone data[vi] = c_cone
end end
elseif y < depth_peak then -- cone elseif y < depth_peak + 5 then -- cone
if vector.distance({x=x, y=y, z=z}, {x=x_coord, y=depth_peak, z=z_coord}) - distance_perturbation < radius_lining * 2.5 then if y > depth_peak - caldera and distance < (y - depth_peak + caldera) and data[vi] ~= c_lava then
data[vi] = c_air -- caldera data[vi] = c_air -- caldera
elseif distance < radius_vent then elseif distance < radius_vent then
data[vi] = pipestuff data[vi] = pipestuff