autofly: cruisemode - its very nice now - no more set_pos :)
This commit is contained in:
parent
f1713e3b71
commit
2010bdff17
@ -46,6 +46,8 @@ from src/client/game.cpp remove
|
|||||||
|
|
||||||
autofly = {}
|
autofly = {}
|
||||||
wps={}
|
wps={}
|
||||||
|
|
||||||
|
|
||||||
local landing_distance=100
|
local landing_distance=100
|
||||||
local speed=0;
|
local speed=0;
|
||||||
local ltime=0
|
local ltime=0
|
||||||
@ -56,6 +58,7 @@ local lpos={x=0,y=0,z=0}
|
|||||||
local info=minetest.get_server_info()
|
local info=minetest.get_server_info()
|
||||||
local stprefix="autofly-".. info['address'] .. '-'
|
local stprefix="autofly-".. info['address'] .. '-'
|
||||||
autofly.flying=false
|
autofly.flying=false
|
||||||
|
autofly.cruiseheight = 30
|
||||||
|
|
||||||
local modname = minetest.get_current_modname()
|
local modname = minetest.get_current_modname()
|
||||||
local modpath = minetest.get_modpath(modname)
|
local modpath = minetest.get_modpath(modname)
|
||||||
@ -233,17 +236,94 @@ function autofly.arrived()
|
|||||||
minetest.sound_play({name = "default_alert", gain = 1.0})
|
minetest.sound_play({name = "default_alert", gain = 1.0})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local cruise_wason=false
|
||||||
|
local nfctr=0
|
||||||
|
local nodenames_ground = {
|
||||||
|
'mcl_core:dirt',
|
||||||
|
'mcl_core:stone',
|
||||||
|
'mcl_core:sand',
|
||||||
|
'mcl_core:redsand',
|
||||||
|
'mcl_colorblocks:hardened_clay',
|
||||||
|
'mcl_colorblocks:hardened_clay_orange',
|
||||||
|
'mcl_colorblocks:hardened_clay_yellow',
|
||||||
|
'mcl_colorblocks:hardened_clay_red',
|
||||||
|
'mcl_core:endstone',
|
||||||
|
'mcl_core:netherrack',
|
||||||
|
'mcl_core:gravel',
|
||||||
|
'mcl_core:water_source',
|
||||||
|
'mcl_core:water_flowing',
|
||||||
|
'mcl_core:lava_source',
|
||||||
|
'mcl_core:lava_flowing',
|
||||||
|
}
|
||||||
|
|
||||||
function autofly.cruise()
|
function autofly.cruise()
|
||||||
if not minetest.settings:get_bool('afly_cruise') then return end
|
if not minetest.settings:get_bool('afly_cruise') then
|
||||||
|
if cruise_wason then
|
||||||
|
cruise_wason=false
|
||||||
|
core.set_keypress("jump",false)
|
||||||
|
core.set_keypress("sneak",false)
|
||||||
|
end
|
||||||
|
return end
|
||||||
|
|
||||||
local lp=minetest.localplayer:get_pos()
|
local lp=minetest.localplayer:get_pos()
|
||||||
local pos2=vector.add(lp,{x=0,y=-50,z=0})
|
local pos1 = vector.add(lp,{x=8,y=100,z=8})
|
||||||
local air, blck = minetest.line_of_sight(lp, pos2)
|
local pos2 = vector.add(lp,{x=-8,y=-100,z=-8})
|
||||||
if blck==nil then return end
|
local nds=minetest.find_nodes_in_area(pos1, pos2, nodenames_ground)
|
||||||
local nd=minetest.get_node_or_nil(blck)
|
local y=0
|
||||||
if not air and nd ~= nil then
|
local found=false
|
||||||
minetest.localplayer:set_pos({x=lp.x,y=blck.y+25,z=lp.z} )
|
|
||||||
minetest.settings:set_bool("free_move",true)
|
|
||||||
|
for k,v in ipairs(nds) do
|
||||||
|
local nd = minetest.get_node_or_nil(v)
|
||||||
|
if nd ~= nil and nd.name ~= "air" then
|
||||||
|
if v.y > y then
|
||||||
|
y=v.y
|
||||||
|
found=true
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
if (autofly.cruiseheight ~= nil) then y=y+autofly.cruiseheight end
|
||||||
|
local diff = math.ceil(lp.y - y)
|
||||||
|
|
||||||
|
if not cruise_wason then --initially set the cruiseheight to the current value above ground
|
||||||
|
if not found then return end --wait with activation til a ground node has been found.
|
||||||
|
autofly.cruiseheight = diff
|
||||||
|
cruise_wason=true
|
||||||
|
minetest.display_chat_message("cruise mode activated. target height set to " .. diff .. " nodes above ground.")
|
||||||
|
end
|
||||||
|
|
||||||
|
if not found then
|
||||||
|
if nfctr<20 then nfctr = nfctr + 1 return end
|
||||||
|
--minetest.display_chat_message("no nodes found for 20 iterations. lowering altitude.")
|
||||||
|
nfctr=0
|
||||||
|
minetest.settings:set_bool("free_move",false)
|
||||||
|
core.set_keypress("jump",false)
|
||||||
|
core.set_keypress("sneak",false)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
local tolerance = 1
|
||||||
|
if diff < -tolerance then
|
||||||
|
minetest.settings:set_bool("free_move",true)
|
||||||
|
core.set_keypress("jump",true)
|
||||||
|
core.set_keypress("sneak",false)
|
||||||
|
--minetest.display_chat_message("too low: " .. y)
|
||||||
|
elseif diff > tolerance * 10 then
|
||||||
|
core.set_keypress("jump",false)
|
||||||
|
core.set_keypress("sneak",true)
|
||||||
|
minetest.settings:set_bool("free_move",false)
|
||||||
|
--minetest.display_chat_message("too high: " .. y)
|
||||||
|
elseif diff > tolerance then
|
||||||
|
core.set_keypress("jump",false)
|
||||||
|
core.set_keypress("sneak",true)
|
||||||
|
else
|
||||||
|
minetest.settings:set_bool("free_move",true)
|
||||||
|
core.set_keypress("jump",false)
|
||||||
|
core.set_keypress("sneak",false)
|
||||||
|
--minetest.display_chat_message("target height reached: " .. y)
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function autofly.aim(tpos)
|
function autofly.aim(tpos)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user