diff --git a/lua/entities/gmod_wire_cameracontroller.lua b/lua/entities/gmod_wire_cameracontroller.lua index db9ebc7701..4b00bf433c 100644 --- a/lua/entities/gmod_wire_cameracontroller.lua +++ b/lua/entities/gmod_wire_cameracontroller.lua @@ -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 @@ -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 @@ -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) @@ -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]", @@ -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 = {} @@ -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 ) @@ -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 @@ -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 @@ -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 @@ -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