1
0
mirror of https://github.com/tacigar/maidroid.git synced 2025-01-11 00:30:16 +01:00
maidroid/modules/_aux.lua

93 lines
2.9 KiB
Lua
Raw Normal View History

2016-05-31 06:26:54 +02:00
------------------------------------------------------------
-- Copyright (c) 2016 tacigar
-- https://github.com/tacigar/maidroid
------------------------------------------------------------
maidroid.modules._aux = {}
2016-06-09 07:44:44 +02:00
local velocity = 3
-- change direction to destination and velocity vector
function maidroid.modules._aux.change_dir_to(self, dest)
2016-09-13 02:48:17 +02:00
local pos = self.object:getpos()
local dir = vector.subtract(dest, pos)
local vel = vector.multiply(vector.normalize(dir), velocity)
self.object:setvelocity(vel)
self.object:setyaw(math.atan2(vel.z, vel.x) + math.pi / 2)
2016-06-09 07:44:44 +02:00
end
2016-06-02 06:18:58 +02:00
-- change direction and velocity vector
2016-05-31 06:26:54 +02:00
function maidroid.modules._aux.change_dir(self)
2016-09-13 02:48:17 +02:00
local rnd = function() return math.random(0, 5) * 2 - 5 end
local dir = {x = rnd(), y = 0, z = rnd()}
local vel = vector.multiply(vector.normalize(dir), velocity)
self.object:setvelocity(vel)
self.object:setyaw(math.atan2(vel.z, vel.x) + math.pi / 2)
2016-05-31 06:26:54 +02:00
end
2016-06-02 06:18:58 +02:00
-- get direction vector by yaw
2016-05-31 06:26:54 +02:00
function maidroid.modules._aux.get_forward(yaw)
2016-09-13 02:48:17 +02:00
return { x = math.sin(yaw), y = 0.0, z = -math.cos(yaw) }
2016-05-31 06:26:54 +02:00
end
2016-06-02 06:18:58 +02:00
-- round direction vector
2016-05-31 06:26:54 +02:00
function maidroid.modules._aux.get_round_forward(forward)
2016-09-13 02:48:17 +02:00
local rforward = { x = 0, y = 0, z = 0}
if math.abs((forward.x / (math.abs(forward.x) + math.abs(forward.z)))) > 0.5 then
if forward.x > 0 then rforward.x = 1
else rforward.x = -1 end
end
if math.abs((forward.z / (math.abs(forward.x) + math.abs(forward.z)))) > 0.5 then
if forward.z > 0 then rforward.z = 1
else rforward.z = -1 end
end
return rforward
2016-05-31 06:26:54 +02:00
end
2016-06-09 07:44:44 +02:00
2016-05-31 06:26:54 +02:00
function maidroid.modules._aux.get_under_pos(vec)
2016-09-13 02:48:17 +02:00
return { x = vec.x, y = vec.y - 1, z = vec.z }
2016-05-31 06:26:54 +02:00
end
2016-06-09 07:44:44 +02:00
2016-05-31 06:26:54 +02:00
function maidroid.modules._aux.get_upper_pos(vec)
2016-09-13 02:48:17 +02:00
return { x = vec.x, y = vec.y + 1, z = vec.z }
2016-05-31 06:26:54 +02:00
end
2016-06-02 06:18:58 +02:00
-- pickup droped items
2016-06-01 04:15:14 +02:00
function maidroid.modules._aux.pickup_item(self, radius, target_pred)
2016-09-13 02:48:17 +02:00
local pos = self.object:getpos()
local pred = target_pred or (function(itemstring) return true end)
local all_objects = minetest.get_objects_inside_radius(pos, radius)
for _, obj in ipairs(all_objects) do
if not obj:is_player() and obj:get_luaentity() then
local itemstring = obj:get_luaentity().itemstring
if itemstring then
if pred(itemstring) then
local inv = maidroid._aux.get_maidroid_inventory(self)
local stack = ItemStack(itemstring)
local leftover = inv:add_item("main", stack)
minetest.add_item(obj:getpos(), leftover)
obj:get_luaentity().itemstring = ""
obj:remove()
end
end
end
end
2016-05-31 06:26:54 +02:00
end
2016-06-09 07:44:44 +02:00
-- search surrounding nodes
function maidroid.modules._aux.search_surrounding(self, lenvec, pred)
2016-09-13 02:48:17 +02:00
local pos = vector.round(self.object:getpos())
for xi = -lenvec.x, lenvec.x do
for yi = -lenvec.y, lenvec.y do
for zi = -lenvec.z, lenvec.z do
local p = {x = pos.x + xi, y = pos.y + yi, z = pos.z + zi}
local node = minetest.get_node(p)
if pred(self, p, node) then return true, p, node end
end
end
end
return false, nil, nil
2016-06-09 07:44:44 +02:00
end