Skip to content

Commit

Permalink
Add a max distance input to the cam controller (#3237)
Browse files Browse the repository at this point in the history
* add max distance input for wire cam

* hack for changing zoom without scrolling first

* made the sync message unreliable
  • Loading branch information
unknao authored Jan 6, 2025
1 parent 886ef66 commit c4d0ca9
Showing 1 changed file with 16 additions and 5 deletions.
21 changes: 16 additions & 5 deletions lua/entities/gmod_wire_cameracontroller.lua
Original file line number Diff line number Diff line change
Expand Up @@ -56,6 +56,7 @@ if CLIENT then
local curdistance = 0
local oldcurdistance = 0
local smoothdistance = 0
local maxdistance = 16000

local zoomdistance = 0
local zoombind = 0
Expand Down Expand Up @@ -154,7 +155,7 @@ if CLIENT then

if AllowZoom then
if zoombind ~= 0 then
zoomdistance = math.Clamp(zoomdistance + zoombind * FrameTime() * 100 * max((abs(curdistance) + abs(zoomdistance))/10,10),0,16000-curdistance)
zoomdistance = math.Clamp(zoomdistance + zoombind * FrameTime() * 100 * max((abs(curdistance) + abs(zoomdistance))/10,10),0,math.min(16000-curdistance, maxdistance))
zoombind = 0
end
curdistance = curdistance + zoomdistance
Expand Down Expand Up @@ -268,6 +269,11 @@ if CLIENT then

-- distance
distance = math.Clamp(net.ReadFloat(),-16000,16000)
maxdistance = net.ReadFloat()

if AutoMove and AllowZoom then
zoombind = 1
end

-- Parent
WaitingForID = net.ReadInt(32)
Expand Down Expand Up @@ -374,6 +380,7 @@ function ENT:Initialize()
"Angle (Sets the direction of the camera, in angle form.\nIf clientside movement is enabled, this is ignored.) [ANGLE]",
"Position (Sets the position of the camera.\nIf clientside movement is enabled, this specifies the center of the camera's orbit.) [VECTOR]",
"Distance (Sets the 'distance' of the camera.\nIn other words, the camera will be moved away from the specified position by this amount.\nIf clientside zooming is enabled, this is the farthest you can zoom in.)",
"MaxDistance (Sets the max distance the camera can zoom out to.\n Needs clientside movement and clientside zooming to be enabled.)",
"UnRoll (If free movement is enabled, this resets the roll back to zero.)",
"Parent (Parents the camera to this entity.) [ENTITY]",
"FilterEntities (In addition to ignoring the contraption of the 'Parent' entity, or the cam controller itself\nif parent isn't used, entities in this list will be ignored by the 'HitPos' and 'Trace' outputs) [ARRAY]",
Expand All @@ -390,6 +397,7 @@ function ENT:Initialize()
self.Position = Vector(0,0,0)
self.Angle = Angle(0,0,0)
self.Distance = 0
self.MaxDistance = 16000
self.UnRoll = false

self.Players = {}
Expand Down Expand Up @@ -456,7 +464,7 @@ end
-- Data sending
--------------------------------------------------

local function SendPositions( pos, ang, dist, parent, unroll )
local function SendPositions( pos, ang, dist, parent, unroll, maxdist )
-- pos/ang
net.WriteFloat( pos.x )
net.WriteFloat( pos.y )
Expand All @@ -469,6 +477,7 @@ local function SendPositions( pos, ang, dist, parent, unroll )

-- distance
net.WriteFloat( dist )
net.WriteFloat( maxdist )

-- parent
local id = IsValid( parent ) and parent:EntIndex() or -1
Expand All @@ -492,7 +501,7 @@ function ENT:SyncSettings( ply, active )
net.WriteBit( self.AutoUnclip_IgnoreWater )
net.WriteBit( self.DrawPlayer )
net.WriteBit( self.DrawParent )
SendPositions( self.Position, self.Angle, self.Distance, self.Parent, self.UnRoll )
SendPositions( self.Position, self.Angle, self.Distance, self.Parent, self.UnRoll, self.MaxDistance )
end
net.Send( ply )
end
Expand All @@ -501,9 +510,9 @@ end
util.AddNetworkString( "wire_camera_controller_sync" )
function ENT:SyncPositions( ply )
if not IsValid(ply) then ply = self.Players end
net.Start( "wire_camera_controller_sync" )
net.Start( "wire_camera_controller_sync", true )
net.WriteEntity( self )
SendPositions( self.Position, self.Angle, self.Distance, self.Parent, self.UnRoll )
SendPositions( self.Position, self.Angle, self.Distance, self.Parent, self.UnRoll, self.MaxDistance )
net.Send( ply )
end

Expand Down Expand Up @@ -863,6 +872,8 @@ function ENT:TriggerInput( name, value )
self.Position = value
elseif name == "Distance" then
self.Distance = value
elseif name == "MaxDistance" then
self.MaxDistance = value
elseif name == "UnRoll" then
self.UnRoll = tobool(value)
elseif name == "Direction" then
Expand Down

0 comments on commit c4d0ca9

Please sign in to comment.