Actions: Fix bugs and improve dig and place action commands.

This commit is contained in:
Hector Franqui 2017-09-07 08:51:50 -04:00
parent 2a0b0aa538
commit ce47958144

View File

@ -178,8 +178,15 @@ function npc.actions.dig(self, args)
if add_to_inventory then if add_to_inventory then
-- Get node drop -- Get node drop
local drop = minetest.registered_nodes[node.name].drop local drop = minetest.registered_nodes[node.name].drop
local drop_itemname = node.name
if drop and drop.items then
local random_item = drop.items[math.random(1, #drop)]
if random_item then
drop_itemname = random_item.items[1]
end
end
-- Add to NPC inventory -- Add to NPC inventory
npc.npc.add_item_to_inventory(self, drop, 1) npc.add_item_to_inventory(self, drop_itemname, 1)
end end
return true return true
end end
@ -222,18 +229,18 @@ function npc.actions.place(self, args)
-- Take from inventory if necessary -- Take from inventory if necessary
local place_item = false local place_item = false
if source == npc.actions.take_from_inventory then if source == npc.actions.take_from_inventory then
if npc.take_item_from_inventory(self, node.name, 1) then if npc.take_item_from_inventory(self, node, 1) then
place_item = true place_item = true
end end
elseif source == npc.actions.take_from_inventory_forced then elseif source == npc.actions.take_from_inventory_forced then
npc.take_item_from_inventory(self, node.name, 1) npc.take_item_from_inventory(self, node, 1)
place_item = true place_item = true
elseif source == npc.actions.force_place then elseif source == npc.actions.force_place then
place_item = true place_item = true
end end
-- Place node -- Place node
if place_item then if place_item == true then
minetest.set_node(pos, node) minetest.set_node(pos, {name=node})
end end
end end
end end
@ -272,19 +279,22 @@ function npc.actions.walk_step(self, args)
local dir = args.dir local dir = args.dir
local speed = args.speed local speed = args.speed
local target_pos = args.target_pos local target_pos = args.target_pos
local start_pos = args.start_pos
local vel = {} local vel = {}
-- Set default node per seconds -- Set default node per seconds
if speed == nil then if speed == nil then
speed = npc.actions.one_nps_speed speed = npc.actions.one_nps_speed
end end
-- If there is a target position to reach, set it
if target_pos ~= nil then
self.actions.walking.target_pos = target_pos
end
-- Set is_walking = true -- Set is_walking = true
self.actions.walking.is_walking = true self.actions.walking.is_walking = true
-- Check if dir should be random
if dir == "random" then
dir = math.random(0, 7)
end
if dir == npc.direction.north then if dir == npc.direction.north then
vel = {x=0, y=0, z=speed} vel = {x=0, y=0, z=speed}
elseif dir == npc.direction.north_east then elseif dir == npc.direction.north_east then
@ -302,6 +312,18 @@ function npc.actions.walk_step(self, args)
elseif dir == npc.direction.north_west then elseif dir == npc.direction.north_west then
vel = {x=-speed, y=0, z=speed } vel = {x=-speed, y=0, z=speed }
end end
-- Automatically calculate target pos for dir = "random"
if args.dir == "random" and not target_pos and start_pos then
--minetest.log("Vel: "..dump(vel.x/speed)..", "..dump(vel.y/speed)..", "..dump(vel.z/speed))
target_pos = {x=start_pos.x + (vel.x/speed), y=start_pos.y + (vel.y/speed), z=start_pos.z + (vel.z/speed)}
end
-- If there is a target position to reach, set it
if target_pos ~= nil then
self.actions.walking.target_pos = target_pos
end
-- Rotate NPC -- Rotate NPC
npc.actions.rotate(self, {dir=dir}) npc.actions.rotate(self, {dir=dir})
-- Set velocity so that NPC walks -- Set velocity so that NPC walks
@ -533,7 +555,7 @@ local function get_pos_argument(self, pos, use_access_node)
end end
elseif type(pos) == "string" then elseif type(pos) == "string" then
-- Received name of place, so we are going to look for the actual pos -- Received name of place, so we are going to look for the actual pos
local places_pos = npc.places.get_by_type(self, pos) local places_pos = npc.places.get_by_type(self, pos, false)
-- Return nil if no position found -- Return nil if no position found
if places_pos == nil or #places_pos == 0 then if places_pos == nil or #places_pos == 0 then
return nil return nil