Revert "Use an LVM to emerge map, place schematic, and fix lighting"
This reverts commit 7732d0c23d
.
This commit is contained in:
parent
35da0ca3fe
commit
da8c9b53aa
1 changed files with 34 additions and 37 deletions
|
@ -22,8 +22,8 @@ minetest.register_alias("default:grass_5", "air")
|
|||
minetest.register_alias("default:bush_leaves", "air")
|
||||
minetest.register_alias("default:bush_stem", "air")
|
||||
|
||||
|
||||
local max_r = 120
|
||||
local max_h = 150
|
||||
local mapdir = minetest.get_modpath("ctf_map") .. "/maps/"
|
||||
ctf_map.map = nil
|
||||
|
||||
|
@ -73,48 +73,45 @@ minetest.register_chatcommand("maps_reload", {
|
|||
|
||||
|
||||
function ctf_map.place_map(map)
|
||||
local schempath = mapdir .. map.schematic
|
||||
ctf_map.emerge_with_callbacks(nil, map.pos1, map.pos2, function()
|
||||
local schempath = mapdir .. map.schematic
|
||||
local res = minetest.place_schematic(map.pos1, schempath,
|
||||
map.rotation == "z" and "0" or "90")
|
||||
|
||||
--------------------------------------------------
|
||||
-- LVM
|
||||
assert(res)
|
||||
|
||||
local vm = minetest.get_voxel_manip(map.pos1, map.pos2)
|
||||
local res = minetest.place_schematic_on_vmanip(vm, map.pos1, schempath,
|
||||
map.rotation == "z" and "0" or "90")
|
||||
|
||||
assert(res)
|
||||
|
||||
vm:write_to_map()
|
||||
|
||||
--------------------------------------------------
|
||||
|
||||
for _, value in pairs(ctf_map.map.teams) do
|
||||
ctf_team_base.place(value.color, value.pos)
|
||||
end
|
||||
|
||||
local seed = minetest.get_mapgen_setting("seed")
|
||||
for _, chestzone in pairs(ctf_map.map.chests) do
|
||||
minetest.log("warning", "Placing " .. chestzone.n .. " chests from " ..
|
||||
minetest.pos_to_string(chestzone.from) .. " to "..
|
||||
minetest.pos_to_string(chestzone.to))
|
||||
place_chests(chestzone.from, chestzone.to, seed, chestzone.n)
|
||||
end
|
||||
|
||||
minetest.after(2, function()
|
||||
local msg = "Map: " .. map.name .. " by " .. map.author
|
||||
if map.hint then
|
||||
msg = msg .. "\n" .. map.hint
|
||||
for _, value in pairs(ctf_map.map.teams) do
|
||||
ctf_team_base.place(value.color, value.pos)
|
||||
end
|
||||
minetest.chat_send_all(msg)
|
||||
if minetest.global_exists("irc") and irc.connected then
|
||||
irc:say("Map: " .. map.name)
|
||||
|
||||
local seed = minetest.get_mapgen_setting("seed")
|
||||
for _, chestzone in pairs(ctf_map.map.chests) do
|
||||
minetest.log("warning", "Placing " .. chestzone.n .. " chests from " ..
|
||||
minetest.pos_to_string(chestzone.from) .. " to "..
|
||||
minetest.pos_to_string(chestzone.to))
|
||||
place_chests(chestzone.from, chestzone.to, seed, chestzone.n)
|
||||
end
|
||||
end)
|
||||
|
||||
minetest.after(2, function()
|
||||
local msg = "Map: " .. map.name .. " by " .. map.author
|
||||
if map.hint then
|
||||
msg = msg .. "\n" .. map.hint
|
||||
end
|
||||
minetest.chat_send_all(msg)
|
||||
if minetest.global_exists("irc") and irc.connected then
|
||||
irc:say("Map: " .. map.name)
|
||||
end
|
||||
end)
|
||||
|
||||
minetest.after(10, function()
|
||||
minetest.fix_light(ctf_map.map.pos1, ctf_map.map.pos2)
|
||||
end)
|
||||
end, nil)
|
||||
end
|
||||
|
||||
function ctf_match.load_map_meta(idx, name)
|
||||
local offset = vector.new(600 * idx, 0, 0)
|
||||
local meta = Settings(mapdir .. name .. ".conf")
|
||||
local meta = Settings(mapdir .. name .. ".conf")
|
||||
|
||||
local initial_stuff = meta:get("initial_stuff")
|
||||
local map = {
|
||||
|
@ -132,10 +129,10 @@ function ctf_match.load_map_meta(idx, name)
|
|||
chests = {},
|
||||
}
|
||||
|
||||
assert(map.r <= max_r and map.h <= max_h)
|
||||
assert(map.r <= max_r)
|
||||
|
||||
map.pos1 = vector.add(offset, { x = -map.r, y = -map.h / 2, z = -map.r })
|
||||
map.pos2 = vector.add(offset, { x = map.r, y = map.h / 2, z = map.r })
|
||||
map.pos2 = vector.add(offset, { x = map.r, y = map.h / 2, z = map.r })
|
||||
|
||||
-- Read teams from config
|
||||
local i = 1
|
||||
|
|
Loading…
Reference in a new issue