mirror of
https://github.com/sys4-fr/server-nalc.git
synced 2025-04-01 18:20:39 +02:00
Merged dungeon master and fixed typo in stonemonsters
- Merged new and old dungeon master adding special removing features - Fixed comma typo in stonemonsters' file
This commit is contained in:
parent
32e911db37
commit
b6549bd321
@ -119,11 +119,37 @@ mobs:register_arrow("mobs:fireball", {
|
|||||||
local n = minetest.get_node(p).name
|
local n = minetest.get_node(p).name
|
||||||
-- do NOT destroy protection nodes but DO destroy nodes in protected area
|
-- do NOT destroy protection nodes but DO destroy nodes in protected area
|
||||||
if not n:find("protector:") then -- and not minetest.is_protected(p, "") then
|
if not n:find("protector:") then -- and not minetest.is_protected(p, "") then
|
||||||
if minetest.registered_nodes[n].groups.flammable or math.random(1, 100) <= 30 then
|
local excluding = minetest.get_item_group(n, "unbreakable") == 1
|
||||||
minetest.set_node(p, {name="fire:basic_flame"})
|
or n:split(":")[1] == "nether"
|
||||||
else
|
or next(areas:getAreasAtPos(p)) ~= nil
|
||||||
minetest.remove_node(p)
|
for _,i in ipairs(excluded) do
|
||||||
end
|
if i == n then excluding = true end
|
||||||
|
end
|
||||||
|
--if p.y < -19600 and including and n:split(":")[1] == "nether" then
|
||||||
|
if excluding then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if n == "default:chest" then
|
||||||
|
meta = minetest.get_meta(p)
|
||||||
|
inv = meta:get_inventory()
|
||||||
|
for i = 1,32 do
|
||||||
|
m_stack = inv:get_stack("main",i)
|
||||||
|
obj = minetest.add_item(pos,m_stack)
|
||||||
|
if obj then
|
||||||
|
obj:setvelocity({x=math.random(-2,1), y=7, z=math.random(-2,1)})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if minetest.registered_nodes[n].groups.flammable or math.random(1, 100) <= 30 then
|
||||||
|
minetest.set_node(p, {name="fire:basic_flame"})
|
||||||
|
else
|
||||||
|
minetest.remove_node(p)
|
||||||
|
end
|
||||||
|
if n == "doors:door_wood_b_1" then
|
||||||
|
minetest.remove_node({x=p.x,y=p.y+1,z=p.z})
|
||||||
|
elseif n == "doors:door_wood_t_1" then
|
||||||
|
minetest.remove_node({x=p.x,y=p.y-1,z=p.z})
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
vi = vi + 1
|
vi = vi + 1
|
@ -1,139 +0,0 @@
|
|||||||
|
|
||||||
-- Dungeon Master by PilzAdam
|
|
||||||
|
|
||||||
-- Node which cannot be destroyed by DungeonMasters' fireballs
|
|
||||||
local excluded = {"nether:netherrack","default:obsidian_glass","default:obsidian", "default:obsidian_cooled", "default:bedrock", "doors:door_steel_b_1", "doors:door_steel_t_1", "doors:door_steel_b_2", "doors:door_steel_t_2","default:chest_locked"}
|
|
||||||
|
|
||||||
mobs:register_mob("mobs:dungeon_master", {
|
|
||||||
-- animal, monster, npc, barbarian
|
|
||||||
type = "monster",
|
|
||||||
-- aggressive, shoots fireballs at player, deal 13 damages
|
|
||||||
passive = false,
|
|
||||||
damage = 13,
|
|
||||||
attack_type = "shoot",
|
|
||||||
shoot_interval = 2.5,
|
|
||||||
arrow = "mobs:fireball",
|
|
||||||
shoot_offset = 0,
|
|
||||||
-- health & armor
|
|
||||||
hp_min = 50,
|
|
||||||
hp_max = 60,
|
|
||||||
armor = 60,
|
|
||||||
-- textures and model
|
|
||||||
collisionbox = {-0.7, -0.01, -0.7, 0.7, 2.6, 0.7},
|
|
||||||
visual = "mesh",
|
|
||||||
mesh = "mobs_dungeon_master.x",
|
|
||||||
textures = {
|
|
||||||
{"mobs_dungeon_master.png"},
|
|
||||||
{"mobs_dungeon_master_cobblestone.png"},
|
|
||||||
{"mobs_dungeon_master_strangewhite.png"},
|
|
||||||
},
|
|
||||||
visual_size = {x=8, y=8},
|
|
||||||
blood_texture = "mobs_blood.png",
|
|
||||||
-- sounds
|
|
||||||
makes_footstep_sound = true,
|
|
||||||
sounds = {
|
|
||||||
random = "mobs_dungeonmaster",
|
|
||||||
attack = "mobs_fireball",
|
|
||||||
},
|
|
||||||
-- speed and jump
|
|
||||||
walk_velocity = 1,
|
|
||||||
run_velocity = 2,
|
|
||||||
jump = false,
|
|
||||||
view_range = 16,
|
|
||||||
-- drops mese or diamond when dead
|
|
||||||
drops = {
|
|
||||||
{name = "default:mese_crystal_fragment",
|
|
||||||
chance = 1, min = 1, max = 3,},
|
|
||||||
{name = "default:diamond",
|
|
||||||
chance = 5, min = 1, max = 3,},
|
|
||||||
{name = "default:mese_crystal",
|
|
||||||
chance = 2, min = 1, max = 3,},
|
|
||||||
{name = "default:diamond_block",
|
|
||||||
chance = 30, min = 1, max = 1,},
|
|
||||||
{name = "maptools:gold_coin",
|
|
||||||
chance = 15, min = 1, max = 2,},
|
|
||||||
{name = "maptools:silver_coin",
|
|
||||||
chance = 1, min = 2, max = 10,},
|
|
||||||
},
|
|
||||||
-- damaged by
|
|
||||||
water_damage = 1,
|
|
||||||
lava_damage = 1,
|
|
||||||
light_damage = 0,
|
|
||||||
-- model animation
|
|
||||||
animation = {
|
|
||||||
stand_start = 0, stand_end = 19,
|
|
||||||
walk_start = 20, walk_end = 35,
|
|
||||||
punch_start = 36, punch_end = 48,
|
|
||||||
speed_normal = 15, speed_run = 15,
|
|
||||||
},
|
|
||||||
})
|
|
||||||
-- spawn on stone between 20 and -1 light, 1 in 7000 chance, 1 dungeon master in area starting at -100 and below
|
|
||||||
mobs:register_spawn("mobs:dungeon_master", {"default:stone, nether:netherrack"}, 20, -1, 7000, 1, -100)
|
|
||||||
-- register spawn egg
|
|
||||||
mobs:register_egg("mobs:dungeon_master", "Dungeon Master", "fire_basic_flame.png", 1)
|
|
||||||
|
|
||||||
-- fireball (weapon)
|
|
||||||
mobs:register_arrow("mobs:fireball", {
|
|
||||||
visual = "sprite",
|
|
||||||
visual_size = {x=1, y=1},
|
|
||||||
textures = {"mobs_fireball.png"},
|
|
||||||
velocity = 6,
|
|
||||||
|
|
||||||
-- direct hit, no fire... just plenty of pain
|
|
||||||
hit_player = function(self, player)
|
|
||||||
player:punch(self.object, 1.0, {
|
|
||||||
full_punch_interval=1.0,
|
|
||||||
damage_groups = {fleshy=13},
|
|
||||||
}, 0)
|
|
||||||
end,
|
|
||||||
|
|
||||||
hit_mob = function(self, player)
|
|
||||||
player:punch(self.object, 1.0, {
|
|
||||||
full_punch_interval=1.0,
|
|
||||||
damage_groups = {fleshy=8},
|
|
||||||
}, 0)
|
|
||||||
end,
|
|
||||||
|
|
||||||
-- node hit, bursts into flame (cannot blast through obsidian or protection redo mod items)
|
|
||||||
hit_node = function(self, pos, node)
|
|
||||||
for dx=-1,1 do
|
|
||||||
for dy=-1,1 do
|
|
||||||
for dz=-1,1 do
|
|
||||||
local p = {x=pos.x+dx, y=pos.y+dy, z=pos.z+dz}
|
|
||||||
local n = minetest.get_node(p).name
|
|
||||||
local excluding = minetest.get_item_group(n, "unbreakable") == 1
|
|
||||||
or n:split(":")[1] == "nether"
|
|
||||||
or next(areas:getAreasAtPos(p)) ~= nil
|
|
||||||
for _,i in ipairs(excluded) do
|
|
||||||
if i == n then excluding = true end
|
|
||||||
end
|
|
||||||
--if p.y < -19600 and including and n:split(":")[1] == "nether" then
|
|
||||||
if excluding then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
if n == "default:chest" then
|
|
||||||
meta = minetest.get_meta(p)
|
|
||||||
inv = meta:get_inventory()
|
|
||||||
for i = 1,32 do
|
|
||||||
m_stack = inv:get_stack("main",i)
|
|
||||||
obj = minetest.add_item(pos,m_stack)
|
|
||||||
if obj then
|
|
||||||
obj:setvelocity({x=math.random(-2,1), y=7, z=math.random(-2,1)})
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if minetest.registered_nodes[n].groups.flammable or math.random(1, 100) <= 30 then
|
|
||||||
minetest.set_node(p, {name="fire:basic_flame"})
|
|
||||||
else
|
|
||||||
minetest.set_node(p, {name="air"})
|
|
||||||
end
|
|
||||||
if n == "doors:door_wood_b_1" then
|
|
||||||
minetest.remove_node({x=p.x,y=p.y+1,z=p.z})
|
|
||||||
elseif n == "doors:door_wood_t_1" then
|
|
||||||
minetest.remove_node({x=p.x,y=p.y-1,z=p.z})
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
})
|
|
@ -46,7 +46,7 @@ mobs:register_mob("mobs:stone_monster", {
|
|||||||
},
|
},
|
||||||
-- damaged by
|
-- damaged by
|
||||||
water_damage = 0,
|
water_damage = 0,
|
||||||
lava_damage = 0
|
lava_damage = 0,
|
||||||
light_damage = 0,
|
light_damage = 0,
|
||||||
-- model animation
|
-- model animation
|
||||||
animation = {
|
animation = {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user