forked from VoxeLibre/MineClone2Client
Add sprinting with double-W
This commit is contained in:
parent
59e61c353b
commit
ed8cfb2c66
5
init.lua
5
init.lua
|
@ -1 +1,6 @@
|
||||||
|
local modname = minetest.get_current_modname()
|
||||||
|
local modpath = minetest.get_modpath(modname)
|
||||||
|
|
||||||
|
for _, f in ipairs({"sprint"}) do
|
||||||
|
dofile(modpath .. "/" .. f .. ".lua")
|
||||||
|
end
|
||||||
|
|
|
@ -0,0 +1,72 @@
|
||||||
|
-- set up our initial values
|
||||||
|
local running = false
|
||||||
|
local run_discharge_timer = 0
|
||||||
|
local old_up = false
|
||||||
|
local channel
|
||||||
|
local channel_name
|
||||||
|
|
||||||
|
-- receive the server states
|
||||||
|
minetest.register_on_modchannel_message(function(cname, sender, message)
|
||||||
|
if sender == "" and cname == channel_name then
|
||||||
|
running = false
|
||||||
|
run_discharge_timer = 0
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
|
-- check player's input on the "up" key
|
||||||
|
minetest.register_globalstep(function(dtime)
|
||||||
|
local player = minetest.localplayer
|
||||||
|
|
||||||
|
if not player then
|
||||||
|
return
|
||||||
|
elseif not channel then
|
||||||
|
channel_name = "mcl_sprint:" .. player:get_name()
|
||||||
|
channel = minetest.mod_channel_join(channel_name)
|
||||||
|
end
|
||||||
|
|
||||||
|
local old_running = running
|
||||||
|
|
||||||
|
local control = player:get_control()
|
||||||
|
local velocity = player:get_velocity()
|
||||||
|
local last_velocity = player:get_last_velocity()
|
||||||
|
|
||||||
|
-- cancel running if the player bumps into something
|
||||||
|
if running and (velocity.x == 0 and last_velocity.x ~= 0 or velocity.z == 0 and last_velocity.z ~= 0) then
|
||||||
|
running = false
|
||||||
|
run_discharge_timer = 0
|
||||||
|
end
|
||||||
|
|
||||||
|
-- reset the run flag
|
||||||
|
if running and (not control.up or control.sneak or control.down) then
|
||||||
|
running = false
|
||||||
|
end
|
||||||
|
|
||||||
|
-- half second window to double tap running
|
||||||
|
if run_discharge_timer > 0 then
|
||||||
|
run_discharge_timer = run_discharge_timer - dtime
|
||||||
|
|
||||||
|
-- initialize double tap run
|
||||||
|
if not old_up and control.up == true and velocity.x ~= 0 and velocity.z ~= 0 then
|
||||||
|
run_discharge_timer = 0
|
||||||
|
running = true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- check if new input of walking forwards
|
||||||
|
if control.up and not control.down and not control.sneak and not old_up and not running and run_discharge_timer <= 0 then
|
||||||
|
run_discharge_timer = 0.2
|
||||||
|
end
|
||||||
|
|
||||||
|
-- add this here so the player can sneak
|
||||||
|
if control.sneak then
|
||||||
|
running = false
|
||||||
|
run_discharge_timer = 0
|
||||||
|
end
|
||||||
|
|
||||||
|
-- only send if state has changed
|
||||||
|
if running ~= old_running then
|
||||||
|
channel:send_all(running and "true" or "false")
|
||||||
|
end
|
||||||
|
|
||||||
|
old_up = control.up
|
||||||
|
end)
|
Loading…
Reference in New Issue