mirror of
https://repo.or.cz/minetest_playereffects.git
synced 2025-01-10 02:50:18 +01:00
Add support for HUD icons; improve HUD alignment
This commit is contained in:
parent
49dafa6425
commit
bbc90ad630
@ -1,6 +1,6 @@
|
|||||||
----- EXAMPLE EFFECT TYPES -----
|
----- EXAMPLE EFFECT TYPES -----
|
||||||
|
|
||||||
playereffects.register_effect_type("high_speed", "high speed", {"speed"},
|
playereffects.register_effect_type("high_speed", "High speed", nil, {"speed"},
|
||||||
function(player)
|
function(player)
|
||||||
player:set_physics_override(4,nil,nil)
|
player:set_physics_override(4,nil,nil)
|
||||||
end,
|
end,
|
||||||
@ -10,7 +10,7 @@ playereffects.register_effect_type("high_speed", "high speed", {"speed"},
|
|||||||
player:set_physics_override(1,nil,nil)
|
player:set_physics_override(1,nil,nil)
|
||||||
end
|
end
|
||||||
)
|
)
|
||||||
playereffects.register_effect_type("low_speed", "low speed", {"speed"},
|
playereffects.register_effect_type("low_speed", "Low speed", nil, {"speed"},
|
||||||
function(player)
|
function(player)
|
||||||
player:set_physics_override(0.25,nil,nil)
|
player:set_physics_override(0.25,nil,nil)
|
||||||
end,
|
end,
|
||||||
@ -20,7 +20,7 @@ playereffects.register_effect_type("low_speed", "low speed", {"speed"},
|
|||||||
player:set_physics_override(1,nil,nil)
|
player:set_physics_override(1,nil,nil)
|
||||||
end
|
end
|
||||||
)
|
)
|
||||||
playereffects.register_effect_type("highjump", "greater jump height", {"jump"},
|
playereffects.register_effect_type("highjump", "Greater jump height", "playereffects_example_highjump.png", {"jump"},
|
||||||
function(player)
|
function(player)
|
||||||
player:set_physics_override(nil,2,nil)
|
player:set_physics_override(nil,2,nil)
|
||||||
end,
|
end,
|
||||||
@ -29,7 +29,7 @@ playereffects.register_effect_type("highjump", "greater jump height", {"jump"},
|
|||||||
player:set_physics_override(nil,1,nil)
|
player:set_physics_override(nil,1,nil)
|
||||||
end
|
end
|
||||||
)
|
)
|
||||||
playereffects.register_effect_type("fly", "fly mode available", {"fly"},
|
playereffects.register_effect_type("fly", "Fly mode available", "playereffects_example_fly.png", {"fly"},
|
||||||
function(player)
|
function(player)
|
||||||
local playername = player:get_player_name()
|
local playername = player:get_player_name()
|
||||||
local privs = minetest.get_player_privs(playername)
|
local privs = minetest.get_player_privs(playername)
|
||||||
|
44
init.lua
44
init.lua
@ -45,11 +45,12 @@ function playereffects.next_effect_id()
|
|||||||
end
|
end
|
||||||
|
|
||||||
--[=[ API functions ]=]
|
--[=[ API functions ]=]
|
||||||
function playereffects.register_effect_type(name, description, groups, apply, cancel)
|
function playereffects.register_effect_type(name, description, icon, groups, apply, cancel)
|
||||||
effect_type = {}
|
effect_type = {}
|
||||||
effect_type.description = description
|
effect_type.description = description
|
||||||
effect_type.apply = apply
|
effect_type.apply = apply
|
||||||
effect_type.groups = groups
|
effect_type.groups = groups
|
||||||
|
effect_type.icon = icon
|
||||||
if cancel ~= nil then
|
if cancel ~= nil then
|
||||||
effect_type.cancel = cancel
|
effect_type.cancel = cancel
|
||||||
else
|
else
|
||||||
@ -89,7 +90,7 @@ function playereffects.apply_effect_type(effect_type_id, duration, player)
|
|||||||
else
|
else
|
||||||
free_hudpos = biggest_hudpos + 1
|
free_hudpos = biggest_hudpos + 1
|
||||||
end
|
end
|
||||||
local hudid = playereffects.hud_effect(effect_type_id, player, free_hudpos, duration)
|
local hudids = playereffects.hud_effect(effect_type_id, player, free_hudpos, duration)
|
||||||
|
|
||||||
local effect = {
|
local effect = {
|
||||||
playername = playername,
|
playername = playername,
|
||||||
@ -97,7 +98,7 @@ function playereffects.apply_effect_type(effect_type_id, duration, player)
|
|||||||
effect_type_id = effect_type_id,
|
effect_type_id = effect_type_id,
|
||||||
start_time = start_time,
|
start_time = start_time,
|
||||||
time_left = duration,
|
time_left = duration,
|
||||||
hudid = hudid,
|
hudids = hudids,
|
||||||
hudpos = free_hudpos,
|
hudpos = free_hudpos,
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -133,7 +134,10 @@ function playereffects.cancel_effect(effect_id)
|
|||||||
local effect = playereffects.effects[effect_id]
|
local effect = playereffects.effects[effect_id]
|
||||||
if(effect ~= nil) then
|
if(effect ~= nil) then
|
||||||
local player = minetest.get_player_by_name(effect.playername)
|
local player = minetest.get_player_by_name(effect.playername)
|
||||||
player:hud_remove(effect.hudid)
|
player:hud_remove(effect.hudids.text_id)
|
||||||
|
if(effect.hudids.icon_id~=nil) then
|
||||||
|
player:hud_remove(effect.hudids.icon_id)
|
||||||
|
end
|
||||||
playereffects.effect_types[effect.effect_type_id].cancel(effect)
|
playereffects.effect_types[effect.effect_type_id].cancel(effect)
|
||||||
playereffects.effects[effect_id] = nil
|
playereffects.effects[effect_id] = nil
|
||||||
minetest.log("action", "Effect type "..effect.effect_type_id.." cancelled from player "..effect.playername.."!")
|
minetest.log("action", "Effect type "..effect.effect_type_id.." cancelled from player "..effect.playername.."!")
|
||||||
@ -248,7 +252,7 @@ function playereffects.hud_update(player)
|
|||||||
local effect = effects[e]
|
local effect = effects[e]
|
||||||
local description = playereffects.effect_types[effect.effect_type_id].description
|
local description = playereffects.effect_types[effect.effect_type_id].description
|
||||||
local time_left = os.difftime(effect.start_time + effect.time_left, now)
|
local time_left = os.difftime(effect.start_time + effect.time_left, now)
|
||||||
player:hud_change(effect.hudid, "text", description .. " ("..tostring(time_left).." s)")
|
player:hud_change(effect.hudids.text_id, "text", description .. " ("..tostring(time_left).." s)")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -257,26 +261,40 @@ function playereffects.hud_clear(player)
|
|||||||
local effects = playereffects.get_player_effects(playername)
|
local effects = playereffects.get_player_effects(playername)
|
||||||
if(effects ~= nil) then
|
if(effects ~= nil) then
|
||||||
for e=1,#effects do
|
for e=1,#effects do
|
||||||
player:hud_remove(effects[e].hudid)
|
player:hud_remove(effects[e].hudids.text_id)
|
||||||
|
if(effects[e].hudids.icon_id ~= nil) then
|
||||||
|
player:hud_remove(effects[e].hudids.icon_id)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
function playereffects.hud_effect(effect_type_id, player, pos, time_left)
|
function playereffects.hud_effect(effect_type_id, player, pos, time_left)
|
||||||
local id
|
local text_id, icon_id
|
||||||
id = player:hud_add({
|
text_id = player:hud_add({
|
||||||
hud_elem_type = "text",
|
hud_elem_type = "text",
|
||||||
position = { x = 1, y = 0.3 },
|
position = { x = 1, y = 0.3 },
|
||||||
name = "effect_"..effect_type_id,
|
name = "effect_"..effect_type_id,
|
||||||
text = playereffects.effect_types[effect_type_id].description .. " ("..tostring(time_left).." s)",
|
text = playereffects.effect_types[effect_type_id].description .. " ("..tostring(time_left).." s)",
|
||||||
scale = { x = 120, y = 20},
|
scale = { x = 170, y = 20},
|
||||||
alignment = 1,
|
alignment = { x = -1, y = 0 },
|
||||||
direction = 1,
|
direction = 1,
|
||||||
number = 0xFFFFFF,
|
number = 0xFFFFFF,
|
||||||
offset = { x = -120, y = pos*20 }
|
offset = { x = -5, y = pos*20 }
|
||||||
})
|
})
|
||||||
local playername = player:get_player_name()
|
if(playereffects.effect_types[effect_type_id].icon ~= nil) then
|
||||||
return id
|
icon_id = player:hud_add({
|
||||||
|
hud_elem_type = "image",
|
||||||
|
scale = { x = 1, y = 1 },
|
||||||
|
position = { x = 1, y = 0.3 },
|
||||||
|
name = "effect_icon_"..effect_type_id,
|
||||||
|
text = playereffects.effect_types[effect_type_id].icon,
|
||||||
|
alignment = { x = -1, y=0 },
|
||||||
|
direction = 0,
|
||||||
|
offset = { x = -186, y = pos*20 },
|
||||||
|
})
|
||||||
|
end
|
||||||
|
return { text_id = text_id, icon_id = icon_id }
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
BIN
textures/playereffects_example_fly.png
Normal file
BIN
textures/playereffects_example_fly.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 140 B |
BIN
textures/playereffects_example_highjump.png
Normal file
BIN
textures/playereffects_example_highjump.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 120 B |
Loading…
Reference in New Issue
Block a user