111 lines
4.1 KiB
Lua
Raw Normal View History

village = {}
2016-03-03 18:27:39 +01:00
village.houses = {}
2016-03-13 15:59:30 +01:00
village.num = 1
2016-03-03 18:27:39 +01:00
function village.facedir_to_text_1(f)
local all = {[0]="0",[3]="90",[2]="180",[1]="270",[4]="360"}
local o = all[f]
return o
end
function village.facedir_to_text_2(f)
local all = {[2]="0",[1]="90",[0]="180",[3]="270",[4]="360"}
local o = all[f]
return o
end
--main func
2016-03-01 19:17:16 +01:00
function village.gen(pos)
2016-03-03 18:27:39 +01:00
village.road(pos)
village.road(pos)
village.road(pos)
village.road(pos)
end
2016-03-03 18:27:39 +01:00
function village.road(pos)
local path_house_1 = minetest.get_modpath("village") .. "/schematics/house_1.mts"
local path_house_2 = minetest.get_modpath("village") .. "/schematics/house_2.mts"
local path_road = minetest.get_modpath("village") .. "/schematics/road.mts"
local facedir = math.random(0,2)
local dir = minetest.facedir_to_dir(facedir)
pos = vector.add(pos, vector.multiply(dir, 6))
for x=0,3,1 do
minetest.place_schematic({x = pos.x+(dir.x*6*x), y = pos.y - 1, z = pos.z+(dir.z*6*x)}, path_road, 0, nil, true)
if dir.x < 0 then
minetest.place_schematic({x = pos.x+(dir.x*6*x), y = pos.y - 1, z = pos.z+(dir.z*6*x)+6}, village.houses[ math.random( #village.houses ) ] , village.facedir_to_text_2(facedir), 0, nil, true)
minetest.place_schematic({x = pos.x+(dir.x*6*x), y = pos.y - 1, z = pos.z+(dir.z*6*x)-6}, village.houses[ math.random( #village.houses ) ], village.facedir_to_text_1(facedir), 0, nil, true)
elseif dir.x > 0 then
minetest.place_schematic({x = pos.x+(dir.x*6*x), y = pos.y - 1, z = pos.z+(dir.z*6*x)+6}, village.houses[ math.random( #village.houses ) ], village.facedir_to_text_1(facedir), 0, nil, true)
minetest.place_schematic({x = pos.x+(dir.x*6*x), y = pos.y - 1, z = pos.z+(dir.z*6*x)-6}, village.houses[ math.random( #village.houses ) ], village.facedir_to_text_2(facedir), 0, nil, true)
elseif dir.z > 0 then
minetest.place_schematic({x = pos.x+(dir.x*6*x)+6, y = pos.y - 1, z = pos.z+(dir.z*6*x)}, village.houses[ math.random( #village.houses ) ], village.facedir_to_text_1(facedir), 0, nil, true)
minetest.place_schematic({x = pos.x+(dir.x*6*x)-6, y = pos.y - 1, z = pos.z+(dir.z*6*x)}, village.houses[ math.random( #village.houses ) ], village.facedir_to_text_2(facedir), 0, nil, true)
else
minetest.place_schematic({x = pos.x+(dir.x*6*x)+6, y = pos.y - 1, z = pos.z+(dir.z*6*x)}, village.houses[ math.random( #village.houses ) ], village.facedir_to_text_2(facedir), 0, nil, true)
minetest.place_schematic({x = pos.x+(dir.x*6*x)-6, y = pos.y - 1, z = pos.z+(dir.z*6*x)}, village.houses[ math.random( #village.houses ) ], village.facedir_to_text_1(facedir), 0, nil, true)
end
end
minetest.place_schematic({x = pos.x+(dir.x*6*4), y = pos.y - 1, z = pos.z+(dir.z*6*4)}, path_road, 0, nil, true)
2016-03-13 16:14:49 +01:00
if math.random(2) == 1 then
2016-03-03 18:27:39 +01:00
village.road(vector.add(pos, vector.multiply(dir, 6*4)))
end
end
function village.register_house(f)
table.insert(village.houses, minetest.get_modpath("village") .. "/schematics/"..f)
end
village.register_house("house_1.mts")
village.register_house("house_2.mts")
village.register_house("garden.mts")
village.register_house("farm.mts")
minetest.register_node("village:spawn", {
description = "Village",
tiles = {"village_spawn.png"},
groups = {crumbly = 3},
})
minetest.register_abm({
nodenames = {"village:spawn"},
2016-03-19 11:21:31 +01:00
interval = 1.0,
2016-03-03 18:27:39 +01:00
chance = 1,
action = function(pos, node, active_object_count, active_object_count_wider)
minetest.set_node(pos, {name = "air"})
2016-03-19 11:21:31 +01:00
if math.random(150) == 50 then
village.gen(pos)
2016-03-13 15:59:30 +01:00
if not places.pos["village_" .. tostring(village.num)] then
places.pos["village_" .. tostring(village.num)] = {x=pos.x, y=pos.y, z=pos.z}
village.num = village.num +1
places.save_places()
2016-03-19 11:21:31 +01:00
else
-- TODO : save village num
village.num = village.num +10
if not places.pos["village_" .. tostring(village.num)] then
places.pos["village_" .. tostring(village.num)] = {x=pos.x, y=pos.y, z=pos.z}
village.num = village.num +1
places.save_places()
end
2016-03-13 15:59:30 +01:00
end
end
2016-03-03 18:27:39 +01:00
end,
})
2016-03-19 11:21:31 +01:00
minetest.register_decoration({
deco_type = "simple",
place_on = {"default:grass", "default:wet_grass"},
sidelen = 16,
fill_ratio = 0.004,
biomes = {
"grassland", "jungle"
},
2016-03-19 11:49:45 +01:00
y_min = 6,
y_max = 20,
2016-03-19 11:21:31 +01:00
decoration = "village:spawn",
})