drops/init.lua

99 lines
3.1 KiB
Lua
Raw Permalink Normal View History

2017-09-15 23:21:53 -07:00
local age = 1 --how old an item has to be before collecting
local radius_magnet = 2.5 --radius of item magnet
local player_collect_height = 1.3 --added to their pos y value
local adjuster_collect = 0.01 --Delay before collecting to visualize moveme
2017-10-02 12:50:11 -07:00
2016-11-19 22:10:30 -08:00
--Item collection
2016-07-17 00:40:40 -07:00
minetest.register_globalstep(function(dtime)
2017-09-15 23:21:53 -07:00
--collection
2016-07-17 00:40:40 -07:00
for _,player in ipairs(minetest.get_connected_players()) do
2017-09-15 23:21:53 -07:00
--don't magnetize to dead players
2016-11-19 21:02:16 -08:00
if player:get_hp() > 0 then
2016-07-17 00:40:40 -07:00
local pos = player:getpos()
local inv = player:get_inventory()
2017-09-15 23:21:53 -07:00
--radial detection
for _,object in ipairs(minetest.env:get_objects_inside_radius({x=pos.x,y=pos.y + player_collect_height,z=pos.z}, radius_magnet)) do
2016-07-17 00:40:40 -07:00
if not object:is_player() and object:get_luaentity() and object:get_luaentity().name == "__builtin:item" then
2016-11-19 21:02:16 -08:00
if object:get_luaentity().age > age then
2016-07-17 00:40:40 -07:00
if inv and inv:room_for_item("main", ItemStack(object:get_luaentity().itemstring)) then
2017-09-15 23:21:53 -07:00
--collect
if object:get_luaentity().collectioner == true and object:get_luaentity().age > age and object:get_luaentity().age > object:get_luaentity().age_stamp + adjuster_collect then
if object:get_luaentity().itemstring ~= "" then
inv:add_item("main", ItemStack(object:get_luaentity().itemstring))
minetest.sound_play("item_drop_pickup", {
pos = pos,
2017-12-16 18:41:59 -08:00
max_hear_distance = 15,
gain = 0.1,
2017-09-15 23:21:53 -07:00
})
object:get_luaentity().itemstring = ""
object:remove()
end
2017-10-02 12:50:11 -07:00
2017-09-15 23:21:53 -07:00
--magnet
else
--moveto for extreme speed boost
local pos1 = pos
pos1.y = pos1.y + player_collect_height
object:moveto(pos1)
object:get_luaentity().collectioner = true
object:get_luaentity().age_stamp = object:get_luaentity().age
2017-10-02 12:50:11 -07:00
2017-09-15 23:21:53 -07:00
end
2016-07-17 00:40:40 -07:00
end
end
end
end
end
end
end)
2016-11-19 22:10:30 -08:00
--Drop items on dig
2017-09-15 23:21:53 -07:00
function minetest.handle_node_drops(pos, drops, digger)
for _,item in ipairs(drops) do
local count, name
if type(item) == "string" then
count = 1
name = item
else
count = item:get_count()
name = item:get_name()
2016-11-19 21:02:16 -08:00
end
2017-10-06 15:22:30 -07:00
--if not inv or not inv:contains_item("main", ItemStack(name)) then
2017-09-15 23:21:53 -07:00
for i=1,count do
local obj = minetest.add_item(pos, name)
if obj ~= nil then
obj:get_luaentity().collect = true
obj:get_luaentity().age = age
obj:setvelocity({x=math.random(-3,3), y=math.random(2,5), z=math.random(-3,3)})
2016-07-17 00:40:40 -07:00
end
end
2017-10-06 15:22:30 -07:00
--end
2016-07-17 00:40:40 -07:00
end
end
2016-11-19 22:10:30 -08:00
2017-09-15 23:21:53 -07:00
--Throw items using player's velocity
2016-07-17 00:40:40 -07:00
function minetest.item_drop(itemstack, dropper, pos)
2017-10-02 12:50:11 -07:00
2016-11-23 17:40:27 -08:00
--if player then do modified item drop
2017-09-15 23:21:53 -07:00
if dropper and minetest.get_player_information(dropper:get_player_name()) then
2016-07-17 00:40:40 -07:00
local v = dropper:get_look_dir()
2016-11-19 22:10:30 -08:00
local vel = dropper:get_player_velocity()
local p = {x=pos.x, y=pos.y+1.3, z=pos.z}
2016-11-19 21:02:16 -08:00
local item = itemstack:to_string()
2016-07-17 00:40:40 -07:00
local obj = core.add_item(p, item)
if obj then
2016-11-19 22:10:30 -08:00
v.x = (v.x*5)+vel.x
v.y = ((v.y*5)+2)+vel.y
v.z = (v.z*5)+vel.z
2016-07-17 00:40:40 -07:00
obj:setvelocity(v)
2016-11-23 17:40:27 -08:00
obj:get_luaentity().dropped_by = dropper:get_player_name()
2016-11-19 21:02:16 -08:00
itemstack:clear()
2016-07-17 00:40:40 -07:00
return itemstack
end
end
end
2017-10-02 12:50:11 -07:00
if minetest.settings:get("log_mods") then
2017-09-15 23:21:53 -07:00
minetest.log("action", "Drops loaded")
2016-07-17 00:40:40 -07:00
end