Bugfix: LMB release wasn't being tracked when pressed too fast

This commit is contained in:
Zughy 2020-11-13 20:41:32 +00:00
commit 17dff58ac0
2 changed files with 47 additions and 13 deletions

View File

@ -132,6 +132,30 @@ end
function block_league.shoot_end(player, weapon)
local p_name = player:get_player_name()
local arena = arena_lib.get_arena_by_player(p_name)
local p_meta = player:get_meta()
p_meta:set_int("bl_is_shooting", 0)
minetest.after(0.5, function()
if not arena_lib.is_player_in_arena(p_name, "block_league")
or arena.players[p_name].energy == 0
or p_meta:get_int("bl_reloading") == 1
or p_meta:get_int("bl_is_shooting") == 1
then return end
player:set_physics_override({
speed = block_league.SPEED,
jump = 1.5
})
end)
end
-- ritorna un array di giocatori con il numero di giocatori trovati a indice 1. -- ritorna un array di giocatori con il numero di giocatori trovati a indice 1.
-- Se non trova giocatori diversi da se stesso ritorna nil -- Se non trova giocatori diversi da se stesso ritorna nil
function block_league.get_pointed_players(head_pos, dir, range, user, particle, has_piercing) function block_league.get_pointed_players(head_pos, dir, range, user, particle, has_piercing)
@ -317,6 +341,24 @@ function weapon_left_click(weapon, player, pointed_thing)
jump = 1.5 jump = 1.5
}) })
end end
if weapon.type ~= 3 then
player:get_meta():set_int("bl_is_shooting", 1)
end
-- controls.register_on_release non funziona se un tasto viene premuto E rilasciato
-- sullo stesso step. Quindi, quando questo fallisce (perché il giocatore è stato
-- troppo veloce), interviene l'after seguente che ricontrolla lo stato del tasto sx
-- sullo step subito successivo. Il metadato bl_is_shooting è usato come sistema di
-- verifica (attivato quando si spara con successo e disattivato quando si rilascia).
-- Se il tasto sx è stato rilasciato ma bl_is_shooting è ancora 1, vuol dire che
-- register_on_release ha fallito e c'è bisogno di intervenire chiamando la funzione
-- di rilascio
minetest.after(0.1, function()
if not player:get_player_control().LMB and player:get_meta():get_int("bl_is_shooting") == 1 then
block_league.shoot_end(player, weapon)
end
end)
end end
@ -471,12 +513,11 @@ end
function check_weapon_type_and_attack(player, weapon, pointed_thing) function check_weapon_type_and_attack(player, weapon, pointed_thing)
if weapon.weapon_type ~= 3 then if weapon.weapon_type ~= 3 then
local bullet = weapon.bullet or nil
if weapon.weapon_type == 1 then if weapon.weapon_type == 1 then
block_league.shoot_hitscan(player, weapon, pointed_thing) block_league.shoot_hitscan(player, weapon, pointed_thing)
elseif weapon.weapon_type == 2 then elseif weapon.weapon_type == 2 then
block_league.shoot_bullet(player, bullet, pointed_thing) block_league.shoot_bullet(player, weapon.bullet, pointed_thing)
end end
else else

View File

@ -43,17 +43,10 @@ controls.register_on_release(function(player, key)
elseif key == "LMB" then elseif key == "LMB" then
local weapon_name = player:get_wielded_item():get_name() local weapon_name = player:get_wielded_item():get_name()
local weap_def = minetest.registered_nodes[weapon_name] local weapon = minetest.registered_nodes[weapon_name]
local arena = arena_lib.get_arena_by_player(p_name)
if not weap_def or not weap_def.slow_down_when_firing then return end if not weapon.type or weapon.type == 3 or player:get_meta():get_int("bl_is_shooting") == 0 then return end
minetest.after(0.5, function() block_league.shoot_end(player, weapon)
if not arena_lib.is_player_in_arena(p_name, "block_league") or arena.players[p_name].energy == 0 or player:get_meta():get_int("bl_reloading") == 1 then return end end
player:set_physics_override({
speed = block_league.SPEED,
jump = 1.5
})
end)
end
end) end)