Modified tree generation and sapling growth calls
to comply with new plantlife API In addition to that, there have been numerous other, smaller changes: * Tweaked palm tree model to add coconuts * Tweaked size of all "fruit" items (really just cones). Rotated their images in inventory and wield. * Changed descriptions of sideways trunks to "Sideways Xxxx Trunk" * Tweaked names of jungle tree leaves to be Jungle Tree Leaves (Xxxx) * Moved jungletree trunk, sideways trunk, sapling into nodedef loop * Renamed trunks and trunk tops to bear "_trunk" and "_trunk_top" in their filenames. * Added copies of default jungle tree trunks and tops, with naming similar to the above change. * Re-arranged init.lua to put all leaves/needles definitions in one place. * Deleted some outdated textures. * combined leaves definitions back into main loop with an exception for jungletrees (if that one is called for, it is skipped, because leaves for those trees are explicitly defined later) * Made all leaves drop saplings when dug, 1/20 chance. * Added leafdecay radii to main tree table but disabled the use of it. To be implemented in the future. Disabled leaf decay for firs.
63
init.lua
@ -59,10 +59,10 @@ minetest.register_alias("mapgen_leaves", "air")
|
|||||||
plantslib:register_generate_plant(moretrees.beech_biome, moretrees.beech_model)
|
plantslib:register_generate_plant(moretrees.beech_biome, moretrees.beech_model)
|
||||||
]]--
|
]]--
|
||||||
|
|
||||||
-- sapling growth setup
|
-- sapling growth
|
||||||
|
|
||||||
local sapling_interval = 500
|
local sapling_interval = 1
|
||||||
local sapling_chance = 10
|
local sapling_chance = 1
|
||||||
|
|
||||||
for i in ipairs(simple_trees) do
|
for i in ipairs(simple_trees) do
|
||||||
local tree_name = trees[i][1]
|
local tree_name = trees[i][1]
|
||||||
@ -71,27 +71,46 @@ for i in ipairs(simple_trees) do
|
|||||||
|
|
||||||
plantslib:dbg(dump(moretrees[tree_biome].surface))
|
plantslib:dbg(dump(moretrees[tree_biome].surface))
|
||||||
|
|
||||||
plantslib:grow_plants(
|
plantslib:grow_plants({
|
||||||
sapling_interval,
|
grow_delay = sapling_interval,
|
||||||
sapling_chance,
|
grow_chance = sapling_chance,
|
||||||
"moretrees:"..tree_name.."_sapling",
|
grow_plant = "moretrees:"..tree_name.."_sapling",
|
||||||
nil,
|
grow_nodes = moretrees[tree_biome].surface,
|
||||||
nil,
|
grow_function = moretrees[tree_model],
|
||||||
moretrees[tree_biome].surface,
|
})
|
||||||
nil,
|
|
||||||
nil,
|
|
||||||
nil,
|
|
||||||
nil,
|
|
||||||
nil,
|
|
||||||
moretrees[tree_model],
|
|
||||||
nil
|
|
||||||
)
|
|
||||||
end
|
end
|
||||||
|
|
||||||
plantslib:grow_plants(sapling_interval,sapling_chance,"moretrees:birch_sapling",nil,nil,nil,nil,nil,nil,nil,nil,"moretrees:grow_birch",nil)
|
plantslib:grow_plants({
|
||||||
plantslib:grow_plants(sapling_interval,sapling_chance,"moretrees:spruce_sapling",nil,nil,nil,nil,nil,nil,nil,nil,"moretrees:grow_spruce",nil)
|
grow_delay = sapling_interval,
|
||||||
plantslib:grow_plants(sapling_interval,sapling_chance,"moretrees:fir_sapling",nil,nil,nil,nil,nil,nil,nil,nil,"moretrees:grow_fir",nil)
|
grow_chance = sapling_chance,
|
||||||
plantslib:grow_plants(sapling_interval,sapling_chance,"moretrees:jungletree_sapling",nil,nil,nil,nil,nil,nil,nil,nil,"moretrees:grow_jungletree",nil)
|
grow_plant = "moretrees:birch_sapling",
|
||||||
|
grow_nodes = moretrees.birch_biome.surface,
|
||||||
|
grow_function = "moretrees:grow_birch"
|
||||||
|
})
|
||||||
|
|
||||||
|
plantslib:grow_plants({
|
||||||
|
grow_delay = sapling_interval,
|
||||||
|
grow_chance = sapling_chance,
|
||||||
|
grow_plant = "moretrees:spruce_sapling",
|
||||||
|
grow_nodes = moretrees.spruce_biome.surface,
|
||||||
|
grow_function = "moretrees:grow_spruce"
|
||||||
|
})
|
||||||
|
|
||||||
|
plantslib:grow_plants({
|
||||||
|
grow_delay = sapling_interval,
|
||||||
|
grow_chance = sapling_chance,
|
||||||
|
grow_plant = "moretrees:fir_sapling",
|
||||||
|
grow_nodes = moretrees.fir_biome.surface,
|
||||||
|
grow_function = "moretrees:grow_fir"
|
||||||
|
})
|
||||||
|
|
||||||
|
plantslib:grow_plants({
|
||||||
|
grow_delay = sapling_interval,
|
||||||
|
grow_chance = sapling_chance,
|
||||||
|
grow_plant = "moretrees:jungletree_sapling",
|
||||||
|
grow_nodes = moretrees.jungletree_biome.surface,
|
||||||
|
grow_function = "moretrees:grow_jungletree"
|
||||||
|
})
|
||||||
|
|
||||||
-- Code to spawn a birch tree
|
-- Code to spawn a birch tree
|
||||||
|
|
||||||
|
317
node_defs.lua
@ -1,16 +1,3 @@
|
|||||||
leaves = {
|
|
||||||
{"beech", "Beech Leaves"},
|
|
||||||
{"apple_tree", "Apple Tree Leaves"},
|
|
||||||
{"oak", "Oak Leaves"},
|
|
||||||
{"sequoia", "Sequoia Needles"},
|
|
||||||
{"birch", "Birch Leaves"},
|
|
||||||
{"palm", "Palm Leaves"},
|
|
||||||
{"spruce", "Spruce Needles"},
|
|
||||||
{"pine", "Pine Needles"},
|
|
||||||
{"willow", "Willow Leaves"},
|
|
||||||
{"rubber_tree", "Rubber Tree Leaves"},
|
|
||||||
}
|
|
||||||
|
|
||||||
moretrees.avoidnodes = {}
|
moretrees.avoidnodes = {}
|
||||||
|
|
||||||
table.insert(moretrees.avoidnodes, "default:jungletree")
|
table.insert(moretrees.avoidnodes, "default:jungletree")
|
||||||
@ -22,30 +9,19 @@ table.insert(moretrees.avoidnodes, "moretrees:fir_trunk")
|
|||||||
table.insert(moretrees.avoidnodes, "moretrees:fir_leaves")
|
table.insert(moretrees.avoidnodes, "moretrees:fir_leaves")
|
||||||
table.insert(moretrees.avoidnodes, "moretrees:fir_leaves_bright")
|
table.insert(moretrees.avoidnodes, "moretrees:fir_leaves_bright")
|
||||||
|
|
||||||
for i in ipairs(leaves) do
|
|
||||||
local name = leaves[i]
|
|
||||||
minetest.register_node("moretrees:"..leaves[i][1].."_leaves", {
|
|
||||||
description = leaves[i][2],
|
|
||||||
drawtype = "allfaces_optional",
|
|
||||||
tiles = { "moretrees_"..leaves[i][1].."_leaves.png" },
|
|
||||||
paramtype = "light",
|
|
||||||
groups = {tree=1, snappy=3, flammable=2},
|
|
||||||
sounds = default.node_sound_leaves_defaults(),
|
|
||||||
})
|
|
||||||
table.insert(moretrees.avoidnodes, "moretrees:"..leaves[i][1].."_leaves")
|
|
||||||
end
|
|
||||||
|
|
||||||
trees = {
|
trees = {
|
||||||
{"beech", "Beech", nil, nil, nil },
|
{"beech", "Beech", 4 },
|
||||||
{"apple_tree", "Apple Tree", nil, nil, nil },
|
{"apple_tree", "Apple Tree", 10 },
|
||||||
{"oak", "Oak", "acorn", "Acorn", {-0.2, -0.5, -0.2, 0.2, 0, 0.2} },
|
{"oak", "Oak", 10, "acorn", "Acorn", {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
|
||||||
{"sequoia", "Sequoia", nil, nil, nil },
|
{"sequoia", "Sequoia", 7 },
|
||||||
{"birch", "Birch", nil, nil, nil },
|
{"birch", "Birch", 10 },
|
||||||
{"palm", "Palm", "coconut", "Coconut", {-0.2, -0.5, -0.2, 0.2, 0, 0.2} },
|
{"palm", "Palm", 15, "coconut", "Coconut", {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 1.0 },
|
||||||
{"spruce", "Spruce", "spruce_cone", "Spruce Cone", {-0.2, -0.5, -0.2, 0.2, 0, 0.2} },
|
{"spruce", "Spruce", 10, "spruce_cone", "Spruce Cone", {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
|
||||||
{"pine", "Pine", "pine_cone", "Pine Cone", {-0.2, -0.5, -0.2, 0.2, 0, 0.2} },
|
{"pine", "Pine", 10, "pine_cone", "Pine Cone", {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
|
||||||
{"willow", "Willow", nil, nil, nil },
|
{"willow", "Willow", 15 },
|
||||||
{"rubber_tree", "Rubber Tree", nil, nil, nil },
|
{"rubber_tree", "Rubber Tree", 7 },
|
||||||
|
{"jungletree", "Jungle Tree"},
|
||||||
|
{"fir", "Fir", 15, "fir_cone", "Fir Cone", {-0.2, -0.5, -0.2, 0.2, 0, 0.2}, 0.8 },
|
||||||
}
|
}
|
||||||
|
|
||||||
simple_trees = { "beech", "apple_tree", "oak", "sequoia", "palm", "pine", "willow", "rubber_tree"}
|
simple_trees = { "beech", "apple_tree", "oak", "sequoia", "palm", "pine", "willow", "rubber_tree"}
|
||||||
@ -53,18 +29,18 @@ simple_trees = { "beech", "apple_tree", "oak", "sequoia", "palm", "pine", "willo
|
|||||||
for i in ipairs(trees) do
|
for i in ipairs(trees) do
|
||||||
local treename = trees[i][1]
|
local treename = trees[i][1]
|
||||||
local treedesc = trees[i][2]
|
local treedesc = trees[i][2]
|
||||||
local fruit = trees[i][3]
|
local leafdecayradius = trees[i][3] -- future use, not yet implemented.
|
||||||
local fruitdesc = trees[i][4]
|
local fruit = trees[i][4]
|
||||||
local selbox = trees[i][5]
|
local fruitdesc = trees[i][5]
|
||||||
|
local selbox = trees[i][6]
|
||||||
table.insert(moretrees.avoidnodes, "moretrees:"..treename.."_trunk")
|
local vscale = trees[i][7]
|
||||||
|
|
||||||
minetest.register_node("moretrees:"..treename.."_trunk", {
|
minetest.register_node("moretrees:"..treename.."_trunk", {
|
||||||
description = treedesc.." Trunk",
|
description = treedesc.." Tree Trunk",
|
||||||
tiles = {
|
tiles = {
|
||||||
"moretrees_"..treename.."_top.png",
|
"moretrees_"..treename.."_trunk_top.png",
|
||||||
"moretrees_"..treename.."_top.png",
|
"moretrees_"..treename.."_trunk_top.png",
|
||||||
"moretrees_"..treename..".png"
|
"moretrees_"..treename.."_trunk.png"
|
||||||
},
|
},
|
||||||
is_ground_content = true,
|
is_ground_content = true,
|
||||||
groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2},
|
groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2},
|
||||||
@ -72,14 +48,14 @@ for i in ipairs(trees) do
|
|||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_node("moretrees:"..treename.."_trunk_sideways", {
|
minetest.register_node("moretrees:"..treename.."_trunk_sideways", {
|
||||||
description = treedesc.." Trunk (sideways)",
|
description = "Sideways "..treedesc.." Tree Trunk",
|
||||||
tiles = {
|
tiles = {
|
||||||
"moretrees_"..treename..".png^[transformR90",
|
"moretrees_"..treename.."_trunk.png^[transformR90",
|
||||||
"moretrees_"..treename..".png^[transformR90",
|
"moretrees_"..treename.."_trunk.png^[transformR90",
|
||||||
"moretrees_"..treename.."_top.png",
|
"moretrees_"..treename.."_trunk_top.png",
|
||||||
"moretrees_"..treename.."_top.png",
|
"moretrees_"..treename.."_trunk_top.png",
|
||||||
"moretrees_"..treename..".png^[transformR90",
|
"moretrees_"..treename.."_trunk.png^[transformR90",
|
||||||
"moretrees_"..treename..".png^[transformR90"
|
"moretrees_"..treename.."_trunk.png^[transformR90"
|
||||||
},
|
},
|
||||||
is_ground_content = true,
|
is_ground_content = true,
|
||||||
groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2},
|
groups = {tree=1,snappy=1,choppy=2,oddly_breakable_by_hand=1,flammable=2},
|
||||||
@ -87,7 +63,7 @@ for i in ipairs(trees) do
|
|||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_node("moretrees:"..treename.."_planks", {
|
minetest.register_node("moretrees:"..treename.."_planks", {
|
||||||
description = treedesc.." Planks",
|
description = treedesc.." Beech Planks",
|
||||||
tiles = {"moretrees_"..treename.."_wood.png"},
|
tiles = {"moretrees_"..treename.."_wood.png"},
|
||||||
is_ground_content = true,
|
is_ground_content = true,
|
||||||
groups = {snappy=1,choppy=2,oddly_breakable_by_hand=2,flammable=3,wood=1},
|
groups = {snappy=1,choppy=2,oddly_breakable_by_hand=2,flammable=3,wood=1},
|
||||||
@ -95,7 +71,7 @@ for i in ipairs(trees) do
|
|||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_node("moretrees:"..treename.."_sapling", {
|
minetest.register_node("moretrees:"..treename.."_sapling", {
|
||||||
description = treedesc.." Sapling",
|
description = treedesc.." Tree Sapling",
|
||||||
drawtype = "plantlike",
|
drawtype = "plantlike",
|
||||||
tiles = {"moretrees_"..treename.."_sapling.png"},
|
tiles = {"moretrees_"..treename.."_sapling.png"},
|
||||||
inventory_image = "moretrees_"..treename.."_sapling.png",
|
inventory_image = "moretrees_"..treename.."_sapling.png",
|
||||||
@ -114,7 +90,9 @@ for i in ipairs(trees) do
|
|||||||
description = fruitdesc,
|
description = fruitdesc,
|
||||||
drawtype = "plantlike",
|
drawtype = "plantlike",
|
||||||
tiles = { "moretrees_"..fruit..".png" },
|
tiles = { "moretrees_"..fruit..".png" },
|
||||||
inventory_image = "moretrees_"..fruit..".png",
|
inventory_image = "moretrees_"..fruit..".png^[transformR180",
|
||||||
|
wield_image = "moretrees_"..fruit..".png^[transformR180",
|
||||||
|
visual_scale = vscale,
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
walkable = false,
|
walkable = false,
|
||||||
@ -127,165 +105,61 @@ for i in ipairs(trees) do
|
|||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- player will get sapling with 1/20 chance
|
||||||
|
-- player will get leaves only if he get no saplings,
|
||||||
|
-- this is because max_items is 1
|
||||||
|
|
||||||
|
if treename ~= "jungletree" then
|
||||||
|
minetest.register_node("moretrees:"..treename.."_leaves", {
|
||||||
|
description = treedesc.." Tree Leaves",
|
||||||
|
drawtype = "allfaces_optional",
|
||||||
|
tiles = { "moretrees_"..treename.."_leaves.png" },
|
||||||
|
paramtype = "light",
|
||||||
|
groups = {tree=1, snappy=3, flammable=2 },
|
||||||
|
sounds = default.node_sound_leaves_defaults(),
|
||||||
|
|
||||||
|
-- player will get sapling with 1/20 chance
|
||||||
|
-- player will get leaves only if he/she gets no
|
||||||
|
-- saplings, because max_items is 1.
|
||||||
|
|
||||||
|
drop = {
|
||||||
|
max_items = 1,
|
||||||
|
items = {
|
||||||
|
{items = {"moretrees:"..treename.."_sapling"}, rarity = 20 },
|
||||||
|
{items = {"moretrees:"..treename.."_leaves"} }
|
||||||
|
}
|
||||||
|
},
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
|
table.insert(moretrees.avoidnodes, "moretrees:"..treename.."_trunk")
|
||||||
|
table.insert(moretrees.avoidnodes, "moretrees:"..treename.."_leaves")
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Nodes for jungle trees
|
-- Extra leaves for jungle trees:
|
||||||
|
|
||||||
minetest.register_node("moretrees:jungletree_sapling", {
|
local jungleleaves = {"green","yellow","red"}
|
||||||
description = "Jungle Tree Sapling",
|
local jungleleavesnames = {"Green", "Yellow", "Red"}
|
||||||
drawtype = "plantlike",
|
|
||||||
tiles = {"moretrees_jungletree_sapling.png"},
|
|
||||||
inventory_image = "moretrees_jungletree_sapling.png",
|
|
||||||
paramtype = "light",
|
|
||||||
walkable = false,
|
|
||||||
groups = {snappy=2,dig_immediate=3,flammable=2},
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("moretrees:jungletree_trunk", {
|
|
||||||
description = "Jungle Tree trunk (sideways)",
|
|
||||||
tiles = {
|
|
||||||
"default_jungletree_top.png",
|
|
||||||
"default_jungletree_top.png",
|
|
||||||
"default_jungletree.png",
|
|
||||||
"default_jungletree.png",
|
|
||||||
"default_jungletree.png",
|
|
||||||
"default_jungletree.png"
|
|
||||||
},
|
|
||||||
groups = {wood=1,snappy=2,dig_immediate=3,flammable=2},
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("moretrees:jungletree_planks", {
|
|
||||||
description = "Jungle Tree Planks",
|
|
||||||
tiles = {
|
|
||||||
"moretrees_jungletree_wood.png",
|
|
||||||
},
|
|
||||||
groups = {wood=1,snappy=2,dig_immediate=3,flammable=2},
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("moretrees:jungletree_trunk_sideways", {
|
|
||||||
description = "Jungle Tree trunk (sideways)",
|
|
||||||
tiles = {
|
|
||||||
"default_jungletree.png^[transformR90",
|
|
||||||
"default_jungletree.png^[transformR90",
|
|
||||||
"default_jungletree_top.png",
|
|
||||||
"default_jungletree_top.png",
|
|
||||||
"default_jungletree.png^[transformR90",
|
|
||||||
"default_jungletree.png^[transformR90"
|
|
||||||
},
|
|
||||||
groups = {wood=1,snappy=2,dig_immediate=3,flammable=2},
|
|
||||||
})
|
|
||||||
|
|
||||||
local leaves = {"green","yellow","red"}
|
|
||||||
for color = 1, 3 do
|
for color = 1, 3 do
|
||||||
local leave_name = "moretrees:jungletree_leaves_"..leaves[color]
|
local leave_name = "moretrees:jungletree_leaves_"..jungleleaves[color]
|
||||||
minetest.register_node(leave_name, {
|
minetest.register_node(leave_name, {
|
||||||
description = "Jungle Tree Leaves",
|
description = "Jungle Tree Leaves ("..jungleleavesnames[color]..")",
|
||||||
drawtype = "allfaces_optional",
|
drawtype = "allfaces_optional",
|
||||||
tiles = {"moretrees_jungletree_leaves_"..leaves[color]..".png"},
|
tiles = {"moretrees_jungletree_leaves_"..jungleleaves[color]..".png"},
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
groups = {snappy=3, leafdecay=3, flammable=2},
|
groups = {snappy=3, flammable=2},
|
||||||
drop = {
|
drop = {
|
||||||
max_items = 1,
|
max_items = 1,
|
||||||
items = {
|
items = {
|
||||||
{
|
{items = {'moretrees:jungletree_sapling'}, rarity = 20 },
|
||||||
-- player will get sapling with 1/20 chance
|
{items = {"moretrees:jungletree_leaves_"..jungleleaves[color]} }
|
||||||
items = {'moretrees:jungletree_sapling'},
|
|
||||||
rarity = 20,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
-- player will get leaves only if he get no saplings,
|
|
||||||
-- this is because max_items is 1
|
|
||||||
items = {"moretrees:jungletree_leaves_"..leaves[color]},
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
sounds = default.node_sound_leaves_defaults(),
|
sounds = default.node_sound_leaves_defaults(),
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Nodes for firs
|
-- Extra needles for firs
|
||||||
|
|
||||||
minetest.register_node("moretrees:fir_trunk", {
|
|
||||||
description = "Fir trunk",
|
|
||||||
tile_images = {
|
|
||||||
"moretrees_fir_trunktop.png",
|
|
||||||
"moretrees_fir_trunktop.png",
|
|
||||||
"moretrees_fir_trunk.png",
|
|
||||||
"moretrees_fir_trunk.png",
|
|
||||||
"moretrees_fir_trunk.png",
|
|
||||||
"moretrees_fir_trunk.png"
|
|
||||||
},
|
|
||||||
is_ground_content = true,
|
|
||||||
groups = {
|
|
||||||
tree = 1,
|
|
||||||
snappy = 2,
|
|
||||||
choppy = 2,
|
|
||||||
oddly_breakable_by_hand = 1,
|
|
||||||
flammable = 2,
|
|
||||||
wood = 1
|
|
||||||
},
|
|
||||||
sounds = default.node_sound_wood_defaults()
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("moretrees:fir_trunk_sideways", {
|
|
||||||
description = "Fir Trunk (sideways)",
|
|
||||||
tile_images = {
|
|
||||||
"moretrees_fir_trunk.png^[transformR90",
|
|
||||||
"moretrees_fir_trunk.png^[transformR90",
|
|
||||||
"moretrees_fir_trunktop.png",
|
|
||||||
"moretrees_fir_trunktop.png",
|
|
||||||
"moretrees_fir_trunk.png^[transformR90",
|
|
||||||
"moretrees_fir_trunk.png^[transformR90"
|
|
||||||
},
|
|
||||||
paramtype2 = "facedir",
|
|
||||||
material = minetest.digprop_woodlike(1.0),
|
|
||||||
|
|
||||||
groups = {
|
|
||||||
tree = 1,
|
|
||||||
snappy = 2,
|
|
||||||
choppy = 2,
|
|
||||||
oddly_breakable_by_hand = 1,
|
|
||||||
flammable = 2,
|
|
||||||
wood = 1
|
|
||||||
},
|
|
||||||
sounds = default.node_sound_wood_defaults()
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("moretrees:fir_planks", {
|
|
||||||
description = "Fir Planks",
|
|
||||||
tiles = {
|
|
||||||
"moretrees_fir_wood.png",
|
|
||||||
},
|
|
||||||
groups = {wood=1,snappy=2,dig_immediate=3,flammable=2},
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("moretrees:fir_leaves", {
|
|
||||||
drawtype = "allfaces_optional",
|
|
||||||
description = "Fir Leaves",
|
|
||||||
tile_images = { "moretrees_fir_leaves.png" },
|
|
||||||
paramtype = "light",
|
|
||||||
groups = {
|
|
||||||
snappy = 3,
|
|
||||||
leafdecay = 3,
|
|
||||||
flammable = 2
|
|
||||||
},
|
|
||||||
drop = {
|
|
||||||
max_items = 1,
|
|
||||||
items = {
|
|
||||||
{
|
|
||||||
-- player will get sapling with 1/20 chance
|
|
||||||
items = {'moretrees:fir_sapling'},
|
|
||||||
rarity = 20,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
-- player will get leaves only if he get no saplings,
|
|
||||||
-- this is because max_items is 1
|
|
||||||
items = {'moretrees:fir_leaves'},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
|
||||||
sounds = default.node_sound_leaves_defaults()
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("moretrees:fir_leaves_bright", {
|
minetest.register_node("moretrees:fir_leaves_bright", {
|
||||||
drawtype = "allfaces_optional",
|
drawtype = "allfaces_optional",
|
||||||
@ -293,59 +167,18 @@ minetest.register_node("moretrees:fir_leaves_bright", {
|
|||||||
tile_images = { "moretrees_fir_leaves_bright.png" },
|
tile_images = { "moretrees_fir_leaves_bright.png" },
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
|
|
||||||
groups = {
|
groups = {snappy=3, flammable=2 },
|
||||||
snappy = 3,
|
|
||||||
leafdecay = 3,
|
|
||||||
flammable = 2
|
|
||||||
},
|
|
||||||
drop = {
|
drop = {
|
||||||
max_items = 1,
|
max_items = 1,
|
||||||
items = {
|
items = {
|
||||||
{
|
{items = {'moretrees:fir_sapling'}, rarity = 20 },
|
||||||
-- player will get sapling with 1/20 chance
|
{items = {'moretrees:fir_leaves'} }
|
||||||
items = {'moretrees:fir_sapling'},
|
|
||||||
rarity = 20,
|
|
||||||
},
|
|
||||||
{
|
|
||||||
-- player will get leaves only if he get no saplings,
|
|
||||||
-- this is because max_items is 1
|
|
||||||
items = {'moretrees:fir_leaves'},
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
sounds = default.node_sound_leaves_defaults()
|
sounds = default.node_sound_leaves_defaults()
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_node("moretrees:fir_sapling", {
|
|
||||||
description = "Fir sapling",
|
|
||||||
drawtype = "plantlike",
|
|
||||||
tile_images = {"moretrees_fir_sapling.png"},
|
|
||||||
inventory_image = "moretrees_fir_sapling.png",
|
|
||||||
paramtype = "light",
|
|
||||||
walkable = false,
|
|
||||||
groups = {
|
|
||||||
snappy = 2,
|
|
||||||
dig_immediate = 3,
|
|
||||||
flammable = 2
|
|
||||||
},
|
|
||||||
sounds = default.node_sound_defaults(),
|
|
||||||
})
|
|
||||||
|
|
||||||
minetest.register_node("moretrees:fir_cone", {
|
|
||||||
description = "Fir cone",
|
|
||||||
drawtype = "plantlike",
|
|
||||||
tiles = {"moretrees_fir_cone.png"},
|
|
||||||
inventory_image = "moretrees_fir_cone.png",
|
|
||||||
paramtype = "light",
|
|
||||||
sunlight_propagates = true,
|
|
||||||
walkable = false,
|
|
||||||
groups = {fleshy=3,dig_immediate=3,flammable=2},
|
|
||||||
sounds = default.node_sound_defaults(),
|
|
||||||
selection_box = {
|
|
||||||
type = "fixed",
|
|
||||||
fixed = {-0.2, -0.5, -0.2, 0.2, 0, 0.2}
|
|
||||||
},
|
|
||||||
})
|
|
||||||
|
|
||||||
-- Backward compatbility with old mods/nodes:
|
-- Backward compatbility with old mods/nodes:
|
||||||
|
|
||||||
|
Before Width: | Height: | Size: 754 B After Width: | Height: | Size: 754 B |
Before Width: | Height: | Size: 800 B After Width: | Height: | Size: 800 B |
Before Width: | Height: | Size: 706 B After Width: | Height: | Size: 706 B |
Before Width: | Height: | Size: 843 B After Width: | Height: | Size: 843 B |
Before Width: | Height: | Size: 989 B After Width: | Height: | Size: 989 B |
Before Width: | Height: | Size: 830 B After Width: | Height: | Size: 830 B |
Before Width: | Height: | Size: 721 B |
Before Width: | Height: | Size: 768 B After Width: | Height: | Size: 768 B |
Before Width: | Height: | Size: 705 B |
BIN
textures/moretrees_jungletree_trunk.png
Normal file
After Width: | Height: | Size: 751 B |
BIN
textures/moretrees_jungletree_trunk_top.png
Normal file
After Width: | Height: | Size: 865 B |
Before Width: | Height: | Size: 816 B After Width: | Height: | Size: 816 B |
Before Width: | Height: | Size: 792 B After Width: | Height: | Size: 792 B |
Before Width: | Height: | Size: 640 B After Width: | Height: | Size: 640 B |
Before Width: | Height: | Size: 738 B After Width: | Height: | Size: 738 B |
Before Width: | Height: | Size: 872 B After Width: | Height: | Size: 872 B |
Before Width: | Height: | Size: 777 B After Width: | Height: | Size: 777 B |
Before Width: | Height: | Size: 808 B After Width: | Height: | Size: 808 B |
Before Width: | Height: | Size: 791 B After Width: | Height: | Size: 791 B |
Before Width: | Height: | Size: 508 B After Width: | Height: | Size: 508 B |
Before Width: | Height: | Size: 787 B After Width: | Height: | Size: 787 B |
Before Width: | Height: | Size: 699 B After Width: | Height: | Size: 699 B |
Before Width: | Height: | Size: 738 B After Width: | Height: | Size: 738 B |
Before Width: | Height: | Size: 510 B After Width: | Height: | Size: 510 B |
Before Width: | Height: | Size: 805 B After Width: | Height: | Size: 805 B |
@ -89,7 +89,7 @@ moretrees.birch_model2={
|
|||||||
}
|
}
|
||||||
|
|
||||||
moretrees.palm_model={
|
moretrees.palm_model={
|
||||||
axiom="FFccc&FFFFFdddFA//A//A//A//A//A",
|
axiom="FFcccccc&FFFFFddd[^&&&GR][^///&&&GR][^//////&&&GR][^***&&&GR]FA//A//A//A//A//A",
|
||||||
rules_a="[&fb&bbb[++f--&ffff&ff][--f++&ffff&ff]&ffff&bbbb&b]",
|
rules_a="[&fb&bbb[++f--&ffff&ff][--f++&ffff&ff]&ffff&bbbb&b]",
|
||||||
rules_b="f",
|
rules_b="f",
|
||||||
rules_c="/",
|
rules_c="/",
|
||||||
|