Compare commits
3 commits
2b0031c683
...
125bcc4fd4
Author | SHA1 | Date | |
---|---|---|---|
125bcc4fd4 | |||
c0a09101ab | |||
e3aad2621a |
4 changed files with 172 additions and 8 deletions
|
@ -17,7 +17,7 @@
|
||||||
TODO: Literally everything
|
TODO: Literally everything
|
||||||
TODO: Update checker
|
TODO: Update checker
|
||||||
TODO: On module load, grab default config values. Write changed values
|
TODO: On module load, grab default config values. Write changed values
|
||||||
TODO: Clientside core:log, with network to owner
|
TODO: Clientside core:log, with network to owner or server
|
||||||
prop.createSent(chip():getPos()+Vector(0,0,90),Angle(0,0,0),"Seat_Airboat",true)
|
prop.createSent(chip():getPos()+Vector(0,0,90),Angle(0,0,0),"Seat_Airboat",true)
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
|
|
|
@ -2,6 +2,11 @@
|
||||||
--@author
|
--@author
|
||||||
--@client
|
--@client
|
||||||
|
|
||||||
|
--[[
|
||||||
|
TODO: Clean this up
|
||||||
|
TODO: Add keybind for teleport
|
||||||
|
--]]
|
||||||
|
|
||||||
if player() == owner() then do
|
if player() == owner() then do
|
||||||
net.start("LSFT-Get-Config")
|
net.start("LSFT-Get-Config")
|
||||||
net.writeString("LSFT-Get-Freecam-Binds")
|
net.writeString("LSFT-Get-Freecam-Binds")
|
||||||
|
@ -65,6 +70,16 @@ if player() == owner() then do
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if input.isKeyDown(KEY.R) then
|
||||||
|
input.lockControls(false)
|
||||||
|
net.start("LSFT-Teleport-Spectate")
|
||||||
|
net.writeVector(target:getEyePos())
|
||||||
|
net.send()
|
||||||
|
|
||||||
|
hook.remove("calcview", "freecam")
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
return {
|
return {
|
||||||
origin = target:getEyePos(),
|
origin = target:getEyePos(),
|
||||||
angles = target:getEyeAngles(),
|
angles = target:getEyeAngles(),
|
||||||
|
@ -95,6 +110,18 @@ if player() == owner() then do
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if input.isKeyDown(KEY.R) then
|
||||||
|
input.lockControls(false)
|
||||||
|
net.start("LSFT-Teleport-Spectate")
|
||||||
|
net.writeVector(position)
|
||||||
|
net.send()
|
||||||
|
|
||||||
|
hook.remove("calcview", "freecam")
|
||||||
|
hook.remove("think", "updatepos")
|
||||||
|
timer.remove("updateholo")
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
return {
|
return {
|
||||||
origin = position,
|
origin = position,
|
||||||
angles = eyeAngles(),
|
angles = eyeAngles(),
|
||||||
|
|
|
@ -3,24 +3,35 @@
|
||||||
--@server
|
--@server
|
||||||
|
|
||||||
--[[
|
--[[
|
||||||
TODO: Draw viewmodel (not possible :c)
|
|
||||||
TODO: Custom HUD (health, armor, etc)
|
TODO: Custom HUD (health, armor, etc)
|
||||||
|
TODO: Grab binds from game instead of settings
|
||||||
|
TODO: Let user open chatbox
|
||||||
--]]
|
--]]
|
||||||
|
|
||||||
do
|
do
|
||||||
function spectate(args)
|
local function spectate(args)
|
||||||
local loadHolo = nil
|
local function stopSpectate()
|
||||||
|
|
||||||
net.start("LSFT-Start-Spectate")
|
|
||||||
|
|
||||||
net.receive("LSFT-Stop-Spectate", function()
|
|
||||||
core:log(log.INFO, "Stopped spectating.")
|
core:log(log.INFO, "Stopped spectating.")
|
||||||
owner():setViewEntity()
|
owner():setViewEntity()
|
||||||
if loadHolo ~= nil then
|
if loadHolo ~= nil then
|
||||||
loadHolo:remove()
|
loadHolo:remove()
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local loadHolo = nil
|
||||||
|
|
||||||
|
net.receive("LSFT-Stop-Spectate", function()
|
||||||
|
stopSpectate()
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
net.receive("LSFT-Teleport-Spectate", function()
|
||||||
|
local coords = net.readVector()
|
||||||
|
teleport:tpteleport({coords.x, coords.y, coords.z})
|
||||||
|
stopSpectate()
|
||||||
|
end)
|
||||||
|
|
||||||
|
net.start("LSFT-Start-Spectate")
|
||||||
|
|
||||||
if args[1] == nil then
|
if args[1] == nil then
|
||||||
if not holograms.canSpawn() then
|
if not holograms.canSpawn() then
|
||||||
core:log(log.ERROR, "Cannot spawn hologram for freecam!")
|
core:log(log.ERROR, "Cannot spawn hologram for freecam!")
|
||||||
|
|
126
modules/server/sv_teleport.txt
Normal file
126
modules/server/sv_teleport.txt
Normal file
|
@ -0,0 +1,126 @@
|
||||||
|
--@name
|
||||||
|
--@author
|
||||||
|
--@server
|
||||||
|
|
||||||
|
teleport = {}
|
||||||
|
do
|
||||||
|
local function findSafeCoords(coordsin)
|
||||||
|
local MULTIPLIER = 50 -- How spaced apart the teleport checks are
|
||||||
|
local CHECKPOINTS = 3 -- How many points to check per axis, MUST BE ODD!
|
||||||
|
|
||||||
|
local min = -math.floor(CHECKPOINTS/2)
|
||||||
|
local max = math.floor(CHECKPOINTS/2)
|
||||||
|
|
||||||
|
|
||||||
|
for x = min,max do
|
||||||
|
for y = min,max do
|
||||||
|
for z = min,max do
|
||||||
|
local teleportcoords = coordsin + Vector(x,y,z)*MULTIPLIER + Vector(0,0,10)
|
||||||
|
local cornersw = teleportcoords - Vector(17,17,0)
|
||||||
|
local cornerne = teleportcoords + Vector(17,17,0)
|
||||||
|
|
||||||
|
-- TraceHull was being stupid, this is good enough probably
|
||||||
|
local traceresult = (
|
||||||
|
trace.trace(cornersw, cornerne+Vector(0,0,90), nil, nil, nil, false).Hit
|
||||||
|
or
|
||||||
|
trace.trace(cornerne, cornersw+Vector(0,0,90), nil, nil, nil, false).Hit
|
||||||
|
)
|
||||||
|
|
||||||
|
local testresult = (
|
||||||
|
trace.pointContents(cornersw) == 1
|
||||||
|
or
|
||||||
|
trace.pointContents(cornerne) == 1
|
||||||
|
or
|
||||||
|
trace.pointContents(cornersw+Vector(0,0,90)) == 1
|
||||||
|
or
|
||||||
|
trace.pointContents(cornerne+Vector(0,0,90)) == 1
|
||||||
|
or
|
||||||
|
trace.pointContents(teleportcoords) == 1
|
||||||
|
)
|
||||||
|
|
||||||
|
if not traceresult and not testresult then
|
||||||
|
--print(trace.pointContents(teleportcoords))
|
||||||
|
return teleportcoords
|
||||||
|
--holograms.create(teleportcoords, Angle(0,0,0), "models/hunter/misc/sphere025x025.mdl", Vector(0.5,0.5,0.5)):setColor(Color(0,255,0))
|
||||||
|
else
|
||||||
|
--holograms.create(teleportcoords, Angle(0,0,0), "models/hunter/misc/sphere025x025.mdl", Vector(0.5,0.5,0.5)):setColor(Color(255,0,0))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
function teleport:tpteleport(args)
|
||||||
|
local coords = chip():getPos()
|
||||||
|
if args[1] ~= nil and args[2] ~= nil and args[3] ~= nil then
|
||||||
|
coords = Vector(tonumber(args[1]),tonumber(args[2]),tonumber(args[3]))
|
||||||
|
else
|
||||||
|
coords = owner():getEyeTrace().HitPos
|
||||||
|
|
||||||
|
local offset = Vector(40,40,40)
|
||||||
|
offset:rotate(owner():getEyeAngles())
|
||||||
|
|
||||||
|
coords = coords-offset
|
||||||
|
end
|
||||||
|
|
||||||
|
coords = findSafeCoords(coords)
|
||||||
|
|
||||||
|
if not coords then
|
||||||
|
core:log(log.WARNING, "Could not find a safe position to teleport to!")
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
local seat = prop.createSent(coords, Angle(0,0,0), "Seat_Airboat", true)
|
||||||
|
seat:setColor(Color(255,255,255,0))
|
||||||
|
seat:setSolid(false)
|
||||||
|
seat:use()
|
||||||
|
seat:remove()
|
||||||
|
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
|
function teleport:tpgoto(args)
|
||||||
|
local targets = find.playersByName(args[1])
|
||||||
|
|
||||||
|
if #targets == 0 or targets == nil then
|
||||||
|
core:log(log.ERROR, "No targets found!")
|
||||||
|
return
|
||||||
|
elseif #targets > 1 then
|
||||||
|
local list = ""
|
||||||
|
for i, v in pairs(target) do
|
||||||
|
list = list..v..", "
|
||||||
|
end
|
||||||
|
|
||||||
|
list:sub(1, -2)
|
||||||
|
core:log(log.ERROR, "Muliple targets found! ("..list..")")
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
local targetpos = findSafeCoords(targets[1]:getPos())
|
||||||
|
|
||||||
|
local result = teleport:tpteleport({targetpos.x, targetpos.y, targetpos.z})
|
||||||
|
|
||||||
|
if result then
|
||||||
|
core:log(log.INFO, "Successfully teleported to \""..targets[1]:getName().."\".")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
core.modules.teleport = {
|
||||||
|
version = 1,
|
||||||
|
desc = "Move player to somewhere else.",
|
||||||
|
commands = {
|
||||||
|
goto = {
|
||||||
|
func = function(args) teleport:tpgoto(args) end, -- Fuck you Lua
|
||||||
|
usage = "goto <ply>",
|
||||||
|
desc = "Send yourself to player ply.",
|
||||||
|
},
|
||||||
|
teleport = {
|
||||||
|
func = function(args) teleport:tpteleport(args) end, -- :(
|
||||||
|
usage = "teleport [x] [y] [z]",
|
||||||
|
desc = "Send yourself to either your aimpos or the specified coordinates.",
|
||||||
|
},
|
||||||
|
},
|
||||||
|
}
|
||||||
|
end
|
Loading…
Reference in a new issue