Compare commits

...

3 Commits

Author SHA1 Message Date
de62b0dd1b mods - default/player_api - provide hp_max player configuration
* se hp_max to 40 so we will need more life due lack of armors
2023-07-23 21:47:26 -04:00
33d68fa60b mods - toolranks - removed cos it not necesary and overload simplification
* also fixed wrong reference to 3d_armor
2023-07-23 21:46:00 -04:00
875ba2653f feature sections in config file 2023-07-18 20:32:10 -04:00
14 changed files with 15 additions and 346 deletions

View File

@ -49,9 +49,6 @@ To download you can play this game with the following minetest engines:
* simple_skins as `skins` [mods/skins](mods/skins) from https://codeberg.org/minenux/minetest-mod-simple_skins
* regrow as `regrow` [mods/regrow](mods/regrow) from https://codeberg.org/minenux/minetest-mod-regrow
* ethereal as `ethereal` [mods/ethereal](mods/ethereal) from https://codeberg.org/minenux/minetest-mod-ethereal
* toolranks as `toolranks` [mods/toolranks](mods/toolranks) (reduced) from https://codeberg.org/minenux/minetest-mod-toolranks
* armors and stuff mods
* 3d_armor and shields [mods/3d_armor](mods/3d_armor) https://codeberg.org/minenux/minetest-mod-3d_armor
* player stuffs:
* minenux bags as `backpacks` [mods/backpacks](mods/backpacks)
* NPXcoot

View File

@ -2,6 +2,7 @@
## player related configs
[subnasa-player-server]
enable_pvp = true
creative_mode = false
enable_damage = true
@ -26,7 +27,7 @@ movement_speed_walk = 5
movement_speed_crouch = 2.35
movement_speed_fast = 25
movement_speed_climb = 3
movement_speed_jump = 5
movement_speed_jump = 6
movement_liquid_fluidity = 0.8
movement_liquid_fluidity_smooth = 0.1
movement_liquid_sink = 10
@ -39,9 +40,11 @@ rspawn.min_x = -20000
rspawn.max_x = 20000
rspawn.min_z = -20000
rspawn.max_z = 20000
default_hp_player_maximun = 40
## server as client related
[subnasa-server-client]
# name =
# language =
# main_menu_script =

View File

