mirror of
https://github.com/HybridDog/riesenpilz.git
synced 2025-01-09 17:30:27 +01:00
fix mapgen
This commit is contained in:
parent
db18ac6d58
commit
7102f34d9f
@ -10,6 +10,5 @@ If you got ideas or found bugs, please tell them to me.
|
|||||||
|
|
||||||
|
|
||||||
TODO:
|
TODO:
|
||||||
— add giant nethershroom
|
— add more giant mushrooms
|
||||||
— finish supporting the mushrooms mod
|
— finish supporting the mushrooms mod
|
||||||
— find out why the mapgen doesn't work correctly
|
|
||||||
|
79
mapgen.lua
79
mapgen.lua
@ -1,7 +1,9 @@
|
|||||||
local c
|
local c
|
||||||
local function define_contents()
|
local function define_contents()
|
||||||
c = {
|
c = {
|
||||||
|
ignore = minetest.get_content_id("ignore"),
|
||||||
air = minetest.get_content_id("air"),
|
air = minetest.get_content_id("air"),
|
||||||
|
|
||||||
stone = minetest.get_content_id("default:stone"),
|
stone = minetest.get_content_id("default:stone"),
|
||||||
dirt = minetest.get_content_id("default:dirt"),
|
dirt = minetest.get_content_id("default:dirt"),
|
||||||
desert_sand = minetest.get_content_id("default:desert_sand"),
|
desert_sand = minetest.get_content_id("default:desert_sand"),
|
||||||
@ -43,8 +45,8 @@ end
|
|||||||
|
|
||||||
|
|
||||||
local function find_ground(a,list)
|
local function find_ground(a,list)
|
||||||
for _,nam in ipairs(list) do
|
for i = 1,#list do
|
||||||
if a == nam then
|
if a == list[i] then
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -52,25 +54,14 @@ local function find_ground(a,list)
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
local function fix_light(minp, maxp)
|
|
||||||
local manip = minetest.get_voxel_manip()
|
|
||||||
local emerged_pos1, emerged_pos2 = manip:read_from_map(minp, maxp)
|
|
||||||
local area = VoxelArea:new({MinEdge=emerged_pos1, MaxEdge=emerged_pos2})
|
|
||||||
local nodes = manip:get_data()
|
|
||||||
|
|
||||||
manip:set_data(nodes)
|
|
||||||
manip:write_to_map()
|
|
||||||
manip:update_map()
|
|
||||||
end
|
|
||||||
|
|
||||||
local data, area
|
local data, area
|
||||||
function riesenpilz_circle(nam, pos, radius, chance)
|
function riesenpilz_circle(nam, pos, radius, chance)
|
||||||
for _,p in pairs(vector.circle(radius)) do
|
for _,p in pairs(vector.circle(radius)) do
|
||||||
if pr:next(1,chance) == 1 then
|
if pr:next(1,chance) == 1 then
|
||||||
local p = vector.add(pos, p)
|
local p = vector.add(pos, p)
|
||||||
local p_p = area:indexp(p)
|
local p_p = area:indexp(p)
|
||||||
if data[p_p] == c.air
|
if (data[p_p] == c.air or data[p_p] == c.ignore)
|
||||||
and data[area:index(p.x, p.y-1, p.z)] == c.ground then
|
and find_ground(data[area:index(p.x, p.y-1, p.z)], c.GROUND) then
|
||||||
data[p_p] = nam
|
data[p_p] = nam
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -218,16 +209,10 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
if ground_y then
|
if ground_y then
|
||||||
local p_ground = area:index(x, ground_y, z)
|
data[area:index(x, ground_y, z)] = c.ground
|
||||||
local p_boden = area:index(x, ground_y+1, z)
|
|
||||||
local d_p_ground = data[p_ground]
|
|
||||||
local d_p_boden = data[p_boden]
|
|
||||||
|
|
||||||
data[p_ground] = c.ground
|
|
||||||
for i = -1,-5,-1 do
|
for i = -1,-5,-1 do
|
||||||
local p_pos = area:index(x, ground_y+i, z)
|
local p_pos = area:index(x, ground_y+i, z)
|
||||||
local d_p_pos = data[p_pos]
|
if data[p_pos] == c.desert_sand then
|
||||||
if d_p_pos == c.desert_sand then
|
|
||||||
data[p_pos] = c.dirt
|
data[p_pos] = c.dirt
|
||||||
else
|
else
|
||||||
break
|
break
|
||||||
@ -235,7 +220,7 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
end
|
end
|
||||||
local boden = {x=x,y=ground_y+1,z=z}
|
local boden = {x=x,y=ground_y+1,z=z}
|
||||||
if pr:next(1,15) == 1 then
|
if pr:next(1,15) == 1 then
|
||||||
data[p_boden] = c.dry_shrub
|
data[area:index(x, ground_y+1, z)] = c.dry_shrub
|
||||||
elseif pr:next(1,80) == 1 then
|
elseif pr:next(1,80) == 1 then
|
||||||
riesenpilz_circle(c.riesenpilz_brown, boden, pr:next(3,4), 3)
|
riesenpilz_circle(c.riesenpilz_brown, boden, pr:next(3,4), 3)
|
||||||
elseif pr:next(1,85) == 1 then
|
elseif pr:next(1,85) == 1 then
|
||||||
@ -248,16 +233,6 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
riesenpilz_circle(c.riesenpilz_lavashroom, boden, pr:next(5,6), 3)
|
riesenpilz_circle(c.riesenpilz_lavashroom, boden, pr:next(5,6), 3)
|
||||||
elseif pr:next(1,5000) == 1 then
|
elseif pr:next(1,5000) == 1 then
|
||||||
riesenpilz_circle(c.riesenpilz_glowshroom, boden, 3, 3)
|
riesenpilz_circle(c.riesenpilz_glowshroom, boden, 3, 3)
|
||||||
--[[elseif pr:next(1,80) == 1 then
|
|
||||||
env:add_node(boden, {name="riesenpilz:brown"})
|
|
||||||
elseif pr:next(1,90) == 1 then
|
|
||||||
env:add_node(boden, {name="riesenpilz:red"})
|
|
||||||
elseif pr:next(1,100) == 1 then
|
|
||||||
env:add_node(boden, {name="riesenpilz:fly_agaric"})
|
|
||||||
elseif pr:next(1,4000) == 1 then
|
|
||||||
env:add_node(boden, {name="riesenpilz:lavashroom"})
|
|
||||||
elseif pr:next(1,5000) == 1 then
|
|
||||||
env:add_node(boden, {name="riesenpilz:glowshroom"})]]
|
|
||||||
elseif pr:next(1,380) == 1 then
|
elseif pr:next(1,380) == 1 then
|
||||||
tab[num] = {1, boden}
|
tab[num] = {1, boden}
|
||||||
num = num+1
|
num = num+1
|
||||||
@ -278,35 +253,41 @@ minetest.register_on_generated(function(minp, maxp, seed)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
vm:set_data(data)
|
|
||||||
vm:write_to_map()
|
|
||||||
riesenpilz.inform("ground finished", 2, t1)
|
riesenpilz.inform("ground finished", 2, t1)
|
||||||
|
|
||||||
|
local param2s
|
||||||
|
if num ~= 1 then
|
||||||
local t2 = os.clock()
|
local t2 = os.clock()
|
||||||
local single_map_update = #tab > 3
|
|
||||||
if single_map_update then
|
|
||||||
riesenpilz.vm_update = false
|
|
||||||
end
|
|
||||||
for _,v in pairs(tab) do
|
for _,v in pairs(tab) do
|
||||||
local p = v[2]
|
local p = v[2]
|
||||||
local m = v[1]
|
local m = v[1]
|
||||||
if m == 1 then
|
if m == 1 then
|
||||||
riesenpilz_hybridpilz(p)
|
riesenpilz.red(p, data, area)
|
||||||
elseif m == 2 then
|
elseif m == 2 then
|
||||||
riesenpilz_brauner_minecraftpilz(p)
|
riesenpilz.brown(p, data, area)
|
||||||
elseif m == 3 then
|
elseif m == 3 then
|
||||||
riesenpilz_minecraft_fliegenpilz(p)
|
if not param2s then
|
||||||
|
param2s = vm:get_param2_data()
|
||||||
|
end
|
||||||
|
riesenpilz.fly_agaric(p, data, area, param2s)
|
||||||
elseif m == 4 then
|
elseif m == 4 then
|
||||||
riesenpilz_lavashroom(p)
|
riesenpilz.lavashroom(p, data, area)
|
||||||
elseif m == 5 then
|
elseif m == 5 then
|
||||||
riesenpilz_parasol(p)
|
riesenpilz.parasol(p, data, area)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if single_map_update then
|
|
||||||
riesenpilz.vm_update = true
|
|
||||||
fix_light(minp, maxp)
|
|
||||||
end
|
|
||||||
riesenpilz.inform("giant shrooms generated", 2, t2)
|
riesenpilz.inform("giant shrooms generated", 2, t2)
|
||||||
|
end
|
||||||
|
|
||||||
|
local t2 = os.clock()
|
||||||
|
vm:set_data(data)
|
||||||
|
if param2s then
|
||||||
|
vm:set_param2_data(param2s)
|
||||||
|
end
|
||||||
|
vm:set_lighting({day=0, night=0})
|
||||||
|
vm:calc_lighting()
|
||||||
|
vm:write_to_map()
|
||||||
|
riesenpilz.inform("data set", 2, t2)
|
||||||
|
|
||||||
riesenpilz.inform("done", 1, t1)
|
riesenpilz.inform("done", 1, t1)
|
||||||
end)
|
end)
|
||||||
|
Loading…
Reference in New Issue
Block a user