Compare commits

...

5 Commits

Author SHA1 Message Date
David Leal 478402dda9
Replace Travis CI with GitHub Actions (#12) 2023-08-31 20:50:04 +02:00
sys4-fr 98f346882d
Fix crash on `math.round` field as `nil` (#11)
Co-authored-by: sys4 <bricassa@sys4.fr>
2021-11-10 01:20:25 +01:00
Hugo Locurcio 7c916f93a0
Update changelog with recent additions 2021-11-02 00:31:29 +01:00
savilli b08db516d5 Don't lose hp_bar when teleporting
If a player teleports far away, their hp_bar can become deactivated and disappear. The mod installs the gauge only when a player joins, so it will be forever missing. `static_save = false` prevents the item from deactivating https://github.com/minetest/minetest/blob/master/src/serverenvironment.cpp#L2028 .
Also, it doesn't make sense to save `gauges:hp_bar` to map meta since it's not a standalone item.
2021-11-02 00:20:07 +01:00
LoneWolfHT 8e4faffe8d
Make health bars show rough percentage of max hp (#9) 2021-10-18 18:22:03 +02:00
5 changed files with 55 additions and 21 deletions

20
.github/workflows/build.yml vendored Normal file
View File

@ -0,0 +1,20 @@
name: build
on: [push, pull_request]
jobs:
luacheck:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v3
- name: Install dependencies
run: |
sudo apt-get update -qq
sudo apt-get install -qqq luarocks
- name: Install LuaCheck and pre-commit
run: |
pip3 install pre-commit
luarocks install --local luacheck
- name: Run LuaCheck with pre-commit
run: |
export PATH="$HOME/.luarocks/bin:$PATH"
pre-commit run --all-files

View File

@ -21,6 +21,11 @@ stds.minetest = {
"copy",
},
},
math = {
fields = {
"round",
},
}
}
}

View File

@ -1,16 +0,0 @@
dist: bionic
language: python
python:
- 3.7.1
install:
- sudo apt-get update -qq
- sudo apt-get install -qqq luarocks
- pip3 install pre-commit
- luarocks install --local luacheck
script:
# All linters are run with pre-commit hooks
- export PATH="$HOME/.luarocks/bin:$PATH"
- pre-commit run --all-files

View File

@ -7,6 +7,15 @@ and this project adheres to [Semantic Versioning](http://semver.org/spec/v2.0.0.
## [Unreleased]
### Changed
- [Health and breath bars now adapt to custom maximum values instead of being hardcoded to 20 and 11 respectively.](https://github.com/minetest-mods/gauges/pull/9)
### Fixed
- [The health bar entity is no longer lost when a player teleports.](https://github.com/minetest-mods/gauges/pull/10)
- A side effect is that health bar entities are no longer saved in map metadata.
## [1.0.4] - 2020-09-27
### Added

View File

@ -3,6 +3,10 @@
-- Copyright © 2014-2020 4aiman, Hugo Locurcio and contributors - MIT License
-- See `LICENSE.md` included in the source distribution for details.
local function round(v)
return math.floor(v + 0.5)
end
local enabled = minetest.settings:get_bool("health_bars") ~= false
if enabled then
enabled = minetest.settings:get_bool("enable_damage")
@ -11,8 +15,10 @@ end
-- Localize this functions for better performance,
-- as it's called on every step
local vector_distance = vector.distance
local min = math.min
local max_breath = minetest.PLAYER_MAX_BREATH_DEFAULT or 11
local max = {
breath = 11,
hp = 20,
}
local mt_5 = minetest.features.object_independent_selectionbox
@ -29,12 +35,22 @@ local function add_gauge(player)
end
end
-- credit:
-- https://github.com/minetest/minetest/blob/master/builtin/game/statbars.lua#L31-L37
local function scaleToDefault(player, field)
-- Scale "hp" or "breath" to supported amount
local current = player["get_" .. field](player)
local max_display = math.max(player:get_properties()[field .. "_max"], current)
return round(current / max_display * max[field])
end
minetest.register_entity("gauges:hp_bar", {
visual = "sprite",
visual_size = {x=1, y=1/16, z=1},
textures = {"blank.png"},
collisionbox = {0},
physical = false,
static_save = false,
on_step = function(self)
local player = self.wielder
@ -50,8 +66,8 @@ minetest.register_entity("gauges:hp_bar", {
return
end
local hp = min(player:get_hp(), 20)
local breath = min(player:get_breath(), max_breath)
local hp = scaleToDefault(player, "hp")
local breath = scaleToDefault(player, "breath")
if self.hp ~= hp or self.breath ~= breath then
local health_t = "health_"..hp..".png"
@ -61,7 +77,7 @@ minetest.register_entity("gauges:hp_bar", {
health_t = "blank.png"
end
if breath == max_breath then
if breath == max.breath then
breath_t = "blank.png"
end