Fix wielditem not spawning reliably
This commit is contained in:
parent
ab2a67fa91
commit
c7e33f828f
|
@ -9,6 +9,15 @@ local wielditem = {}
|
||||||
local update_time = 1
|
local update_time = 1
|
||||||
local timer = 10 -- needs to be more than update_time
|
local timer = 10 -- needs to be more than update_time
|
||||||
|
|
||||||
|
local function attach_wielditem(player)
|
||||||
|
local name = player:get_player_name()
|
||||||
|
local pos = player:get_pos()
|
||||||
|
|
||||||
|
wielditem[name] = minetest.add_entity(pos, "wielditem:wielditem", name)
|
||||||
|
wielditem[name]:set_attach(player, "right_arm", {x = -1.5, y = 5.7, z = 2.5}, {x = 90, y = -45, z = 270})
|
||||||
|
wielditem[name]:get_luaentity()._wielder = player
|
||||||
|
end
|
||||||
|
|
||||||
minetest.register_entity("wielditem:wielditem", {
|
minetest.register_entity("wielditem:wielditem", {
|
||||||
is_visible = false,
|
is_visible = false,
|
||||||
|
|
||||||
|
@ -26,47 +35,40 @@ minetest.register_entity("wielditem:wielditem", {
|
||||||
_wielder = nil,
|
_wielder = nil,
|
||||||
|
|
||||||
on_activate = function(self, staticdata)
|
on_activate = function(self, staticdata)
|
||||||
local name = staticdata
|
self.object:set_armor_groups({immortal=1})
|
||||||
local wielder = minetest.get_player_by_name(name)
|
end,
|
||||||
|
on_deactivate = function(self)
|
||||||
|
-- Respawn wielditem entity if neccessary
|
||||||
|
local wielder = self._wielder
|
||||||
if wielder and wielder:is_player() then
|
if wielder and wielder:is_player() then
|
||||||
self._wielder = wielder
|
minetest.after(3, function(player)
|
||||||
else
|
if player and player:is_player() then
|
||||||
-- Remove orphan wielditem
|
attach_wielditem(player)
|
||||||
minetest.log("info", "[wielditem] Attempted to spawn orphan wielditem entity!")
|
end
|
||||||
|
end, wielder)
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
on_step = function(self, dtime)
|
||||||
|
local player = self._wielder
|
||||||
|
-- Remove orphan wielditem
|
||||||
|
if player == nil or (minetest.get_player_by_name(player:get_player_name()) == nil) then
|
||||||
|
minetest.log("info", "[wielditem] Removed orphan wielditem!")
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
self.object:set_armor_groups({immortal=1})
|
|
||||||
end,
|
|
||||||
on_step = function(self, dtime)
|
|
||||||
local player = self._wielder
|
|
||||||
-- Remove orphan wielditem
|
|
||||||
if player == nil or (minetest.get_player_by_name(player:get_player_name()) == nil) then
|
|
||||||
self.object:remove()
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
local itemname = player:get_wielded_item():get_name()
|
local itemname = player:get_wielded_item():get_name()
|
||||||
|
|
||||||
if itemname ~= "" then
|
if itemname ~= "" then
|
||||||
self.object:set_properties({textures = {itemname}, is_visible=true})
|
self.object:set_properties({wield_item = itemname, is_visible=true})
|
||||||
else
|
else
|
||||||
self.object:set_properties({is_visible=false})
|
self.object:set_properties({is_visible=false})
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
})
|
})
|
||||||
|
|
||||||
local function attach_wielditem(player)
|
|
||||||
local name = player:get_player_name()
|
|
||||||
local pos = player:get_pos()
|
|
||||||
|
|
||||||
wielditem[name] = minetest.add_entity(pos, "wielditem:wielditem", name)
|
|
||||||
wielditem[name]:set_attach(player, "right_arm", {x = -1.5, y = 5.7, z = 2.5}, {x = 90, y = -45, z = 270})
|
|
||||||
wielditem[name]:get_luaentity()._wielder = player
|
|
||||||
end
|
|
||||||
|
|
||||||
minetest.register_on_joinplayer(function(player)
|
minetest.register_on_joinplayer(function(player)
|
||||||
minetest.after(1, function(player)
|
minetest.after(3, function(player)
|
||||||
if player and player:is_player() then
|
if player and player:is_player() then
|
||||||
attach_wielditem(player)
|
attach_wielditem(player)
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in New Issue