forked from mtcontrib/moretrees
Enabled several new types of trees, all spawned at mapgen time!
This code will slow the map generator down a little due to bugs therein, and is generally still in the experimental stages, but it works and is actually quite fast!
This commit is contained in:
parent
1bd0afbc84
commit
2c3345aa04
@ -2,7 +2,7 @@
|
||||
|
||||
-- Example biome definition:
|
||||
|
||||
mytree_biome = {
|
||||
moretrees.mytree_biome = {
|
||||
surface = "default:dirt_with_grass", -- must grow on these nodes only
|
||||
avoid_nodes = {"default:tree"}, -- avoid spawning near these
|
||||
avoid_radius = 12, -- Keep this much room around the above avoid items
|
||||
@ -20,27 +20,11 @@ mytree_biome = {
|
||||
}
|
||||
]]--
|
||||
|
||||
moretrees.jungletree_biome = {
|
||||
surface = "default:dirt_with_grass",
|
||||
avoid_nodes = moretrees.avoidnodes,
|
||||
avoid_radius = 12,
|
||||
seed_diff = 329,
|
||||
min_elevation = -5,
|
||||
max_elevation = 10,
|
||||
near_nodes = {"default:water_source"},
|
||||
near_nodes_size = 15,
|
||||
near_nodes_count = 10,
|
||||
-- temp_min = 0.05,
|
||||
}
|
||||
|
||||
moretrees.conifer_biome = {
|
||||
moretrees.beech_biome = {
|
||||
surface = "default:dirt_with_grass",
|
||||
avoid_nodes = moretrees.avoidnodes,
|
||||
avoid_radius = 10,
|
||||
seed_diff = 359,
|
||||
min_elevation = 25,
|
||||
temp_min = 0.9,
|
||||
temp_max = 0.3,
|
||||
seed_diff = 2,
|
||||
}
|
||||
|
||||
moretrees.palm_biome = {
|
||||
@ -57,7 +41,7 @@ moretrees.palm_biome = {
|
||||
temp_max = -0.15,
|
||||
}
|
||||
|
||||
moretrees.apple_biome = {
|
||||
moretrees.apple_tree_biome = {
|
||||
surface = "default:dirt_with_grass",
|
||||
avoid_nodes = moretrees.avoidnodes,
|
||||
avoid_radius = 15,
|
||||
@ -133,7 +117,7 @@ moretrees.willow_biome = {
|
||||
near_nodes_count = 5,
|
||||
}
|
||||
|
||||
moretrees.rubber_biome = {
|
||||
moretrees.rubber_tree_biome = {
|
||||
surface = "default:dirt_with_grass",
|
||||
avoid_nodes = moretrees.avoidnodes,
|
||||
avoid_radius = 20,
|
||||
@ -146,3 +130,26 @@ moretrees.rubber_biome = {
|
||||
temp_min = -0.15,
|
||||
}
|
||||
|
||||
|
||||
moretrees.jungletree_biome = {
|
||||
surface = "default:dirt_with_grass",
|
||||
avoid_nodes = moretrees.avoidnodes,
|
||||
avoid_radius = 12,
|
||||
seed_diff = 329,
|
||||
min_elevation = -5,
|
||||
max_elevation = 10,
|
||||
near_nodes = {"default:water_source"},
|
||||
near_nodes_size = 15,
|
||||
near_nodes_count = 10,
|
||||
-- temp_min = 0.05,
|
||||
}
|
||||
|
||||
moretrees.conifer_biome = {
|
||||
surface = "default:dirt_with_grass",
|
||||
avoid_nodes = moretrees.avoidnodes,
|
||||
avoid_radius = 10,
|
||||
seed_diff = 359,
|
||||
min_elevation = 25,
|
||||
temp_min = 0.9,
|
||||
temp_max = 0.3,
|
||||
}
|
||||
|
48
init.lua
48
init.lua
@ -34,20 +34,50 @@ dofile(minetest.get_modpath("moretrees").."/node_defs.lua")
|
||||
dofile(minetest.get_modpath("moretrees").."/tree_models.lua")
|
||||
dofile(minetest.get_modpath("moretrees").."/biome_defs.lua")
|
||||
|
||||
plantslib:register_generate_plant(moretrees.apple_tree_biome, moretrees.apple_tree_model)
|
||||
plantslib:register_generate_plant(moretrees.oak_biome, moretrees.oak_model)
|
||||
plantslib:register_generate_plant(moretrees.sequoia_biome, moretrees.sequoia_model)
|
||||
plantslib:register_generate_plant(moretrees.palm_biome, moretrees.palm_model)
|
||||
plantslib:register_generate_plant(moretrees.pine_biome, moretrees.pine_model)
|
||||
plantslib:register_generate_plant(moretrees.rubber_tree_biome, moretrees.rubber_tree_model)
|
||||
plantslib:register_generate_plant(moretrees.willow_biome, moretrees.willow_model)
|
||||
|
||||
plantslib:register_generate_plant(moretrees.birch_biome, "moretrees:grow_birch")
|
||||
plantslib:register_generate_plant(moretrees.spruce_biome, "moretrees:grow_spruce")
|
||||
plantslib:register_generate_plant(moretrees.jungletree_biome, "moretrees:grow_jungletree")
|
||||
plantslib:register_generate_plant(moretrees.conifer_biome, "moretrees:grow_conifer")
|
||||
|
||||
--plantslib:register_generate_plant(moretrees.palm_biome, moretrees.palm_model)
|
||||
-- These three lines replace default trees with beech
|
||||
-- Enable them if you want but be warned - due to serious bugs in the speed
|
||||
-- of the engine's map generator/loader, doing so will slow it WAY down.
|
||||
|
||||
--------------------------
|
||||
-- Other stuff
|
||||
--
|
||||
-- for backward compatibility with previous mods/code, jungle trees and
|
||||
-- firs ("conifers") L-Systems definitions are established separately.
|
||||
--
|
||||
--------------------------
|
||||
--[[
|
||||
minetest.register_alias("mapgen_tree", "air")
|
||||
minetest.register_alias("mapgen_leaves", "air")
|
||||
plantslib:register_generate_plant(moretrees.beech_biome, moretrees.beech_model)
|
||||
]]--
|
||||
|
||||
-- Code that spawns jungle trees and firs ("conifers")
|
||||
-- Code to spawn a birch tree
|
||||
|
||||
function moretrees:grow_birch(pos)
|
||||
if math.random(1,2) == 1 then
|
||||
minetest.env:spawn_tree(pos, moretrees.birch_model1)
|
||||
else
|
||||
minetest.env:spawn_tree(pos, moretrees.birch_model2)
|
||||
end
|
||||
end
|
||||
|
||||
-- Code to spawn a spruce tree
|
||||
|
||||
function moretrees:grow_spruce(pos)
|
||||
if math.random(1,2) == 1 then
|
||||
minetest.env:spawn_tree(pos, moretrees.spruce_model1)
|
||||
else
|
||||
minetest.env:spawn_tree(pos, moretrees.spruce_model2)
|
||||
end
|
||||
end
|
||||
|
||||
-- Code that spawns jungle trees and firs ("conifer")
|
||||
|
||||
moretrees.jt_axiom1 = "FFFA"
|
||||
moretrees.jt_rules_a1 = "FFF[&&-FBf[&&&Ff]^^^Ff][&&+FBFf[&&&FFf]^^^Ff][&&---FBFf[&&&Ff]^^^Ff][&&+++FBFf[&&&Ff]^^^Ff]F/A"
|
||||
|
@ -1,4 +1,4 @@
|
||||
beech_model={
|
||||
moretrees.beech_model={
|
||||
axiom="FFFFFBFB",
|
||||
rules_a="[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fd]]////[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fd]]////[&&&GGF[++^Fd][--&Fd]//Fd[+^Fd][--&Fdd]]",
|
||||
rules_b="[&&&F[++^Fd][--&d]//d[+^d][--&d]]////[&&&F[++^Fd][--&d]//d[+^d][--&d]]////[&&&F[++^Fd][--&Fd]//d[+^d][--&d]]",
|
||||
@ -13,7 +13,7 @@ trunk_type="single";
|
||||
thin_branches=true;
|
||||
}
|
||||
|
||||
apple_tree_model={
|
||||
moretrees.apple_tree_model={
|
||||
axiom="FFFFFAFFBF",
|
||||
rules_a="[&&&FFFFF&&FFFF][&&&++++FFFFF&&FFFF][&&&----FFFFF&&FFFF]",
|
||||
rules_b="[&&&++FFFFF&&FFFF][&&&--FFFFF&&FFFF][&&&------FFFFF&&FFFF]",
|
||||
@ -28,7 +28,7 @@ fruit="default:apple",
|
||||
fruit_chance=15,
|
||||
}
|
||||
|
||||
oak_model={
|
||||
moretrees.oak_model={
|
||||
axiom="FFFFFFA",
|
||||
rules_a="[&FFBFA]////[&BFFFA]////[&FBFFA]",
|
||||
rules_b="[&FFFA]////[&FFFA]////[&FFFA]",
|
||||
@ -43,7 +43,7 @@ fruit="moretrees:acorn",
|
||||
fruit_chance=3,
|
||||
}
|
||||
|
||||
sequoia_model={
|
||||
moretrees.sequoia_model={
|
||||
axiom="FFFFFFFFFFddccA///cccFddcFA///ddFcFA/cFFddFcdBddd/A/ccdcddd/ccAddddcFBcccAccFdFcFBcccc/BFdFFcFFdcccc/B",
|
||||
rules_a="[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]////[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]////[&&&GGF[++^FFdd][--&Fddd]//Fdd[+^Fd][--&Fdd]]",
|
||||
rules_b="[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]////[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]////[&&&GGF[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]",
|
||||
@ -58,7 +58,7 @@ trunk_type="crossed",
|
||||
thin_branches=true
|
||||
}
|
||||
|
||||
birch_model1={
|
||||
moretrees.birch_model1={
|
||||
axiom="FFFFFdddccA/FFFFFFcA/FFFFFFcB",
|
||||
rules_a="[&&&dddd^^ddddddd][&&&---dddd^^ddddddd][&&&+++dddd^^ddddddd][&&&++++++dddd^^ddddddd]",
|
||||
rules_b="[&&&ddd^^ddddd][&&&---ddd^^ddddd][&&&+++ddd^^ddddd][&&&++++++ddd^^ddddd]",
|
||||
@ -73,7 +73,7 @@ trunk_type="single",
|
||||
thin_branches=true
|
||||
}
|
||||
|
||||
birch_model2={
|
||||
moretrees.birch_model2={
|
||||
axiom="FFFdddccA/FFFFFccA/FFFFFccB",
|
||||
rules_a="[&&&dFFF^^FFFdd][&&&---dFFF^^FFFdd][&&&+++dFFF^^FFFdd][&&&++++++dFFF^^FFFdd]",
|
||||
rules_b="[&&&dFF^^FFFd][&&&---dFFF^^FFFd][&&&+++dFF^^FFFd][&&&++++++dFF^^FFFd]",
|
||||
@ -88,7 +88,7 @@ trunk_type="single",
|
||||
thin_branches=true
|
||||
}
|
||||
|
||||
palm_model={
|
||||
moretrees.palm_model={
|
||||
axiom="FFccc&FFFFFdddFA//A//A//A//A//A",
|
||||
rules_a="[&fb&bbb[++f--&ffff&ff][--f++&ffff&ff]&ffff&bbbb&b]",
|
||||
rules_b="f",
|
||||
@ -105,7 +105,7 @@ fruit="moretrees:coconut",
|
||||
fruit_chance=0
|
||||
}
|
||||
|
||||
spruce_model1={
|
||||
moretrees.spruce_model1={
|
||||
axiom="FFFFFAFFFFFFBFFFFFFCFFFFFFDFFFFFF[&&&F^^FF][&&&++F^^FF][&&&++++F^^FF][&&&++++++F^^FF][&&&--F^^FF][&&&----F^^FF][FFFFf]",
|
||||
rules_a="[&&&FFFFFF^^FFF][&&&++FFFFFF^^FFF][&&&++++FFFFFF^^FFF][&&&++++++FFFFFF^^FFF][&&&--FFFFFF^^FFF][&&&----FFFFFF^^FFF]",
|
||||
rules_b="[&&&FFFFF^^FFF][&&&++FFFFF^^FFF][&&&++++FFFFF^^FFF][&&&++++++FFFFF^^FFF][&&&--FFFFF^^FFF][&&&----FFFFF^^FFF]",
|
||||
@ -122,7 +122,7 @@ fruit="moretrees:cone",
|
||||
fruit_chance=8
|
||||
}
|
||||
|
||||
spruce_model2={
|
||||
moretrees.spruce_model2={
|
||||
axiom="FFFFFFBFFFFFFCFFFFFFDFFFFFF[&&&F^^FF][&&&++F^^FF][&&&++++F^^FF][&&&++++++F^^FF][&&&--F^^FF][&&&----F^^FF][FFFFf]",
|
||||
rules_b="[&&&FFFFF^^FFF][&&&++FFFFF^^FFF][&&&++++FFFFF^^FFF][&&&++++++FFFFF^^FFF][&&&--FFFFF^^FFF][&&&----FFFFF^^FFF]",
|
||||
rules_c="[&&&FFFF^^FFF][&&&++FFFF^^FFF][&&&++++FFFF^^FFF][&&&++++++FFFF^^FFF][&&&--FFFF^^FFF][&&&----FFFF^^FFF]",
|
||||
@ -138,7 +138,7 @@ fruit="moretrees:cone",
|
||||
fruit_chance=8
|
||||
}
|
||||
|
||||
pine_model={
|
||||
moretrees.pine_model={
|
||||
axiom="FFFFFcccdddB///cFdFB////cFdFB///cFdFB///cFdFA///cFdFA///cFdFB[FF]f",
|
||||
rules_a="[&&&TTTT[++^TFdd][--&TFd]//Tdd[+^Fd][--&Fdd]]",
|
||||
rules_b="[&&&TTT[++^Fdd][--&Fdd]//dd[+^d][--&Fd]]",
|
||||
@ -155,7 +155,7 @@ fruit="moretrees:pine_cone",
|
||||
fruit_chance=8
|
||||
}
|
||||
|
||||
willow_model={
|
||||
moretrees.willow_model={
|
||||
axiom="FFFFFFFFccA",
|
||||
rules_a="[&FF&FFFF&&F&FFFFFFFdddd][**&FF&FFFF&&F&FFFFFFFdddd][//&FF&FFFF&&F&FFFFFFFdddd][////&FF&FFFF&&F&FFFFFFFdddd][//////&FF&FFFF&&F&FFFFFFFdddd][////////&FF&FFFF&&F&FFFFFFFdddd]",
|
||||
rules_c="/",
|
||||
@ -169,7 +169,7 @@ trunk_type="crossed",
|
||||
thin_branches=true
|
||||
}
|
||||
|
||||
rubber_tree={
|
||||
moretrees.rubber_tree_model={
|
||||
axiom="FFFFA",
|
||||
rules_a="[&FFBFA]////[&BFFFA]////[&FBFFA]",
|
||||
rules_b="[&FFA]////[&FFA]////[&FFA]",
|
||||
@ -208,5 +208,6 @@ moretrees.conifer_model={
|
||||
angle=45,
|
||||
iterations=7,
|
||||
random_level=5,
|
||||
thin_trunks=true
|
||||
trunk_type="single",
|
||||
thin_branches=true
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user