forked from mtcontrib/minetest_hbarmor
General code cleanup
This commit is contained in:
parent
835c477361
commit
e6b9bc6836
46
init.lua
46
init.lua
@ -17,11 +17,22 @@ if set then
|
|||||||
set:close()
|
set:close()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local must_hide = function(playername, arm)
|
||||||
|
return ((not armor.def[playername].count or armor.def[playername].count == 0) and arm == 0)
|
||||||
|
end
|
||||||
|
|
||||||
|
local arm_printable = function(arm)
|
||||||
|
return math.ceil(math.floor(arm+0.5))
|
||||||
|
end
|
||||||
|
|
||||||
local function custom_hud(player)
|
local function custom_hud(player)
|
||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
|
|
||||||
if minetest.setting_getbool("enable_damage") then
|
if minetest.setting_getbool("enable_damage") then
|
||||||
hb.init_hudbar(player, "armor")
|
local arm = tonumber(hud.armor[name])
|
||||||
|
if not arm then arm = 0 end
|
||||||
|
local hide = must_hide(name, arm)
|
||||||
|
hb.init_hudbar(player, "armor", arm_printable(arm), nil, nil, hide)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -32,9 +43,9 @@ hb.register_hudbar("armor", 0xFFFFFF, "Armor", { icon = "hbarmor_icon.png", bar
|
|||||||
function hud.set_armor()
|
function hud.set_armor()
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
dofile(minetest.get_modpath("hbarmor").."/armor.lua")
|
dofile(minetest.get_modpath("hbarmor").."/armor.lua")
|
||||||
|
|
||||||
|
|
||||||
-- update hud elemtens if value has changed
|
-- update hud elemtens if value has changed
|
||||||
local function update_hud(player)
|
local function update_hud(player)
|
||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
@ -45,14 +56,13 @@ local function update_hud(player)
|
|||||||
if not arm then arm = 0 end
|
if not arm then arm = 0 end
|
||||||
if arm_out ~= arm then
|
if arm_out ~= arm then
|
||||||
hud.armor_out[name] = arm
|
hud.armor_out[name] = arm
|
||||||
local arm_displayed = math.ceil(math.floor(arm+0.5))
|
|
||||||
hb.change_hudbar(player, "armor", arm_displayed)
|
|
||||||
-- hide armor bar completely when there is none
|
-- hide armor bar completely when there is none
|
||||||
if (not armor.def[name].count or armor.def[name].count == 0) and arm == 0 then
|
if must_hide(name, arm) then
|
||||||
hb.hide_hudbar(player, "armor")
|
hb.hide_hudbar(player, "armor")
|
||||||
else
|
else
|
||||||
hb.unhide_hudbar(player, "armor")
|
hb.unhide_hudbar(player, "armor")
|
||||||
end
|
end
|
||||||
|
hb.change_hudbar(player, "armor", arm_printable(arm))
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -68,24 +78,22 @@ end)
|
|||||||
|
|
||||||
local main_timer = 0
|
local main_timer = 0
|
||||||
local timer = 0
|
local timer = 0
|
||||||
minetest.after(2.5, function()
|
minetest.register_globalstep(function(dtime)
|
||||||
minetest.register_globalstep(function(dtime)
|
|
||||||
main_timer = main_timer + dtime
|
main_timer = main_timer + dtime
|
||||||
timer = timer + dtime
|
timer = timer + dtime
|
||||||
if main_timer > HUD_TICK or timer > 4 then
|
if main_timer > HUD_TICK or timer > 4 then
|
||||||
if main_timer > HUD_TICK then main_timer = 0 end
|
if main_timer > HUD_TICK then main_timer = 0 end
|
||||||
for _,player in ipairs(minetest.get_connected_players()) do
|
for _,player in ipairs(minetest.get_connected_players()) do
|
||||||
local name = player:get_player_name()
|
local name = player:get_player_name()
|
||||||
|
|
||||||
-- only proceed if damage is enabled
|
-- only proceed if damage is enabled
|
||||||
if minetest.setting_getbool("enable_damage") then
|
if minetest.setting_getbool("enable_damage") then
|
||||||
hud.get_armor(player)
|
hud.get_armor(player)
|
||||||
|
|
||||||
-- update all hud elements
|
-- update all hud elements
|
||||||
update_hud(player)
|
update_hud(player)
|
||||||
end
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if timer > 4 then timer = 0 end
|
end
|
||||||
end)
|
if timer > 4 then timer = 0 end
|
||||||
end)
|
end)
|
||||||
|
Loading…
Reference in New Issue
Block a user