mapgen: Fix removal of usual stuff and generate giant mushrooms not next to the chunk border

This commit is contained in:
HybridDog 2018-08-07 11:53:18 +02:00
parent df97e1e4ee
commit 2f91256fbf

View File

@ -29,10 +29,6 @@ local function define_contents()
minetest.get_content_id("default:jungleleaves"), minetest.get_content_id("default:jungleleaves"),
minetest.get_content_id("default:junglegrass"), minetest.get_content_id("default:junglegrass"),
}, },
USUAL_STUFF = {
[minetest.get_content_id("default:cactus")] = true,
[minetest.get_content_id("default:papyrus")] = true
},
} }
end end
@ -59,6 +55,27 @@ function is_ground(id)
return false return false
end end
local toremoves = {}
function is_toremove(id)
local is = toremoves[id]
if is ~= nil then
return is
end
local data = minetest.registered_nodes[minetest.get_name_from_content_id(id)]
if not data then
toremoves[id] = false
return false
end
local groups = data.groups
if groups
and groups.flammable then
toremoves[id] = true
return true
end
toremoves[id] = false
return false
end
local data, area, pr local data, area, pr
function riesenpilz_circle(nam, pos, radius, chance) function riesenpilz_circle(nam, pos, radius, chance)
@ -74,6 +91,7 @@ function riesenpilz_circle(nam, pos, radius, chance)
end end
end end
-- perlin noise "hills" are not peaks but looking like sinus curve -- perlin noise "hills" are not peaks but looking like sinus curve
local function upper_rarity(rarity) local function upper_rarity(rarity)
return math.sign(rarity)*math.sin(math.abs(rarity)*math.pi/2) return math.sign(rarity)*math.sin(math.abs(rarity)*math.pi/2)
@ -94,8 +112,6 @@ if smooth then
end end
nosmooth_rarity = upper_rarity(nosmooth_rarity) nosmooth_rarity = upper_rarity(nosmooth_rarity)
--local USUAL_STUFF = {"default:leaves","default:apple","default:tree","default:cactus","default:papyrus"}
local contents_defined local contents_defined
minetest.register_on_generated(function(minp, maxp, seed) minetest.register_on_generated(function(minp, maxp, seed)
if maxp.y <= 0 if maxp.y <= 0
@ -139,6 +155,7 @@ minetest.register_on_generated(function(minp, maxp, seed)
local heightmap = minetest.get_mapgen_object("heightmap") local heightmap = minetest.get_mapgen_object("heightmap")
local hmi = 1 local hmi = 1
local hm_zstride = divs+1
local vm, emin, emax = minetest.get_mapgen_object("voxelmanip") local vm, emin, emax = minetest.get_mapgen_object("voxelmanip")
data = vm:get_data() data = vm:get_data()
@ -196,12 +213,13 @@ minetest.register_on_generated(function(minp, maxp, seed)
if ground then if ground then
for y = ground, ymin, -1 do for y = ground, ymin, -1 do
local d_p_pos = data[vi] local d_p_pos = data[vi]
if c.USUAL_STUFF[d_p_pos] then if is_toremove(d_p_pos) then
-- remove trees etc. -- remove trees etc.
data[vi] = c.air data[vi] = c.air
else else
if is_ground(d_p_pos) then if is_ground(d_p_pos) then
ground_y = y ground_y = y
heightmap[hmi] = y
end end
break break
end end
@ -268,6 +286,34 @@ minetest.register_on_generated(function(minp, maxp, seed)
local t2 = os.clock() local t2 = os.clock()
for _,v in pairs(tab) do for _,v in pairs(tab) do
local p = v[2] local p = v[2]
-- simple test for the distance to the biome border
local found_border = false
local dist = 5
local xmin = math.max(minp.x, p.x - dist)
local xmax = math.min(maxp.x, p.x + dist)
local hm_vi = (p.z - minp.z) * hm_zstride + xmin - minp.x + 1
for _ = xmin, xmax do
if not heightmap[hm_vi] then
found_border = true
break
end
hm_vi = hm_vi+1
end
if not found_border then
local zmin = math.max(minp.z, p.z - dist)
local zmax = math.min(maxp.z, p.z + dist)
hm_vi = (zmin - minp.z) * hm_zstride + p.x - minp.x + 1
for _ = zmin, zmax do
if not heightmap[hm_vi] then
found_border = true
break
end
hm_vi = hm_vi + hm_zstride
end
end
if not found_border then
local m = v[1] local m = v[1]
if m == 1 then if m == 1 then
riesenpilz.red(p, data, area) riesenpilz.red(p, data, area)
@ -286,6 +332,7 @@ minetest.register_on_generated(function(minp, maxp, seed)
riesenpilz.red45(p, data, area) riesenpilz.red45(p, data, area)
end end
end end
end
riesenpilz.inform("giant shrooms generated", 2, t2) riesenpilz.inform("giant shrooms generated", 2, t2)
end end