Add files via upload
@ -129,9 +129,79 @@ function bucket.register_liquid(source, flowing, itemname, inventory_image, name
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
minetest.register_craftitem("bucket:bucket_clay_empty", {
|
||||||
|
description = "".. core.colorize("#FFFFFF", "Empty Clay Bucket\n")..core.colorize("#ababab", "Use empty bucket to collect toxic water."),
|
||||||
|
inventory_image = "ws_clay_pot.png",
|
||||||
|
stack_max = 99,
|
||||||
|
liquids_pointable = true,
|
||||||
|
on_use = function(itemstack, user, pointed_thing)
|
||||||
|
if pointed_thing.type == "object" then
|
||||||
|
pointed_thing.ref:punch(user, 1.0, { full_punch_interval=1.0 }, nil)
|
||||||
|
return user:get_wielded_item()
|
||||||
|
elseif pointed_thing.type ~= "node" then
|
||||||
|
-- do nothing if it's neither object nor node
|
||||||
|
return
|
||||||
|
end
|
||||||
|
-- Check if pointing to a liquid source
|
||||||
|
local node = minetest.get_node(pointed_thing.under)
|
||||||
|
local liquiddef = bucket.liquids[node.name]
|
||||||
|
local item_count = user:get_wielded_item():get_count()
|
||||||
|
|
||||||
|
if liquiddef ~= nil
|
||||||
|
and liquiddef.itemname ~= nil
|
||||||
|
and node.name == liquiddef.source then
|
||||||
|
if check_protection(pointed_thing.under,
|
||||||
|
user:get_player_name(),
|
||||||
|
"take ".. node.name) then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
-- default set to return filled bucket
|
||||||
|
local giving_back = liquiddef.itemname
|
||||||
|
|
||||||
|
-- check if holding more than 1 empty bucket
|
||||||
|
if item_count > 1 then
|
||||||
|
|
||||||
|
-- if space in inventory add filled bucked, otherwise drop as item
|
||||||
|
local inv = user:get_inventory()
|
||||||
|
if inv:room_for_item("main", {name=liquiddef.itemname}) then
|
||||||
|
inv:add_item("main", liquiddef.itemname)
|
||||||
|
else
|
||||||
|
local pos = user:get_pos()
|
||||||
|
pos.y = math.floor(pos.y + 0.5)
|
||||||
|
minetest.add_item(pos, liquiddef.itemname)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- set to return empty buckets minus 1
|
||||||
|
giving_back = "bucket:bucket_clay_empty "..tostring(item_count-1)
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
-- force_renew requires a source neighbour
|
||||||
|
local source_neighbor = false
|
||||||
|
if liquiddef.force_renew then
|
||||||
|
source_neighbor =
|
||||||
|
minetest.find_node_near(pointed_thing.under, 1, liquiddef.source)
|
||||||
|
end
|
||||||
|
if not (source_neighbor and liquiddef.force_renew) then
|
||||||
|
minetest.add_node(pointed_thing.under, {name = "air"})
|
||||||
|
end
|
||||||
|
|
||||||
|
return ItemStack(giving_back)
|
||||||
|
else
|
||||||
|
-- non-liquid nodes will have their on_punch triggered
|
||||||
|
local node_def = minetest.registered_nodes[node.name]
|
||||||
|
if node_def then
|
||||||
|
node_def.on_punch(pointed_thing.under, node, user, pointed_thing)
|
||||||
|
end
|
||||||
|
return user:get_wielded_item()
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
minetest.register_craftitem("bucket:bucket_empty", {
|
minetest.register_craftitem("bucket:bucket_empty", {
|
||||||
description = "".. core.colorize("#FFFFFF", "Empty Bucket\n")..core.colorize("#ababab", "Use empty bucket to collect toxic water."),
|
description = "".. core.colorize("#FFFFFF", "Empty Bucket\n")..core.colorize("#ababab", "Use empty bucket to collect toxic water."),
|
||||||
inventory_image = "ws_clay_pot.png",
|
inventory_image = "ws_bucket.png",
|
||||||
stack_max = 99,
|
stack_max = 99,
|
||||||
liquids_pointable = true,
|
liquids_pointable = true,
|
||||||
on_use = function(itemstack, user, pointed_thing)
|
on_use = function(itemstack, user, pointed_thing)
|
||||||
@ -202,24 +272,51 @@ minetest.register_craftitem("bucket:bucket_empty", {
|
|||||||
bucket.register_liquid(
|
bucket.register_liquid(
|
||||||
"ws_core:water_source_toxic",
|
"ws_core:water_source_toxic",
|
||||||
"ws_core:water_flowing_toxic",
|
"ws_core:water_flowing_toxic",
|
||||||
"bucket:bucket_water_toxic",
|
"bucket:bucket_clay_water_toxic",
|
||||||
"ws_clay_pot_water_toxic.png",
|
"ws_clay_pot_water_toxic.png",
|
||||||
"Toxic Water Bucket (Clay)",
|
"Toxic Water Bucket (Clay)",
|
||||||
{water_bucket = 1}
|
{water_bucket = 1}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
bucket.register_liquid(
|
||||||
|
"ws_core:water_source",
|
||||||
|
"ws_core:water_flowing",
|
||||||
|
"bucket:bucket_clay_water",
|
||||||
|
"ws_clay_pot_water.png",
|
||||||
|
"Water Bucket (Clay)",
|
||||||
|
{water_bucket = 1},
|
||||||
|
true
|
||||||
|
)
|
||||||
|
|
||||||
-- River water source is 'liquid_renewable = false' to avoid horizontal spread
|
-- River water source is 'liquid_renewable = false' to avoid horizontal spread
|
||||||
-- of water sources in sloping rivers that can cause water to overflow
|
-- of water sources in sloping rivers that can cause water to overflow
|
||||||
-- riverbanks and cause floods.
|
-- riverbanks and cause floods.
|
||||||
-- River water source is instead made renewable by the 'force renew' option
|
-- River water source is instead made renewable by the 'force renew' option
|
||||||
-- used here.
|
-- used here.
|
||||||
|
|
||||||
|
bucket.register_liquid(
|
||||||
|
"ws_core:water_source_toxic",
|
||||||
|
"ws_core:water_flowing_toxic",
|
||||||
|
"bucket:bucket_water_toxic",
|
||||||
|
"ws_bucket_toxic_water.png",
|
||||||
|
"Toxic Water Bucket",
|
||||||
|
{water_bucket = 1}
|
||||||
|
)
|
||||||
|
|
||||||
bucket.register_liquid(
|
bucket.register_liquid(
|
||||||
"ws_core:water_source",
|
"ws_core:water_source",
|
||||||
"ws_core:water_flowing",
|
"ws_core:water_flowing",
|
||||||
"bucket:bucket_water",
|
"bucket:bucket_water",
|
||||||
"ws_clay_pot_water.png",
|
"ws_bucket_water.png",
|
||||||
"Water Bucket (Clay)",
|
"Water Bucket",
|
||||||
{water_bucket_wooden = 1},
|
{water_bucket = 1}
|
||||||
true
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
bucket.register_liquid(
|
||||||
|
"ws_core:oil_source",
|
||||||
|
"ws_core:oil_flowing",
|
||||||
|
"bucket:bucket_oil",
|
||||||
|
"ws_bucket_oil.png",
|
||||||
|
"Oil Bucket",
|
||||||
|
{oil_bucket = 1}
|
||||||
|
)
|
97
mods/hbhunger/README.md
Normal file
@ -0,0 +1,97 @@
|
|||||||
|
# Hunger with HUD bar [`hbhunger`]
|
||||||
|
|
||||||
|
* Version: 0.7.1
|
||||||
|
|
||||||
|
## Using the mod
|
||||||
|
|
||||||
|
This mod adds a mechanic for hunger.
|
||||||
|
This mod depends on the HUD bars mod [`hudbars`], version 1.4.1 or any later version
|
||||||
|
starting with “1.”.
|
||||||
|
|
||||||
|
## About hunger
|
||||||
|
This mod adds a hunger mechanic to the game. Players get a new attribute called “satiation”:
|
||||||
|
|
||||||
|
* A new player starts with 20 satiation points out of 30
|
||||||
|
* Actions like digging, placing and walking cause exhaustion, which lower the satiation
|
||||||
|
* Every 800 seconds you lose 1 satiation point without doing anything
|
||||||
|
* At 1 or 0 satiation you will suffer damage and die in case you don't eat something
|
||||||
|
* If your satiation is 16 or higher, you will slowly regenerate health points
|
||||||
|
* Eating food will increase your satiation (Duh!)
|
||||||
|
|
||||||
|
Important: Eating food will not directly increase your health anymore, as long as the food
|
||||||
|
item is supported by this mod (see below).
|
||||||
|
|
||||||
|
Careful! Some foods may be poisoned. If you eat a poisoned item, you may still get a satiation
|
||||||
|
boost, but for a brief period you lose health points because of food poisoning. However,
|
||||||
|
food poisoning can never kill you.
|
||||||
|
|
||||||
|
## Statbar mode
|
||||||
|
If you use the statbar mode of the HUD Bars mod, these things are important to know:
|
||||||
|
As with all mods using HUD Bars, the bread statbar symbols represent the rough percentage
|
||||||
|
out of 30 satiation points, in steps of 5%, so the symbols give you an estimate of your
|
||||||
|
satiation. This is different from the hunger mod by BlockMen.
|
||||||
|
|
||||||
|
You gain health at 5.5 symbols or more, as 5.5 symbols correspond to 16 satiation points.
|
||||||
|
You *may* lose health at exactly 0.5 symbols, as 0.5 symbols correspond to 1-2 satiation points.
|
||||||
|
|
||||||
|
## Supported food
|
||||||
|
All mods which add food through standard measures (`minetest.item_eat`) are already
|
||||||
|
supported automatically. Poisoned food needs special support.
|
||||||
|
|
||||||
|
### Known supported food mods
|
||||||
|
* Apple from Minetest Game [`default`]
|
||||||
|
* Red and brown mushroom from Minetest Game [`flowers`]
|
||||||
|
* Bread from Minetest Game [`farming`]
|
||||||
|
* [`animalmaterials`] (Mob Framework (`mobf` modpack))
|
||||||
|
* Bushes [`bushes`]
|
||||||
|
* [`bushes_classic`]
|
||||||
|
* Creatures [`creatures`]
|
||||||
|
* [`dwarves`] (beer and such)
|
||||||
|
* Docfarming [`docfarming`]
|
||||||
|
* Ethereal / Ethereal NG [`ethereal`]
|
||||||
|
* Farming Redo [`farming`] by TenPlus1
|
||||||
|
* Farming plus [`farming_plus`]
|
||||||
|
* Ferns [`ferns`]
|
||||||
|
* Fishing [`fishing`]
|
||||||
|
* [`fruit`]
|
||||||
|
* Glooptest [`glooptest`]
|
||||||
|
* JKMod ([`jkanimals`], [`jkfarming`], [`jkwine`])
|
||||||
|
* [`kpgmobs`]
|
||||||
|
* [`mobfcooking`]
|
||||||
|
* [`mooretrees`]
|
||||||
|
* [`mtfoods`]
|
||||||
|
* [`mushroom`]
|
||||||
|
* [`mush45`]
|
||||||
|
* Seaplants [`sea`]
|
||||||
|
* Simple mobs [`mobs`]
|
||||||
|
* Pizza [`pizza`]
|
||||||
|
* Not So Simple Mobs [`nssm`]
|
||||||
|
|
||||||
|
### Supported mods without optional dependency (mods provide their own support)
|
||||||
|
|
||||||
|
* Food ([`food`], [`food_basic`])
|
||||||
|
* Sweet Foods [`food_sweet`]
|
||||||
|
|
||||||
|
### Examples
|
||||||
|
|
||||||
|
* Eating an apple (from Minetest Game) increases your satiation by 2;
|
||||||
|
* eating a bread (from Minetest Game) increases your satiation by 4.
|
||||||
|
|
||||||
|
## Licensing
|
||||||
|
This mod is free software.
|
||||||
|
|
||||||
|
### Source code
|
||||||
|
|
||||||
|
* License: [LGPL v2.1](https://www.gnu.org/licenses/old-licenses/lgpl-2.1.en.html)
|
||||||
|
* Author: by Wuzzy (2015-2016)
|
||||||
|
* Forked from the “Better HUD (and hunger)” mod by BlockMen (2013-2015),
|
||||||
|
most code comes from this mod.
|
||||||
|
|
||||||
|
### Textures
|
||||||
|
|
||||||
|
* `hbhunger_icon.png`—PilzAdam ([MIT License](https://opensource.org/licenses/MIT)), modified by BlockMen
|
||||||
|
* `hbhunger_bgicon.png`—PilzAdam (MIT License), modified by BlockMen
|
||||||
|
* `hbhunger_bar.png—Wuzzy` (MIT License)
|
||||||
|
* `hbhunger_icon_health_poison.png`—celeron55 ([CC BY-SA 3.0](https://creativecommons.org/licenses/by-sa/3.0/)), modified by BlockMen, modified again by Wuzzy
|
||||||
|
* Everything else: MIT License, by BlockMen and Wuzzy
|
||||||
|
|
51
mods/hbhunger/changelog.txt
Normal file
@ -0,0 +1,51 @@
|
|||||||
|
0.1.0
|
||||||
|
-----
|
||||||
|
Initial release
|
||||||
|
|
||||||
|
0.2.0
|
||||||
|
-----
|
||||||
|
- Change “saturation” to “satiation”
|
||||||
|
- Rename global table to “hbhunger” to avoid collisions
|
||||||
|
- General cleanup
|
||||||
|
|
||||||
|
0.3.0
|
||||||
|
-----
|
||||||
|
- Play simple eating sound when something is eaten
|
||||||
|
|
||||||
|
0.3.1
|
||||||
|
-----
|
||||||
|
- Add Ethereal orange
|
||||||
|
- Fix exhaus variable
|
||||||
|
|
||||||
|
0.3.2
|
||||||
|
-----
|
||||||
|
- Fix another crash
|
||||||
|
|
||||||
|
0.4.0
|
||||||
|
-----
|
||||||
|
- Generic eating functionality, items using the minetest.item_eat are automatically supported
|
||||||
|
- Change health bar and icon when poisoned
|
||||||
|
- Special support for red and brown mushroom from Minetest Game [flowers]
|
||||||
|
- Special support for [pizza]
|
||||||
|
- Special support for beans from Farming Redo [farming]
|
||||||
|
- Fix crash when poisoned player leaves server
|
||||||
|
- Changed license to LGPL v2.1
|
||||||
|
|
||||||
|
0.4.1
|
||||||
|
-----
|
||||||
|
- Add foods from Not So Simple Mobs [nssm]
|
||||||
|
|
||||||
|
0.5.0
|
||||||
|
-----
|
||||||
|
- Fix custom sound not working
|
||||||
|
- Add Portuguese translation
|
||||||
|
|
||||||
|
0.5.1
|
||||||
|
-----
|
||||||
|
- Fix incompability problem with pipeworks mod
|
||||||
|
|
||||||
|
0.5.2
|
||||||
|
-----
|
||||||
|
- Fix mod not working with both intllib and mod security enabled
|
||||||
|
- Add missing screenshot
|
||||||
|
- Rewrite README and use Markdown format
|
32
mods/hbhunger/depends.txt
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
hudbars
|
||||||
|
intllib?
|
||||||
|
default?
|
||||||
|
flowers?
|
||||||
|
animalmaterials?
|
||||||
|
bucket?
|
||||||
|
bushes?
|
||||||
|
bushes_classic?
|
||||||
|
cooking?
|
||||||
|
creatures?
|
||||||
|
docfarming?
|
||||||
|
dwarves?
|
||||||
|
ethereal?
|
||||||
|
farming?
|
||||||
|
farming_plus?
|
||||||
|
ferns?
|
||||||
|
fishing?
|
||||||
|
fruit?
|
||||||
|
glooptest?
|
||||||
|
jkanimals?
|
||||||
|
jkfarming?
|
||||||
|
jkwine?
|
||||||
|
kpgmobs?
|
||||||
|
mobfcooking?
|
||||||
|
mobs?
|
||||||
|
moretrees?
|
||||||
|
mtfoods?
|
||||||
|
mush45?
|
||||||
|
mushroom?
|
||||||
|
seaplants?
|
||||||
|
pizza?
|
||||||
|
nssm?
|
1
mods/hbhunger/description.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
Adds a simple hunger meachanic with satiation, food poisoning and different healing.
|
481
mods/hbhunger/hunger.lua
Normal file
@ -0,0 +1,481 @@
|
|||||||
|
-- Keep these for backwards compatibility
|
||||||
|
function hbhunger.save_hunger(player)
|
||||||
|
hbhunger.set_hunger_raw(player)
|
||||||
|
end
|
||||||
|
function hbhunger.load_hunger(player)
|
||||||
|
hbhunger.get_hunger_raw(player)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- wrapper for minetest.item_eat (this way we make sure other mods can't break this one)
|
||||||
|
local org_eat = core.do_item_eat
|
||||||
|
core.do_item_eat = function(hp_change, replace_with_item, itemstack, user, pointed_thing)
|
||||||
|
local old_itemstack = itemstack
|
||||||
|
itemstack = hbhunger.eat(hp_change, replace_with_item, itemstack, user, pointed_thing)
|
||||||
|
for _, callback in pairs(core.registered_on_item_eats) do
|
||||||
|
local result = callback(hp_change, replace_with_item, itemstack, user, pointed_thing, old_itemstack)
|
||||||
|
if result then
|
||||||
|
return result
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return itemstack
|
||||||
|
end
|
||||||
|
|
||||||
|
-- food functions
|
||||||
|
local food = hbhunger.food
|
||||||
|
|
||||||
|
function hbhunger.register_food(name, hunger_change, replace_with_item, poisen, heal, sound)
|
||||||
|
food[name] = {}
|
||||||
|
food[name].saturation = hunger_change -- hunger points added
|
||||||
|
food[name].replace = replace_with_item -- what item is given back after eating
|
||||||
|
food[name].poisen = poisen -- time its poisening
|
||||||
|
food[name].healing = heal -- amount of HP
|
||||||
|
food[name].sound = sound -- special sound that is played when eating
|
||||||
|
end
|
||||||
|
|
||||||
|
function hbhunger.eat(hp_change, replace_with_item, itemstack, user, pointed_thing)
|
||||||
|
local item = itemstack:get_name()
|
||||||
|
local def = food[item]
|
||||||
|
if not def then
|
||||||
|
def = {}
|
||||||
|
if type(hp_change) ~= "number" then
|
||||||
|
hp_change = 1
|
||||||
|
core.log("error", "Wrong on_use() definition for item '" .. item .. "'")
|
||||||
|
end
|
||||||
|
def.saturation = hp_change * 1.3
|
||||||
|
def.replace = replace_with_item
|
||||||
|
end
|
||||||
|
local func = hbhunger.item_eat(def.saturation, def.replace, def.poisen, def.healing, def.sound)
|
||||||
|
return func(itemstack, user, pointed_thing)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Poison player
|
||||||
|
local function poisenp(tick, time, time_left, player)
|
||||||
|
-- First check if player is still there
|
||||||
|
if not player:is_player() then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
time_left = time_left + tick
|
||||||
|
if time_left < time then
|
||||||
|
minetest.after(tick, poisenp, tick, time, time_left, player)
|
||||||
|
else
|
||||||
|
hbhunger.poisonings[player:get_player_name()] = hbhunger.poisonings[player:get_player_name()] - 1
|
||||||
|
if hbhunger.poisonings[player:get_player_name()] <= 0 then
|
||||||
|
-- Reset HUD bar color
|
||||||
|
hb.change_hudbar(player, "health", nil, nil, "hudbars_icon_health.png", nil, "hudbars_bar_health.png")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if player:get_hp()-1 > 0 then
|
||||||
|
player:set_hp(player:get_hp()-1)
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
function hbhunger.item_eat(hunger_change, replace_with_item, poisen, heal, sound)
|
||||||
|
return function(itemstack, user, pointed_thing)
|
||||||
|
if itemstack:take_item() ~= nil and user ~= nil then
|
||||||
|
local name = user:get_player_name()
|
||||||
|
local h = tonumber(hbhunger.hunger[name])
|
||||||
|
local hp = user:get_hp()
|
||||||
|
if h == nil or hp == nil then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
minetest.sound_play({name = sound or "hbhunger_eat_generic", gain = 1}, {pos=user:getpos(), max_hear_distance = 16})
|
||||||
|
|
||||||
|
-- Saturation
|
||||||
|
if h < 30 and hunger_change then
|
||||||
|
h = h + hunger_change
|
||||||
|
if h > 30 then h = 30 end
|
||||||
|
hbhunger.hunger[name] = h
|
||||||
|
hbhunger.set_hunger_raw(user)
|
||||||
|
end
|
||||||
|
-- Healing
|
||||||
|
if hp < 20 and heal then
|
||||||
|
hp = hp + heal
|
||||||
|
if hp > 20 then hp = 20 end
|
||||||
|
user:set_hp(hp)
|
||||||
|
end
|
||||||
|
-- Poison
|
||||||
|
if poisen then
|
||||||
|
-- Set poison bar
|
||||||
|
hb.change_hudbar(user, "health", nil, nil, "hbhunger_icon_health_poison.png", nil, "hbhunger_bar_health_poison.png")
|
||||||
|
hbhunger.poisonings[name] = hbhunger.poisonings[name] + 1
|
||||||
|
poisenp(1, poisen, 0, user)
|
||||||
|
end
|
||||||
|
|
||||||
|
if itemstack:get_count() == 0 then
|
||||||
|
itemstack:add_item(replace_with_item)
|
||||||
|
else
|
||||||
|
local inv = user:get_inventory()
|
||||||
|
if inv:room_for_item("main", replace_with_item) then
|
||||||
|
inv:add_item("main", replace_with_item)
|
||||||
|
else
|
||||||
|
minetest.add_item(user:getpos(), replace_with_item)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return itemstack
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("default") ~= nil then
|
||||||
|
hbhunger.register_food("default:apple", 2)
|
||||||
|
end
|
||||||
|
if minetest.get_modpath("flowers") ~= nil then
|
||||||
|
hbhunger.register_food("flowers:mushroom_brown", 1)
|
||||||
|
hbhunger.register_food("flowers:mushroom_red", 1, "", 3)
|
||||||
|
end
|
||||||
|
if minetest.get_modpath("farming") ~= nil then
|
||||||
|
hbhunger.register_food("farming:bread", 4)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("mobs") ~= nil then
|
||||||
|
if mobs.mod ~= nil and mobs.mod == "redo" then
|
||||||
|
hbhunger.register_food("mobs:cheese", 4)
|
||||||
|
hbhunger.register_food("mobs:meat", 8)
|
||||||
|
hbhunger.register_food("mobs:meat_raw", 4)
|
||||||
|
hbhunger.register_food("mobs:rat_cooked", 4)
|
||||||
|
hbhunger.register_food("mobs:honey", 2)
|
||||||
|
hbhunger.register_food("mobs:pork_raw", 3, "", 3)
|
||||||
|
hbhunger.register_food("mobs:pork_cooked", 8)
|
||||||
|
hbhunger.register_food("mobs:chicken_cooked", 6)
|
||||||
|
hbhunger.register_food("mobs:chicken_raw", 2, "", 3)
|
||||||
|
hbhunger.register_food("mobs:chicken_egg_fried", 2)
|
||||||
|
if minetest.get_modpath("bucket") then
|
||||||
|
hbhunger.register_food("mobs:bucket_milk", 3, "bucket:bucket_empty")
|
||||||
|
end
|
||||||
|
else
|
||||||
|
hbhunger.register_food("mobs:meat", 6)
|
||||||
|
hbhunger.register_food("mobs:meat_raw", 3)
|
||||||
|
hbhunger.register_food("mobs:rat_cooked", 5)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("moretrees") ~= nil then
|
||||||
|
hbhunger.register_food("moretrees:coconut_milk", 1)
|
||||||
|
hbhunger.register_food("moretrees:raw_coconut", 2)
|
||||||
|
hbhunger.register_food("moretrees:acorn_muffin", 3)
|
||||||
|
hbhunger.register_food("moretrees:spruce_nuts", 1)
|
||||||
|
hbhunger.register_food("moretrees:pine_nuts", 1)
|
||||||
|
hbhunger.register_food("moretrees:fir_nuts", 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("dwarves") ~= nil then
|
||||||
|
hbhunger.register_food("dwarves:beer", 2)
|
||||||
|
hbhunger.register_food("dwarves:apple_cider", 1)
|
||||||
|
hbhunger.register_food("dwarves:midus", 2)
|
||||||
|
hbhunger.register_food("dwarves:tequila", 2)
|
||||||
|
hbhunger.register_food("dwarves:tequila_with_lime", 2)
|
||||||
|
hbhunger.register_food("dwarves:sake", 2)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("animalmaterials") ~= nil then
|
||||||
|
hbhunger.register_food("animalmaterials:milk", 2)
|
||||||
|
hbhunger.register_food("animalmaterials:meat_raw", 3)
|
||||||
|
hbhunger.register_food("animalmaterials:meat_pork", 3)
|
||||||
|
hbhunger.register_food("animalmaterials:meat_beef", 3)
|
||||||
|
hbhunger.register_food("animalmaterials:meat_chicken", 3)
|
||||||
|
hbhunger.register_food("animalmaterials:meat_lamb", 3)
|
||||||
|
hbhunger.register_food("animalmaterials:meat_venison", 3)
|
||||||
|
hbhunger.register_food("animalmaterials:meat_undead", 3, "", 3)
|
||||||
|
hbhunger.register_food("animalmaterials:meat_toxic", 3, "", 5)
|
||||||
|
hbhunger.register_food("animalmaterials:meat_ostrich", 3)
|
||||||
|
hbhunger.register_food("animalmaterials:fish_bluewhite", 2)
|
||||||
|
hbhunger.register_food("animalmaterials:fish_clownfish", 2)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("fishing") ~= nil then
|
||||||
|
hbhunger.register_food("fishing:fish_raw", 2)
|
||||||
|
hbhunger.register_food("fishing:fish_cooked", 5)
|
||||||
|
hbhunger.register_food("fishing:sushi", 6)
|
||||||
|
hbhunger.register_food("fishing:shark", 4)
|
||||||
|
hbhunger.register_food("fishing:shark_cooked", 8)
|
||||||
|
hbhunger.register_food("fishing:pike", 4)
|
||||||
|
hbhunger.register_food("fishing:pike_cooked", 8)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("glooptest") ~= nil then
|
||||||
|
hbhunger.register_food("glooptest:kalite_lump", 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("bushes") ~= nil then
|
||||||
|
hbhunger.register_food("bushes:sugar", 1)
|
||||||
|
hbhunger.register_food("bushes:strawberry", 2)
|
||||||
|
hbhunger.register_food("bushes:berry_pie_raw", 3)
|
||||||
|
hbhunger.register_food("bushes:berry_pie_cooked", 4)
|
||||||
|
hbhunger.register_food("bushes:basket_pies", 15)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("bushes_classic") then
|
||||||
|
-- bushes_classic mod, as found in the plantlife modpack
|
||||||
|
local berries = {
|
||||||
|
"strawberry",
|
||||||
|
"blackberry",
|
||||||
|
"blueberry",
|
||||||
|
"raspberry",
|
||||||
|
"gooseberry",
|
||||||
|
"mixed_berry"}
|
||||||
|
for _, berry in ipairs(berries) do
|
||||||
|
if berry ~= "mixed_berry" then
|
||||||
|
hbhunger.register_food("bushes:"..berry, 1)
|
||||||
|
end
|
||||||
|
hbhunger.register_food("bushes:"..berry.."_pie_raw", 2)
|
||||||
|
hbhunger.register_food("bushes:"..berry.."_pie_cooked", 5)
|
||||||
|
hbhunger.register_food("bushes:basket_"..berry, 15)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("mushroom") ~= nil then
|
||||||
|
hbhunger.register_food("mushroom:brown", 1)
|
||||||
|
hbhunger.register_food("mushroom:red", 1, "", 3)
|
||||||
|
-- mushroom potions: red = strong poison, brown = light restorative
|
||||||
|
if minetest.get_modpath("vessels") then
|
||||||
|
hbhunger.register_food("mushroom:brown_essence", 1, "vessels:glass_bottle", nil, 4)
|
||||||
|
hbhunger.register_food("mushroom:poison", 1, "vessels:glass_bottle", 10)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("docfarming") ~= nil then
|
||||||
|
hbhunger.register_food("docfarming:carrot", 3)
|
||||||
|
hbhunger.register_food("docfarming:cucumber", 2)
|
||||||
|
hbhunger.register_food("docfarming:corn", 3)
|
||||||
|
hbhunger.register_food("docfarming:potato", 4)
|
||||||
|
hbhunger.register_food("docfarming:bakedpotato", 5)
|
||||||
|
hbhunger.register_food("docfarming:raspberry", 3)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("farming_plus") ~= nil then
|
||||||
|
hbhunger.register_food("farming_plus:carrot_item", 3)
|
||||||
|
hbhunger.register_food("farming_plus:banana", 2)
|
||||||
|
hbhunger.register_food("farming_plus:orange_item", 2)
|
||||||
|
hbhunger.register_food("farming:pumpkin_bread", 4)
|
||||||
|
hbhunger.register_food("farming_plus:strawberry_item", 2)
|
||||||
|
hbhunger.register_food("farming_plus:tomato_item", 2)
|
||||||
|
hbhunger.register_food("farming_plus:potato_item", 4)
|
||||||
|
hbhunger.register_food("farming_plus:rhubarb_item", 2)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("mtfoods") ~= nil then
|
||||||
|
hbhunger.register_food("mtfoods:dandelion_milk", 1)
|
||||||
|
hbhunger.register_food("mtfoods:sugar", 1)
|
||||||
|
hbhunger.register_food("mtfoods:short_bread", 4)
|
||||||
|
hbhunger.register_food("mtfoods:cream", 1)
|
||||||
|
hbhunger.register_food("mtfoods:chocolate", 2)
|
||||||
|
hbhunger.register_food("mtfoods:cupcake", 2)
|
||||||
|
hbhunger.register_food("mtfoods:strawberry_shortcake", 2)
|
||||||
|
hbhunger.register_food("mtfoods:cake", 3)
|
||||||
|
hbhunger.register_food("mtfoods:chocolate_cake", 3)
|
||||||
|
hbhunger.register_food("mtfoods:carrot_cake", 3)
|
||||||
|
hbhunger.register_food("mtfoods:pie_crust", 3)
|
||||||
|
hbhunger.register_food("mtfoods:apple_pie", 3)
|
||||||
|
hbhunger.register_food("mtfoods:rhubarb_pie", 2)
|
||||||
|
hbhunger.register_food("mtfoods:banana_pie", 3)
|
||||||
|
hbhunger.register_food("mtfoods:pumpkin_pie", 3)
|
||||||
|
hbhunger.register_food("mtfoods:cookies", 2)
|
||||||
|
hbhunger.register_food("mtfoods:mlt_burger", 5)
|
||||||
|
hbhunger.register_food("mtfoods:potato_slices", 2)
|
||||||
|
hbhunger.register_food("mtfoods:potato_chips", 3)
|
||||||
|
--mtfoods:medicine
|
||||||
|
hbhunger.register_food("mtfoods:casserole", 3)
|
||||||
|
hbhunger.register_food("mtfoods:glass_flute", 2)
|
||||||
|
hbhunger.register_food("mtfoods:orange_juice", 2)
|
||||||
|
hbhunger.register_food("mtfoods:apple_juice", 2)
|
||||||
|
hbhunger.register_food("mtfoods:apple_cider", 2)
|
||||||
|
hbhunger.register_food("mtfoods:cider_rack", 2)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("fruit") ~= nil then
|
||||||
|
hbhunger.register_food("fruit:apple", 2)
|
||||||
|
hbhunger.register_food("fruit:pear", 2)
|
||||||
|
hbhunger.register_food("fruit:bananna", 3)
|
||||||
|
hbhunger.register_food("fruit:orange", 2)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("mush45") ~= nil then
|
||||||
|
hbhunger.register_food("mush45:meal", 4)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("seaplants") ~= nil then
|
||||||
|
hbhunger.register_food("seaplants:kelpgreen", 1)
|
||||||
|
hbhunger.register_food("seaplants:kelpbrown", 1)
|
||||||
|
hbhunger.register_food("seaplants:seagrassgreen", 1)
|
||||||
|
hbhunger.register_food("seaplants:seagrassred", 1)
|
||||||
|
hbhunger.register_food("seaplants:seasaladmix", 6)
|
||||||
|
hbhunger.register_food("seaplants:kelpgreensalad", 1)
|
||||||
|
hbhunger.register_food("seaplants:kelpbrownsalad", 1)
|
||||||
|
hbhunger.register_food("seaplants:seagrassgreensalad", 1)
|
||||||
|
hbhunger.register_food("seaplants:seagrassgreensalad", 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("mobfcooking") ~= nil then
|
||||||
|
hbhunger.register_food("mobfcooking:cooked_pork", 6)
|
||||||
|
hbhunger.register_food("mobfcooking:cooked_ostrich", 6)
|
||||||
|
hbhunger.register_food("mobfcooking:cooked_beef", 6)
|
||||||
|
hbhunger.register_food("mobfcooking:cooked_chicken", 6)
|
||||||
|
hbhunger.register_food("mobfcooking:cooked_lamb", 6)
|
||||||
|
hbhunger.register_food("mobfcooking:cooked_venison", 6)
|
||||||
|
hbhunger.register_food("mobfcooking:cooked_fish", 6)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("creatures") ~= nil then
|
||||||
|
hbhunger.register_food("creatures:meat", 6)
|
||||||
|
hbhunger.register_food("creatures:flesh", 3)
|
||||||
|
hbhunger.register_food("creatures:rotten_flesh", 3, "", 3)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("ethereal") then
|
||||||
|
hbhunger.register_food("ethereal:strawberry", 1)
|
||||||
|
hbhunger.register_food("ethereal:banana", 4)
|
||||||
|
hbhunger.register_food("ethereal:pine_nuts", 1)
|
||||||
|
hbhunger.register_food("ethereal:bamboo_sprout", 0, "", 3)
|
||||||
|
hbhunger.register_food("ethereal:fern_tubers", 1)
|
||||||
|
hbhunger.register_food("ethereal:banana_bread", 7)
|
||||||
|
hbhunger.register_food("ethereal:mushroom_plant", 2)
|
||||||
|
hbhunger.register_food("ethereal:coconut_slice", 2)
|
||||||
|
hbhunger.register_food("ethereal:golden_apple", 4, "", nil, 10)
|
||||||
|
hbhunger.register_food("ethereal:wild_onion_plant", 2)
|
||||||
|
hbhunger.register_food("ethereal:mushroom_soup", 4, "ethereal:bowl")
|
||||||
|
hbhunger.register_food("ethereal:mushroom_soup_cooked", 6, "ethereal:bowl")
|
||||||
|
hbhunger.register_food("ethereal:hearty_stew", 6, "ethereal:bowl", 3)
|
||||||
|
hbhunger.register_food("ethereal:hearty_stew_cooked", 10, "ethereal:bowl")
|
||||||
|
if minetest.get_modpath("bucket") then
|
||||||
|
hbhunger.register_food("ethereal:bucket_cactus", 2, "bucket:bucket_empty")
|
||||||
|
end
|
||||||
|
hbhunger.register_food("ethereal:fish_raw", 2)
|
||||||
|
hbhunger.register_food("ethereal:fish_cooked", 5)
|
||||||
|
hbhunger.register_food("ethereal:seaweed", 1)
|
||||||
|
hbhunger.register_food("ethereal:yellowleaves", 1, "", nil, 1)
|
||||||
|
hbhunger.register_food("ethereal:sashimi", 4)
|
||||||
|
hbhunger.register_food("ethereal:orange", 2)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("farming") and farming.mod == "redo" then
|
||||||
|
hbhunger.register_food("farming:bread", 6)
|
||||||
|
hbhunger.register_food("farming:potato", 1)
|
||||||
|
hbhunger.register_food("farming:baked_potato", 6)
|
||||||
|
hbhunger.register_food("farming:cucumber", 4)
|
||||||
|
hbhunger.register_food("farming:tomato", 4)
|
||||||
|
hbhunger.register_food("farming:carrot", 3)
|
||||||
|
hbhunger.register_food("farming:carrot_gold", 6, "", nil, 8)
|
||||||
|
hbhunger.register_food("farming:corn", 3)
|
||||||
|
hbhunger.register_food("farming:corn_cob", 5)
|
||||||
|
hbhunger.register_food("farming:melon_slice", 2)
|
||||||
|
hbhunger.register_food("farming:pumpkin_slice", 1)
|
||||||
|
hbhunger.register_food("farming:pumpkin_bread", 9)
|
||||||
|
hbhunger.register_food("farming:coffee_cup", 2, "farming:drinking_cup")
|
||||||
|
hbhunger.register_food("farming:coffee_cup_hot", 3, "farming:drinking_cup", nil, 2)
|
||||||
|
hbhunger.register_food("farming:cookie", 2)
|
||||||
|
hbhunger.register_food("farming:chocolate_dark", 3)
|
||||||
|
hbhunger.register_food("farming:donut", 4)
|
||||||
|
hbhunger.register_food("farming:donut_chocolate", 6)
|
||||||
|
hbhunger.register_food("farming:donut_apple", 6)
|
||||||
|
hbhunger.register_food("farming:raspberries", 1)
|
||||||
|
hbhunger.register_food("farming:blueberries", 1)
|
||||||
|
hbhunger.register_food("farming:muffin_blueberry", 4)
|
||||||
|
if minetest.get_modpath("vessels") then
|
||||||
|
hbhunger.register_food("farming:smoothie_raspberry", 2, "vessels:drinking_glass")
|
||||||
|
end
|
||||||
|
hbhunger.register_food("farming:rhubarb", 1)
|
||||||
|
hbhunger.register_food("farming:rhubarb_pie", 6)
|
||||||
|
hbhunger.register_food("farming:beans", 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("kpgmobs") ~= nil then
|
||||||
|
hbhunger.register_food("kpgmobs:uley", 3)
|
||||||
|
hbhunger.register_food("kpgmobs:meat", 6)
|
||||||
|
hbhunger.register_food("kpgmobs:rat_cooked", 5)
|
||||||
|
hbhunger.register_food("kpgmobs:med_cooked", 4)
|
||||||
|
if minetest.get_modpath("bucket") then
|
||||||
|
hbhunger.register_food("kpgmobs:bucket_milk", 4, "bucket:bucket_empty")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("jkfarming") ~= nil then
|
||||||
|
hbhunger.register_food("jkfarming:carrot", 3)
|
||||||
|
hbhunger.register_food("jkfarming:corn", 3)
|
||||||
|
hbhunger.register_food("jkfarming:melon_part", 2)
|
||||||
|
hbhunger.register_food("jkfarming:cake", 3)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("jkanimals") ~= nil then
|
||||||
|
hbhunger.register_food("jkanimals:meat", 6)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("jkwine") ~= nil then
|
||||||
|
hbhunger.register_food("jkwine:grapes", 2)
|
||||||
|
hbhunger.register_food("jkwine:winebottle", 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("cooking") ~= nil then
|
||||||
|
hbhunger.register_food("cooking:meat_beef_cooked", 4)
|
||||||
|
hbhunger.register_food("cooking:fish_bluewhite_cooked", 3)
|
||||||
|
hbhunger.register_food("cooking:fish_clownfish_cooked", 1)
|
||||||
|
hbhunger.register_food("cooking:meat_chicken_cooked", 2)
|
||||||
|
hbhunger.register_food("cooking:meat_cooked", 2)
|
||||||
|
hbhunger.register_food("cooking:meat_pork_cooked", 3)
|
||||||
|
hbhunger.register_food("cooking:meat_toxic_cooked", -3)
|
||||||
|
hbhunger.register_food("cooking:meat_venison_cooked", 3)
|
||||||
|
hbhunger.register_food("cooking:meat_undead_cooked", 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- ferns mod of plantlife_modpack
|
||||||
|
if minetest.get_modpath("ferns") ~= nil then
|
||||||
|
hbhunger.register_food("ferns:fiddlehead", 1, "", 1)
|
||||||
|
hbhunger.register_food("ferns:fiddlehead_roasted", 3)
|
||||||
|
hbhunger.register_food("ferns:ferntuber_roasted", 3)
|
||||||
|
hbhunger.register_food("ferns:horsetail_01", 1)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("pizza") ~= nil then
|
||||||
|
hbhunger.register_food("pizza:pizza", 30, "", nil, 30)
|
||||||
|
hbhunger.register_food("pizza:pizzaslice", 5, "", nil, 5)
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.get_modpath("nssm") then
|
||||||
|
hbhunger.register_food("nssm:werewolf_leg", 3)
|
||||||
|
hbhunger.register_food("nssm:heron_leg", 2)
|
||||||
|
hbhunger.register_food("nssm:chichibios_heron_leg", 4)
|
||||||
|
hbhunger.register_food("nssm:crocodile_tail", 3)
|
||||||
|
hbhunger.register_food("nssm:duck_legs", 1)
|
||||||
|
hbhunger.register_food("nssm:ant_leg", 1)
|
||||||
|
hbhunger.register_food("nssm:spider_leg", 1)
|
||||||
|
hbhunger.register_food("nssm:tentacle", 2)
|
||||||
|
hbhunger.register_food("nssm:worm_flesh", 2, "", 2) -- poisonous
|
||||||
|
hbhunger.register_food("nssm:amphibian_heart", 1)
|
||||||
|
hbhunger.register_food("nssm:raw_scrausics_wing", 1)
|
||||||
|
-- superfoods
|
||||||
|
hbhunger.register_food("nssm:phoenix_nuggets", 20, "", nil, 20)
|
||||||
|
hbhunger.register_food("nssm:phoenix_tear", 20, "", nil, 20)
|
||||||
|
end
|
||||||
|
|
||||||
|
-- player-action based hunger changes
|
||||||
|
function hbhunger.handle_node_actions(pos, oldnode, player, ext)
|
||||||
|
-- is_fake_player comes from the pipeworks, we are not interested in those
|
||||||
|
if not player or not player:is_player() or player.is_fake_player == true then
|
||||||
|
return
|
||||||
|
end
|
||||||
|
local name = player:get_player_name()
|
||||||
|
local exhaus = hbhunger.exhaustion[name]
|
||||||
|
if exhaus == nil then return end
|
||||||
|
local new = hbhunger.EXHAUST_PLACE
|
||||||
|
-- placenode event
|
||||||
|
if not ext then
|
||||||
|
new = hbhunger.EXHAUST_DIG
|
||||||
|
end
|
||||||
|
-- assume its send by main timer when movement detected
|
||||||
|
if not pos and not oldnode then
|
||||||
|
new = hbhunger.EXHAUST_MOVE
|
||||||
|
end
|
||||||
|
exhaus = exhaus + new
|
||||||
|
if exhaus > hbhunger.EXHAUST_LVL then
|
||||||
|
exhaus = 0
|
||||||
|
local h = tonumber(hbhunger.hunger[name])
|
||||||
|
h = h - 1
|
||||||
|
if h < 0 then h = 0 end
|
||||||
|
hbhunger.hunger[name] = h
|
||||||
|
hbhunger.set_hunger_raw(player)
|
||||||
|
end
|
||||||
|
hbhunger.exhaustion[name] = exhaus
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_on_placenode(hbhunger.handle_node_actions)
|
||||||
|
minetest.register_on_dignode(hbhunger.handle_node_actions)
|
155
mods/hbhunger/init.lua
Normal file
@ -0,0 +1,155 @@
|
|||||||
|
local S
|
||||||
|
if (minetest.get_modpath("intllib")) then
|
||||||
|
S = intllib.Getter()
|
||||||
|
else
|
||||||
|
S = function ( s ) return s end
|
||||||
|
end
|
||||||
|
|
||||||
|
if minetest.settings:get_bool("enable_damage") then
|
||||||
|
|
||||||
|
hbhunger = {}
|
||||||
|
hbhunger.food = {}
|
||||||
|
|
||||||
|
-- HUD statbar values
|
||||||
|
hbhunger.hunger = {}
|
||||||
|
hbhunger.hunger_out = {}
|
||||||
|
|
||||||
|
-- Count number of poisonings a player has at once
|
||||||
|
hbhunger.poisonings = {}
|
||||||
|
|
||||||
|
-- HUD item ids
|
||||||
|
local hunger_hud = {}
|
||||||
|
|
||||||
|
hbhunger.HUD_TICK = 0.1
|
||||||
|
|
||||||
|
--Some hunger settings
|
||||||
|
hbhunger.exhaustion = {} -- Exhaustion is experimental!
|
||||||
|
|
||||||
|
hbhunger.HUNGER_TICK = 800 -- time in seconds after that 1 hunger point is taken
|
||||||
|
hbhunger.EXHAUST_DIG = 3 -- exhaustion increased this value after digged node
|
||||||
|
hbhunger.EXHAUST_PLACE = 1 -- exhaustion increased this value after placed
|
||||||
|
hbhunger.EXHAUST_MOVE = 0.3 -- exhaustion increased this value if player movement detected
|
||||||
|
hbhunger.EXHAUST_LVL = 160 -- at what exhaustion player satiation gets lowerd
|
||||||
|
|
||||||
|
|
||||||
|
--load custom settings
|
||||||
|
local set = io.open(minetest.get_modpath("hbhunger").."/hbhunger.conf", "r")
|
||||||
|
if set then
|
||||||
|
dofile(minetest.get_modpath("hbhunger").."/hbhunger.conf")
|
||||||
|
set:close()
|
||||||
|
end
|
||||||
|
|
||||||
|
local function custom_hud(player)
|
||||||
|
hb.init_hudbar(player, "satiation", hbhunger.get_hunger_raw(player))
|
||||||
|
end
|
||||||
|
|
||||||
|
dofile(minetest.get_modpath("hbhunger").."/hunger.lua")
|
||||||
|
|
||||||
|
-- register satiation hudbar
|
||||||
|
hb.register_hudbar("satiation", 0xFFFFFF, S("Satiation"), { icon = "hbhunger_icon.png", bgicon = "hbhunger_bgicon.png", bar = "hbhunger_bar.png" }, 20, 30, false)
|
||||||
|
|
||||||
|
-- update hud elemtens if value has changed
|
||||||
|
local function update_hud(player)
|
||||||
|
local name = player:get_player_name()
|
||||||
|
--hunger
|
||||||
|
local h_out = tonumber(hbhunger.hunger_out[name])
|
||||||
|
local h = tonumber(hbhunger.hunger[name])
|
||||||
|
if h_out ~= h then
|
||||||
|
hbhunger.hunger_out[name] = h
|
||||||
|
hb.change_hudbar(player, "satiation", h)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
hbhunger.get_hunger_raw = function(player)
|
||||||
|
local inv = player:get_inventory()
|
||||||
|
if not inv then return nil end
|
||||||
|
local hgp = inv:get_stack("hunger", 1):get_count()
|
||||||
|
if hgp == 0 then
|
||||||
|
hgp = 21
|
||||||
|
inv:set_stack("hunger", 1, ItemStack({name=":", count=hgp}))
|
||||||
|
else
|
||||||
|
hgp = hgp
|
||||||
|
end
|
||||||
|
return hgp-1
|
||||||
|
end
|
||||||
|
|
||||||
|
hbhunger.set_hunger_raw = function(player)
|
||||||
|
local inv = player:get_inventory()
|
||||||
|
local name = player:get_player_name()
|
||||||
|
local value = hbhunger.hunger[name]
|
||||||
|
if not inv or not value then return nil end
|
||||||
|
if value > 30 then value = 30 end
|
||||||
|
if value < 0 then value = 0 end
|
||||||
|
|
||||||
|
inv:set_stack("hunger", 1, ItemStack({name=":", count=value+1}))
|
||||||
|
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_on_joinplayer(function(player)
|
||||||
|
local name = player:get_player_name()
|
||||||
|
local inv = player:get_inventory()
|
||||||
|
inv:set_size("hunger",1)
|
||||||
|
hbhunger.hunger[name] = hbhunger.get_hunger_raw(player)
|
||||||
|
hbhunger.hunger_out[name] = hbhunger.hunger[name]
|
||||||
|
hbhunger.exhaustion[name] = 0
|
||||||
|
hbhunger.poisonings[name] = 0
|
||||||
|
custom_hud(player)
|
||||||
|
hbhunger.set_hunger_raw(player)
|
||||||
|
end)
|
||||||
|
|
||||||
|
minetest.register_on_respawnplayer(function(player)
|
||||||
|
-- reset hunger (and save)
|
||||||
|
local name = player:get_player_name()
|
||||||
|
hbhunger.hunger[name] = 20
|
||||||
|
hbhunger.set_hunger_raw(player)
|
||||||
|
hbhunger.exhaustion[name] = 0
|
||||||
|
end)
|
||||||
|
|
||||||
|
local main_timer = 0
|
||||||
|
local timer = 0
|
||||||
|
local timer2 = 0
|
||||||
|
minetest.register_globalstep(function(dtime)
|
||||||
|
main_timer = main_timer + dtime
|
||||||
|
timer = timer + dtime
|
||||||
|
timer2 = timer2 + dtime
|
||||||
|
if main_timer > hbhunger.HUD_TICK or timer > 4 or timer2 > hbhunger.HUNGER_TICK then
|
||||||
|
if main_timer > hbhunger.HUD_TICK then main_timer = 0 end
|
||||||
|
for _,player in ipairs(minetest.get_connected_players()) do
|
||||||
|
local name = player:get_player_name()
|
||||||
|
|
||||||
|
local h = tonumber(hbhunger.hunger[name])
|
||||||
|
local hp = player:get_hp()
|
||||||
|
if timer > 4 then
|
||||||
|
-- heal player by 1 hp if not dead and satiation is > 15 (of 30)
|
||||||
|
if h > 15 and hp > 0 and player:get_breath() > 0 then
|
||||||
|
player:set_hp(hp+1)
|
||||||
|
-- or damage player by 1 hp if satiation is < 2 (of 30)
|
||||||
|
elseif h <= 1 then
|
||||||
|
if hp-1 >= 0 then player:set_hp(hp-1) end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- lower satiation by 1 point after xx seconds
|
||||||
|
if timer2 > hbhunger.HUNGER_TICK then
|
||||||
|
if h > 0 then
|
||||||
|
h = h-1
|
||||||
|
hbhunger.hunger[name] = h
|
||||||
|
hbhunger.set_hunger_raw(player)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- update all hud elements
|
||||||
|
update_hud(player)
|
||||||
|
|
||||||
|
local controls = player:get_player_control()
|
||||||
|
-- Determine if the player is walking
|
||||||
|
if controls.up or controls.down or controls.left or controls.right then
|
||||||
|
hbhunger.handle_node_actions(nil, nil, player)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if timer > 4 then timer = 0 end
|
||||||
|
if timer2 > hbhunger.HUNGER_TICK then timer2 = 0 end
|
||||||
|
end)
|
||||||
|
|
||||||
|
end
|
1
mods/hbhunger/locale/de.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
Satiation = Sättigung
|
1
mods/hbhunger/locale/it.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
Satiation = Sazietà
|
1
mods/hbhunger/locale/ms.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
Satiation = Kekenyangan
|
1
mods/hbhunger/locale/pt.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
Satiation = Saciedade
|
1
mods/hbhunger/locale/template.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
Satiation
|
1
mods/hbhunger/mod.conf
Normal file
@ -0,0 +1 @@
|
|||||||
|
name = hbhunger
|
BIN
mods/hbhunger/screenshot.png
Normal file
After Width: | Height: | Size: 8.3 KiB |
BIN
mods/hbhunger/sounds/hbhunger_eat_generic.ogg
Normal file
BIN
mods/hbhunger/textures/hbhunger_bar.png
Normal file
After Width: | Height: | Size: 80 B |
BIN
mods/hbhunger/textures/hbhunger_bar_health_poison.png
Normal file
After Width: | Height: | Size: 151 B |
BIN
mods/hbhunger/textures/hbhunger_bgicon.png
Normal file
After Width: | Height: | Size: 220 B |
BIN
mods/hbhunger/textures/hbhunger_icon.png
Normal file
After Width: | Height: | Size: 377 B |
BIN
mods/hbhunger/textures/hbhunger_icon_health_poison.png
Normal file
After Width: | Height: | Size: 332 B |
196
mods/hudbars/API.md
Normal file
@ -0,0 +1,196 @@
|
|||||||
|
API documentation for the HUD bars mod
|
||||||
|
======================================
|
||||||
|
|
||||||
|
## Introduction
|
||||||
|
This API allows you to add, change, hide and unhide custom HUD bars for this mod.
|
||||||
|
|
||||||
|
## Overview
|
||||||
|
To give you a *very* brief overview over this API, here is the basic workflow on how to add your own custom HUD bar:
|
||||||
|
|
||||||
|
* Create images for your HUD bar
|
||||||
|
* Call `hb.register_hudbar` to make the definition of the HUD bar known to this mod
|
||||||
|
* Call `hb.init_hudbar` for each player for which you want to use previously defined HUD bar
|
||||||
|
* Use `hb.change_hudbar` whenever you need to change the values of a HUD bar of a certain player
|
||||||
|
* If you need it: Use `hb.hide_hudbar` and `hb.unhide_hudbar` to hide or unhide HUD bars of a certain player
|
||||||
|
|
||||||
|
## The basic rules
|
||||||
|
In order to use this API, you should be aware of a few basic rules in order to understand it:
|
||||||
|
|
||||||
|
* A HUD bar is an approximate graphical representation of the ratio of a current value and a maximum value, i.e. current health of 15 and maximum health of 20. A full HUD bar represents 100%, an empty HUD bar represents 0%.
|
||||||
|
* The current value must always be equal to or smaller then the maximum
|
||||||
|
* Both current value and maximum must not be smaller than 0
|
||||||
|
* Both current value and maximum must be real numbers. So no NaN, infinity, etc.
|
||||||
|
* The HUD bar will be hidden if the maximum equals 0. This is intentional.
|
||||||
|
* The health and breath HUD bars are hardcoded.
|
||||||
|
|
||||||
|
These are soft rules, the HUD bars mod will not enforce all of these.
|
||||||
|
But this mod has been programmed under the assumption that these rules are followed, for integrity.
|
||||||
|
|
||||||
|
## Adding a HUD bar
|
||||||
|
To make a new HUD bar known to this mod, you need …
|
||||||
|
|
||||||
|
* … an image of size 2×16 for the bar
|
||||||
|
* … an icon of size 16×16 (optional)
|
||||||
|
* … to register it with `hb.register_hudbar`
|
||||||
|
|
||||||
|
### Bar image
|
||||||
|
The image for the bar will be repeated horizontally to denote the “value” of the HUD bar.
|
||||||
|
It **must** be of size 2×16.
|
||||||
|
If neccessary, the image will be split vertically in half, and only the left half of the image
|
||||||
|
is displayed. So the final HUD bar will always be displayed on a per-pixel basis.
|
||||||
|
|
||||||
|
The default bar images are single-colored, but you can use other styles as well, for instance,
|
||||||
|
a vertical gradient.
|
||||||
|
|
||||||
|
### Icon
|
||||||
|
A 16×16 image shown left of the HUD bar. This is optional.
|
||||||
|
|
||||||
|
### `hb.register_hudbar(identifier, text_color, label, textures, default_start_value, default_start_max, default_start_hidden, format_string)`
|
||||||
|
This function registers a new custom HUD bar definition to the HUD bars mod, so it can be later used to be displayed, changed, hidden
|
||||||
|
and unhidden on a per-player basis.
|
||||||
|
Note this does not yet display the HUD bar.
|
||||||
|
|
||||||
|
The HUD bars will be displayed in a “first come, first serve” order. This API does not allow fow a custom order or a way to set it
|
||||||
|
manually in a reliable way. However, you can use the setting `hudbars_sorting` for this. See the advanced setting menu in Minetest
|
||||||
|
for more information.
|
||||||
|
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
* `identifier`: A globally unique internal name for the HUD bar, will be used later to refer to it. Please only rely on alphanumeric characters for now. The identifiers “`health`” and “`breath`” are used internally for the built-in health and breath bar, respectively. Please do not use these names.
|
||||||
|
* `text_color`: A 3-octet number defining the color of the text. The octets denote, in this order red, green and blue and range from `0x00` (complete lack of this component) to `0xFF` (full intensity of this component). Example: `0xFFFFFF` for white.
|
||||||
|
* `label`: A string which is displayed on the HUD bar itself to describe the HUD bar. Try to keep this string short.
|
||||||
|
* `textures`: A table with the following fields:
|
||||||
|
* `bar`: The file name of the bar image (as string). This is only used for the `progress_bar` bar type (see `README.txt`, settings section).
|
||||||
|
* `icon`: The file name of the icon, as string. For the `progress_bar` type, it is shown as single image left of the bar, for the two statbar bar types, it is used as the statbar icon and will be repeated. This field can be `nil`, in which case no icon will be used, but this is not recommended, because the HUD bar will be invisible if the one of the statbar bar types is used.
|
||||||
|
* `bgicon`: The file name of the background icon, it is used as the background for the modern statbar mode only. This field can be `nil`, in which case no background icon will be displayed in this mode.
|
||||||
|
* `default_start_value`: If this HUD bar is added to a player, and no initial value is specified, this value will be used as initial current value
|
||||||
|
* `default_max_value`: If this HUD bar is added to a player, and no initial maximum value is specified, this value will be used as initial maximum value
|
||||||
|
* `default_start_hidden`: The HUD bar will be initially start hidden by default when added to a player. Use `hb.unhide_hudbar` to unhide it.
|
||||||
|
* `format_string`: This is optional; You can specify an alternative format string display the final text on the HUD bar. The default format string is “`%s: %d/%d`” (in this order: Label, current value, maximum value). See also the Lua documentation of `string.format`.
|
||||||
|
|
||||||
|
#### Return value
|
||||||
|
Always `nil`.
|
||||||
|
|
||||||
|
|
||||||
|
## Displaying a HUD bar
|
||||||
|
After a HUD bar has been registered, they are not yet displayed yet for any player. HUD bars must be
|
||||||
|
explicitly initialized on a per-player basis.
|
||||||
|
|
||||||
|
You probably want to do this in the `minetest.register_on_joinplayer`.
|
||||||
|
|
||||||
|
### `hb.init_hudbar(player, identifier, start_value, start_max, start_hidden)`
|
||||||
|
This function initialzes and activates a previously registered HUD bar and assigns it to a
|
||||||
|
certain client/player. This has only to be done once per player and after that, you can change
|
||||||
|
the values using `hb.change_hudbar`.
|
||||||
|
|
||||||
|
However, if `start_hidden` was set to `true` for the HUD bar (in `hb.register_hudbar`), the HUD bar
|
||||||
|
will initially be hidden, but the HUD elements are still sent to the client. Otherwise,
|
||||||
|
the HUD bar will be initially be shown to the player.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
* `player`: `ObjectRef` of the player to which the new HUD bar should be displayed to.
|
||||||
|
* `identifier`: The identifier of the HUD bar type, as specified in `hb.register_hudbar`.
|
||||||
|
* `start_value`: The initial current value of the HUD bar. This is optional, `default_start_value` of the registration function will be used, if this is `nil`.
|
||||||
|
* `start_max`: The initial maximum value of the HUD bar. This is optional, `default_start_max` of the registration function will be used, if this is `nil`
|
||||||
|
* `start_hidden`: Whether the HUD bar is initially hidden. This is optional, `default_start_hidden` of the registration function will be used as default
|
||||||
|
|
||||||
|
#### Return value
|
||||||
|
`true` on success, `false` otherwise.
|
||||||
|
|
||||||
|
|
||||||
|
## Modifying a HUD bar
|
||||||
|
After a HUD bar has been added, you can change the current and maximum value and other attributes on a per-player basis.
|
||||||
|
You use the function `hb.change_hudbar` for this.
|
||||||
|
|
||||||
|
### `hb.change_hudbar(player, identifier, new_value, new_max_value, new_icon, new_bgicon, new_bar, new_label, new_text_color)`
|
||||||
|
Changes the values and the appearance of an initialized HUD bar for a certain player. `new_value`
|
||||||
|
and `new_max_value` are the most important parameters as they specify the new current and maximum new values, you do not need
|
||||||
|
to worry too much about the other parameters.
|
||||||
|
|
||||||
|
The following parameters are less important and provided for styling the HUD bar after registration (if
|
||||||
|
this is desired). The “styling” parameters parallel the parameters of `hb.register_hudbar`. It is
|
||||||
|
recommended to not change the style of a HUD bar too often as this can be distracting or confusing
|
||||||
|
for players.
|
||||||
|
|
||||||
|
`new_value`, `new_max_value` `new_icon`, `new_bgicon`, `new_bar`, `new_label` and `new_text_color` can be
|
||||||
|
`nil`; if one of them is `nil`, that means the value is unchanged. If all those values are `nil`, this
|
||||||
|
function is a no-op.
|
||||||
|
|
||||||
|
This function tries to minimize the amount of calls to `hud_change` of the Minetest Lua API
|
||||||
|
(and thus, network traffic), when you only change the value and/or maximum value. In this case,
|
||||||
|
`hud_change` is only called if it is actually needed, e.g. when the actual length of the bar
|
||||||
|
or the displayed string changed, so you do not have to worry about it. There is, however, no
|
||||||
|
such network optimization for the “styling” parameters, so keep this in mind.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
* `player`: `ObjectRef` of the player to which the HUD bar belongs to
|
||||||
|
* `identifier`: The identifier of the HUD bar type to change, as specified in `hb.register_hudbar`.
|
||||||
|
* `new_value`: The new current value of the HUD bar
|
||||||
|
* `new_max_value`: The new maximum value of the HUD bar
|
||||||
|
* `new_icon`: File name of the new icon
|
||||||
|
* `new_bgicon`: File name of the new background icon for the modern-style statbar
|
||||||
|
* `new_bar`: File name of the new bar segment image
|
||||||
|
* `new_label`: A new text label of the HUD bar. Note the format string still applies
|
||||||
|
* `new_text_color`: A 3-octet number defining the new color of the text.
|
||||||
|
|
||||||
|
#### Return value
|
||||||
|
`true` on success, `false` otherwise.
|
||||||
|
|
||||||
|
|
||||||
|
## Hiding and unhiding a HUD bar
|
||||||
|
You can also hide custom HUD bars, meaning they will not be displayed for a certain player. You can still
|
||||||
|
use `hb.change_hudbar` on a hidden HUD bar, the new values will be correctly displayed after the HUD bar
|
||||||
|
has been unhidden. Both functions will only call `hud_change` if there has been an actual change to avoid
|
||||||
|
unneccessary traffic.
|
||||||
|
|
||||||
|
Note that the hidden state of a HUD bar will *not* be saved by this mod on server shutdown, so you may need
|
||||||
|
to write your own routines for this or by setting the correct value for `start_hidden` when calling
|
||||||
|
`hb.init_hudbar`.
|
||||||
|
|
||||||
|
### `hb.hide_hudbar(player, identifier)`
|
||||||
|
Hides the specified HUD bar from the screen of the specified player.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
* `player`: `ObjectRef` of the player to which the HUD bar belongs to
|
||||||
|
* `identifier`: The identifier of the HUD bar type to hide, as specified in `hb.register_hudbar`.
|
||||||
|
|
||||||
|
#### Return value
|
||||||
|
`true` on success, `false` otherwise.
|
||||||
|
|
||||||
|
|
||||||
|
### `hb.unhide_hudbar(player, identifier)`
|
||||||
|
Makes a previously hidden HUD bar visible again to a player.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
* `player`: `ObjectRef` of the player to which the HUD bar belongs to
|
||||||
|
* `identifier`: The identifier of the HUD bar type to unhide, as specified in `hb.register_hudbar`.
|
||||||
|
|
||||||
|
#### Return value
|
||||||
|
`true` on success, `false` otherwise.
|
||||||
|
|
||||||
|
|
||||||
|
## Reading HUD bar information
|
||||||
|
It is also possible to read information about existing HUD bars.
|
||||||
|
|
||||||
|
### `hb.get_hudbar_state(player, identifier)`
|
||||||
|
Returns the current state of the active player's HUD bar.
|
||||||
|
|
||||||
|
#### Parameters
|
||||||
|
* `player`: `ObjectRef` of the player to which the HUD bar belongs to
|
||||||
|
* `identifier`: The identifier of the HUD bar type to hide, as specified in `hb.register_hudbar`.
|
||||||
|
|
||||||
|
#### Return value
|
||||||
|
On success, returns a table which holds information on the current state of the HUD bar. Note
|
||||||
|
the table is a deep copy of the internal HUD bar state, it is *not* a reference; the information
|
||||||
|
hold by the table is only true for the moment you called this function. The fields of this table are:
|
||||||
|
|
||||||
|
* `value`: Current value of HUD bar.
|
||||||
|
* `max`: Current maximum value of HUD bar.
|
||||||
|
* `hidden`: Boolean denoting whether the HUD bar is hidden.
|
||||||
|
* `barlength`: The length of the HUD bar in pixels. This field is meaningless if the HUD bar is currently hidden.
|
||||||
|
* `text`: The text shown on the HUD bar. This fiels is meaningless if the HUD bar is currently hidden.
|
||||||
|
|
||||||
|
If the player does not exist, returns `nil` instead.
|
||||||
|
|
||||||
|
### `hb.get_hudbar_identifiers()`
|
||||||
|
Returns a table of all currently registered HUD bar identifiers.
|
59
mods/hudbars/README.md
Normal file
@ -0,0 +1,59 @@
|
|||||||
|
# HUD bars
|
||||||
|
|
||||||
|
## Description
|
||||||
|
This mod changes the HUD of Minetest. It replaces the default health and breath
|
||||||
|
symbols by horizontal colored bars with text showing the number.
|
||||||
|
|
||||||
|
Furthermore, it enables other mods to add their own custom bars to the HUD,
|
||||||
|
this mod will place them accordingly.
|
||||||
|
|
||||||
|
**Important**: Keep in mind if running a server with this mod, that the custom
|
||||||
|
position should be displayed correctly on every screen size.
|
||||||
|
|
||||||
|
## Current version
|
||||||
|
The current version is 1.11.0.
|
||||||
|
|
||||||
|
This software uses [semantic versioning](http://semver.org), as defined by version 2.0.0 of the SemVer
|
||||||
|
standard.
|
||||||
|
|
||||||
|
## Settings
|
||||||
|
This mod can be configured quite a bit. You can change HUD bar appearance, offsets, ordering, and more.
|
||||||
|
Use the advanced settings menu in Minetest for detailed configuration.
|
||||||
|
|
||||||
|
## API
|
||||||
|
The API is used to add your own custom HUD bars.
|
||||||
|
Documentation for the API of this mod can be found in `API.md`.
|
||||||
|
|
||||||
|
## Legal
|
||||||
|
### License of source code
|
||||||
|
Author: Wuzzy (2015)
|
||||||
|
|
||||||
|
Also: This mod was forked from the “Better HUD” [hud] mod by BlockMen.
|
||||||
|
|
||||||
|
Translations:
|
||||||
|
|
||||||
|
* German: Wuzzy
|
||||||
|
* Portuguese: BrunoMine
|
||||||
|
* Turkish: admicos
|
||||||
|
* Dutch: kingoscargames
|
||||||
|
* Italian: Hamlet
|
||||||
|
* Malay: muhdnurhidayat
|
||||||
|
|
||||||
|
This program is free software. It comes without any warranty, to
|
||||||
|
the extent permitted by applicable law. You can redistribute it
|
||||||
|
and/or modify it under the terms of the MIT License.
|
||||||
|
|
||||||
|
### Licenses of textures
|
||||||
|
|
||||||
|
* `hudbars_icon_health.png`—celeron55 (CC BY-SA 3.0), modified by BlockMen
|
||||||
|
* `hudbars_bgicon_health.png`—celeron55 (CC BY-SA 3.0), modified by BlockMen
|
||||||
|
* `hudbars_icon_breath.png`—kaeza (MIT License), modified by BlockMen, modified again by Wuzzy
|
||||||
|
* `hudbars_bgicon_breath.png`—based on previous image, edited by Wuzzy (MIT License)
|
||||||
|
* `hudbars_bar_health.png`—Wuzzy (MIT License)
|
||||||
|
* `hudbars_bar_breath.png`—Wuzzy (MIT License)
|
||||||
|
* `hudbars_bar_background.png`—Wuzzy (MIT License)
|
||||||
|
|
||||||
|
### License references
|
||||||
|
|
||||||
|
* [CC-BY-SA 3.0](https://creativecommons.org/licenses/by-sa/3.0/)
|
||||||
|
* [MIT License](https://opensource.org/licenses/MIT)
|
92
mods/hudbars/changelog.txt
Normal file
@ -0,0 +1,92 @@
|
|||||||
|
Note: This software uses semantic versioning,
|
||||||
|
as of version 2.0.0 of the standard <http://semver.org/>.
|
||||||
|
|
||||||
|
0.1.0
|
||||||
|
-----
|
||||||
|
- Initial release, forked from mod “Better HUD” [hud].
|
||||||
|
|
||||||
|
0.2.0
|
||||||
|
-----
|
||||||
|
- Add API documentation
|
||||||
|
|
||||||
|
0.3.0
|
||||||
|
-----
|
||||||
|
- Rename main table from “hud” to “hb” (affects function names!)
|
||||||
|
- Arguments 3-4 of hb.change_hudbar can be nil for values which should not change
|
||||||
|
- Add proper function hb.init_hudbar, replaces odd call to hud.hudtables[identifier].add_all
|
||||||
|
- Update API documentation and fix mistakes
|
||||||
|
- Use “hudbars.conf” instead of “hud.conf”
|
||||||
|
|
||||||
|
0.4.0
|
||||||
|
-----
|
||||||
|
- New function: hb.get_hudbar_state to get information about the state of an active HUD bar, such as values, whether it is hidden, etc.
|
||||||
|
- hb.change_hudbar has been optimized to call hud_change fewer times, which is hopefully good for networking
|
||||||
|
- Rename hb.register_hudbar parameter “start_hide” to “start_hidden”
|
||||||
|
- start_hidden parameter now finally works
|
||||||
|
- Do not affect other HUD flags (crosshair, wielditem, etc.) when starting mod
|
||||||
|
- Show error message when trying to call hb.init_hudbar or hb.change_hudbar with bad values
|
||||||
|
- Update documentation
|
||||||
|
- Lots of refactoring
|
||||||
|
- Health and breath bar now use API
|
||||||
|
|
||||||
|
1.0.0
|
||||||
|
-----
|
||||||
|
- Add new parameter start_hidden to hb.init_hudbar, specified whether HUD bar is hidden on start
|
||||||
|
- Copy-editing of API.md and README.txt
|
||||||
|
- Internal: Fix add_all weirdness
|
||||||
|
|
||||||
|
1.0.1
|
||||||
|
-----
|
||||||
|
- Fix race condition causing crash at start of server
|
||||||
|
|
||||||
|
1.0.2
|
||||||
|
-----
|
||||||
|
- Fix other HUD elements disappearing for rejoining players
|
||||||
|
- Remove pointless delays for initializing the HUD for new or rejoining players
|
||||||
|
|
||||||
|
1.0.3
|
||||||
|
-----
|
||||||
|
- Adjust default HUD bars position for Minetest 0.4.12
|
||||||
|
|
||||||
|
1.1.0
|
||||||
|
-----
|
||||||
|
- Add boolean minetest.conf setting support (hudbars_autohide_breathbar) to control whether the breath bar is automatically hidden when full (default: yes)
|
||||||
|
|
||||||
|
1.2.0
|
||||||
|
-----
|
||||||
|
- New setting: hudbars_sorting. You can now manually sort all the HUD bars. Useful if you don't like automatic order
|
||||||
|
- New setting: hudbars_bar_type. You now can change the appearance of the HUD bars.
|
||||||
|
- New HUD bar types, slightly experimental: Classic statbars and modern [hud]-style statbars
|
||||||
|
- New experimental/unfinished setting: hudbars_alignment_pattern: You can now make the HUD bars stack vertically instead of the current zig-zag pattern. Note you probably need to change source code to productively use this feature
|
||||||
|
- Various position-related HUD bar settings (see README.txt)
|
||||||
|
- Remove hudbars.conf support and hudbars.conf.example (was never officially supported anyways)
|
||||||
|
|
||||||
|
1.2.1
|
||||||
|
-----
|
||||||
|
- Fix crash when enable_damage is changed in mid-game
|
||||||
|
|
||||||
|
1.3.0
|
||||||
|
-----
|
||||||
|
- Make all settings avaialbe in Minetest's advanced settings menu
|
||||||
|
- Fix HUD bars overlap when both hudbars_tick and hudbars_vmargin were set
|
||||||
|
- Use Markdown syntax in readme file
|
||||||
|
- Fix some factual mistakes in readme file
|
||||||
|
- Add metadata: mod.conf, description.txt, screenshot.png
|
||||||
|
|
||||||
|
1.4.0
|
||||||
|
-----
|
||||||
|
- Allow to change HUD bar images and label after it has been registered
|
||||||
|
- Minor API.md correction
|
||||||
|
|
||||||
|
1.4.1
|
||||||
|
-----
|
||||||
|
- Fix bug in hb.change_hudbar being a no-op if new_value and new_max value are nil
|
||||||
|
|
||||||
|
1.5.0
|
||||||
|
-----
|
||||||
|
- Portuguese translation by BrunoMine
|
||||||
|
|
||||||
|
1.5.1
|
||||||
|
-----
|
||||||
|
- Fix critical bug: Mod does not work with both intllib and mod security enabled
|
||||||
|
- Update screenshot to use new 3:2 aspect ratio
|
48
mods/hudbars/default_settings.lua
Normal file
@ -0,0 +1,48 @@
|
|||||||
|
-- (Hardcoded) default settings
|
||||||
|
|
||||||
|
hb.settings.max_bar_length = 160
|
||||||
|
hb.settings.statbar_length = 20
|
||||||
|
|
||||||
|
-- Statbar positions
|
||||||
|
hb.settings.pos_left = {}
|
||||||
|
hb.settings.pos_right = {}
|
||||||
|
hb.settings.start_offset_left = {}
|
||||||
|
hb.settings.start_offset_right= {}
|
||||||
|
hb.settings.pos_left.x = hb.load_setting("hudbars_pos_left_x", "number", 0.5)
|
||||||
|
hb.settings.pos_left.y = hb.load_setting("hudbars_pos_left_y", "number", 1)
|
||||||
|
hb.settings.pos_right.x = hb.load_setting("hudbars_pos_right_x", "number", 0.5)
|
||||||
|
hb.settings.pos_right.y = hb.load_setting("hudbars_pos_right_y", "number", 1)
|
||||||
|
hb.settings.bar_type = hb.load_setting("hudbars_bar_type", "string", "statbar_classic", {"progress_bar", "statbar_classic", "statbar_modern"})
|
||||||
|
if hb.settings.bar_type == "progress_bar" then
|
||||||
|
hb.settings.start_offset_left.x = hb.load_setting("hudbars_start_offset_left_x", "number", -175)
|
||||||
|
hb.settings.start_offset_left.y = hb.load_setting("hudbars_start_offset_left_y", "number", -86)
|
||||||
|
hb.settings.start_offset_right.x = hb.load_setting("hudbars_start_offset_right_x", "number", 15)
|
||||||
|
hb.settings.start_offset_right.y = hb.load_setting("hudbars_start_offset_right_y", "number", -86)
|
||||||
|
else
|
||||||
|
hb.settings.start_offset_left.x = hb.load_setting("hudbars_start_statbar_offset_left_x", "number", -265)
|
||||||
|
hb.settings.start_offset_left.y = hb.load_setting("hudbars_start_statbar_offset_left_y", "number", -90)
|
||||||
|
hb.settings.start_offset_right.x = hb.load_setting("hudbars_start_statbar_offset_right_x", "number", 25)
|
||||||
|
hb.settings.start_offset_right.y = hb.load_setting("hudbars_start_statbar_offset_right_y", "number", -90)
|
||||||
|
end
|
||||||
|
hb.settings.vmargin = hb.load_setting("hudbars_vmargin", "number", 24)
|
||||||
|
hb.settings.tick = hb.load_setting("hudbars_tick", "number", 0.1)
|
||||||
|
|
||||||
|
-- Experimental setting: Changing this setting is not officially supported, do NOT rely on it!
|
||||||
|
hb.settings.forceload_default_hudbars = hb.load_setting("hudbars_forceload_default_hudbars", "bool", true)
|
||||||
|
|
||||||
|
-- Misc. settings
|
||||||
|
hb.settings.alignment_pattern = hb.load_setting("hudbars_alignment_pattern", "string", "zigzag", {"zigzag", "stack_up", "stack_down"})
|
||||||
|
hb.settings.autohide_breath = hb.load_setting("hudbars_autohide_breath", "bool", true)
|
||||||
|
|
||||||
|
local sorting = minetest.settings:get("hudbars_sorting")
|
||||||
|
if sorting ~= nil then
|
||||||
|
hb.settings.sorting = {}
|
||||||
|
hb.settings.sorting_reverse = {}
|
||||||
|
for k,v in string.gmatch(sorting, "(%w+)=(%w+)") do
|
||||||
|
hb.settings.sorting[k] = tonumber(v)
|
||||||
|
hb.settings.sorting_reverse[tonumber(v)] = k
|
||||||
|
end
|
||||||
|
else
|
||||||
|
hb.settings.sorting = { ["health"] = 0, ["breath"] = 1 }
|
||||||
|
hb.settings.sorting_reverse = { [0] = "health", [1] = "breath" }
|
||||||
|
end
|
1
mods/hudbars/depends.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
intllib?
|
1
mods/hudbars/description.txt
Normal file
@ -0,0 +1 @@
|
|||||||
|
Replaces the health and breath symbols in the HUD by “progress bars” and shows exact values. Other mods can add more progress bars for custom player stats.
|
528
mods/hudbars/init.lua
Normal file
@ -0,0 +1,528 @@
|
|||||||
|
local S
|
||||||
|
if minetest.global_exists("intllib") then
|
||||||
|
if intllib.make_gettext_pair then
|
||||||
|
S = intllib.make_gettext_pair()
|
||||||
|
else
|
||||||
|
S = intllib.Getter()
|
||||||
|
end
|
||||||
|
else
|
||||||
|
S = function ( s ) return s end
|
||||||
|
end
|
||||||
|
|
||||||
|
hb = {}
|
||||||
|
|
||||||
|
hb.hudtables = {}
|
||||||
|
|
||||||
|
-- number of registered HUD bars
|
||||||
|
hb.hudbars_count = 0
|
||||||
|
|
||||||
|
-- table which records which HUD bar slots have been “registered” so far; used for automatic positioning
|
||||||
|
hb.registered_slots = {}
|
||||||
|
|
||||||
|
hb.settings = {}
|
||||||
|
|
||||||
|
function hb.load_setting(sname, stype, defaultval, valid_values)
|
||||||
|
local sval
|
||||||
|
if stype == "string" then
|
||||||
|
sval = minetest.settings:get(sname)
|
||||||
|
elseif stype == "bool" then
|
||||||
|
sval = minetest.settings:get_bool(sname)
|
||||||
|
elseif stype == "number" then
|
||||||
|
sval = tonumber(minetest.settings:get(sname))
|
||||||
|
end
|
||||||
|
if sval ~= nil then
|
||||||
|
if valid_values ~= nil then
|
||||||
|
local valid = false
|
||||||
|
for i=1,#valid_values do
|
||||||
|
if sval == valid_values[i] then
|
||||||
|
valid = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if not valid then
|
||||||
|
minetest.log("error", "[hudbars] Invalid value for "..sname.."! Using default value ("..tostring(defaultval)..").")
|
||||||
|
return defaultval
|
||||||
|
else
|
||||||
|
return sval
|
||||||
|
end
|
||||||
|
else
|
||||||
|
return sval
|
||||||
|
end
|
||||||
|
else
|
||||||
|
return defaultval
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Load default settings
|
||||||
|
dofile(minetest.get_modpath("hudbars").."/default_settings.lua")
|
||||||
|
|
||||||
|
local function player_exists(player)
|
||||||
|
return player ~= nil and player:is_player()
|
||||||
|
end
|
||||||
|
|
||||||
|
-- Table which contains all players with active default HUD bars (only for internal use)
|
||||||
|
hb.players = {}
|
||||||
|
|
||||||
|
function hb.value_to_barlength(value, max)
|
||||||
|
if max == 0 then
|
||||||
|
return 0
|
||||||
|
else
|
||||||
|
if hb.settings.bar_type == "progress_bar" then
|
||||||
|
local x
|
||||||
|
if value < 0 then x=-0.5 else x = 0.5 end
|
||||||
|
local ret = math.modf((value/max) * hb.settings.max_bar_length + x)
|
||||||
|
return ret
|
||||||
|
else
|
||||||
|
local x
|
||||||
|
if value < 0 then x=-0.5 else x = 0.5 end
|
||||||
|
local ret = math.modf((value/max) * hb.settings.statbar_length + x)
|
||||||
|
return ret
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function hb.get_hudtable(identifier)
|
||||||
|
return hb.hudtables[identifier]
|
||||||
|
end
|
||||||
|
|
||||||
|
function hb.get_hudbar_position_index(identifier)
|
||||||
|
if hb.settings.sorting[identifier] ~= nil then
|
||||||
|
return hb.settings.sorting[identifier]
|
||||||
|
else
|
||||||
|
local i = 0
|
||||||
|
while true do
|
||||||
|
if hb.registered_slots[i] ~= true and hb.settings.sorting_reverse[i] == nil then
|
||||||
|
return i
|
||||||
|
end
|
||||||
|
i = i + 1
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
function hb.register_hudbar(identifier, text_color, label, textures, default_start_value, default_start_max, default_start_hidden, format_string)
|
||||||
|
minetest.log("action", "hb.register_hudbar: "..tostring(identifier))
|
||||||
|
local hudtable = {}
|
||||||
|
local pos, offset
|
||||||
|
local index = math.floor(hb.get_hudbar_position_index(identifier))
|
||||||
|
hb.registered_slots[index] = true
|
||||||
|
if hb.settings.alignment_pattern == "stack_up" then
|
||||||
|
pos = hb.settings.pos_left
|
||||||
|
offset = {
|
||||||
|
x = hb.settings.start_offset_left.x,
|
||||||
|
y = hb.settings.start_offset_left.y - hb.settings.vmargin * index
|
||||||
|
}
|
||||||
|
elseif hb.settings.alignment_pattern == "stack_down" then
|
||||||
|
pos = hb.settings.pos_left
|
||||||
|
offset = {
|
||||||
|
x = hb.settings.start_offset_left.x,
|
||||||
|
y = hb.settings.start_offset_left.y + hb.settings.vmargin * index
|
||||||
|
}
|
||||||
|
else
|
||||||
|
if index % 2 == 0 then
|
||||||
|
pos = hb.settings.pos_left
|
||||||
|
offset = {
|
||||||
|
x = hb.settings.start_offset_left.x,
|
||||||
|
y = hb.settings.start_offset_left.y - hb.settings.vmargin * (index/2)
|
||||||
|
}
|
||||||
|
else
|
||||||
|
pos = hb.settings.pos_right
|
||||||
|
offset = {
|
||||||
|
x = hb.settings.start_offset_right.x,
|
||||||
|
y = hb.settings.start_offset_right.y - hb.settings.vmargin * ((index-1)/2)
|
||||||
|
}
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if format_string == nil then
|
||||||
|
format_string = S("%s: %d/%d")
|
||||||
|
end
|
||||||
|
|
||||||
|
hudtable.add_all = function(player, hudtable, start_value, start_max, start_hidden)
|
||||||
|
if start_value == nil then start_value = hudtable.default_start_value end
|
||||||
|
if start_max == nil then start_max = hudtable.default_start_max end
|
||||||
|
if start_hidden == nil then start_hidden = hudtable.default_start_hidden end
|
||||||
|
local ids = {}
|
||||||
|
local state = {}
|
||||||
|
local name = player:get_player_name()
|
||||||
|
local bgscale, iconscale, text, barnumber, bgiconnumber
|
||||||
|
if start_max == 0 or start_hidden then
|
||||||
|
bgscale = { x=0, y=0 }
|
||||||
|
else
|
||||||
|
bgscale = { x=1, y=1 }
|
||||||
|
end
|
||||||
|
if start_hidden then
|
||||||
|
iconscale = { x=0, y=0 }
|
||||||
|
barnumber = 0
|
||||||
|
bgiconnumber = 0
|
||||||
|
text = ""
|
||||||
|
else
|
||||||
|
iconscale = { x=1, y=1 }
|
||||||
|
barnumber = hb.value_to_barlength(start_value, start_max)
|
||||||
|
bgiconnumber = hb.settings.statbar_length
|
||||||
|
text = string.format(format_string, label, start_value, start_max)
|
||||||
|
end
|
||||||
|
if hb.settings.bar_type == "progress_bar" then
|
||||||
|
ids.bg = player:hud_add({
|
||||||
|
hud_elem_type = "image",
|
||||||
|
position = pos,
|
||||||
|
scale = bgscale,
|
||||||
|
text = "hudbars_bar_background.png",
|
||||||
|
alignment = {x=1,y=1},
|
||||||
|
offset = { x = offset.x - 1, y = offset.y - 1 },
|
||||||
|
})
|
||||||
|
if textures.icon ~= nil then
|
||||||
|
ids.icon = player:hud_add({
|
||||||
|
hud_elem_type = "image",
|
||||||
|
position = pos,
|
||||||
|
scale = iconscale,
|
||||||
|
text = textures.icon,
|
||||||
|
alignment = {x=-1,y=1},
|
||||||
|
offset = { x = offset.x - 3, y = offset.y },
|
||||||
|
})
|
||||||
|
end
|
||||||
|
elseif hb.settings.bar_type == "statbar_modern" then
|
||||||
|
if textures.bgicon ~= nil then
|
||||||
|
ids.bg = player:hud_add({
|
||||||
|
hud_elem_type = "statbar",
|
||||||
|
position = pos,
|
||||||
|
text = textures.bgicon,
|
||||||
|
number = bgiconnumber,
|
||||||
|
alignment = {x=-1,y=-1},
|
||||||
|
offset = { x = offset.x, y = offset.y },
|
||||||
|
direction = 0,
|
||||||
|
size = {x=24, y=24},
|
||||||
|
})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local bar_image, bar_size
|
||||||
|
if hb.settings.bar_type == "progress_bar" then
|
||||||
|
bar_image = textures.bar
|
||||||
|
bar_size = nil
|
||||||
|
elseif hb.settings.bar_type == "statbar_classic" or hb.settings.bar_type == "statbar_modern" then
|
||||||
|
bar_image = textures.icon
|
||||||
|
bar_size = {x=24, y=24}
|
||||||
|
end
|
||||||
|
ids.bar = player:hud_add({
|
||||||
|
hud_elem_type = "statbar",
|
||||||
|
position = pos,
|
||||||
|
text = bar_image,
|
||||||
|
number = barnumber,
|
||||||
|
alignment = {x=-1,y=-1},
|
||||||
|
offset = offset,
|
||||||
|
direction = 0,
|
||||||
|
size = bar_size,
|
||||||
|
})
|
||||||
|
if hb.settings.bar_type == "progress_bar" then
|
||||||
|
ids.text = player:hud_add({
|
||||||
|
hud_elem_type = "text",
|
||||||
|
position = pos,
|
||||||
|
text = text,
|
||||||
|
alignment = {x=1,y=1},
|
||||||
|
number = text_color,
|
||||||
|
direction = 0,
|
||||||
|
offset = { x = offset.x + 2, y = offset.y - 1},
|
||||||
|
})
|
||||||
|
end
|
||||||
|
-- Do not forget to update hb.get_hudbar_state if you add new fields to the state table
|
||||||
|
state.hidden = start_hidden
|
||||||
|
state.value = start_value
|
||||||
|
state.max = start_max
|
||||||
|
state.text = text
|
||||||
|
state.barlength = hb.value_to_barlength(start_value, start_max)
|
||||||
|
|
||||||
|
local main_error_text =
|
||||||
|
"[hudbars] Bad initial values of HUD bar identifier “"..tostring(identifier).."” for player "..name..". "
|
||||||
|
|
||||||
|
if start_max < start_value then
|
||||||
|
minetest.log("error", main_error_text.."start_max ("..start_max..") is smaller than start_value ("..start_value..")!")
|
||||||
|
end
|
||||||
|
if start_max < 0 then
|
||||||
|
minetest.log("error", main_error_text.."start_max ("..start_max..") is smaller than 0!")
|
||||||
|
end
|
||||||
|
if start_value < 0 then
|
||||||
|
minetest.log("error", main_error_text.."start_value ("..start_value..") is smaller than 0!")
|
||||||
|
end
|
||||||
|
|
||||||
|
hb.hudtables[identifier].hudids[name] = ids
|
||||||
|
hb.hudtables[identifier].hudstate[name] = state
|
||||||
|
end
|
||||||
|
|
||||||
|
hudtable.identifier = identifier
|
||||||
|
hudtable.format_string = format_string
|
||||||
|
hudtable.label = label
|
||||||
|
hudtable.hudids = {}
|
||||||
|
hudtable.hudstate = {}
|
||||||
|
hudtable.default_start_hidden = default_start_hidden
|
||||||
|
hudtable.default_start_value = default_start_value
|
||||||
|
hudtable.default_start_max = default_start_max
|
||||||
|
|
||||||
|
hb.hudbars_count= hb.hudbars_count + 1
|
||||||
|
|
||||||
|
hb.hudtables[identifier] = hudtable
|
||||||
|
end
|
||||||
|
|
||||||
|
function hb.init_hudbar(player, identifier, start_value, start_max, start_hidden)
|
||||||
|
if not player_exists(player) then return false end
|
||||||
|
local hudtable = hb.get_hudtable(identifier)
|
||||||
|
hb.hudtables[identifier].add_all(player, hudtable, start_value, start_max, start_hidden)
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
function hb.change_hudbar(player, identifier, new_value, new_max_value, new_icon, new_bgicon, new_bar, new_label, new_text_color)
|
||||||
|
if new_value == nil and new_max_value == nil and new_icon == nil and new_bgicon == nil and new_bar == nil and new_label == nil and new_text_color == nil then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
if not player_exists(player) then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
local name = player:get_player_name()
|
||||||
|
local hudtable = hb.get_hudtable(identifier)
|
||||||
|
local value_changed, max_changed = false, false
|
||||||
|
|
||||||
|
if new_value ~= nil then
|
||||||
|
if new_value ~= hudtable.hudstate[name].value then
|
||||||
|
hudtable.hudstate[name].value = new_value
|
||||||
|
value_changed = true
|
||||||
|
end
|
||||||
|
else
|
||||||
|
new_value = hudtable.hudstate[name].value
|
||||||
|
end
|
||||||
|
if new_max_value ~= nil then
|
||||||
|
if new_max_value ~= hudtable.hudstate[name].max then
|
||||||
|
hudtable.hudstate[name].max = new_max_value
|
||||||
|
max_changed = true
|
||||||
|
end
|
||||||
|
else
|
||||||
|
new_max_value = hudtable.hudstate[name].max
|
||||||
|
end
|
||||||
|
|
||||||
|
if hb.settings.bar_type == "progress_bar" then
|
||||||
|
if new_icon ~= nil and hudtable.hudids[name].icon ~= nil then
|
||||||
|
player:hud_change(hudtable.hudids[name].icon, "text", new_icon)
|
||||||
|
end
|
||||||
|
if new_bgicon ~= nil and hudtable.hudids[name].bgicon ~= nil then
|
||||||
|
player:hud_change(hudtable.hudids[name].bgicon, "text", new_bgicon)
|
||||||
|
end
|
||||||
|
if new_bar ~= nil then
|
||||||
|
player:hud_change(hudtable.hudids[name].bar , "text", new_bar)
|
||||||
|
end
|
||||||
|
if new_label ~= nil then
|
||||||
|
hudtable.label = new_label
|
||||||
|
local new_text = string.format(hudtable.format_string, new_label, hudtable.hudstate[name].value, hudtable.hudstate[name].max)
|
||||||
|
player:hud_change(hudtable.hudids[name].text, "text", new_text)
|
||||||
|
end
|
||||||
|
if new_text_color ~= nil then
|
||||||
|
player:hud_change(hudtable.hudids[name].text, "number", new_text_color)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
if new_icon ~= nil and hudtable.hudids[name].bar ~= nil then
|
||||||
|
player:hud_change(hudtable.hudids[name].bar, "text", new_icon)
|
||||||
|
end
|
||||||
|
if new_bgicon ~= nil and hudtable.hudids[name].bg ~= nil then
|
||||||
|
player:hud_change(hudtable.hudids[name].bg, "text", new_bgicon)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local main_error_text =
|
||||||
|
"[hudbars] Bad call to hb.change_hudbar, identifier: “"..tostring(identifier).."”, player name: “"..name.."”. "
|
||||||
|
if new_max_value < new_value then
|
||||||
|
minetest.log("error", main_error_text.."new_max_value ("..new_max_value..") is smaller than new_value ("..new_value..")!")
|
||||||
|
end
|
||||||
|
if new_max_value < 0 then
|
||||||
|
minetest.log("error", main_error_text.."new_max_value ("..new_max_value..") is smaller than 0!")
|
||||||
|
end
|
||||||
|
if new_value < 0 then
|
||||||
|
minetest.log("error", main_error_text.."new_value ("..new_value..") is smaller than 0!")
|
||||||
|
end
|
||||||
|
|
||||||
|
if hudtable.hudstate[name].hidden == false then
|
||||||
|
if max_changed and hb.settings.bar_type == "progress_bar" then
|
||||||
|
if hudtable.hudstate[name].max == 0 then
|
||||||
|
player:hud_change(hudtable.hudids[name].bg, "scale", {x=0,y=0})
|
||||||
|
else
|
||||||
|
player:hud_change(hudtable.hudids[name].bg, "scale", {x=1,y=1})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if value_changed or max_changed then
|
||||||
|
local new_barlength = hb.value_to_barlength(new_value, new_max_value)
|
||||||
|
if new_barlength ~= hudtable.hudstate[name].barlength then
|
||||||
|
player:hud_change(hudtable.hudids[name].bar, "number", hb.value_to_barlength(new_value, new_max_value))
|
||||||
|
hudtable.hudstate[name].barlength = new_barlength
|
||||||
|
end
|
||||||
|
|
||||||
|
if hb.settings.bar_type == "progress_bar" then
|
||||||
|
local new_text = string.format(hudtable.format_string, hudtable.label, new_value, new_max_value)
|
||||||
|
if new_text ~= hudtable.hudstate[name].text then
|
||||||
|
player:hud_change(hudtable.hudids[name].text, "text", new_text)
|
||||||
|
hudtable.hudstate[name].text = new_text
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
function hb.hide_hudbar(player, identifier)
|
||||||
|
if not player_exists(player) then return false end
|
||||||
|
local name = player:get_player_name()
|
||||||
|
local hudtable = hb.get_hudtable(identifier)
|
||||||
|
if hudtable == nil then return false end
|
||||||
|
if(hudtable.hudstate[name].hidden == false) then
|
||||||
|
if hb.settings.bar_type == "progress_bar" then
|
||||||
|
if hudtable.hudids[name].icon ~= nil then
|
||||||
|
player:hud_change(hudtable.hudids[name].icon, "scale", {x=0,y=0})
|
||||||
|
end
|
||||||
|
player:hud_change(hudtable.hudids[name].bg, "scale", {x=0,y=0})
|
||||||
|
player:hud_change(hudtable.hudids[name].text, "text", "")
|
||||||
|
elseif hb.settings.bar_type == "statbar_modern" then
|
||||||
|
player:hud_change(hudtable.hudids[name].bg, "number", 0)
|
||||||
|
end
|
||||||
|
player:hud_change(hudtable.hudids[name].bar, "number", 0)
|
||||||
|
hudtable.hudstate[name].hidden = true
|
||||||
|
end
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
function hb.unhide_hudbar(player, identifier)
|
||||||
|
if not player_exists(player) then return false end
|
||||||
|
local name = player:get_player_name()
|
||||||
|
local hudtable = hb.get_hudtable(identifier)
|
||||||
|
if hudtable == nil then return false end
|
||||||
|
if(hudtable.hudstate[name].hidden) then
|
||||||
|
local value = hudtable.hudstate[name].value
|
||||||
|
local max = hudtable.hudstate[name].max
|
||||||
|
if hb.settings.bar_type == "progress_bar" then
|
||||||
|
if hudtable.hudids[name].icon ~= nil then
|
||||||
|
player:hud_change(hudtable.hudids[name].icon, "scale", {x=1,y=1})
|
||||||
|
end
|
||||||
|
if hudtable.hudstate[name].max ~= 0 then
|
||||||
|
player:hud_change(hudtable.hudids[name].bg, "scale", {x=1,y=1})
|
||||||
|
end
|
||||||
|
player:hud_change(hudtable.hudids[name].text, "text", tostring(string.format(hudtable.format_string, hudtable.label, value, max)))
|
||||||
|
elseif hb.settings.bar_type == "statbar_modern" then
|
||||||
|
player:hud_change(hudtable.hudids[name].bg, "number", hb.settings.statbar_length)
|
||||||
|
end
|
||||||
|
player:hud_change(hudtable.hudids[name].bar, "number", hb.value_to_barlength(value, max))
|
||||||
|
hudtable.hudstate[name].hidden = false
|
||||||
|
end
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
function hb.get_hudbar_state(player, identifier)
|
||||||
|
if not player_exists(player) then return nil end
|
||||||
|
local ref = hb.get_hudtable(identifier).hudstate[player:get_player_name()]
|
||||||
|
-- Do not forget to update this chunk of code in case the state changes
|
||||||
|
local copy = {
|
||||||
|
hidden = ref.hidden,
|
||||||
|
value = ref.value,
|
||||||
|
max = ref.max,
|
||||||
|
text = ref.text,
|
||||||
|
barlength = ref.barlength,
|
||||||
|
}
|
||||||
|
return copy
|
||||||
|
end
|
||||||
|
|
||||||
|
function hb.get_hudbar_identifiers()
|
||||||
|
local ids = {}
|
||||||
|
for id, _ in pairs(hb.hudtables) do
|
||||||
|
table.insert(ids, id)
|
||||||
|
end
|
||||||
|
return ids
|
||||||
|
end
|
||||||
|
|
||||||
|
--register built-in HUD bars
|
||||||
|
if minetest.settings:get_bool("enable_damage") or hb.settings.forceload_default_hudbars then
|
||||||
|
hb.register_hudbar("health", 0xFFFFFF, S("Health"), { bar = "hudbars_bar_health.png", icon = "hudbars_icon_health.png", bgicon = "hudbars_bgicon_health.png" }, 20, 20, true)
|
||||||
|
hb.register_hudbar("breath", 0xFFFFFF, S("Breath"), { bar = "hudbars_bar_breath.png", icon = "hudbars_icon_breath.png", bgicon = "hudbars_bgicon_breath.png" }, 10, 10, true)
|
||||||
|
end
|
||||||
|
|
||||||
|
local function hide_builtin(player)
|
||||||
|
local flags = player:hud_get_flags()
|
||||||
|
flags.healthbar = false
|
||||||
|
flags.breathbar = false
|
||||||
|
player:hud_set_flags(flags)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
|
local function custom_hud(player)
|
||||||
|
if minetest.settings:get_bool("enable_damage") or hb.settings.forceload_default_hudbars then
|
||||||
|
local hide
|
||||||
|
if minetest.settings:get_bool("enable_damage") then
|
||||||
|
hide = false
|
||||||
|
else
|
||||||
|
hide = true
|
||||||
|
end
|
||||||
|
hb.init_hudbar(player, "health", player:get_hp(), nil, hide)
|
||||||
|
local breath = player:get_breath()
|
||||||
|
local hide_breath
|
||||||
|
if breath == 11 and hb.settings.autohide_breath == true then hide_breath = true else hide_breath = false end
|
||||||
|
hb.init_hudbar(player, "breath", math.min(breath, 10), nil, hide_breath or hide)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local function update_health(player)
|
||||||
|
hb.change_hudbar(player, "health", player:get_hp())
|
||||||
|
end
|
||||||
|
|
||||||
|
-- update built-in HUD bars
|
||||||
|
local function update_hud(player)
|
||||||
|
if not player_exists(player) then return end
|
||||||
|
if minetest.settings:get_bool("enable_damage") then
|
||||||
|
if hb.settings.forceload_default_hudbars then
|
||||||
|
hb.unhide_hudbar(player, "health")
|
||||||
|
end
|
||||||
|
--air
|
||||||
|
local breath = player:get_breath()
|
||||||
|
|
||||||
|
if breath == 11 and hb.settings.autohide_breath == true then
|
||||||
|
hb.hide_hudbar(player, "breath")
|
||||||
|
else
|
||||||
|
hb.unhide_hudbar(player, "breath")
|
||||||
|
hb.change_hudbar(player, "breath", math.min(breath, 10))
|
||||||
|
end
|
||||||
|
--health
|
||||||
|
update_health(player)
|
||||||
|
elseif hb.settings.forceload_default_hudbars then
|
||||||
|
hb.hide_hudbar(player, "health")
|
||||||
|
hb.hide_hudbar(player, "breath")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_on_player_hpchange(function(player)
|
||||||
|
if hb.players[player:get_player_name()] ~= nil then
|
||||||
|
update_health(player)
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
|
minetest.register_on_respawnplayer(function(player)
|
||||||
|
update_health(player)
|
||||||
|
hb.hide_hudbar(player, "breath")
|
||||||
|
end)
|
||||||
|
|
||||||
|
minetest.register_on_joinplayer(function(player)
|
||||||
|
hide_builtin(player)
|
||||||
|
custom_hud(player)
|
||||||
|
hb.players[player:get_player_name()] = player
|
||||||
|
end)
|
||||||
|
|
||||||
|
minetest.register_on_leaveplayer(function(player)
|
||||||
|
hb.players[player:get_player_name()] = nil
|
||||||
|
end)
|
||||||
|
|
||||||
|
local main_timer = 0
|
||||||
|
local timer = 0
|
||||||
|
minetest.register_globalstep(function(dtime)
|
||||||
|
main_timer = main_timer + dtime
|
||||||
|
timer = timer + dtime
|
||||||
|
if main_timer > hb.settings.tick or timer > 4 then
|
||||||
|
if main_timer > hb.settings.tick then main_timer = 0 end
|
||||||
|
-- only proceed if damage is enabled
|
||||||
|
if minetest.settings:get_bool("enable_damage") or hb.settings.forceload_default_hudbars then
|
||||||
|
for _, player in pairs(hb.players) do
|
||||||
|
-- update all hud elements
|
||||||
|
update_hud(player)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if timer > 4 then timer = 0 end
|
||||||
|
end)
|
3
mods/hudbars/locale/de.txt
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
Health = Leben
|
||||||
|
Breath = Atem
|
||||||
|
%s: %d/%d = %s: %d/%d
|
5
mods/hudbars/locale/it.txt
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
Health = Salute
|
||||||
|
Breath = Ossigeno
|
||||||
|
|
||||||
|
# Default format string for progress bar-style HUD bars, e.g. “Health 5/20”
|
||||||
|
%s: %d/%d
|
3
mods/hudbars/locale/ms.txt
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
Health = Kesihatan
|
||||||
|
Breath = Nafas
|
||||||
|
%s: %d/%d = %s: %d/%d
|
5
mods/hudbars/locale/nl.txt
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
Health = Gezondheid
|
||||||
|
Breath = Adem
|
||||||
|
|
||||||
|
# Default format string for progress bar-style HUD bars, e.g. “Health 5/20”
|
||||||
|
%s: %d/%d
|
5
mods/hudbars/locale/pt.txt
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
Health = Saude
|
||||||
|
Breath = Folego
|
||||||
|
|
||||||
|
# Formato de string padrão para progresso bar-style de barras do HUD, por exemplo “Saude 5/20”
|
||||||
|
%s: %d/%d
|
5
mods/hudbars/locale/template.txt
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
Health
|
||||||
|
Breath
|
||||||
|
|
||||||
|
# Default format string for progress bar-style HUD bars, e.g. “Health 5/20”
|
||||||
|
%s: %d/%d
|
3
mods/hudbars/locale/tr.txt
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
Health = Can
|
||||||
|
Breath = Nefes
|
||||||
|
%s: %d/%d = %s: %d/%d
|
1
mods/hudbars/mod.conf
Normal file
@ -0,0 +1 @@
|
|||||||
|
name = hudbars
|
BIN
mods/hudbars/screenshot.png
Normal file
After Width: | Height: | Size: 9.3 KiB |
119
mods/hudbars/settingtypes.txt
Normal file
@ -0,0 +1,119 @@
|
|||||||
|
[Appearance]
|
||||||
|
# Specifies how the value indicators (i.e. health, breah, etc.) look. There are 3 styles
|
||||||
|
# available. You can choose between the default progress-bar-like bars and the good
|
||||||
|
# old statbars like you know from vanilla Minetest.
|
||||||
|
# These values are possible:
|
||||||
|
# - progress_bar: A horizontal progress-bar-like bar with a label, showing numerical value
|
||||||
|
# (current, maximum), and an icon. These bars usually convey the most
|
||||||
|
# information. This is the default and recommended value.
|
||||||
|
# - statbar_classic: Classic statbar, like in vanilla Minetest. Made out of up to 20
|
||||||
|
# half-symbols. Those bars represent the vague ratio between
|
||||||
|
# the current value and the maximum value. 1 half-symbol stands for
|
||||||
|
# approximately 5% of the maximum value.
|
||||||
|
# - statbar_modern: Like the classic statbar, but also supports background images, this
|
||||||
|
# kind of statbar may be considered to be more user-friendly than the
|
||||||
|
# classic statbar. This bar type closely resembles the mod
|
||||||
|
# “Better HUD” [hud] by BlockMen.
|
||||||
|
hudbars_bar_type (HUD bars style) enum progress_bar progress_bar,statbar_classic,statbar_modern
|
||||||
|
|
||||||
|
|
||||||
|
# If enabled (default), the breath indicators in the HUD will be automatically hidden shortly
|
||||||
|
# after the breath has been filled up. Otherwise, the breath will always be displayed.
|
||||||
|
hudbars_autohide_breath (Automatically hide breath indicators) bool true
|
||||||
|
|
||||||
|
# This setting changes the way the HUD bars are ordered on the display. You can choose
|
||||||
|
# between a zig-zag pattern (default) or a vertically stacked pattern.
|
||||||
|
# The following values are allowed:
|
||||||
|
# - zigzag: Starting from the left bottom, the next is right from the first,
|
||||||
|
# the next is above the first, the next is right of the third, etc.
|
||||||
|
# - stack_up: The HUD bars are stacked vertically, going upwards.
|
||||||
|
# - stack_down: The HUD bars are stacked vertically, going downwards.
|
||||||
|
hudbars_alignment_pattern (HUD bars alignment pattern) enum zigzag zigzag,stack_up,stack_down
|
||||||
|
|
||||||
|
# This setting allows you to specify the order of the HUD bars explicitly. If left empty
|
||||||
|
# (the default), the health and breath indicators come first, additional indicators
|
||||||
|
# may appear in any order. This setting is quite technical and normal users probably do not
|
||||||
|
# need to worry about it.
|
||||||
|
#
|
||||||
|
# Syntax:
|
||||||
|
# The setting has to be specified as a comma-seperated list of key=value pairs, where a key
|
||||||
|
# refers to the identifier of a HUD bar and the value refers to the slot number of where the
|
||||||
|
# HUD bar should be placed. The slot number must be an integer greater of equal to 0. Where
|
||||||
|
# the HUD bars will be displayed exactly depends on the alignment pattern being used.
|
||||||
|
# All HUD bars to which no order value has been applied will fill in all slots which have
|
||||||
|
# not been occupied by the HUD bars specified in this setting, the slots will be filled in
|
||||||
|
# from the lowest slot number.
|
||||||
|
# Note that the order of those remaining HUD bars is not fixed, it basically just boils
|
||||||
|
# down on which mod “came” first. Don't worry, the mod will still work perfectly fine, this
|
||||||
|
# setting is entirely optional.
|
||||||
|
# The identifier for the health bar is “health” and the identifier for the breath bar is
|
||||||
|
# “breath”. For other HUD bars, you have to learn it from the mod which is supplying them.
|
||||||
|
#
|
||||||
|
# Be careful not to use slot indices twice, or else different HUD bars will be drawn over
|
||||||
|
# each other!
|
||||||
|
#
|
||||||
|
# Example: “breath=0, health=1”
|
||||||
|
# This makes the breath bar first and the health bar second, which is the opposite order
|
||||||
|
# of the default one.
|
||||||
|
hudbars_sorting (HUD bars order) string
|
||||||
|
|
||||||
|
[Positions and offsets]
|
||||||
|
# Horizontal (x) main position of the HUD bars over the entire screen.
|
||||||
|
# 0.0 is left-most, 1.0 is right-most.
|
||||||
|
# For the zig-zag alignment pattern, this is for the left HUD bars.
|
||||||
|
hudbars_pos_left_x (Left HUD bar screen x position) float 0.5 0.0 1.0
|
||||||
|
# Vertical (y) main position of the HUD bars over the entire screen.
|
||||||
|
# 0.0 is top, 1.0 is bottom.
|
||||||
|
# For the zig-zag alignment pattern, this is for the left HUD bars.
|
||||||
|
hudbars_pos_left_y (Left HUD bar screen y position) float 1.0 0.0 1.0
|
||||||
|
# Horizontal (x) main position of the right HUD bars over the entire screen.
|
||||||
|
# 0.0 is left-most, 1.0 is right-most.
|
||||||
|
# Only used for the zig-zag alignment pattern.
|
||||||
|
hudbars_pos_right_x (Right HUD bar screen x position) float 0.5 0.0 1.0
|
||||||
|
# Vertical main position (y) of the right HUD bars over the entire screen.
|
||||||
|
# 0.0 is top, 1.0 is bottom.
|
||||||
|
# Only used for the zig-zag alignment pattern.
|
||||||
|
hudbars_pos_right_y (Right HUD bar screen y position) float 1.0 0.0 1.0
|
||||||
|
|
||||||
|
# Precise x offset in pixels from the basic screen x position of the HUD bars.
|
||||||
|
# For the zig-zag alignment pattern, this is for the left HUD bars.
|
||||||
|
# This setting is used for the progress bar HUD bar style.
|
||||||
|
hudbars_start_offset_left_x (Left HUD bar x offset) int -175
|
||||||
|
# Precise y offset in pixels from the basic screen y position of the HUD bars.
|
||||||
|
# For the zig-zag alignment pattern, this is for the left HUD bars.
|
||||||
|
# This setting is used for the progress bar HUD bar style.
|
||||||
|
hudbars_start_offset_left_y (Left HUD bar y offset) int -86
|
||||||
|
# Precise x offset in pixels from the basic screen x position of the right HUD bars.
|
||||||
|
# Only used for the zig-zag alignment pattern.
|
||||||
|
# This setting is used for the progress bar HUD bar style.
|
||||||
|
hudbars_start_offset_right_x (Right HUD bar x offset) int 15
|
||||||
|
# Precise y offset in pixels from the basic screen y position of the right HUD bars.
|
||||||
|
# Only used for the zig-zag alignment pattern.
|
||||||
|
# This setting is used for the progress bar HUD bar style.
|
||||||
|
hudbars_start_offset_right_y (Right HUD bar y offset) int -86
|
||||||
|
|
||||||
|
# Precise x offset in pixels from the basic screen x position of the HUD statbars.
|
||||||
|
# For the zig-zag alignment pattern, this is for the left HUD statbars.
|
||||||
|
# This setting is used for the classic and modern statbar styles.
|
||||||
|
hudbars_start_statbar_offset_left_x (Left HUD statbar x offset) int -265
|
||||||
|
# Precise y offset in pixels from the basic screen y position of the HUD statbars.
|
||||||
|
# For the zig-zag alignment pattern, this is for the left HUD statbars.
|
||||||
|
# This setting is used for the classic and modern statbar styles.
|
||||||
|
hudbars_start_statbar_offset_left_y (Left HUD statbar y offset) int -90
|
||||||
|
# Precise x offset in pixels from the basic screen x position of the right HUD statbars.
|
||||||
|
# Only used for the zig-zag alignment pattern.
|
||||||
|
# This setting is used for the classic and modern statbar styles.
|
||||||
|
hudbars_start_statbar_offset_right_x (Right HUD statbar x offset) int 25
|
||||||
|
# Precise y offset in pixels from the basic screen y position of the right HUD statbars.
|
||||||
|
# Only used for the zig-zag alignment pattern.
|
||||||
|
# This setting is used for the classic and modern statbar styles.
|
||||||
|
hudbars_start_statbar_offset_right_y (Right HUD statbar y offset) int -90
|
||||||
|
|
||||||
|
# The vertical distance between two HUD bars, in pixels.
|
||||||
|
hudbars_vmargin (Vertical distance between HUD bars) int 24 0
|
||||||
|
|
||||||
|
[Performance]
|
||||||
|
# The of seconds which need to pass before the server updates the default HUD bars
|
||||||
|
# (health and breath). Increase this number if you have a slow server or a slow network
|
||||||
|
# connection and experience performance problems.
|
||||||
|
hudbars_tick (Default HUD bars update interval) float 0.1 0.0 4.0
|
BIN
mods/hudbars/textures/hudbars_bar_background.png
Normal file
After Width: | Height: | Size: 140 B |
BIN
mods/hudbars/textures/hudbars_bar_breath.png
Normal file
After Width: | Height: | Size: 80 B |
BIN
mods/hudbars/textures/hudbars_bar_health.png
Normal file
After Width: | Height: | Size: 80 B |
BIN
mods/hudbars/textures/hudbars_bgicon_breath.png
Normal file
After Width: | Height: | Size: 811 B |
BIN
mods/hudbars/textures/hudbars_bgicon_health.png
Normal file
After Width: | Height: | Size: 419 B |
BIN
mods/hudbars/textures/hudbars_icon_breath.png
Normal file
After Width: | Height: | Size: 818 B |
BIN
mods/hudbars/textures/hudbars_icon_health.png
Normal file
After Width: | Height: | Size: 432 B |