mirror of
https://git.minetest.land/VoxeLibre/VoxeLibre.git
synced 2024-11-19 09:31:07 +01:00
Add mcl_raids
This commit is contained in:
parent
6e6f163b71
commit
8b6409b7f1
2 changed files with 92 additions and 0 deletions
91
mods/ENVIRONMENT/mcl_raids/init.lua
Normal file
91
mods/ENVIRONMENT/mcl_raids/init.lua
Normal file
|
@ -0,0 +1,91 @@
|
||||||
|
-- mcl_raids
|
||||||
|
|
||||||
|
mcl_raids = {}
|
||||||
|
|
||||||
|
-- Define the amount of illagers to spawn each wave.
|
||||||
|
mcl_raids.wave_definitions = {
|
||||||
|
-- Pillager
|
||||||
|
{
|
||||||
|
illager_name = "mobs_mc:pillager",
|
||||||
|
wave_1 = 5,
|
||||||
|
wave_2 = 4,
|
||||||
|
wave_3 = 4,
|
||||||
|
wave_4 = 5,
|
||||||
|
wave_5 = 5,
|
||||||
|
extra_wave = 5,
|
||||||
|
},
|
||||||
|
-- Vindicator aka Angry Axeman
|
||||||
|
{
|
||||||
|
illager_name = "mobs_mc:vindicator",
|
||||||
|
wave_1 = 1,
|
||||||
|
wave_2 = 3,
|
||||||
|
wave_3 = 1,
|
||||||
|
wave_4 = 2,
|
||||||
|
wave_5 = 5,
|
||||||
|
extra_wave = 5,
|
||||||
|
},
|
||||||
|
--{"mobs_mc:ravager", 0, 0, 1, 0, 0, 2},
|
||||||
|
-- Witch
|
||||||
|
{
|
||||||
|
illager_name = "mobs_mc:witch",
|
||||||
|
wave_1 = 0,
|
||||||
|
wave_2 = 0,
|
||||||
|
wave_3 = 1,
|
||||||
|
wave_4 = 3,
|
||||||
|
wave_5 = 1,
|
||||||
|
extra_wave = 1,
|
||||||
|
},
|
||||||
|
-- Evoker
|
||||||
|
{
|
||||||
|
illager_name = "mobs_mc:evoker",
|
||||||
|
wave_1 = 0,
|
||||||
|
wave_2 = 0,
|
||||||
|
wave_3 = 0,
|
||||||
|
wave_4 = 0,
|
||||||
|
wave_5 = 1,
|
||||||
|
extra_wave = 1,
|
||||||
|
},
|
||||||
|
}
|
||||||
|
|
||||||
|
minetest.register_chatcommand("spawn_raid", {
|
||||||
|
privs = {
|
||||||
|
server = true,
|
||||||
|
},
|
||||||
|
func = function(name)
|
||||||
|
local wave = 1
|
||||||
|
local illager_count = 0
|
||||||
|
local player = minetest.get_player_by_name(name)
|
||||||
|
local pos = player:get_pos()
|
||||||
|
local spawnable = false
|
||||||
|
local r = 32
|
||||||
|
local n = 12
|
||||||
|
local i = math.random(1, n)
|
||||||
|
local raid_pos = vector.offset(pos,r * math.cos(((i-1)/n) * (2*math.pi)),0, r * math.sin(((i-1)/n) * (2*math.pi)))
|
||||||
|
local sn = minetest.find_nodes_in_area_under_air(vector.offset(raid_pos,0,100,0), vector.offset(raid_pos,0,-100,0), {"group:grass_block", "group:grass_block_snow", "group:snow_cover", "group:sand"})
|
||||||
|
if sn and #sn > 0 then
|
||||||
|
spawn_pos = sn[1]
|
||||||
|
if spawn_pos then
|
||||||
|
minetest.log("action", "[mcl_raids] Raid Spawn Position chosen at " .. minetest.pos_to_string(spawn_pos) .. ".")
|
||||||
|
spawnable = true
|
||||||
|
else
|
||||||
|
minetest.log("action", "[mcl_raids] Raid Spawn Postion not chosen.")
|
||||||
|
end
|
||||||
|
elseif not sn then
|
||||||
|
minetest.log("action", "[mcl_raids] Raid Spawn Position error, no appropriate site found.")
|
||||||
|
end
|
||||||
|
if spawnable and spawn_pos then
|
||||||
|
for _, raiddefs in pairs(mcl_raids.wave_definitions) do
|
||||||
|
local wave_count = raiddefs.wave_1
|
||||||
|
for i = 0, wave_count do
|
||||||
|
local entity = minetest.add_entity(spawn_pos, raiddefs.illager_name)
|
||||||
|
if entity then
|
||||||
|
local l = entity:get_luaentity()
|
||||||
|
l.raidmember = true
|
||||||
|
illager_count = illager_count + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
minetest.log("action", "[mcl_raids] Raid Spawned. Illager Count: " .. illager_count .. ".")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
})
|
1
mods/ENVIRONMENT/mcl_raids/mod.conf
Normal file
1
mods/ENVIRONMENT/mcl_raids/mod.conf
Normal file
|
@ -0,0 +1 @@
|
||||||
|
name = mcl_raids
|
Loading…
Reference in a new issue