2012-11-09 22:55:59 +06:00
|
|
|
trees = {}
|
2012-10-13 20:45:01 +06:00
|
|
|
|
2012-11-16 13:39:39 +06:00
|
|
|
dofile(minetest.get_modpath("trees").."/leavesgen.lua")
|
2012-10-13 22:51:40 +06:00
|
|
|
|
2012-11-16 13:39:39 +06:00
|
|
|
function trees.make_tree(pos, tree)
|
|
|
|
local tree = realtest.registered_trees[tree]
|
2012-11-16 16:36:11 +06:00
|
|
|
if not table.contains(tree.grounds, minetest.env:get_node({x=pos.x,y=pos.y-1,z=pos.z}).name) then
|
2012-11-16 13:39:39 +06:00
|
|
|
return
|
|
|
|
end
|
|
|
|
local height = tree.height()
|
2012-11-16 16:36:11 +06:00
|
|
|
for i = 1,height do
|
2012-11-16 13:39:39 +06:00
|
|
|
if minetest.env:get_node({x=pos.x, y=pos.y+i, z=pos.z}).name ~= "air" then
|
2012-11-15 17:26:45 +06:00
|
|
|
return
|
|
|
|
end
|
|
|
|
end
|
|
|
|
for i = 0,height do
|
2012-11-16 13:39:39 +06:00
|
|
|
minetest.env:add_node({x=pos.x, y=pos.y+i, z=pos.z}, {name=tree.name.."_trunk"})
|
2012-10-14 18:13:36 +06:00
|
|
|
end
|
2012-11-16 13:39:39 +06:00
|
|
|
for i = 1,#tree.leaves do
|
|
|
|
local p = {x=pos.x+tree.leaves[i][1], y=pos.y+height+tree.leaves[i][2], z=pos.z+tree.leaves[i][3]}
|
2012-11-15 19:58:35 +06:00
|
|
|
if minetest.env:get_node(p).name == "air" or minetest.env:get_node(p).name == "ignore" then
|
2012-11-16 13:39:39 +06:00
|
|
|
minetest.env:add_node(p, {name=tree.name.."_leaves"})
|
2012-11-15 17:26:45 +06:00
|
|
|
end
|
2012-10-14 18:13:36 +06:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-11-23 14:20:18 +06:00
|
|
|
local function generate(tree, minp, maxp, seed)
|
|
|
|
local perlin1 = minetest.env:get_perlin(329, 3, 0.6, 100)
|
|
|
|
-- Assume X and Z lengths are equal
|
|
|
|
local divlen = 16
|
|
|
|
local divs = (maxp.x-minp.x)/divlen+1;
|
|
|
|
for divx=0,divs-1 do
|
|
|
|
for divz=0,divs-1 do
|
|
|
|
local x0 = minp.x + math.floor((divx+0)*divlen)
|
|
|
|
local z0 = minp.z + math.floor((divz+0)*divlen)
|
|
|
|
local x1 = minp.x + math.floor((divx+1)*divlen)
|
|
|
|
local z1 = minp.z + math.floor((divz+1)*divlen)
|
|
|
|
-- Determine trees amount from perlin noise
|
|
|
|
local trees_amount = math.floor(perlin1:get2d({x=x0, y=z0}) * 5 + 0)
|
|
|
|
-- Find random positions for trees based on this random
|
|
|
|
local pr = PseudoRandom(seed)
|
|
|
|
for i=0,trees_amount do
|
|
|
|
local x = pr:next(x0, x1)
|
|
|
|
local z = pr:next(z0, z1)
|
|
|
|
-- Find ground level (0...30)
|
|
|
|
local ground_y = nil
|
|
|
|
for y=30,0,-1 do
|
|
|
|
if minetest.env:get_node({x=x,y=y,z=z}).name ~= "air" then
|
|
|
|
ground_y = y
|
|
|
|
break
|
2012-10-13 22:51:40 +06:00
|
|
|
end
|
|
|
|
end
|
2012-11-23 14:20:18 +06:00
|
|
|
if ground_y then
|
|
|
|
trees.make_tree({x=x,y=ground_y+1,z=z}, tree)
|
|
|
|
end
|
2012-10-13 20:45:01 +06:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-11-16 16:36:11 +06:00
|
|
|
dofile(minetest.get_modpath("trees").."/registration.lua")
|
|
|
|
|
2012-11-15 17:26:45 +06:00
|
|
|
minetest.register_on_generated(function(minp, maxp, seed)
|
2012-10-13 23:49:15 +06:00
|
|
|
local pr = PseudoRandom(seed)
|
2012-11-23 14:58:00 +06:00
|
|
|
local n = 0
|
|
|
|
if pr:next(1,5) == 1 then
|
|
|
|
n = n + 1
|
|
|
|
end
|
|
|
|
if pr:next(1, 10) == 1 then
|
|
|
|
n = n + 1
|
|
|
|
end
|
|
|
|
if pr:next(1, 20) == 1 then
|
|
|
|
n = n + 1
|
|
|
|
end
|
|
|
|
if n > 0 then
|
|
|
|
for i = 1, n do
|
|
|
|
generate(realtest.registered_trees_list[pr:next(1,#realtest.registered_trees_list)], minp, maxp, seed, 1/8/2, 1)
|
2012-11-16 13:39:39 +06:00
|
|
|
end
|
2012-11-15 17:26:45 +06:00
|
|
|
end
|
2012-11-09 22:55:59 +06:00
|
|
|
end)
|