2022-09-18 15:45:08 +00:00
local wea_c = worldeditadditions_core
local v3 = worldeditadditions_core.Vector3
2021-08-06 03:38:59 +00:00
--- Returns the player's position (at leg level).
2021-07-29 01:06:10 +00:00
-- @param name string The name of the player to return facing direction of.
2021-08-06 03:38:59 +00:00
-- @return vector Returns position.
2022-09-18 15:45:08 +00:00
function wea_c . player_vector ( name )
2022-09-18 21:20:04 +00:00
return v3.clone ( minetest.get_player_by_name ( name ) : get_pos ( ) )
2021-07-29 01:06:10 +00:00
end
2021-08-06 03:38:59 +00:00
--- Returns the player's facing info including relative DIRs.
-- @param name string The name of the player to return facing direction of.
2021-11-11 01:33:08 +00:00
-- @returns table(vector3+) xyz raw values and {axis,sign} tables for facing direction and relative direction keys (front, back, left, right, up, down).
2022-09-18 15:45:08 +00:00
function wea_c . player_dir ( name )
2021-08-06 03:38:59 +00:00
local dir = v3.clone ( minetest.get_player_by_name ( name ) : get_look_dir ( ) )
local abs = dir : abs ( )
-- Facing info
2022-09-18 15:45:08 +00:00
if abs.x > abs.z then dir.facing = { axis = " x " , sign = wea_c.getsign ( dir.x ) }
else dir.facing = { axis = " z " , sign = wea_c.getsign ( dir.z ) } end
2021-08-06 03:38:59 +00:00
-- Set front and back
dir.front = dir.facing
dir.back = { axis = dir.facing . axis , sign = dir.facing . sign *- 1 }
-- Set left and right
if dir.facing . axis == " x " then dir.left = { axis = " z " , sign = dir.facing . sign }
else dir.left = { axis = " x " , sign = dir.facing . sign *- 1 } end
dir.right = { axis = dir.left . axis , sign = dir.left . sign *- 1 }
-- Set up and down
dir.up = { axis = " y " , sign = 1 }
dir.down = { axis = " y " , sign =- 1 }
return dir
end
2021-11-08 00:16:51 +00:00
2022-09-18 15:45:08 +00:00
-- /lua print(wea_c.vector.tostring(minetest.get_player_by_name(myname):get_look_dir()))
2021-08-06 03:38:59 +00:00
2021-11-11 01:33:08 +00:00
--- DEPRECATED =================================================================
2021-08-06 03:38:59 +00:00
-- TODO: Refactor commands that use the following functions to use player_dir then delete these functions
--- Returns the player's facing direction on the horizontal axes only.
2022-09-18 15:45:08 +00:00
-- @deprecated Use wea_c.player_dir instead.
2021-02-25 03:42:24 +00:00
-- @param name string The name of the player to return facing direction of.
2021-08-06 03:38:59 +00:00
-- @return string,int Returns axis name and sign multiplier.
2022-09-18 15:45:08 +00:00
function wea_c . player_axis2d ( name )
2021-07-29 01:06:10 +00:00
-- minetest.get_player_by_name("singleplayer"):
2021-03-09 19:05:03 +00:00
local dir = minetest.get_player_by_name ( name ) : get_look_dir ( )
local x , z = math.abs ( dir.x ) , math.abs ( dir.z )
if x > z then return " x " , dir.x > 0 and 1 or - 1
else return " z " , dir.z > 0 and 1 or - 1 end
end
2021-03-20 01:53:01 +00:00
2021-08-06 03:38:59 +00:00
--- Returns the axis and sign of the axis to the left of the input axis.
2022-09-18 15:45:08 +00:00
-- @deprecated Use wea_c.player_dir instead.
2021-03-09 19:05:03 +00:00
-- @param axis string x or z.
-- @param sign int Sign multiplier.
2021-08-06 03:38:59 +00:00
-- @return string,int Returns axis name and sign multiplier.
2022-09-18 15:45:08 +00:00
function wea_c . axis_left ( axis , sign )
2021-03-09 19:05:03 +00:00
if not axis : match ( " [xz] " ) then return false , " Error: Not a horizontal axis! "
elseif axis == " x " then return true , " z " , sign
else return true , " x " , - sign end
2021-02-24 16:40:53 +00:00
end
2021-03-17 18:36:12 +00:00
--- Dehumanize Direction: translates up, down, left, right, front, into xyz based on player orientation.
2022-09-18 15:45:08 +00:00
-- @deprecated Use wea_c.player_dir instead.
2021-03-17 18:36:12 +00:00
-- @param name string The name of the player to return facing direction of.
-- @param dir string Relative direction to translate.
2021-08-06 03:38:59 +00:00
-- @return string Returns axis name and sign multiplier.
2022-09-18 15:45:08 +00:00
function wea_c . dir_to_xyz ( name , dir )
local axfac , drfac = wea_c.player_axis2d ( name )
local _ , axlft , drlft = wea_c.axis_left ( axfac , drfac )
2021-03-17 18:36:12 +00:00
if dir : match ( " front " ) or dir : match ( " back " ) then
return axfac , dir : match ( " front " ) and drfac or - drfac
elseif dir : match ( " left " ) or dir : match ( " right " ) then
return axlft , dir : match ( " left " ) and drlft or - drlft
elseif dir : match ( " up " ) or dir : match ( " down " ) then
return " y " , dir == " down " and - 1 or 1
else return false , " \" " .. dir .. " \" not a recognized direction! Try: (up | down | left | right | front | back) " end
end