Update statbars.lua
This commit is contained in:
parent
b7a1d3bc40
commit
e6bc7c6269
|
@ -1,27 +1,6 @@
|
||||||
-- cache setting
|
-- cache setting
|
||||||
local enable_damage = core.settings:get_bool("enable_damage")
|
local enable_damage = core.settings:get_bool("enable_damage")
|
||||||
|
|
||||||
local health_bar_definition = {
|
|
||||||
hud_elem_type = "statbar",
|
|
||||||
position = {x = 0.5, y = 1},
|
|
||||||
alignment = {x = -1, y = -1},
|
|
||||||
offset = {x = -247, y = -108},
|
|
||||||
size = {x = 24, y = 24},
|
|
||||||
text = "heart.png",
|
|
||||||
background = "heart_bg.png",
|
|
||||||
number = 20
|
|
||||||
}
|
|
||||||
|
|
||||||
local breath_bar_definition = {
|
|
||||||
hud_elem_type = "statbar",
|
|
||||||
position = {x = 0.5, y = 1},
|
|
||||||
alignment = {x = -1, y = -1},
|
|
||||||
offset = {x = 8, y = -134},
|
|
||||||
size = {x = 24, y = 24},
|
|
||||||
text = "bubble.png",
|
|
||||||
number = 20
|
|
||||||
}
|
|
||||||
|
|
||||||
local hud_ids = {}
|
local hud_ids = {}
|
||||||
|
|
||||||
local function initialize_builtin_statbars(player)
|
local function initialize_builtin_statbars(player)
|
||||||
|
@ -43,19 +22,7 @@ local function initialize_builtin_statbars(player)
|
||||||
player:hud_set_flags(player:hud_get_flags())
|
player:hud_set_flags(player:hud_get_flags())
|
||||||
end
|
end
|
||||||
|
|
||||||
if player:hud_get_flags().healthbar and enable_damage then
|
|
||||||
if hud_ids[name].id_healthbar == nil then
|
|
||||||
hud_ids[name].id_healthbar = hud.register("health", health_bar_definition)
|
|
||||||
minetest.after(0, function()
|
|
||||||
hud.change_item(player, "health", {number = player:get_hp()})
|
|
||||||
end)
|
|
||||||
end
|
|
||||||
else
|
|
||||||
if hud_ids[name].id_healthbar ~= nil then
|
|
||||||
player:hud_remove(hud_ids[name].id_healthbar)
|
|
||||||
hud_ids[name].id_healthbar = nil
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if (player:get_breath() < 11) then
|
if (player:get_breath() < 11) then
|
||||||
if player:hud_get_flags().breathbar and enable_damage then
|
if player:hud_get_flags().breathbar and enable_damage then
|
||||||
|
@ -98,14 +65,7 @@ local function player_event_handler(player, eventname)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
if eventname == "health_changed" then
|
|
||||||
initialize_builtin_statbars(player)
|
|
||||||
|
|
||||||
if hud_id[name.."_".."health"] ~= nil then
|
|
||||||
hud.change_item(player, "health", {number = player:get_hp()})
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if eventname == "breath_changed" then
|
if eventname == "breath_changed" then
|
||||||
initialize_builtin_statbars(player)
|
initialize_builtin_statbars(player)
|
||||||
|
@ -124,43 +84,6 @@ local function player_event_handler(player, eventname)
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
--[[function core.hud_replace_builtin(name, definition)
|
|
||||||
|
|
||||||
if definition == nil or
|
|
||||||
type(definition) ~= "table" or
|
|
||||||
definition.hud_elem_type ~= "statbar" then
|
|
||||||
return false
|
|
||||||
end
|
|
||||||
|
|
||||||
if name == "health" then
|
|
||||||
health_bar_definition = definition
|
|
||||||
|
|
||||||
for name,ids in pairs(hud_ids) do
|
|
||||||
local player = core.get_player_by_name(name)
|
|
||||||
if player and hud_ids[name].id_healthbar then
|
|
||||||
player:hud_remove(hud_ids[name].id_healthbar)
|
|
||||||
initialize_builtin_statbars(player)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
|
|
||||||
if name == "breath" then
|
|
||||||
breath_bar_definition = definition
|
|
||||||
|
|
||||||
for name,ids in pairs(hud_ids) do
|
|
||||||
local player = core.get_player_by_name(name)
|
|
||||||
if player and hud_ids[name].id_breathbar then
|
|
||||||
player:hud_remove(hud_ids[name].id_breathbar)
|
|
||||||
initialize_builtin_statbars(player)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
|
|
||||||
return false
|
|
||||||
end]]
|
|
||||||
|
|
||||||
if enable_damage then
|
if enable_damage then
|
||||||
core.register_on_joinplayer(initialize_builtin_statbars)
|
core.register_on_joinplayer(initialize_builtin_statbars)
|
||||||
core.register_on_leaveplayer(cleanup_builtin_statbars)
|
core.register_on_leaveplayer(cleanup_builtin_statbars)
|
||||||
|
|
Loading…
Reference in New Issue