Actions: Change use sittable and use bed interface to use them as tasks.

Schedules: Allow tasks to be added as well as actions.
This commit is contained in:
zorman2000 2017-03-09 19:41:44 -05:00
parent f55757d334
commit bd6d735170
2 changed files with 31 additions and 18 deletions

View File

@ -315,7 +315,10 @@ end
-- with the fuel items the NPC will take whatever was cooked and whatever -- with the fuel items the NPC will take whatever was cooked and whatever
-- remained to cook. The function received the position of the furnace -- remained to cook. The function received the position of the furnace
-- to use, and the item to cook in furnace. Item is an itemstring -- to use, and the item to cook in furnace. Item is an itemstring
function npc.actions.use_furnace(self, pos, item, freeze) function npc.actions.use_furnace(self, args)
local pos = args.pos
local item = args.item
local freeze = args.freeze
-- Define which items are usable as fuels. The NPC -- Define which items are usable as fuels. The NPC
-- will mainly use this as fuels to avoid getting useful -- will mainly use this as fuels to avoid getting useful
-- items (such as coal lumps) for burning -- items (such as coal lumps) for burning
@ -487,7 +490,9 @@ end
-- This function makes the NPC lay or stand up from a bed. The -- This function makes the NPC lay or stand up from a bed. The
-- pos is the location of the bed, action can be lay or get up -- pos is the location of the bed, action can be lay or get up
function npc.actions.use_sittable(self, pos, action) function npc.actions.use_sittable(self, args)
local pos = args.pos
local action = args.action
local node = minetest.get_node(pos) local node = minetest.get_node(pos)
if action == npc.actions.const.sittable.SIT then if action == npc.actions.const.sittable.SIT then

38
npc.lua
View File

@ -659,7 +659,7 @@ local function npc_spawn(self, pos)
} }
-- Temporary initialization of actions for testing -- Temporary initialization of actions for testing
local nodes = npc.places.find_node_nearby(ent.object:getpos(), {"default:furnace"}, 20) local nodes = npc.places.find_node_nearby(ent.object:getpos(), {"cottages:bench"}, 20)
minetest.log("Found nodes: "..dump(nodes)) minetest.log("Found nodes: "..dump(nodes))
--local path = pathfinder.find_path(ent.object:getpos(), nodes[1], 20) --local path = pathfinder.find_path(ent.object:getpos(), nodes[1], 20)
@ -667,17 +667,17 @@ local function npc_spawn(self, pos)
--npc.add_action(ent, npc.actions.use_door, {self = ent, pos = nodes[1], action = npc.actions.door_action.OPEN}) --npc.add_action(ent, npc.actions.use_door, {self = ent, pos = nodes[1], action = npc.actions.door_action.OPEN})
--npc.add_action(ent, npc.actions.stand, {self = ent}) --npc.add_action(ent, npc.actions.stand, {self = ent})
--npc.add_action(ent, npc.actions.stand, {self = ent}) --npc.add_action(ent, npc.actions.stand, {self = ent})
if nodes[1] ~= nil then -- if nodes[1] ~= nil then
npc.add_task(ent, npc.actions.walk_to_pos, {end_pos=nodes[1], walkable={}}) -- npc.add_task(ent, npc.actions.walk_to_pos, {end_pos=nodes[1], walkable={}})
npc.actions.use_furnace(ent, nodes[1], "default:cobble 5", false) -- npc.actions.use_furnace(ent, nodes[1], "default:cobble 5", false)
--npc.add_action(ent, npc.actions.sit, {self = ent}) -- --npc.add_action(ent, npc.actions.sit, {self = ent})
-- npc.add_action(ent, npc.actions.lay, {self = ent}) -- -- npc.add_action(ent, npc.actions.lay, {self = ent})
-- npc.add_action(ent, npc.actions.lay, {self = ent}) -- -- npc.add_action(ent, npc.actions.lay, {self = ent})
-- npc.add_action(ent, npc.actions.lay, {self = ent}) -- -- npc.add_action(ent, npc.actions.lay, {self = ent})
--npc.actions.use_sittable(ent, nodes[1], npc.actions.const.sittable.GET_UP) -- --npc.actions.use_sittable(ent, nodes[1], npc.actions.const.sittable.GET_UP)
--npc.add_action(ent, npc.actions.set_interval, {self=ent, interval=10, freeze=true}) -- --npc.add_action(ent, npc.actions.set_interval, {self=ent, interval=10, freeze=true})
npc.add_action(ent, npc.actions.freeze, {freeze = false}) -- npc.add_action(ent, npc.actions.freeze, {freeze = false})
end -- end
-- Dedicated trade test -- Dedicated trade test
ent.trader_data.trade_list.both = { ent.trader_data.trade_list.both = {
@ -707,7 +707,11 @@ local function npc_spawn(self, pos)
-- Add a simple schedule for testing -- Add a simple schedule for testing
npc.create_schedule(ent, npc.schedule_types.generic, 0) npc.create_schedule(ent, npc.schedule_types.generic, 0)
-- Add schedule entries -- Add schedule entries
local morning_actions = { [1] = {action = npc.actions.sit, args = {}} } local morning_actions = {
[1] = {task = npc.actions.walk_to_pos, args = {end_pos=nodes[1], walkable={}} } ,
[2] = {task = npc.actions.use_sittable, args = {pos=nodes[1], action=npc.actions.const.sittable.SIT} },
[3] = {action = npc.actions.freeze, args = {freeze = true}}
}
npc.add_schedule_entry(ent, npc.schedule_types.generic, 0, 7, nil, morning_actions) npc.add_schedule_entry(ent, npc.schedule_types.generic, 0, 7, nil, morning_actions)
local afternoon_actions = { [1] = {action = npc.actions.stand, args = {}} } local afternoon_actions = { [1] = {action = npc.actions.stand, args = {}} }
npc.add_schedule_entry(ent, npc.schedule_types.generic, 0, 9, nil, afternoon_actions) npc.add_schedule_entry(ent, npc.schedule_types.generic, 0, 9, nil, afternoon_actions)
@ -922,8 +926,6 @@ mobs:register_mob("advanced_npc:npc", {
-- Check if schedule for this time exists -- Check if schedule for this time exists
minetest.log("Found default schedule") minetest.log("Found default schedule")
if schedule[time] ~= nil then if schedule[time] ~= nil then
minetest.log("Found schedule for time "..dump(time)..": "..dump(schedule[time]))
minetest.log("Check: "..dump(schedule[time].check))
-- Check if schedule has a check function -- Check if schedule has a check function
if schedule[time].check ~= nil then if schedule[time].check ~= nil then
-- Execute check function and then add corresponding action -- Execute check function and then add corresponding action
@ -933,8 +935,14 @@ mobs:register_mob("advanced_npc:npc", {
minetest.log("Adding actions to action queue") minetest.log("Adding actions to action queue")
-- Add to action queue all actions on schedule -- Add to action queue all actions on schedule
for i = 1, #schedule[time] do for i = 1, #schedule[time] do
if schedule[time][i].action == nil then
-- Add task
npc.add_task(self, schedule[time][i].task, schedule[time][i].args)
else
-- Add action
npc.add_action(self, schedule[time][i].action, schedule[time][i].args) npc.add_action(self, schedule[time][i].action, schedule[time][i].args)
end end
end
minetest.log("New action queue: "..dump(self.actions)) minetest.log("New action queue: "..dump(self.actions))
end end
end end