forked from mtcontrib/maidroid
Replace deprecated method
This commit is contained in:
parent
453b6c7400
commit
59fcc6875e
@ -78,12 +78,12 @@ end
|
|||||||
-- is the nearest to the maidroid.
|
-- is the nearest to the maidroid.
|
||||||
function maidroid.maidroid.get_nearest_player(self, range_distance)
|
function maidroid.maidroid.get_nearest_player(self, range_distance)
|
||||||
local player, min_distance = nil, range_distance
|
local player, min_distance = nil, range_distance
|
||||||
local position = self.object:getpos()
|
local position = self.object:get_pos()
|
||||||
|
|
||||||
local all_objects = minetest.get_objects_inside_radius(position, range_distance)
|
local all_objects = minetest.get_objects_inside_radius(position, range_distance)
|
||||||
for _, object in pairs(all_objects) do
|
for _, object in pairs(all_objects) do
|
||||||
if object:is_player() then
|
if object:is_player() then
|
||||||
local player_position = object:getpos()
|
local player_position = object:get_pos()
|
||||||
local distance = vector.distance(position, player_position)
|
local distance = vector.distance(position, player_position)
|
||||||
|
|
||||||
if distance < min_distance then
|
if distance < min_distance then
|
||||||
@ -110,7 +110,7 @@ function maidroid.maidroid.get_front(self)
|
|||||||
direction.z = 0
|
direction.z = 0
|
||||||
end
|
end
|
||||||
|
|
||||||
return vector.add(vector.round(self.object:getpos()), direction)
|
return vector.add(vector.round(self.object:get_pos()), direction)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- maidroid.maidroid.get_front_node returns a node that exists in front of the maidroid.
|
-- maidroid.maidroid.get_front_node returns a node that exists in front of the maidroid.
|
||||||
@ -195,12 +195,12 @@ end
|
|||||||
|
|
||||||
-- maidroid.maidroid.change_direction change direction to destination and velocity vector.
|
-- maidroid.maidroid.change_direction change direction to destination and velocity vector.
|
||||||
function maidroid.maidroid.change_direction(self, destination)
|
function maidroid.maidroid.change_direction(self, destination)
|
||||||
local position = self.object:getpos()
|
local position = self.object:get_pos()
|
||||||
local direction = vector.subtract(destination, position)
|
local direction = vector.subtract(destination, position)
|
||||||
direction.y = 0
|
direction.y = 0
|
||||||
local velocity = vector.multiply(vector.normalize(direction), 1.5)
|
local velocity = vector.multiply(vector.normalize(direction), 1.5)
|
||||||
|
|
||||||
self.object:setvelocity(velocity)
|
self.object:set_velocity(velocity)
|
||||||
self:set_yaw_by_direction(direction)
|
self:set_yaw_by_direction(direction)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -212,7 +212,7 @@ function maidroid.maidroid.change_direction_randomly(self)
|
|||||||
z = math.random(0, 5) * 2 - 5,
|
z = math.random(0, 5) * 2 - 5,
|
||||||
}
|
}
|
||||||
local velocity = vector.multiply(vector.normalize(direction), 1.5)
|
local velocity = vector.multiply(vector.normalize(direction), 1.5)
|
||||||
self.object:setvelocity(velocity)
|
self.object:set_velocity(velocity)
|
||||||
self:set_yaw_by_direction(direction)
|
self:set_yaw_by_direction(direction)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -336,7 +336,7 @@ function maidroid.register_egg(egg_name, def)
|
|||||||
-- set maidroid's direction.
|
-- set maidroid's direction.
|
||||||
local new_maidroid = minetest.add_entity(pointed_thing.above, def.product_name)
|
local new_maidroid = minetest.add_entity(pointed_thing.above, def.product_name)
|
||||||
new_maidroid:get_luaentity():set_yaw_by_direction(
|
new_maidroid:get_luaentity():set_yaw_by_direction(
|
||||||
vector.subtract(user:getpos(), new_maidroid:getpos())
|
vector.subtract(user:get_pos(), new_maidroid:get_pos())
|
||||||
)
|
)
|
||||||
new_maidroid:get_luaentity().owner_name = user:get_player_name()
|
new_maidroid:get_luaentity().owner_name = user:get_player_name()
|
||||||
new_maidroid:get_luaentity():update_infotext()
|
new_maidroid:get_luaentity():update_infotext()
|
||||||
@ -482,7 +482,7 @@ function maidroid.register_maidroid(product_name, def)
|
|||||||
}
|
}
|
||||||
|
|
||||||
-- attach dummy item to new maidroid.
|
-- attach dummy item to new maidroid.
|
||||||
local dummy_item = minetest.add_entity(self.object:getpos(), "maidroid:dummy_item")
|
local dummy_item = minetest.add_entity(self.object:get_pos(), "maidroid:dummy_item")
|
||||||
dummy_item:set_attach(self.object, "Arm_R", {x = 0.065, y = 0.50, z = -0.15}, {x = -45, y = 0, z = 0})
|
dummy_item:set_attach(self.object, "Arm_R", {x = 0.065, y = 0.50, z = -0.15}, {x = -45, y = 0, z = 0})
|
||||||
dummy_item:get_luaentity().maidroid_object = self.object
|
dummy_item:get_luaentity().maidroid_object = self.object
|
||||||
|
|
||||||
@ -490,7 +490,7 @@ function maidroid.register_maidroid(product_name, def)
|
|||||||
if core ~= nil then
|
if core ~= nil then
|
||||||
core.on_start(self)
|
core.on_start(self)
|
||||||
else
|
else
|
||||||
self.object:setvelocity{x = 0, y = 0, z = 0}
|
self.object:set_velocity{x = 0, y = 0, z = 0}
|
||||||
self.object:setacceleration{x = 0, y = -10, z = 0}
|
self.object:setacceleration{x = 0, y = -10, z = 0}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -519,7 +519,7 @@ function maidroid.register_maidroid(product_name, def)
|
|||||||
|
|
||||||
-- maidroid.maidroid.pickup_item pickup items placed and put it to main slot.
|
-- maidroid.maidroid.pickup_item pickup items placed and put it to main slot.
|
||||||
local function pickup_item(self)
|
local function pickup_item(self)
|
||||||
local pos = self.object:getpos()
|
local pos = self.object:get_pos()
|
||||||
local radius = 1.0
|
local radius = 1.0
|
||||||
local all_objects = minetest.get_objects_inside_radius(pos, radius)
|
local all_objects = minetest.get_objects_inside_radius(pos, radius)
|
||||||
|
|
||||||
@ -532,7 +532,7 @@ function maidroid.register_maidroid(product_name, def)
|
|||||||
local stack = ItemStack(itemstring)
|
local stack = ItemStack(itemstring)
|
||||||
local leftover = inv:add_item("main", stack)
|
local leftover = inv:add_item("main", stack)
|
||||||
|
|
||||||
minetest.add_item(obj:getpos(), leftover)
|
minetest.add_item(obj:get_pos(), leftover)
|
||||||
obj:get_luaentity().itemstring = ""
|
obj:get_luaentity().itemstring = ""
|
||||||
obj:remove()
|
obj:remove()
|
||||||
end
|
end
|
||||||
|
@ -8,12 +8,12 @@ local state = {IDLE = 0, ACCOMPANY = 1}
|
|||||||
local function on_start(self)
|
local function on_start(self)
|
||||||
self.state = state.IDLE
|
self.state = state.IDLE
|
||||||
self.object:setacceleration{x = 0, y = -10, z = 0}
|
self.object:setacceleration{x = 0, y = -10, z = 0}
|
||||||
self.object:setvelocity{x = 0, y = 0, z = 0}
|
self.object:set_velocity{x = 0, y = 0, z = 0}
|
||||||
end
|
end
|
||||||
|
|
||||||
local function on_stop(self)
|
local function on_stop(self)
|
||||||
self.state = nil
|
self.state = nil
|
||||||
self.object:setvelocity{x = 0, y = 0, z = 0}
|
self.object:set_velocity{x = 0, y = 0, z = 0}
|
||||||
self:set_animation(maidroid.animation_frames.STAND)
|
self:set_animation(maidroid.animation_frames.STAND)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -24,23 +24,23 @@ local function on_step(self, dtime)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local position = self.object:getpos()
|
local position = self.object:get_pos()
|
||||||
local player_position = player:getpos()
|
local player_position = player:get_pos()
|
||||||
local direction = vector.subtract(player_position, position)
|
local direction = vector.subtract(player_position, position)
|
||||||
local velocity = self.object:getvelocity()
|
local velocity = self.object:get_velocity()
|
||||||
|
|
||||||
if vector.length(direction) < 3 then
|
if vector.length(direction) < 3 then
|
||||||
if self.state == state.ACCOMPANY then
|
if self.state == state.ACCOMPANY then
|
||||||
self:set_animation(maidroid.animation_frames.STAND)
|
self:set_animation(maidroid.animation_frames.STAND)
|
||||||
self.state = state.IDLE
|
self.state = state.IDLE
|
||||||
self.object:setvelocity{x = 0, y = velocity.y, z = 0}
|
self.object:set_velocity{x = 0, y = velocity.y, z = 0}
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if self.state == state.IDLE then
|
if self.state == state.IDLE then
|
||||||
self:set_animation(maidroid.animation_frames.WALK)
|
self:set_animation(maidroid.animation_frames.WALK)
|
||||||
self.state = state.ACCOMPANY
|
self.state = state.ACCOMPANY
|
||||||
end
|
end
|
||||||
self.object:setvelocity{x = direction.x, y = velocity.y, z = direction.z} -- TODO
|
self.object:set_velocity{x = direction.x, y = velocity.y, z = direction.z} -- TODO
|
||||||
end
|
end
|
||||||
self:set_yaw_by_direction(direction)
|
self:set_yaw_by_direction(direction)
|
||||||
|
|
||||||
@ -49,7 +49,7 @@ local function on_step(self, dtime)
|
|||||||
local front_node = self:get_front_node()
|
local front_node = self:get_front_node()
|
||||||
if front_node.name ~= "air" and minetest.registered_nodes[front_node.name] ~= nil
|
if front_node.name ~= "air" and minetest.registered_nodes[front_node.name] ~= nil
|
||||||
and minetest.registered_nodes[front_node.name].walkable then
|
and minetest.registered_nodes[front_node.name].walkable then
|
||||||
self.object:setvelocity{x = direction.x, y = 5, z = direction.z}
|
self.object:set_velocity{x = direction.x, y = 5, z = direction.z}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -48,7 +48,7 @@ local to_walk_randomly, to_walk_to_plant, to_walk_to_mow, to_plant, to_mow
|
|||||||
|
|
||||||
local function on_start(self)
|
local function on_start(self)
|
||||||
self.object:setacceleration{x = 0, y = -10, z = 0}
|
self.object:setacceleration{x = 0, y = -10, z = 0}
|
||||||
self.object:setvelocity{x = 0, y = 0, z = 0}
|
self.object:set_velocity{x = 0, y = 0, z = 0}
|
||||||
self.state = state.WALK_RANDOMLY
|
self.state = state.WALK_RANDOMLY
|
||||||
self.time_counters = {}
|
self.time_counters = {}
|
||||||
self.path = nil
|
self.path = nil
|
||||||
@ -56,7 +56,7 @@ local function on_start(self)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function on_stop(self)
|
local function on_stop(self)
|
||||||
self.object:setvelocity{x = 0, y = 0, z = 0}
|
self.object:set_velocity{x = 0, y = 0, z = 0}
|
||||||
self.state = nil
|
self.state = nil
|
||||||
self.time_counters = nil
|
self.time_counters = nil
|
||||||
self.path = nil
|
self.path = nil
|
||||||
@ -64,7 +64,7 @@ local function on_stop(self)
|
|||||||
end
|
end
|
||||||
|
|
||||||
local function is_near(self, pos, distance)
|
local function is_near(self, pos, distance)
|
||||||
local p = self.object:getpos()
|
local p = self.object:get_pos()
|
||||||
-- p.y = p.y + 0.5
|
-- p.y = p.y + 0.5
|
||||||
return vector.distance(p, pos) < distance
|
return vector.distance(p, pos) < distance
|
||||||
end
|
end
|
||||||
@ -79,9 +79,9 @@ walk_randomly = function(self, dtime)
|
|||||||
local wield_stack = self:get_wield_item_stack()
|
local wield_stack = self:get_wield_item_stack()
|
||||||
if minetest.get_item_group(wield_stack:get_name(), "seed") > 0
|
if minetest.get_item_group(wield_stack:get_name(), "seed") > 0
|
||||||
or self:has_item_in_main(function(itemname) return (minetest.get_item_group(itemname, "seed") > 0) end) then
|
or self:has_item_in_main(function(itemname) return (minetest.get_item_group(itemname, "seed") > 0) end) then
|
||||||
local destination = _aux.search_surrounding(self.object:getpos(), is_plantable_place, searching_range)
|
local destination = _aux.search_surrounding(self.object:get_pos(), is_plantable_place, searching_range)
|
||||||
if destination ~= nil then
|
if destination ~= nil then
|
||||||
local path = minetest.find_path(self.object:getpos(), destination, 10, 1, 1, "A*")
|
local path = minetest.find_path(self.object:get_pos(), destination, 10, 1, 1, "A*")
|
||||||
|
|
||||||
if path ~= nil then -- to walk to plant state.
|
if path ~= nil then -- to walk to plant state.
|
||||||
to_walk_to_plant(self, path, destination)
|
to_walk_to_plant(self, path, destination)
|
||||||
@ -90,9 +90,9 @@ walk_randomly = function(self, dtime)
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- if couldn't find path to plant, try to mow.
|
-- if couldn't find path to plant, try to mow.
|
||||||
local destination = _aux.search_surrounding(self.object:getpos(), is_mowable_place, searching_range)
|
local destination = _aux.search_surrounding(self.object:get_pos(), is_mowable_place, searching_range)
|
||||||
if destination ~= nil then
|
if destination ~= nil then
|
||||||
local path = minetest.find_path(self.object:getpos(), destination, 10, 1, 1, "A*")
|
local path = minetest.find_path(self.object:get_pos(), destination, 10, 1, 1, "A*")
|
||||||
if path ~= nil then -- to walk to mow state.
|
if path ~= nil then -- to walk to mow state.
|
||||||
to_walk_to_mow(self, path, destination)
|
to_walk_to_mow(self, path, destination)
|
||||||
return
|
return
|
||||||
@ -110,7 +110,7 @@ walk_randomly = function(self, dtime)
|
|||||||
self.time_counters[1] = self.time_counters[1] + 1
|
self.time_counters[1] = self.time_counters[1] + 1
|
||||||
self.time_counters[2] = self.time_counters[2] + 1
|
self.time_counters[2] = self.time_counters[2] + 1
|
||||||
|
|
||||||
local velocity = self.object:getvelocity()
|
local velocity = self.object:get_velocity()
|
||||||
if velocity.y == 0 then
|
if velocity.y == 0 then
|
||||||
local front_node = self:get_front_node()
|
local front_node = self:get_front_node()
|
||||||
|
|
||||||
@ -118,7 +118,7 @@ walk_randomly = function(self, dtime)
|
|||||||
self:change_direction_randomly()
|
self:change_direction_randomly()
|
||||||
elseif front_node.name ~= "air" and minetest.registered_nodes[front_node.name] ~= nil
|
elseif front_node.name ~= "air" and minetest.registered_nodes[front_node.name] ~= nil
|
||||||
and minetest.registered_nodes[front_node.name].walkable then
|
and minetest.registered_nodes[front_node.name].walkable then
|
||||||
self.object:setvelocity{x = velocity.x, y = 6, z = velocity.z}
|
self.object:set_velocity{x = velocity.x, y = 6, z = velocity.z}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
return
|
return
|
||||||
@ -159,9 +159,9 @@ to_plant = function(self)
|
|||||||
or self:move_main_to_wield(function(itemname) return (minetest.get_item_group(itemname, "seed") > 0) end) then
|
or self:move_main_to_wield(function(itemname) return (minetest.get_item_group(itemname, "seed") > 0) end) then
|
||||||
self.state = state.PLANT
|
self.state = state.PLANT
|
||||||
self.time_counters[1] = 0
|
self.time_counters[1] = 0
|
||||||
self.object:setvelocity{x = 0, y = 0, z = 0}
|
self.object:set_velocity{x = 0, y = 0, z = 0}
|
||||||
self:set_animation(maidroid.animation_frames.MINE)
|
self:set_animation(maidroid.animation_frames.MINE)
|
||||||
self:set_yaw_by_direction(vector.subtract(self.destination, self.object:getpos()))
|
self:set_yaw_by_direction(vector.subtract(self.destination, self.object:get_pos()))
|
||||||
return
|
return
|
||||||
else
|
else
|
||||||
to_walk_randomly(self)
|
to_walk_randomly(self)
|
||||||
@ -172,9 +172,9 @@ end
|
|||||||
to_mow = function(self)
|
to_mow = function(self)
|
||||||
self.state = state.MOW
|
self.state = state.MOW
|
||||||
self.time_counters[1] = 0
|
self.time_counters[1] = 0
|
||||||
self.object:setvelocity{x = 0, y = 0, z = 0}
|
self.object:set_velocity{x = 0, y = 0, z = 0}
|
||||||
self:set_animation(maidroid.animation_frames.MINE)
|
self:set_animation(maidroid.animation_frames.MINE)
|
||||||
self:set_yaw_by_direction(vector.subtract(self.destination, self.object:getpos()))
|
self:set_yaw_by_direction(vector.subtract(self.destination, self.object:get_pos()))
|
||||||
end
|
end
|
||||||
|
|
||||||
walk_to_plant_and_mow_common = function(self, dtime)
|
walk_to_plant_and_mow_common = function(self, dtime)
|
||||||
@ -198,7 +198,7 @@ walk_to_plant_and_mow_common = function(self, dtime)
|
|||||||
|
|
||||||
if self.time_counters[1] >= FIND_PATH_TIME_INTERVAL then
|
if self.time_counters[1] >= FIND_PATH_TIME_INTERVAL then
|
||||||
self.time_counters[1] = 0
|
self.time_counters[1] = 0
|
||||||
local path = minetest.find_path(self.object:getpos(), self.destination, 10, 1, 1, "A*")
|
local path = minetest.find_path(self.object:get_pos(), self.destination, 10, 1, 1, "A*")
|
||||||
if path == nil then
|
if path == nil then
|
||||||
to_walk_randomly(self)
|
to_walk_randomly(self)
|
||||||
return
|
return
|
||||||
@ -224,13 +224,13 @@ walk_to_plant_and_mow_common = function(self, dtime)
|
|||||||
|
|
||||||
else
|
else
|
||||||
-- if maidroid is stopped by obstacles, the maidroid must jump.
|
-- if maidroid is stopped by obstacles, the maidroid must jump.
|
||||||
local velocity = self.object:getvelocity()
|
local velocity = self.object:get_velocity()
|
||||||
if velocity.y == 0 then
|
if velocity.y == 0 then
|
||||||
local front_node = self:get_front_node()
|
local front_node = self:get_front_node()
|
||||||
if front_node.name ~= "air" and minetest.registered_nodes[front_node.name] ~= nil
|
if front_node.name ~= "air" and minetest.registered_nodes[front_node.name] ~= nil
|
||||||
and minetest.registered_nodes[front_node.name].walkable
|
and minetest.registered_nodes[front_node.name].walkable
|
||||||
and not (minetest.get_item_group(front_node.name, "fence") > 0) then
|
and not (minetest.get_item_group(front_node.name, "fence") > 0) then
|
||||||
self.object:setvelocity{x = velocity.x, y = 6, z = velocity.z}
|
self.object:set_velocity{x = velocity.x, y = 6, z = velocity.z}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
@ -6,7 +6,7 @@
|
|||||||
local maidroid_instruction_set = {
|
local maidroid_instruction_set = {
|
||||||
-- popular (similars in lua_api) information gathering functions
|
-- popular (similars in lua_api) information gathering functions
|
||||||
getpos = function(_, thread)
|
getpos = function(_, thread)
|
||||||
local pos = thread.droid.object:getpos()
|
local pos = thread.droid.object:get_pos()
|
||||||
return true, {pos.x, pos.y, pos.z}
|
return true, {pos.x, pos.y, pos.z}
|
||||||
end,
|
end,
|
||||||
|
|
||||||
@ -57,7 +57,7 @@ local maidroid_instruction_set = {
|
|||||||
end
|
end
|
||||||
|
|
||||||
-- play sound
|
-- play sound
|
||||||
local p = droid.object:getpos()
|
local p = droid.object:get_pos()
|
||||||
p.y = p.y - 1
|
p.y = p.y - 1
|
||||||
local node_under = minetest.get_node(p).name
|
local node_under = minetest.get_node(p).name
|
||||||
local def = minetest.registered_nodes[node_under]
|
local def = minetest.registered_nodes[node_under]
|
||||||
@ -72,12 +72,12 @@ local maidroid_instruction_set = {
|
|||||||
|
|
||||||
-- perform jump
|
-- perform jump
|
||||||
droid.vel.y = math.sqrt(-2 * h * droid.object:getacceleration().y)
|
droid.vel.y = math.sqrt(-2 * h * droid.object:getacceleration().y)
|
||||||
droid.object:setvelocity(droid.vel)
|
droid.object:set_velocity(droid.vel)
|
||||||
return true, true
|
return true, true
|
||||||
end,
|
end,
|
||||||
|
|
||||||
beep = function(_, thread)
|
beep = function(_, thread)
|
||||||
minetest.sound_play("maidroid_beep", {pos = thread.droid.object:getpos()})
|
minetest.sound_play("maidroid_beep", {pos = thread.droid.object:get_pos()})
|
||||||
return true
|
return true
|
||||||
end,
|
end,
|
||||||
}
|
}
|
||||||
@ -111,7 +111,7 @@ end
|
|||||||
|
|
||||||
local function on_start(self)
|
local function on_start(self)
|
||||||
self.object:setacceleration{x = 0, y = -10, z = 0}
|
self.object:setacceleration{x = 0, y = -10, z = 0}
|
||||||
self.object:setvelocity{x = 0, y = 0, z = 0}
|
self.object:set_velocity{x = 0, y = 0, z = 0}
|
||||||
self.vel = {x = 0, y = 0, z = 0}
|
self.vel = {x = 0, y = 0, z = 0}
|
||||||
self.vel_prev = self.vel
|
self.vel_prev = self.vel
|
||||||
|
|
||||||
@ -134,7 +134,7 @@ local function on_step(self)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
self.vel_prev = self.vel
|
self.vel_prev = self.vel
|
||||||
self.vel = self.object:getvelocity()
|
self.vel = self.object:get_velocity()
|
||||||
|
|
||||||
thread:try_rebirth()
|
thread:try_rebirth()
|
||||||
end
|
end
|
||||||
@ -151,7 +151,7 @@ local function on_stop(self)
|
|||||||
self.thread:exit()
|
self.thread:exit()
|
||||||
self.thread = nil
|
self.thread = nil
|
||||||
|
|
||||||
self.object:setvelocity{x = 0, y = 0, z = 0}
|
self.object:set_velocity{x = 0, y = 0, z = 0}
|
||||||
end
|
end
|
||||||
|
|
||||||
-- register a definition of a new core.
|
-- register a definition of a new core.
|
||||||
|
@ -10,14 +10,14 @@ local PLACE_TIME = 4
|
|||||||
local function on_start(self)
|
local function on_start(self)
|
||||||
self.state = state.IDLE
|
self.state = state.IDLE
|
||||||
self.object:setacceleration{x = 0, y = -10, z = 0}
|
self.object:setacceleration{x = 0, y = -10, z = 0}
|
||||||
self.object:setvelocity{x = 0, y = 0, z = 0}
|
self.object:set_velocity{x = 0, y = 0, z = 0}
|
||||||
self.time_counter = -1
|
self.time_counter = -1
|
||||||
self.is_placing = false
|
self.is_placing = false
|
||||||
end
|
end
|
||||||
|
|
||||||
local function on_stop(self)
|
local function on_stop(self)
|
||||||
self.state = nil
|
self.state = nil
|
||||||
self.object:setvelocity{x = 0, y = 0, z = 0}
|
self.object:set_velocity{x = 0, y = 0, z = 0}
|
||||||
self:set_animation(maidroid.animation_frames.STAND)
|
self:set_animation(maidroid.animation_frames.STAND)
|
||||||
self.time_counter = nil
|
self.time_counter = nil
|
||||||
self.is_placing = nil
|
self.is_placing = nil
|
||||||
@ -67,16 +67,16 @@ local function on_step(self, dtime)
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local position = self.object:getpos()
|
local position = self.object:get_pos()
|
||||||
local player_position = player:getpos()
|
local player_position = player:get_pos()
|
||||||
local direction = vector.subtract(player_position, position)
|
local direction = vector.subtract(player_position, position)
|
||||||
local velocity = self.object:getvelocity()
|
local velocity = self.object:get_velocity()
|
||||||
|
|
||||||
if vector.length(direction) < 3 then
|
if vector.length(direction) < 3 then
|
||||||
if self.state == state.ACCOMPANY then
|
if self.state == state.ACCOMPANY then
|
||||||
self:set_animation(maidroid.animation_frames.STAND)
|
self:set_animation(maidroid.animation_frames.STAND)
|
||||||
self.state = state.IDLE
|
self.state = state.IDLE
|
||||||
self.object:setvelocity{x = 0, y = velocity.y, z = 0}
|
self.object:set_velocity{x = 0, y = velocity.y, z = 0}
|
||||||
end
|
end
|
||||||
|
|
||||||
if not self.is_placing then
|
if not self.is_placing then
|
||||||
@ -97,7 +97,7 @@ local function on_step(self, dtime)
|
|||||||
self:set_animation(maidroid.animation_frames.WALK)
|
self:set_animation(maidroid.animation_frames.WALK)
|
||||||
self.state = state.ACCOMPANY
|
self.state = state.ACCOMPANY
|
||||||
end
|
end
|
||||||
self.object:setvelocity{x = direction.x, y = velocity.y, z = direction.z} -- TODO
|
self.object:set_velocity{x = direction.x, y = velocity.y, z = direction.z} -- TODO
|
||||||
|
|
||||||
if not self.is_placing then
|
if not self.is_placing then
|
||||||
local front = self:get_front() -- if it is dark, set touch.
|
local front = self:get_front() -- if it is dark, set touch.
|
||||||
@ -119,7 +119,7 @@ local function on_step(self, dtime)
|
|||||||
local front_node = self:get_front_node()
|
local front_node = self:get_front_node()
|
||||||
if front_node.name ~= "air" and minetest.registered_nodes[front_node.name] ~= nil
|
if front_node.name ~= "air" and minetest.registered_nodes[front_node.name] ~= nil
|
||||||
and minetest.registered_nodes[front_node.name].walkable then
|
and minetest.registered_nodes[front_node.name].walkable then
|
||||||
self.object:setvelocity{x = direction.x, y = 5, z = direction.z}
|
self.object:set_velocity{x = direction.x, y = 5, z = direction.z}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user