1
0
mirror of https://github.com/sys4-fr/server-nalc.git synced 2025-01-12 11:00:25 +01:00

Now players can give orders follow and stand to NPCs

This commit is contained in:
Ombridride 2015-04-02 19:16:47 +02:00
parent 7fa1375fee
commit 0b51e1f7ac
2 changed files with 61 additions and 23 deletions

View File

@ -1,4 +1,4 @@
-- Mobs Api (29th March 2015) -- Mobs Api (2nd April 2015)
mobs = {} mobs = {}
mobs.mod = "redo" mobs.mod = "redo"
@ -12,6 +12,10 @@ local peaceful_only = minetest.setting_getbool("only_peaceful_mobs")
function mobs:register_mob(name, def) function mobs:register_mob(name, def)
minetest.register_entity(name, { minetest.register_entity(name, {
name = name, name = name,
owner = def.owner,
order = def.order or "",
hp_min = def.hp_min or 5, hp_min = def.hp_min or 5,
hp_max = def.hp_max or 10, hp_max = def.hp_max or 10,
physical = true, physical = true,
@ -20,7 +24,7 @@ function mobs:register_mob(name, def)
visual_size = def.visual_size or {x=1, y=1}, visual_size = def.visual_size or {x=1, y=1},
mesh = def.mesh, mesh = def.mesh,
makes_footstep_sound = def.makes_footstep_sound, makes_footstep_sound = def.makes_footstep_sound,
view_range = def.view_range, view_range = def.view_range or 5,
walk_velocity = def.walk_velocity, walk_velocity = def.walk_velocity,
run_velocity = def.run_velocity, run_velocity = def.run_velocity,
damage = def.damage, damage = def.damage,
@ -395,34 +399,43 @@ function mobs:register_mob(name, def)
end end
end end
if self.follow ~= "" and not self.following then if (self.follow ~= "" or self.order == "follow") and not self.following and self.state ~= "attack" then
local s, p, dist local s, p, dist
for _,player in pairs(minetest.get_connected_players()) do for _,player in pairs(minetest.get_connected_players()) do
s = self.object:getpos() s = self.object:getpos()
p = player:getpos() p = player:getpos()
dist = ((p.x-s.x)^2 + (p.y-s.y)^2 + (p.z-s.z)^2)^0.5 dist = ((p.x-s.x)^2 + (p.y-s.y)^2 + (p.z-s.z)^2)^0.5
if self.view_range and dist < self.view_range then if dist < self.view_range then
self.following = player self.following = player
break break
end end
end end
end end
--if self.following and self.following:is_player() and self.following:get_wielded_item():get_name() ~= self.follow then if self.type == "npc" and self.order == "follow" and self.state ~= "attack" then
if self.following and self.following.is_player and self.following:get_wielded_item():get_name() ~= self.follow then -- npc stop following player if not owner
self.following = nil if self.following and self.type == "npc" and self.owner and self.owner ~= self.following:get_player_name() then
self.v_start = false self.following = nil
self.v_start = false
end
else
-- stop following player if not holding specific item
if self.following and self.following.is_player and self.following:get_wielded_item():get_name() ~= self.follow then
self.following = nil
self.v_start = false
end
end end
if self.following then if self.following then
local s = self.object:getpos() local s = self.object:getpos()
local p local p
if self.following.is_player and self.following:is_player() then
if self.following.is_player and self.following:is_player() then
p = self.following:getpos() p = self.following:getpos()
elseif self.following.object then elseif self.following.object then
p = self.following.object:getpos() p = self.following.object:getpos()
end end
if p then if p then
local dist = ((p.x-s.x)^2 + (p.y-s.y)^2 + (p.z-s.z)^2)^0.5 local dist = ((p.x-s.x)^2 + (p.y-s.y)^2 + (p.z-s.z)^2)^0.5
@ -439,7 +452,9 @@ function mobs:register_mob(name, def)
yaw = yaw+math.pi yaw = yaw+math.pi
end end
self.object:setyaw(yaw) self.object:setyaw(yaw)
if dist > 2 then
-- anyone but standing npc's can move along
if dist > 2 and self.order ~= "stand" then
if not self.v_start then if not self.v_start then
self.v_start = true self.v_start = true
self.set_velocity(self, self.walk_velocity) self.set_velocity(self, self.walk_velocity)
@ -456,6 +471,7 @@ function mobs:register_mob(name, def)
self.v_start = false self.v_start = false
self.set_velocity(self, 0) self.set_velocity(self, 0)
self:set_animation("stand") self:set_animation("stand")
end end
return return
end end
@ -499,10 +515,17 @@ function mobs:register_mob(name, def)
self.set_velocity(self, 0) self.set_velocity(self, 0)
self.set_animation(self, "stand") self.set_animation(self, "stand")
if math.random(1, 100) <= self.walk_chance then -- npc's ordered to stand stay standing
self.set_velocity(self, self.walk_velocity) if self.type == "npc" and self.order == "stand" then
self.state = "walk" self.set_velocity(self, 0)
self.set_animation(self, "walk") self.state = "stand"
self:set_animation("stand")
else
if math.random(1, 100) <= self.walk_chance then
self.set_velocity(self, self.walk_velocity)
self.state = "walk"
self.set_animation(self, "walk")
end
end end
elseif self.state == "walk" then elseif self.state == "walk" then
@ -965,10 +988,12 @@ function mobs:register_spawn(name, nodes, max_light, min_light, chance, active_o
-- are we spawning inside a solid node? -- are we spawning inside a solid node?
local nod = minetest.get_node_or_nil(pos) local nod = minetest.get_node_or_nil(pos)
if not nod or not minetest.registered_nodes[nod.name] or minetest.registered_nodes[nod.name].walkable == true then return end if not nod or not minetest.registered_nodes[nod.name]
or minetest.registered_nodes[nod.name].walkable == true then return end
pos.y = pos.y + 1 pos.y = pos.y + 1
nod = minetest.get_node_or_nil(pos) nod = minetest.get_node_or_nil(pos)
if not nod or minetest.registered_nodes[nod.name].walkable == true then return end if not nod or not minetest.registered_nodes[nod.name]
or minetest.registered_nodes[nod.name].walkable == true then return end
if minetest.setting_getbool("display_mob_spawn") then if minetest.setting_getbool("display_mob_spawn") then
minetest.chat_send_all("[mobs] Add "..name.." at "..minetest.pos_to_string(pos)) minetest.chat_send_all("[mobs] Add "..name.." at "..minetest.pos_to_string(pos))
@ -987,8 +1012,8 @@ function effect(pos, amount, texture)
minetest.add_particlespawner({ minetest.add_particlespawner({
amount = amount, amount = amount,
time = 0.25, time = 0.25,
minpos = {x=pos.x-0.2, y=pos.y-0.2, z=pos.z-0.2}, minpos = pos,
maxpos = {x=pos.x+0.2, y=pos.y+0.2, z=pos.z+0.2}, maxpos = pos,
minvel = {x=-0, y=-2, z=-0}, minvel = {x=-0, y=-2, z=-0},
maxvel = {x=2, y=2, z=2}, maxvel = {x=2, y=2, z=2},
minacc = {x=-4, y=-4, z=-4}, minacc = {x=-4, y=-4, z=-4},

View File

@ -29,8 +29,8 @@ mobs:register_mob("mobs:npc", {
makes_footstep_sound = true, makes_footstep_sound = true,
sounds = {}, sounds = {},
-- speed and jump -- speed and jump
walk_velocity = 1.5, walk_velocity = 2,
run_velocity = 2.5, run_velocity = 3,
jump = true, jump = true,
-- drops wood and chance of apples when dead -- drops wood and chance of apples when dead
drops = { drops = {
@ -50,6 +50,9 @@ mobs:register_mob("mobs:npc", {
-- follow diamond -- follow diamond
follow = "default:diamond", follow = "default:diamond",
view_range = 16, view_range = 16,
-- set owner and order
owner = "",
order = "follow",
-- model animation -- model animation
animation = { animation = {
speed_normal = 30, speed_run = 30, speed_normal = 30, speed_run = 30,
@ -78,6 +81,16 @@ mobs:register_mob("mobs:npc", {
local pos = self.object:getpos() local pos = self.object:getpos()
pos.y = pos.y + 0.5 pos.y = pos.y + 0.5
minetest.add_item(pos, {name = mobs.npc_drops[math.random(1,#mobs.npc_drops)]}) minetest.add_item(pos, {name = mobs.npc_drops[math.random(1,#mobs.npc_drops)]})
else
if self.owner == "" then
self.owner = clicker:get_player_name()
else
if self.order == "follow" then
self.order = "stand"
else
self.order = "follow"
end
end
end end
end, end,
}) })