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:
parent
f55757d334
commit
bd6d735170
@ -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
38
npc.lua
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user