@ -4,8 +4,17 @@
-- Player animation blending
-- Note: This is currently broken due to a bug in Irrlicht, leave at 0
local animation_blend = 0
local hp_player_maximun = tonumber(minetest.settings:get('default_hp_player_maximun')) or 40
if minetest.has_feature("object_use_texture_alpha") then
core.PLAYER_MAX_HP_DEFAULT = hp_player_maximun
else
core.PLAYER_MAX_HP = hp_player_maximun
end
default.registered_player_models = { }
if minetest.get_modpath("hudbars") then
hb.settings.hp_player_maximun = hp_player_maximun
end
-- Local for speed.
local models = default.registered_player_models
@ -76,6 +85,7 @@ function default.player_set_textures(player, textures)
local name = player:get_player_name()
player_textures[name] = textures
player:set_properties({textures = textures,})
player:set_properties({hp_max = hp_player_maximun})
end
function default.player_set_animation(player, anim_name, speed)
@ -97,6 +107,7 @@ minetest.register_on_joinplayer(function(player)
default.player_attached[player:get_player_name()] = false
default.player_set_model(player, "character.b3d")
player:set_local_animation({x=0, y=79}, {x=168, y=187}, {x=189, y=198}, {x=200, y=219}, 30)
player:set_properties({hp_max = hp_player_maximun})
player:hud_set_hotbar_image("gui_hotbar.png")
player:hud_set_hotbar_selected_image("gui_hotbar_selected.png")

View File

@ -1,82 +0,0 @@
# Minetest tool ranks mod
Tool gains levels for digging nodes. Higher level take longer to wear out.
Information
------------
It adds improved information on the description label of the tools,
like how much was used the tool and how much is improved,
and also provides improved xperience over the tool as much you use it..
![](screenshot.png)
# Technical information
---------------------
This mod is named `toolranks` this is same as minienux one but with reduced media.
its only used the default songs and defaults textures unless you override.
This ranktool is the tenplus1's version, featured custom values throught
configuration interface for dig speed, mutiplier and durability.
Shows information about the counts the nodes that spend the tool
Also provide interface to add toolrank support on other mods.
#### Dependencies
* default (now optional)
#### configuration
| Config item | type | def | values | Description |
| -------------------------- | ----- | ---- | ----------- | ----------------------------- |
| toolranks_levels | int | 8 | any int | Level (Number of tool levels) |
| toolranks_level_digs | int | 1000 | any int | Number of nodes that need to be dug to reach the next tool level |
| toolranks_speed_multiplier | float | 1.1 | 1.0 to 10.0 | Dig speed multiplier (at maximum tool level, 1.0 to disable) |
| toolranks_use_multiplier | float | 1.1 | 1.0 to 10.0 | Durability multiplier (at maximum tool level,1.0 to disable) |
#### mods toolrank support
The default mod of minetest game has default support in this mod,
but not farming hoes, many other mods already integrates toolrank support,
by example all the tenplus1's "redo"s mod already has support, others will need
extra mods like toolranks_extra due rejection from mod authors.
#### how to add support in mods
If so, to support this mod, add this code to your mod, after your tool's code:
```lua
if minetest.get_modpath("toolranks") then
toolranks.add_tool("mymod:mytool")
end
```
Where `mymod` is the technical/namespace name of the mod and `mytool` the item name.
That function provides all that can be do by custom way also as:
```lua
if minetest.get_modpath("toolranks") then
minetest.override_item("mymod:mytool", {
original_description = "My Tool",
description = toolranks.create_description("My Tool"),
after_use = toolranks.new_afteruse
})
end
end
```
## LICENSE
(c) 2017 lisacvuk
(c) 2017 tenplus1
(c) 2023 mckaygerhard
Code is LGPL v2.1
media is CC-BY
check [license.txt](license.txt)

View File

@ -1 +0,0 @@
default?

View File

@ -1 +0,0 @@
TOOL gains levels for digging nodes. Higher level take longer to wear out

View File

@ -1,211 +0,0 @@
local S
if minetest.get_translator ~= nil then
S = minetest.get_translator("toolranks") -- 5.x translation function
else
if minetest.get_modpath("intllib") then
dofile(minetest.get_modpath("intllib") .. "/init.lua")
if intllib.make_gettext_pair then
gettext, ngettext = intllib.make_gettext_pair() -- new gettext method
else
gettext = intllib.Getter() -- old text file method
end
S = gettext
else -- boilerplate function
S = function(str, ...)
local args = {...}
return str:gsub("@%d+", function(match)
return args[tonumber(match:sub(2))]
end)
end
end
end
toolranks = {
colors = {
grey = minetest.get_color_escape_sequence("#9d9d9d"),
green = minetest.get_color_escape_sequence("#1eff00"),
gold = minetest.get_color_escape_sequence("#ffdf00"),
white = minetest.get_color_escape_sequence("#ffffff")
}
}
local max_speed = tonumber(minetest.settings:get("toolranks_speed_multiplier")) or 1.1--2.0
local max_use = tonumber(minetest.settings:get("toolranks_use_multiplier")) or 1.1
local max_level = tonumber(minetest.settings:get("toolranks_levels")) or 8
local level_digs = tonumber(minetest.settings:get("toolranks_level_digs")) or 1000
local level_multiplier = 1 / max_level
function toolranks.get_level(uses)
if type(uses) == "number" and uses > 0 then
return math.min(max_level, math.floor(uses / level_digs))
end
return 0
end
function toolranks.create_description(name, uses)
local description = name
local newdesc = S(
"@1@2\n@3Level @4 @5\n@6@Node dug: @7",
toolranks.colors.green,
description,
toolranks.colors.gold,
toolranks.get_level(uses),
"", -- was tooltype
toolranks.colors.grey,
(type(uses) == "number" and uses or 0)
)
return newdesc
end
function toolranks.new_afteruse(itemstack, user, node, digparams)
local pname = user:get_player_name()
if not pname then return itemstack end -- player nil check
local itemmeta = itemstack:get_meta()
local dugnodes = tonumber(itemmeta:get_string("dug")) or 0
if digparams.wear > 0 then -- Only count nodes that spend the tool
dugnodes = dugnodes + 1
itemmeta:set_string("dug", dugnodes)
end
if itemstack:get_wear() > 60135 then
minetest.chat_send_player(pname,
toolranks.colors.gold .. S("Your tool is about to break!"))
minetest.sound_play("default_dig_metal", {
to_player = pname,
gain = 2.0,
}, true)
end
local itemdef = itemstack:get_definition()
local itemdesc = itemdef.original_description or ""
local lastlevel = tonumber(itemmeta:get_string("lastlevel")) or 0
local level = toolranks.get_level(dugnodes)
if lastlevel < level then
local levelup_text = S(
"Your @1@2@3 just leveled up!",
toolranks.colors.green,
itemdesc,
toolranks.colors.white
)
minetest.chat_send_player(pname, levelup_text .. " "..lastlevel.." -> "..level)
minetest.sound_play("toolranks_levelup", {
to_player = pname,
gain = 2.0,
}, true)
-- Make tool better by modifying tool_capabilities (if defined)
if itemdef.tool_capabilities then
local speed_multiplier = 1 + (level * level_multiplier * (max_speed - 1))
local use_multiplier = 1 + (level * level_multiplier * (max_use - 1))
local caps = table.copy(itemdef.tool_capabilities)
caps.full_punch_interval = caps.full_punch_interval and
(caps.full_punch_interval / speed_multiplier)
caps.punch_attack_uses = caps.punch_attack_uses and
(caps.punch_attack_uses * use_multiplier)
for _,c in pairs(caps.groupcaps) do
c.uses = c.uses * use_multiplier
for i,t in ipairs(c.times) do
c.times[i] = t / speed_multiplier
end
end
itemmeta:set_tool_capabilities(caps)
end
end
-- Old method for compatibility with tools without tool_capabilities defined
local wear = digparams.wear
if level > 0 and not itemdef.tool_capabilities then
local use_multiplier = 1 + (level * level_multiplier * (max_use - 1))
wear = wear / use_multiplier
end
itemmeta:set_string("lastlevel", level)
itemmeta:set_string("description", toolranks.create_description(itemdesc, dugnodes))
itemstack:add_wear(wear)
return itemstack
end
-- Helper function
function toolranks.add_tool(name)
local desc = ItemStack(name):get_definition().description
minetest.override_item(name, {
original_description = desc,
description = toolranks.create_description(desc),
after_use = toolranks.new_afteruse
})
end
local defaultmod = minetest.get_modpath("default")
if defaultmod then
-- Sword
toolranks.add_tool("default:sword_wood")
toolranks.add_tool("default:sword_stone")
toolranks.add_tool("default:sword_steel")
toolranks.add_tool("default:sword_bronze")
toolranks.add_tool("default:sword_mese")
toolranks.add_tool("default:sword_diamond")
-- Pickaxe
toolranks.add_tool("default:pick_wood")
toolranks.add_tool("default:pick_stone")
toolranks.add_tool("default:pick_steel")
toolranks.add_tool("default:pick_bronze")
toolranks.add_tool("default:pick_mese")
toolranks.add_tool("default:pick_diamond")
-- Axe
toolranks.add_tool("default:axe_wood")
toolranks.add_tool("default:axe_stone")
toolranks.add_tool("default:axe_steel")
toolranks.add_tool("default:axe_bronze")
toolranks.add_tool("default:axe_mese")
toolranks.add_tool("default:axe_diamond")
-- Shovel
toolranks.add_tool("default:shovel_wood")
toolranks.add_tool("default:shovel_stone")
toolranks.add_tool("default:shovel_steel")
toolranks.add_tool("default:shovel_bronze")
toolranks.add_tool("default:shovel_mese")
toolranks.add_tool("default:shovel_diamond")
end
print("[MOD] Tool Ranks loaded")

View File

@ -1,2 +0,0 @@
Code: LGPLv2.1+
Sounds: CC BY 3.0

View File

@ -1,11 +0,0 @@
# textdomain: toolranks
@1@2@n@3Level @4 @5@n@6Node dug: @7=@1@2@n@3Level @4 @5@n@6Node dug: @7
pickaxe=pickaxe
axe=axe
shovel=shovel
hoe=hoe
sword=sword
tool=tool
Most used tool is now a @1@2@3 owned by @4 with @5 uses.=Most used tool is now a @1@2@3 owned by @4 with @5 uses.
Your tool is about to break!=Your tool is about to break!
Your @1@2@3 just leveled up!=Your @1@2@3 just leveled up!

View File

@ -1,11 +0,0 @@
# textdomain: toolranks
@1@2@n@3Level @4 @5@n@6Node dug: @7=@1@2@n@3Nivel @4 @5@n@6Nodos picado: @7
pickaxe=pickaxe
axe=axe
shovel=shovel
hoe=hoe
sword=sword
tool=tool
Most used tool is now a @1@2@3 owned by @4 with @5 uses.=La herramienta mas usada es @1@2@3 pertenece a @4 con @5 veces.
Your tool is about to break!=Tu herramienta esta a punto de romperse!
Your @1@2@3 just leveled up!=Tu @1@2@3 acaba de subir nivel!

View File

@ -1,11 +0,0 @@
# textdomain: toolranks
@1@2@n@3Level @4 @5@n@6Node dug: @7=@1@2@n@3@5 niveau @4@n@6Blocks minés : @7
pickaxe=pioche
axe=hache
shovel=pelle
hoe=houe
sword=épée
tool=outil
Most used tool is now a @1@2@3 owned by @4 with @5 uses.=Loutil le plus utilisé est désormais @1@2@3 appartenant à @4 avec @5 utilisations.
Your tool is about to break!=Votre outil va se casser !
Your @1@2@3 just leveled up!=Votre @1@2@3 a gagné un niveau !

View File

@ -1,4 +0,0 @@
name = toolranks
depends =
optional_depends = default
description = TOOL gains levels for digging nodes. Higher level take longer to wear out

Binary file not shown.

Before

Width:  |  Height:  |  Size: 17 KiB

View File

@ -1,8 +0,0 @@
# Number of tool levels
toolranks_levels (Levels) int 8
# Number of nodes that need to be dug to reach the next tool level
toolranks_level_digs (Digs per level) int 1000
# Dig speed multiplier at maximum tool level (1.0 to disable)
toolranks_speed_multiplier (Dig speed multiplier) float 1.1 1.0 10.0
# Durability multiplier at maximum tool level (1.0 to disable)
toolranks_use_multiplier (Durability multiplier) float 1.1 1.0 10.0