2013-04-20 20:22:10 +02:00
|
|
|
local leaves = {"green","yellow","red"}
|
|
|
|
|
|
|
|
minetest.register_node("jungletree:sapling", {
|
|
|
|
description = "Jungle Tree Sapling",
|
|
|
|
drawtype = "plantlike",
|
|
|
|
visual_scale = 1.0,
|
|
|
|
tiles = {"jungletree_sapling.png"},
|
|
|
|
inventory_image = "jungletree_sapling.png",
|
|
|
|
wield_image = "default_sapling.png",
|
|
|
|
paramtype = "light",
|
|
|
|
walkable = false,
|
2013-06-09 17:43:00 +02:00
|
|
|
groups = {snappy=2,dig_immediate=3,flammable=2,attached_node=1},
|
2013-04-27 13:46:32 +02:00
|
|
|
on_construct = function(pos)
|
2013-08-02 15:47:45 +02:00
|
|
|
if minetest.setting_getbool("creative_mode") then
|
|
|
|
sumpf_make_jungletree(pos)
|
|
|
|
end
|
2013-04-27 13:46:32 +02:00
|
|
|
end
|
2013-04-20 20:22:10 +02:00
|
|
|
})
|
|
|
|
|
|
|
|
--if minetest.setting_get("new_style_leaves") == true then
|
|
|
|
--leavesimg = {"jungletree_leaves_trans.png"}
|
|
|
|
--else
|
|
|
|
--leavesimg = {"jungletree_leaves.png"}
|
|
|
|
--end
|
|
|
|
|
|
|
|
for color = 1, 3 do
|
|
|
|
local leave_name = "jungletree:leaves_"..leaves[color]
|
|
|
|
minetest.register_node(leave_name, {
|
|
|
|
description = "Jungle Tree Leaves",
|
|
|
|
drawtype = "allfaces_optional",
|
|
|
|
tiles = {"jungletree_leaves_"..leaves[color]..".png"},
|
|
|
|
paramtype = "light",
|
2013-06-09 17:43:00 +02:00
|
|
|
groups = {snappy=3, leafdecay=3, flammable=2, leaves=1},
|
2013-04-20 20:22:10 +02:00
|
|
|
drop = {
|
|
|
|
max_items = 1,
|
|
|
|
items = {
|
|
|
|
{
|
|
|
|
-- player will get sapling with 1/20 chance
|
|
|
|
items = {'jungletree:sapling'},
|
|
|
|
rarity = 20,
|
|
|
|
},
|
|
|
|
{
|
|
|
|
-- player will get leaves only if he get no saplings,
|
|
|
|
-- this is because max_items is 1
|
|
|
|
items = {leave_name},
|
|
|
|
}
|
|
|
|
}
|
|
|
|
},
|
|
|
|
sounds = default.node_sound_leaves_defaults(),
|
|
|
|
})
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
--[[ minetest.register_node("jungletree:tree", {
|
|
|
|
description = "Tree",
|
|
|
|
tiles = {"default_tree_top.png",
|
|
|
|
"default_tree_top.png",
|
|
|
|
"jungletree_bark.png"},
|
|
|
|
is_ground_content = true,
|
|
|
|
groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2},
|
|
|
|
}) --]]
|
|
|
|
|
2013-04-27 13:46:32 +02:00
|
|
|
--minetest.register_alias("jungletree:tree", "default:jungletree")
|
2013-04-20 20:22:10 +02:00
|
|
|
|
2013-08-06 10:51:07 +02:00
|
|
|
|
|
|
|
local function tree_branch(ignore, area, nodes, pos)
|
|
|
|
|
|
|
|
--chooze random leave
|
|
|
|
--green leaves are more common
|
|
|
|
local num = 1
|
|
|
|
local tab = {}
|
|
|
|
local chance = math.random(5)
|
|
|
|
local leaf = 2
|
|
|
|
-- local leaf = "jungletree:leaves_"..leaves[1]
|
|
|
|
if (chance < 2) then
|
|
|
|
leaf = math.random(2,4)
|
|
|
|
-- leave = "jungletree:leaves_"..leaves[math.random(1,3)]
|
|
|
|
end
|
|
|
|
|
|
|
|
tab[num] = {1, pos.x, pos.y, pos.z}
|
|
|
|
num = num+1
|
|
|
|
for i = math.random(2), -math.random(2), -1 do
|
|
|
|
for k =math.random(2), -math.random(2), -1 do
|
|
|
|
local p = {x=pos.x+i, y=pos.y, z=pos.z+k}
|
|
|
|
local n = minetest.env:get_node(p)
|
|
|
|
if (n.name=="air")
|
|
|
|
and nodes[area:index(p.x, p.y, p.z)] == ignore then
|
|
|
|
tab[num] = {leaf, p.x, p.y, p.z}
|
|
|
|
num = num+1
|
|
|
|
end
|
|
|
|
local chance = math.abs(i+k)
|
|
|
|
if (chance < 1) then
|
|
|
|
p = {x=pos.x+i, y=pos.y+1, z=pos.z+k}
|
|
|
|
n = minetest.env:get_node(p)
|
|
|
|
if (n.name=="air")
|
|
|
|
and nodes[area:index(p.x, p.y, p.z)] == ignore then
|
|
|
|
tab[num] = {leaf, p.x, p.y, p.z}
|
|
|
|
num = num+1
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
return tab
|
|
|
|
end
|
|
|
|
|
|
|
|
|
|
|
|
function sumpf_make_jungletree(pos, generated)
|
|
|
|
|
|
|
|
local t1 = os.clock()
|
|
|
|
local manip = minetest.get_voxel_manip()
|
|
|
|
local vwidth = 7
|
|
|
|
local vheight = 25
|
|
|
|
local emerged_pos1, emerged_pos2 = manip:read_from_map({x=pos.x-vwidth, y=pos.y-3, z=pos.z-vwidth},
|
|
|
|
{x=pos.x+vwidth, y=pos.y+vheight, z=pos.z+vwidth})
|
|
|
|
local area = VoxelArea:new({MinEdge=emerged_pos1, MaxEdge=emerged_pos2})
|
|
|
|
|
|
|
|
local nodes = {}
|
|
|
|
local ignore = minetest.get_content_id("ignore")
|
|
|
|
for i = 1, sumpf_get_volume(emerged_pos1, emerged_pos2) do
|
|
|
|
nodes[i] = ignore
|
|
|
|
end
|
|
|
|
|
|
|
|
local c_jungletree = minetest.get_content_id("default:jungletree")
|
|
|
|
local c_leaves_green = minetest.get_content_id("jungletree:leaves_green")
|
|
|
|
local c_leaves_red = minetest.get_content_id("jungletree:leaves_red")
|
|
|
|
local c_leaves_yellow = minetest.get_content_id("jungletree:leaves_yellow")
|
|
|
|
local ndtable = {c_jungletree, c_leaves_green, c_leaves_red, c_leaves_yellow}
|
|
|
|
|
|
|
|
local height = 5 + math.random(15)
|
|
|
|
if height < 10 then
|
|
|
|
for i = height, -1, -1 do
|
|
|
|
local p = {x=pos.x, y=pos.y+i, z=pos.z}
|
|
|
|
nodes[area:index(pos.x, pos.y+i, pos.z)] = c_jungletree
|
|
|
|
if i == height then
|
|
|
|
local branches = {
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x, y=pos.y+height+math.random(0, 1), z=pos.z}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x, y=pos.y+height+math.random(0, 1), z=pos.z}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x+1, y=pos.y+i-math.random(2), z=pos.z}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x-1, y=pos.y+i-math.random(2), z=pos.z}),
|
|
|
|
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x, y=pos.y+i-math.random(2), z=pos.z+1}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x, y=pos.y+i-math.random(2), z=pos.z-1})
|
|
|
|
}
|
|
|
|
for _,tbr in ipairs(branches) do
|
|
|
|
for _,nds in ipairs(tbr) do
|
|
|
|
nodes[area:index(nds[2], nds[3], nds[4])] = ndtable[nds[1] ]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
if height <= 0 then
|
|
|
|
|
|
|
|
nodes[area:index(pos.x+1, pos.y+i-math.random(2), pos.z)] = c_jungletree
|
|
|
|
nodes[area:index(pos.x, pos.y+i-math.random(2), pos.z+1)] = c_jungletree
|
|
|
|
nodes[area:index(pos.x-1, pos.y+i-math.random(2), pos.z)] = c_jungletree
|
|
|
|
nodes[area:index(pos.x, pos.y+i-math.random(2), pos.z-1)] = c_jungletree
|
|
|
|
end
|
|
|
|
|
|
|
|
if (math.sin(i/height*i) < 0.2 and i > 3 and math.random(0,2) < 1.5) then
|
|
|
|
branch_pos = {x=pos.x+math.random(0,1), y=pos.y+i, z=pos.z-math.random(0,1)}
|
|
|
|
for _,nds in ipairs(tree_branch(ignore, area, nodes, branch_pos)) do
|
|
|
|
nodes[area:index(nds[2], nds[3], nds[4])] = ndtable[nds[1] ]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
else
|
|
|
|
for i = height, -2, -1 do
|
|
|
|
if (math.sin(i/height*i) < 0.2 and i > 3 and math.random(0,2) < 1.5) then
|
|
|
|
branch_pos = {x=pos.x+math.random(0,1), y=pos.y+i, z=pos.z-math.random(0,1)}
|
|
|
|
for _,nds in ipairs(tree_branch(ignore, area, nodes, branch_pos)) do
|
|
|
|
nodes[area:index(nds[2], nds[3], nds[4])] = ndtable[nds[1] ]
|
|
|
|
end
|
|
|
|
|
|
|
|
end
|
|
|
|
if i < math.random(0,1) then
|
|
|
|
nodes[area:index(pos.x+1, pos.y+i, pos.z+1)] = c_jungletree
|
|
|
|
nodes[area:index(pos.x+2, pos.y+i, pos.z-1)] = c_jungletree
|
|
|
|
nodes[area:index(pos.x, pos.y+i, pos.z-2)] = c_jungletree
|
|
|
|
|
|
|
|
nodes[area:index(pos.x-1, pos.y+i, pos.z)] = c_jungletree
|
|
|
|
end
|
|
|
|
if i == height then
|
|
|
|
local branches = {
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x+1, y=pos.y+i, z=pos.z+1}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x+2, y=pos.y+i, z=pos.z-1}),
|
|
|
|
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x, y=pos.y+i, z=pos.z-2}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x-1, y=pos.y+i, z=pos.z}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x+1, y=pos.y+i, z=pos.z+2}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x+3, y=pos.y+i, z=pos.z-1}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x, y=pos.y+i, z=pos.z-3}),
|
|
|
|
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x-2, y=pos.y+i, z=pos.z}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x+1, y=pos.y+i, z=pos.z}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x+1, y=pos.y+i, z=pos.z-1}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x, y=pos.y+i, z=pos.z-1}),
|
|
|
|
tree_branch(ignore, area, nodes, {x=pos.x, y=pos.y+i, z=pos.z})
|
|
|
|
}
|
|
|
|
for _,tbr in ipairs(branches) do
|
|
|
|
for _,nds in ipairs(tbr) do
|
|
|
|
nodes[area:index(nds[2], nds[3], nds[4])] = ndtable[nds[1] ]
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
else
|
|
|
|
nodes[area:index(pos.x+1, pos.y+i, pos.z)] = c_jungletree
|
|
|
|
nodes[area:index(pos.x+1, pos.y+i, pos.z-1)] = c_jungletree
|
|
|
|
nodes[area:index(pos.x, pos.y+i, pos.z-1)] = c_jungletree
|
|
|
|
nodes[area:index(pos.x, pos.y+i, pos.z)] = c_jungletree
|
|
|
|
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
manip:set_data(nodes)
|
|
|
|
manip:write_to_map()
|
|
|
|
if not generated then --info
|
2013-08-06 13:47:23 +02:00
|
|
|
if sumpf_info_jg then
|
2013-08-06 10:51:07 +02:00
|
|
|
print(string.format("[sumpf] a jungletree grew at ("..pos.x.."|"..pos.y.."|"..pos.z..") in: %.2fms", (os.clock() - t1) * 1000))
|
|
|
|
local t1 = os.clock()
|
|
|
|
manip:update_map()
|
|
|
|
print(string.format("[sumpf] map updated in: %.2fms", (os.clock() - t1) * 1000))
|
|
|
|
else
|
|
|
|
manip:update_map()
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
--[[
|
2013-04-20 20:22:10 +02:00
|
|
|
local function add_tree_branch(pos)
|
|
|
|
|
|
|
|
--chooze random leave
|
|
|
|
--green leaves are more common
|
|
|
|
local chance = math.random(5)
|
|
|
|
local leave = "jungletree:leaves_"..leaves[1]
|
|
|
|
if (chance < 2) then
|
|
|
|
leave = "jungletree:leaves_"..leaves[math.random(1,3)]
|
|
|
|
end
|
|
|
|
|
|
|
|
minetest.env:add_node(pos, {name="default:jungletree"})
|
2013-04-27 13:46:32 +02:00
|
|
|
for i = math.random(2), -math.random(2), -1 do
|
|
|
|
for k =math.random(2), -math.random(2), -1 do
|
2013-04-20 20:22:10 +02:00
|
|
|
local p = {x=pos.x+i, y=pos.y, z=pos.z+k}
|
|
|
|
local n = minetest.env:get_node(p)
|
|
|
|
if (n.name=="air") then
|
|
|
|
minetest.env:add_node(p, {name=leave})
|
|
|
|
end
|
|
|
|
local chance = math.abs(i+k)
|
|
|
|
if (chance < 1) then
|
|
|
|
p = {x=pos.x+i, y=pos.y+1, z=pos.z+k}
|
|
|
|
n = minetest.env:get_node(p)
|
|
|
|
if (n.name=="air") then
|
|
|
|
minetest.env:add_node(p, {name=leave})
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2013-04-27 13:46:32 +02:00
|
|
|
|
|
|
|
function sumpf_make_jungletree(pos)
|
2013-08-06 10:51:07 +02:00
|
|
|
local t1 = os.clock()
|
2013-04-20 20:22:10 +02:00
|
|
|
local height = 5 + math.random(15)
|
|
|
|
if height < 10 then
|
|
|
|
for i = height, -1, -1 do
|
|
|
|
local p = {x=pos.x, y=pos.y+i, z=pos.z}
|
|
|
|
minetest.env:add_node(p, {name="default:jungletree"})
|
|
|
|
if i == height then
|
|
|
|
add_tree_branch({x=pos.x, y=pos.y+height+math.random(0, 1), z=pos.z})
|
|
|
|
add_tree_branch({x=pos.x+1, y=pos.y+i-math.random(2), z=pos.z})
|
|
|
|
add_tree_branch({x=pos.x-1, y=pos.y+i-math.random(2), z=pos.z})
|
2013-04-27 13:46:32 +02:00
|
|
|
|
2013-04-20 20:22:10 +02:00
|
|
|
add_tree_branch({x=pos.x, y=pos.y+i-math.random(2), z=pos.z+1})
|
|
|
|
add_tree_branch({x=pos.x, y=pos.y+i-math.random(2), z=pos.z-1})
|
|
|
|
end
|
|
|
|
if height <= 0 then
|
|
|
|
minetest.env:add_node({x=pos.x+1, y=pos.y+i-math.random(2), z=pos.z}, {name="default:jungletree"})
|
|
|
|
minetest.env:add_node({x=pos.x, y=pos.y+i-math.random(2), z=pos.z+1}, {name="default:jungletree"})
|
|
|
|
minetest.env:add_node({x=pos.x-1, y=pos.y+i-math.random(2), z=pos.z}, {name="default:jungletree"})
|
|
|
|
minetest.env:add_node({x=pos.x, y=pos.y+i-math.random(2), z=pos.z-1}, {name="default:jungletree"})
|
|
|
|
end
|
|
|
|
if (math.sin(i/height*i) < 0.2 and i > 3 and math.random(0,2) < 1.5) then
|
|
|
|
branch_pos = {x=pos.x+math.random(0,1), y=pos.y+i, z=pos.z-math.random(0,1)}
|
|
|
|
add_tree_branch(branch_pos)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
else
|
|
|
|
for i = height, -2, -1 do
|
|
|
|
if (math.sin(i/height*i) < 0.2 and i > 3 and math.random(0,2) < 1.5) then
|
|
|
|
branch_pos = {x=pos.x+math.random(0,1), y=pos.y+i, z=pos.z-math.random(0,1)}
|
|
|
|
add_tree_branch(branch_pos)
|
|
|
|
end
|
|
|
|
if i < math.random(0,1) then
|
|
|
|
minetest.env:add_node({x=pos.x+1, y=pos.y+i, z=pos.z+1}, {name="default:jungletree"})
|
|
|
|
minetest.env:add_node({x=pos.x+2, y=pos.y+i, z=pos.z-1}, {name="default:jungletree"})
|
|
|
|
minetest.env:add_node({x=pos.x, y=pos.y+i, z=pos.z-2}, {name="default:jungletree"})
|
|
|
|
minetest.env:add_node({x=pos.x-1, y=pos.y+i, z=pos.z}, {name="default:jungletree"})
|
|
|
|
end
|
|
|
|
if i == height then
|
|
|
|
add_tree_branch({x=pos.x+1, y=pos.y+i, z=pos.z+1})
|
|
|
|
add_tree_branch({x=pos.x+2, y=pos.y+i, z=pos.z-1})
|
|
|
|
add_tree_branch({x=pos.x, y=pos.y+i, z=pos.z-2})
|
|
|
|
add_tree_branch({x=pos.x-1, y=pos.y+i, z=pos.z})
|
|
|
|
add_tree_branch({x=pos.x+1, y=pos.y+i, z=pos.z+2})
|
|
|
|
add_tree_branch({x=pos.x+3, y=pos.y+i, z=pos.z-1})
|
|
|
|
add_tree_branch({x=pos.x, y=pos.y+i, z=pos.z-3})
|
|
|
|
add_tree_branch({x=pos.x-2, y=pos.y+i, z=pos.z})
|
|
|
|
add_tree_branch({x=pos.x+1, y=pos.y+i, z=pos.z})
|
|
|
|
add_tree_branch({x=pos.x+1, y=pos.y+i, z=pos.z-1})
|
|
|
|
add_tree_branch({x=pos.x, y=pos.y+i, z=pos.z-1})
|
|
|
|
add_tree_branch({x=pos.x, y=pos.y+i, z=pos.z})
|
|
|
|
else
|
|
|
|
minetest.env:add_node({x=pos.x+1, y=pos.y+i, z=pos.z}, {name="default:jungletree"})
|
|
|
|
minetest.env:add_node({x=pos.x+1, y=pos.y+i, z=pos.z-1}, {name="default:jungletree"})
|
|
|
|
minetest.env:add_node({x=pos.x, y=pos.y+i, z=pos.z-1}, {name="default:jungletree"})
|
|
|
|
minetest.env:add_node({x=pos.x, y=pos.y+i, z=pos.z}, {name="default:jungletree"})
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2013-08-06 13:47:23 +02:00
|
|
|
if sumpf_info_jg then
|
2013-08-06 10:51:07 +02:00
|
|
|
print(string.format("[sumpf] a jungletree grew at ("..pos.x.."|"..pos.y.."|"..pos.z..") in: %.2fms", (os.clock() - t1) * 1000))
|
|
|
|
end
|
|
|
|
end]]
|
2013-07-19 18:32:50 +02:00
|
|
|
--[[minetest.register_abm({
|
2013-04-27 13:46:32 +02:00
|
|
|
nodenames = {"jungletree:sapling"},
|
|
|
|
interval = 1,
|
|
|
|
chance = 1,
|
|
|
|
action = function(pos)
|
|
|
|
sumpf_make_jungletree(pos)
|
|
|
|
end
|
2013-07-19 18:32:50 +02:00
|
|
|
})]]
|
|
|
|
|
|
|
|
minetest.register_abm({
|
|
|
|
nodenames = {"jungletree:sapling"},
|
|
|
|
neighbors = {"group:soil"},
|
|
|
|
interval = 40,
|
|
|
|
chance = 5,
|
|
|
|
action = function(pos)
|
|
|
|
if minetest.get_item_group(minetest.get_node({x=pos.x, y=pos.y-1, z=pos.z}).name, "soil") ~= 1
|
|
|
|
or not minetest.get_node_light(pos) then
|
|
|
|
return
|
|
|
|
end
|
|
|
|
if minetest.env:get_node_light(pos, nil) > 6 then
|
|
|
|
sumpf_make_jungletree(pos)
|
|
|
|
end
|
|
|
|
end
|
2013-04-27 13:46:32 +02:00
|
|
|
})
|
2013-07-19 18:32:50 +02:00
|
|
|
|
2013-08-06 10:51:07 +02:00
|
|
|
--very old mod compatible
|
2013-04-27 13:46:32 +02:00
|
|
|
--minetest.register_alias("jungletree:leaves", "jungletree:leaves_green")
|
2013-04-20 20:22:10 +02:00
|
|
|
|
|
|
|
print("[Jungletree] Loaded!")
|