optimize terrain features

This commit is contained in:
cora 2022-06-22 13:31:43 +02:00
parent 69dac8ded4
commit eb8db0dc0b

@ -23,9 +23,9 @@ local function set_node_no_bedrock(pos,node)
return minetest.set_node(pos,node) return minetest.set_node(pos,node)
end end
local function airtower(pos) local function airtower(pos,tbl,h)
for i=0,55 do for i=0,h do
set_node_no_bedrock(vector.offset(pos,0,i,0),{name="air"}) table.insert(tbl,vector.offset(pos,0,i,0))
end end
end end
@ -40,14 +40,16 @@ local function makelake(pos,size,liquid,placein,border,pr)
if not nn[1] then return end if not nn[1] then return end
local y = pos.y - 1 local y = pos.y - 1
local lq = {} local lq = {}
local air = {}
for i=1,pr:next(1,#nn) do for i=1,pr:next(1,#nn) do
if nn[i].y == y then if nn[i].y == y then
set_node_no_bedrock(nn[i],{name=liquid}) airtower(vector.offset(nn[i],0,1,0),air,55)
airtower(vector.offset(nn[i],0,1,0))
table.insert(lq,nn[i]) table.insert(lq,nn[i])
end end
end end
minetest.bulk_set_node(lq,{name=liquid})
local air = {}
local br = {}
for k,v in pairs(lq) do for k,v in pairs(lq) do
for kk,vv in pairs(adjacents) do for kk,vv in pairs(adjacents) do
local pp = vector.add(v,vv) local pp = vector.add(v,vv)
@ -64,13 +66,15 @@ local function makelake(pos,size,liquid,placein,border,pr)
if border == "mcl_core:dirt" then border = "mcl_core:dirt_with_grass" end if border == "mcl_core:dirt" then border = "mcl_core:dirt_with_grass" end
end end
if an.name ~= liquid then if an.name ~= liquid then
set_node_no_bedrock(pp,{name=border}) table.insert(br,pp)
if un.name ~= liquid then if un.name ~= liquid then
airtower(vector.offset(pp,0,1,0)) airtower(vector.offset(pp,0,1,0),air,55)
end end
end end
end end
end end
minetest.bulk_set_node(air,{name="air"})
minetest.bulk_set_node(br,{name=border})
return true return true
end end
@ -136,14 +140,16 @@ mcl_structures.register_structure("basalt_column",{
return vector.distance(vector.new(pos.x,0,pos.z), a) < vector.distance(vector.new(pos.x,0,pos.z), b) return vector.distance(vector.new(pos.x,0,pos.z), a) < vector.distance(vector.new(pos.x,0,pos.z), b)
end) end)
if #nn < 1 then return false end if #nn < 1 then return false end
local basalt = {}
for i=1,pr:next(1,#nn) do for i=1,pr:next(1,#nn) do
if minetest.get_node(vector.offset(nn[i],0,-1,0)).name ~= "air" then if minetest.get_node(vector.offset(nn[i],0,-1,0)).name ~= "air" then
local dst=vector.distance(pos,nn[i]) local dst=vector.distance(pos,nn[i])
for ii=0,pr:next(2,14)-dst do for ii=0,pr:next(2,14)-dst do
set_node_no_bedrock(vector.new(nn[i].x,nn[i].y + ii,nn[i].z),{name="mcl_blackstone:basalt"}) table.insert(basalt,vector.new(nn[i].x,nn[i].y + ii,nn[i].z))
end end
end end
end end
minetest.bulk_set_node(basalt,{name="mcl_blackstone:basalt"})
return true return true
end end
}) })
@ -168,14 +174,16 @@ mcl_structures.register_structure("basalt_pillar",{
return vector.distance(vector.new(pos.x,0,pos.z), a) < vector.distance(vector.new(pos.x,0,pos.z), b) return vector.distance(vector.new(pos.x,0,pos.z), a) < vector.distance(vector.new(pos.x,0,pos.z), b)
end) end)
if #nn < 1 then return false end if #nn < 1 then return false end
local basalt = {}
for i=1,pr:next(1,#nn) do for i=1,pr:next(1,#nn) do
if minetest.get_node(vector.offset(nn[i],0,-1,0)).name ~= "air" then if minetest.get_node(vector.offset(nn[i],0,-1,0)).name ~= "air" then
local dst=vector.distance(pos,nn[i]) local dst=vector.distance(pos,nn[i])
for ii=0,pr:next(19,34)-dst do for ii=0,pr:next(19,34)-dst do
set_node_no_bedrock(vector.new(nn[i].x,nn[i].y + ii,nn[i].z),{name="mcl_blackstone:basalt"}) table.insert(basalt,vector.new(nn[i].x,nn[i].y + ii,nn[i].z))
end end
end end
end end
minetest.bulk_set_node(basalt,{name="mcl_blackstone:basalt"})
return true return true
end end
}) })
@ -205,20 +213,25 @@ mcl_structures.register_structure("lavadelta",{
if #nn < 1 then return false end if #nn < 1 then return false end
local lava = {} local lava = {}
for i=1,pr:next(1,#nn) do for i=1,pr:next(1,#nn) do
set_node_no_bedrock(nn[i],{name="mcl_nether:nether_lava_source"})
table.insert(lava,nn[i]) table.insert(lava,nn[i])
end end
minetest.bulk_set_node(lava,{name="mcl_nether:nether_lava_source"})
local basalt = {}
local magma = {}
for _,v in pairs(lava) do for _,v in pairs(lava) do
for _,vv in pairs(adjacents) do for _,vv in pairs(adjacents) do
local p = vector.add(v,vv) local p = vector.add(v,vv)
if minetest.get_node(p).name ~= "mcl_nether:nether_lava_source" then if minetest.get_node(p).name ~= "mcl_nether:nether_lava_source" then
set_node_no_bedrock(p,{name="mcl_blackstone:basalt"}) table.insert(basalt,p)
end end
end end
if math.random(3) == 1 then if math.random(3) == 1 then
set_node_no_bedrock(v,{name="mcl_nether:magma"}) table.insert(magma,v)
end end
end end
minetest.bulk_set_node(basalt,{name="mcl_blackstone:basalt"})
minetest.bulk_set_node(magma,{name="mcl_nether:magma"})
return true return true
end end
}) })