Actions: Added action to use a bed (from the default beds mod).
This commit is contained in:
parent
7f22a74d7d
commit
80b7eb6ec9
@ -75,8 +75,13 @@ end
|
|||||||
-- This action makes the NPC sit on the node where it is
|
-- This action makes the NPC sit on the node where it is
|
||||||
function npc.actions.sit(args)
|
function npc.actions.sit(args)
|
||||||
local self = args.self
|
local self = args.self
|
||||||
|
local pos = args.pos
|
||||||
-- Stop NPC
|
-- Stop NPC
|
||||||
self.object:setvelocity({x=0, y=0, z=0})
|
self.object:setvelocity({x=0, y=0, z=0})
|
||||||
|
-- If position give, set to that position
|
||||||
|
if pos ~= nil then
|
||||||
|
self.object:setpos(pos)
|
||||||
|
end
|
||||||
-- Set sit animation
|
-- Set sit animation
|
||||||
self.object:set_animation({
|
self.object:set_animation({
|
||||||
x = npc.ANIMATION_SIT_START,
|
x = npc.ANIMATION_SIT_START,
|
||||||
@ -87,8 +92,13 @@ end
|
|||||||
-- This action makes the NPC lay on the node where it is
|
-- This action makes the NPC lay on the node where it is
|
||||||
function npc.actions.lay(args)
|
function npc.actions.lay(args)
|
||||||
local self = args.self
|
local self = args.self
|
||||||
|
local pos = args.pos
|
||||||
-- Stop NPC
|
-- Stop NPC
|
||||||
self.object:setvelocity({x=0, y=0, z=0})
|
self.object:setvelocity({x=0, y=0, z=0})
|
||||||
|
-- If position give, set to that position
|
||||||
|
if pos ~= nil then
|
||||||
|
self.object:setpos(pos)
|
||||||
|
end
|
||||||
-- Set sit animation
|
-- Set sit animation
|
||||||
self.object:set_animation({
|
self.object:set_animation({
|
||||||
x = npc.ANIMATION_LAY_START,
|
x = npc.ANIMATION_LAY_START,
|
||||||
@ -195,7 +205,7 @@ end
|
|||||||
---------------------------------------------------------------------------------------
|
---------------------------------------------------------------------------------------
|
||||||
-- Tasks are operations that require many actions to perform. Basic tasks, like
|
-- Tasks are operations that require many actions to perform. Basic tasks, like
|
||||||
-- walking from one place to another, operating a furnace, storing or taking
|
-- walking from one place to another, operating a furnace, storing or taking
|
||||||
-- items from a chest, opening/closing doors, etc. are provided here.
|
-- items from a chest, are provided here.
|
||||||
|
|
||||||
-- This function allows a NPC to use a furnace using only items from
|
-- This function allows a NPC to use a furnace using only items from
|
||||||
-- its own inventory. Fuel is not provided. Once the furnace is finished
|
-- its own inventory. Fuel is not provided. Once the furnace is finished
|
||||||
@ -204,8 +214,8 @@ end
|
|||||||
-- 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)
|
function npc.actions.use_furnace(self, pos, item)
|
||||||
-- Check if any item in the NPC inventory serve as fuel
|
-- Check if any item in the NPC inventory serve as fuel
|
||||||
-- For now, just use some specific items as fuel
|
-- For now, just use some specific items as fuels
|
||||||
local fuels = {"default:leaves", "default:tree"}
|
local fuels = {"default:leaves", "default:tree", ""}
|
||||||
-- Check if NPC has a fuel item
|
-- Check if NPC has a fuel item
|
||||||
for i = 1,2 do
|
for i = 1,2 do
|
||||||
local fuel_item = npc.inventory_contains(self, fuels[i])
|
local fuel_item = npc.inventory_contains(self, fuels[i])
|
||||||
@ -243,7 +253,42 @@ function npc.actions.use_furnace(self, pos, item)
|
|||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
npc.actions.bed_action = {
|
||||||
|
LAY = 1,
|
||||||
|
GET_UP = 2
|
||||||
|
}
|
||||||
|
|
||||||
|
-- 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
|
||||||
|
function npc.actions.use_bed(self, pos, action)
|
||||||
|
local param2 = minetest.get_node(pos)
|
||||||
|
minetest.log(dump(param2))
|
||||||
|
local dir = minetest.facedir_to_dir(param2.param2)
|
||||||
|
|
||||||
|
if action == npc.actions.bed_action.LAY then
|
||||||
|
-- Calculate position (from beds mod)
|
||||||
|
local bed_pos = {x = pos.x + dir.x / 2, y = pos.y + 1, z = pos.z + dir.z / 2}
|
||||||
|
-- Sit down on bed
|
||||||
|
npc.add_action(self, npc.actions.sit, {self=self})
|
||||||
|
-- Rotate to the correct position
|
||||||
|
npc.add_action(self, npc.actions.rotate, {self=self, dir=param2.param2 + 2 % 4})
|
||||||
|
-- Lay down
|
||||||
|
npc.add_action(self, npc.actions.lay, {self=self, pos=bed_pos})
|
||||||
|
else
|
||||||
|
-- Calculate position to get up
|
||||||
|
local bed_pos = {x = pos.x, y = pos.y + 1, z = pos.z}
|
||||||
|
-- Sit up
|
||||||
|
npc.add_action(self, npc.actions.sit, {self=self, pos=bed_pos})
|
||||||
|
-- Walk up from bed
|
||||||
|
npc.add_action(self, npc.actions.walk_step, {self=self, dir=param2.param2 + 2 % 4})
|
||||||
|
-- Stand
|
||||||
|
npc.add_action(self, npc.actions.stand, {self=self})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
-- This function can be used to make the NPC walk from one
|
||||||
|
-- position to another.
|
||||||
function npc.actions.walk_to_pos(self, end_pos)
|
function npc.actions.walk_to_pos(self, end_pos)
|
||||||
|
|
||||||
local start_pos = self.object:getpos()
|
local start_pos = self.object:getpos()
|
||||||
@ -290,10 +335,21 @@ function npc.actions.walk_to_pos(self, end_pos)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
---------------------------------------------------------------------------------------
|
||||||
|
-- Path-finding code
|
||||||
|
---------------------------------------------------------------------------------------
|
||||||
|
-- This is the limit to search for a path based on the goal node.
|
||||||
|
-- If the path finder code goes beyond this limit in nodes away
|
||||||
|
-- on the x or z plane, it will stop looking for a path
|
||||||
|
npc.actions.PATH_DIFF_LIMIT = 125
|
||||||
|
|
||||||
|
-- Returns the opposite of a vector (scalar multiplication by -1)
|
||||||
local function vector_opposite(v)
|
local function vector_opposite(v)
|
||||||
return vector.multiply(v, -1)
|
return vector.multiply(v, -1)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- Returns a unit direction vector based on the largest coordinate
|
||||||
local function get_unit_dir_vector_based_on_diff(v)
|
local function get_unit_dir_vector_based_on_diff(v)
|
||||||
if math.abs(v.x) > math.abs(v.z) then
|
if math.abs(v.x) > math.abs(v.z) then
|
||||||
return {x=(v.x/math.abs(v.x)) * -1, y=0, z=0}
|
return {x=(v.x/math.abs(v.x)) * -1, y=0, z=0}
|
||||||
@ -344,8 +400,6 @@ local function is_good_node(node)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
DIFF_LIMIT = 125
|
|
||||||
|
|
||||||
-- Finds paths ignoring vertical obstacles
|
-- Finds paths ignoring vertical obstacles
|
||||||
-- This function is recursive and attempts to move all the time on
|
-- This function is recursive and attempts to move all the time on
|
||||||
-- the direction that will definetely lead to the end position.
|
-- the direction that will definetely lead to the end position.
|
||||||
@ -359,7 +413,8 @@ local function find_path_recursive(start_pos, end_pos, path_nodes, last_dir, las
|
|||||||
--minetest.log("Difference: "..dump(diff))
|
--minetest.log("Difference: "..dump(diff))
|
||||||
|
|
||||||
-- End if difference is larger than max difference possible (limit)
|
-- End if difference is larger than max difference possible (limit)
|
||||||
if math.abs(diff.x) > DIFF_LIMIT or math.abs(diff.z) > DIFF_LIMIT then
|
if math.abs(diff.x) > npc.actions.PATH_DIFF_LIMIT
|
||||||
|
or math.abs(diff.z) > npc.actions.PATH_DIFF_LIMIT then
|
||||||
-- Cannot find feasable path
|
-- Cannot find feasable path
|
||||||
return nil
|
return nil
|
||||||
end
|
end
|
||||||
@ -470,7 +525,8 @@ local function find_path_recursive(start_pos, end_pos, path_nodes, last_dir, las
|
|||||||
last_good_dir = dir_vector
|
last_good_dir = dir_vector
|
||||||
--minetest.log("------------ Third attempt ------------")
|
--minetest.log("------------ Third attempt ------------")
|
||||||
|
|
||||||
-- If not walkable, then try the next node
|
-- If not walkable, then try the next node by finding the original
|
||||||
|
-- direction vector, then choosing the opposite of that.
|
||||||
if dir_vector.x ~= 0 then
|
if dir_vector.x ~= 0 then
|
||||||
--minetest.log("Move into opposite z dir")
|
--minetest.log("Move into opposite z dir")
|
||||||
dir_vector = get_unit_dir_vector_based_on_diff(start_pos, diff)
|
dir_vector = get_unit_dir_vector_based_on_diff(start_pos, diff)
|
||||||
@ -500,6 +556,7 @@ local function find_path_recursive(start_pos, end_pos, path_nodes, last_dir, las
|
|||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
-- Calls the recursive function to calculate the path
|
||||||
function npc.actions.find_path(start_pos, end_pos)
|
function npc.actions.find_path(start_pos, end_pos)
|
||||||
return find_path_recursive(start_pos, end_pos, {}, nil, nil)
|
return find_path_recursive(start_pos, end_pos, {}, nil, nil)
|
||||||
end
|
end
|
@ -51,7 +51,7 @@ function npc.places.add_owned(self, place_name, place_type, pos)
|
|||||||
-- Set owned by NPC
|
-- Set owned by NPC
|
||||||
meta:set_string("npc_owner", self.npc_id)
|
meta:set_string("npc_owner", self.npc_id)
|
||||||
-- Add place to list
|
-- Add place to list
|
||||||
npc.places.add(self, place_name, place_type, pos)
|
npc.places.add_public(self, place_name, place_type, pos)
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
return false
|
return false
|
||||||
|
27
npc.lua
27
npc.lua
@ -17,10 +17,10 @@ npc.ANIMATION_LAY_START = 162
|
|||||||
npc.ANIMATION_LAY_END = 166
|
npc.ANIMATION_LAY_END = 166
|
||||||
|
|
||||||
npc.direction = {
|
npc.direction = {
|
||||||
north = 1,
|
north = 0,
|
||||||
east = 2,
|
east = 1,
|
||||||
south = 3,
|
south = 2,
|
||||||
west = 4
|
west = 3
|
||||||
}
|
}
|
||||||
|
|
||||||
---------------------------------------------------------------------------------------
|
---------------------------------------------------------------------------------------
|
||||||
@ -346,11 +346,18 @@ local function npc_spawn(self, pos)
|
|||||||
ent.places_map = {}
|
ent.places_map = {}
|
||||||
|
|
||||||
-- Temporary initialization of actions for testing
|
-- Temporary initialization of actions for testing
|
||||||
local nodes = npc.places.find_new_nearby(ent, {"default:furnace"}, 20)
|
local nodes = npc.places.find_new_nearby(ent, {"beds:bed_bottom"}, 20)
|
||||||
--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})
|
||||||
npc.actions.walk_to_pos(ent, nodes[1])
|
npc.actions.walk_to_pos(ent, nodes[1])
|
||||||
|
npc.actions.use_bed(ent, nodes[1], npc.actions.bed_action.LAY)
|
||||||
|
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_bed(ent, nodes[1], npc.actions.bed_action.GET_UP)
|
||||||
|
|
||||||
-- npc.add_action(ent, npc.action.stand, {self = ent})
|
-- npc.add_action(ent, npc.action.stand, {self = ent})
|
||||||
-- npc.add_action(ent, npc.action.stand, {self = ent})
|
-- npc.add_action(ent, npc.action.stand, {self = ent})
|
||||||
-- npc.add_action(ent, npc.action.walk_step, {self = ent, dir = npc.direction.east})
|
-- npc.add_action(ent, npc.action.walk_step, {self = ent, dir = npc.direction.east})
|
||||||
@ -364,11 +371,11 @@ local function npc_spawn(self, pos)
|
|||||||
-- npc.add_action(ent, npc.action.lay, {self = ent})
|
-- npc.add_action(ent, npc.action.lay, {self = ent})
|
||||||
|
|
||||||
-- Temporary initialization of places
|
-- Temporary initialization of places
|
||||||
local bed_nodes = npc.places.find_new_nearby(ent, npc.places.nodes.BEDS, 8)
|
-- local bed_nodes = npc.places.find_new_nearby(ent, npc.places.nodes.BEDS, 8)
|
||||||
minetest.log("Number of bed nodes: "..dump(#bed_nodes))
|
-- minetest.log("Number of bed nodes: "..dump(#bed_nodes))
|
||||||
if #bed_nodes > 0 then
|
-- if #bed_nodes > 0 then
|
||||||
npc.places.add_owned(ent, "bed1", npc.places.PLACE_TYPE.OWN_BED, bed_nodes[1])
|
-- npc.places.add_owned(ent, "bed1", npc.places.PLACE_TYPE.OWN_BED, bed_nodes[1])
|
||||||
end
|
-- end
|
||||||
|
|
||||||
minetest.log(dump(ent))
|
minetest.log(dump(ent))
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user