Cleanup done

Ziplines deletion for Zipline Gun
This commit is contained in:
Jonny_Bro (Nikita) 2023-05-21 16:04:48 +05:00
parent 95792dbc13
commit 71b7b0e879
4 changed files with 341 additions and 277 deletions

View file

@ -1,13 +1,10 @@
# Добавлено мной # Добавлено мной
* Разрешение Overdrive на сервере - *Beatrun_AllowOvedriveInMultiplayer*. * Разрешение Overdrive на сервере - *Beatrun_AllowOvedriveInMultiplayer*.
* Измение цвета худа - *Beatrun_HUDTextColor*, *Beatrun_HUDCornerColor*, *Beatrun_HUDFloatingXPColor*. * Измение цвета худа - *Beatrun_HUDTextColor*, *Beatrun_HUDCornerColor*, *Beatrun_HUDFloatingXPColor*.
* Discord Rich Presence (Нужен модуль из lua/bin) * Discord Rich Presence (Нужны модули из lua/bin)
* Небольшой толчок камеры при нырянии. * Небольшой толчок камеры при нырянии.
* Изменение максимальной скорости - *Beatrun_MaxSpeed* (Спасибо c4nk, я слепой). * Изменение максимальной скорости - *Beatrun_MaxSpeed* (Спасибо c4nk, я слепой).
* Возможность удалять зиплайны от Zipline Gun на ПКМ. (Завтра доделаю) * Возможность удалять зиплайны от Zipline Gun на ПКМ.
# Фиксы с предыдущей версии # Фиксы с предыдущей версии
* Выключил обратно быстрый разворот, хуйня (Чтобы откатить напишите **Beatrun_QuickturnGround 0** в консоль). * Теперь точно починил сохранение курсов.
* Фикс незакрытия меню постройки.
* Фикс сохранения курсов.
* Отключены реплеи до фикса.

View file

@ -1,19 +1,18 @@
local cvarwindsound local cvarwindsound
local minimalvm local minimalvm
if CLIENT then if CLIENT then
minimalvm = CreateClientConVar("Beatrun_MinimalVM", 1, true, true, "Lowers the running viewmodel", 0, 1) minimalvm = CreateClientConVar("Beatrun_MinimalVM", 1, true, true, "Lowers the running viewmodel", 0, 1)
cvarwindsound = CreateClientConVar("Beatrun_Wind", 1, true, false, "Wind noises") cvarwindsound = CreateClientConVar("Beatrun_Wind", 1, true, false, "Wind noises")
SWEP.PrintName = "Unarmed" SWEP.PrintName = "Unarmed"
SWEP.Slot = 0 SWEP.Slot = 0
SWEP.SlotPos = 1 SWEP.SlotPos = 1
SWEP.DrawAmmo = false SWEP.DrawAmmo = false
SWEP.DrawCrosshair = false SWEP.DrawCrosshair = false
hook.Add("VManipPrePlayAnim", "LOCNoVManip", function() hook.Add("VManipPrePlayAnim", "LOCNoVManip", function()
if LocalPlayer():GetActiveWeapon():GetClass() == "runnerhands" or blinded then if LocalPlayer():GetActiveWeapon():GetClass() == "runnerhands" or blinded then return false end
return false
end
end) end)
end end
@ -51,7 +50,6 @@ SWEP.Secondary.Ammo = "none"
SWEP.wepvelocity = 0 SWEP.wepvelocity = 0
SWEP.lastpunch = 1 --1 right 2 left 3 both SWEP.lastpunch = 1 --1 right 2 left 3 both
SWEP.lastanimenum = 0 SWEP.lastanimenum = 0
SWEP.spamcount = 0 SWEP.spamcount = 0
@ -79,15 +77,20 @@ local runseq = {
[6] = true, [6] = true,
[7] = true [7] = true
} }
local oddseq = { local oddseq = {
[8] = true, [8] = true,
[9] = true, [9] = true,
[10] = true, [10] = true,
[19] = true, [19] = true,
} }
function SWEP:GetViewModelPosition(pos, ang) function SWEP:GetViewModelPosition(pos, ang)
if minimalvm:GetBool() then if minimalvm:GetBool() then
if !self.posz then self.posz = pos.z end if not self.posz then
self.posz = pos.z
end
local seq = self:GetSequence() local seq = self:GetSequence()
if runseq[seq] then if runseq[seq] then
@ -95,8 +98,10 @@ function SWEP:GetViewModelPosition( pos, ang )
else else
self.posz = Lerp(10 * FrameTime(), self.posz, 0) self.posz = Lerp(10 * FrameTime(), self.posz, 0)
end end
pos.z = pos.z + self.posz pos.z = pos.z + self.posz
end end
if oddseq[self:GetSequence()] then return pos, ang end if oddseq[self:GetSequence()] then return pos, ang end
self.BobScale = 0 self.BobScale = 0
@ -111,8 +116,8 @@ function SWEP:Deploy()
self.RespawnDelay = 0 self.RespawnDelay = 0
self:SetWasOnGround(false) self:SetWasOnGround(false)
self:SetBlockAnims(false) self:SetBlockAnims(false)
self:SetPunch(1) self:SetPunch(1)
RunConsoleCommand("fov_desired", 100) RunConsoleCommand("fov_desired", 100)
end end
@ -126,88 +131,109 @@ function SWEP:Initialize()
self:SetBlockAnims(false) self:SetBlockAnims(false)
end end
local jumpseq = { local jumpseq = {ACT_VM_HAULBACK, ACT_VM_SWINGHARD}
ACT_VM_HAULBACK,
ACT_VM_SWINGHARD -- local jumptr, jumptrout = {}, {}
} -- local jumpvec = Vector(0, 0, -50)
local jumptr, jumptrout = {}, {}
local jumpvec = Vector(0,0,-50)
local fallang = Angle() local fallang = Angle()
local infall local infall
local fallct = 0 local fallct = 0
function SWEP:Think() function SWEP:Think()
local ply = self:GetOwner()
local ply=self.Owner
local viewmodel = ply:GetViewModel() local viewmodel = ply:GetViewModel()
if not IsValid(viewmodel) then return end
if !IsValid(viewmodel) then return end
if self:GetHoldType() == "fist" and CurTime() > self:GetPunchReset() then if self:GetHoldType() == "fist" and CurTime() > self:GetPunchReset() then
self:SetHoldType("normal") self:SetHoldType("normal")
end end
if self:GetBlockAnims() then ply:GetViewModel():SetPlaybackRate(1) return end if self:GetBlockAnims() then
ply:GetViewModel():SetPlaybackRate(1)
return
end
local curseq = self:GetSequence() local curseq = self:GetSequence()
local onground = ply:OnGround() local onground = ply:OnGround()
local vel = ply:GetVelocity() local vel = ply:GetVelocity()
vel.z = 0 vel.z = 0
local ismoving = vel:Length()>100 and !ply:KeyDown(IN_BACK) and ply:IsSprinting() and !ply:Crouching() and !ply:KeyDown(IN_DUCK)
local ismoving = vel:Length() > 100 and not ply:KeyDown(IN_BACK) and ply:IsSprinting() and not ply:Crouching() and not ply:KeyDown(IN_DUCK)
local injump = curseq == 13 or curseq == 14 or curseq == 17 or curseq == -1 or curseq == 1 local injump = curseq == 13 or curseq == 14 or curseq == 17 or curseq == -1 or curseq == 1
infall = curseq == 19 infall = curseq == 19
self:SetSideStep((curseq == 15 or curseq == 16) and GetConVar("Beatrun_SideStep"):GetBool()) self:SetSideStep((curseq == 15 or curseq == 16) and GetConVar("Beatrun_SideStep"):GetBool())
local insidestep = self:GetSideStep() local insidestep = self:GetSideStep()
local spvel = ply:GetVelocity() local spvel = ply:GetVelocity()
local ang = ply:EyeAngles() local ang = ply:EyeAngles()
if spvel.z < -800 and ply:GetMoveType() != MOVETYPE_NOCLIP then
if !infall then if spvel.z < -800 and ply:GetMoveType() ~= MOVETYPE_NOCLIP then
if not infall then
-- if CLIENT then -- if CLIENT then
-- RemoveBodyAnim() -- RemoveBodyAnim()
-- elseif game.SinglePlayer() then -- elseif game.SinglePlayer() then
-- self.Owner:SendLua("RemoveBodyAnim()") -- self:GetOwner():SendLua("RemoveBodyAnim()")
-- end -- end
self:SendWeaponAnim(ACT_RUN_ON_FIRE) self:SendWeaponAnim(ACT_RUN_ON_FIRE)
end end
if CLIENT and fallct != CurTime() then
if CLIENT and fallct ~= CurTime() then
local vel = math.min(math.abs(spvel.z) / 2500, 1) local vel = math.min(math.abs(spvel.z) / 2500, 1)
local mult = 20 local mult = 20
fallang:SetUnpacked(2 * vel * FrameTime() * mult, 1.25 * vel * FrameTime() * mult, 1.5 * vel * FrameTime() * mult) fallang:SetUnpacked(2 * vel * FrameTime() * mult, 1.25 * vel * FrameTime() * mult, 1.5 * vel * FrameTime() * mult)
fallang:Add(ang) fallang:Add(ang)
fallct = CurTime() fallct = CurTime()
end end
return return
elseif infall then elseif infall then
self:SendWeaponAnim(ACT_VM_DRAW) self:SendWeaponAnim(ACT_VM_DRAW)
ang.z = 0 ang.z = 0
ply:SetEyeAngles(ang) ply:SetEyeAngles(ang)
end end
spvel.z = 0 spvel.z = 0
local velocity = self:GetOwnerVelocity() local velocity = self:GetOwnerVelocity()
self.punching = curseq == 8 or curseq == 9 or curseq == 10 or curseq == 11 self.punching = curseq == 8 or curseq == 9 or curseq == 10 or curseq == 11
if ply:KeyPressed(IN_JUMP) and self:GetWasOnGround() and !ply:GetJumpTurn() then
if ply:KeyPressed(IN_JUMP) and self:GetWasOnGround() and not ply:GetJumpTurn() then
ply:ViewPunch(Angle(-2, 0, 0)) ply:ViewPunch(Angle(-2, 0, 0))
local eyeang = ply:EyeAngles() local eyeang = ply:EyeAngles()
eyeang.x = 0 eyeang.x = 0
if insidestep and viewmodel:GetCycle() <= 0.1 and GetConVar("Beatrun_QuakeJump"):GetBool() then if insidestep and viewmodel:GetCycle() <= 0.1 and GetConVar("Beatrun_QuakeJump"):GetBool() then
if SERVER then if SERVER then
ply:EmitSound("quakejump.mp3", 100, 100, 0.2) ply:EmitSound("quakejump.mp3", 100, 100, 0.2)
end end
ply.QuakeJumping = true ply.QuakeJumping = true
self:SetQuakeJumping(true) self:SetQuakeJumping(true)
end end
if !ismoving and !ply:Crouching() then if not ismoving and not ply:Crouching() then
ParkourEvent("jumpstill", ply) ParkourEvent("jumpstill", ply)
elseif !ply:Crouching() then elseif not ply:Crouching() then
if !util.QuickTrace(ply:GetPos()+eyeang:Forward()*200, Vector(0,0,-100), ply).Hit then if not util.QuickTrace(ply:GetPos() + eyeang:Forward() * 200, Vector(0, 0, -100), ply).Hit then
self:SendWeaponAnim(jumpseq[1]) self:SendWeaponAnim(jumpseq[1])
ParkourEvent("jumpfar", ply) ParkourEvent("jumpfar", ply)
else else
self:SendWeaponAnim(jumpseq[2]) self:SendWeaponAnim(jumpseq[2])
ParkourEvent("jump", ply) ParkourEvent("jump", ply)
end end
end end
return return
end end
@ -217,40 +243,47 @@ end
if ply:GetSliding() or ply:GetSlidingDelay() - 0.15 > CurTime() then if ply:GetSliding() or ply:GetSlidingDelay() - 0.15 > CurTime() then
self:SendWeaponAnim(ACT_VM_DRAW) self:SendWeaponAnim(ACT_VM_DRAW)
return return
end end
if (self.punching) and viewmodel:GetCycle()>=1 then if self.punching and viewmodel:GetCycle() >= 1 then
self:SendWeaponAnim(ACT_VM_DRAW) self:SendWeaponAnim(ACT_VM_DRAW)
end end
if injump and (viewmodel:GetCycle()>=1 or (ply:GetMantle() != 0 and ply:KeyDown(IN_JUMP)) or ply:GetWallrun() > 1) then if injump and (viewmodel:GetCycle() >= 1 or (ply:GetMantle() ~= 0 and ply:KeyDown(IN_JUMP)) or ply:GetWallrun() > 1) then
self:SendWeaponAnim(ACT_VM_DRAW) self:SendWeaponAnim(ACT_VM_DRAW)
end end
self:SetWeaponVelocity(Lerp(5 * FrameTime(), self:GetWeaponVelocity(), velocity)) self:SetWeaponVelocity(Lerp(5 * FrameTime(), self:GetWeaponVelocity(), velocity))
if !ismoving then
if not ismoving then
self:SetWeaponVelocity(velocity) self:SetWeaponVelocity(velocity)
end end
if !self.punching and !insidestep then
if onground and ismoving and curseq!=6 and velocity<=350 then if not self.punching and not insidestep then
if onground and ismoving and curseq ~= 6 and velocity <= 350 then
self:SendWeaponAnim(ACT_RUN) self:SendWeaponAnim(ACT_RUN)
elseif onground and ismoving and curseq!=7 and velocity>350 then elseif onground and ismoving and curseq ~= 7 and velocity > 350 then
local cycle = self:GetCycle() local cycle = self:GetCycle()
self:SendWeaponAnim(ACT_RUN_PROTECTED) self:SendWeaponAnim(ACT_RUN_PROTECTED)
self:SetCycle(cycle) self:SetCycle(cycle)
elseif (curseq==6 or curseq==7) and (velocity<50 or !ismoving or !onground) and curseq!=13 then elseif (curseq == 6 or curseq == 7) and (velocity < 50 or not ismoving or not onground) and curseq ~= 13 then
self:SendWeaponAnim(ACT_VM_DRAW) self:SendWeaponAnim(ACT_VM_DRAW)
if !onground and ply:GetSafetyRollKeyTime() <= CurTime() and ply:GetSafetyRollTime() <= CurTime() then
ParkourEvent("fall", self.Owner) if not onground and ply:GetSafetyRollKeyTime() <= CurTime() and ply:GetSafetyRollTime() <= CurTime() then
ParkourEvent("fall", self:GetOwner())
end end
end end
end end
curseq = self:GetSequence() curseq = self:GetSequence()
if (curseq == 6 or curseq == 7) and ismoving then if (curseq == 6 or curseq == 7) and ismoving then
local rate = (curseq == 7 and 1.2) or 0.75 local rate = (curseq == 7 and 1.2) or 0.75
if rate != ply:GetViewModel():GetPlaybackRate() then
if rate ~= ply:GetViewModel():GetPlaybackRate() then
ply:GetViewModel():SetPlaybackRate(rate) ply:GetViewModel():SetPlaybackRate(rate)
end end
else else
@ -258,7 +291,7 @@ else
end end
if CLIENT then if CLIENT then
if !self.RunWind1 or !self.RunWind1.Play then if not self.RunWind1 or not self.RunWind1.Play then
self.RunWind1 = CreateSound(self, "clotheswind.wav") self.RunWind1 = CreateSound(self, "clotheswind.wav")
self.RunWind2 = CreateSound(self, "runwind.wav") self.RunWind2 = CreateSound(self, "runwind.wav")
end end
@ -268,10 +301,12 @@ if CLIENT then
self.RunWind2:Play() self.RunWind2:Play()
self.RunWindVolume = math.Clamp(self.RunWindVolume + (0.5 * FrameTime()), 0, 1) self.RunWindVolume = math.Clamp(self.RunWindVolume + (0.5 * FrameTime()), 0, 1)
self.RunWind1:ChangeVolume(self.RunWindVolume) self.RunWind1:ChangeVolume(self.RunWindVolume)
self.RunWind2:ChangeVolume(self.RunWindVolume) self.RunWind2:ChangeVolume(self.RunWindVolume)
else else
self.RunWindVolume = math.Clamp(self.RunWindVolume - (2.5 * FrameTime()), 0, 1) self.RunWindVolume = math.Clamp(self.RunWindVolume - (2.5 * FrameTime()), 0, 1)
self.RunWind1:ChangeVolume(self.RunWindVolume) self.RunWind1:ChangeVolume(self.RunWindVolume)
self.RunWind2:ChangeVolume(self.RunWindVolume) self.RunWind2:ChangeVolume(self.RunWindVolume)
end end
@ -284,34 +319,48 @@ end
if insidestep and viewmodel:GetCycle() >= 1 then if insidestep and viewmodel:GetCycle() >= 1 then
local mult = (ply:InOverdrive() and 1.25) or 1 local mult = (ply:InOverdrive() and 1.25) or 1
self:SendWeaponAnim(ACT_VM_DRAW) self:SendWeaponAnim(ACT_VM_DRAW)
ply:SetMEMoveLimit(350 * mult) ply:SetMEMoveLimit(350 * mult)
ply:SetMESprintDelay(CurTime()) ply:SetMESprintDelay(CurTime())
elseif insidestep then elseif insidestep then
local mult = (ply:InOverdrive() and 1.25) or 1 local mult = (ply:InOverdrive() and 1.25) or 1
ply:SetMEMoveLimit(350 * mult) ply:SetMEMoveLimit(350 * mult)
ply:SetMESprintDelay(CurTime()) ply:SetMESprintDelay(CurTime())
end end
self:SetWasOnGround(ply:OnGround())
self:SetWasOnGround(ply:OnGround())
end end
if CLIENT then if CLIENT then
local didfallang = false local didfallang = false
local mouseang = Angle() local mouseang = Angle()
hook.Add("InputMouseApply", "FallView", function(cmd, x, y, ang) hook.Add("InputMouseApply", "FallView", function(cmd, x, y, ang)
local ply = LocalPlayer() local ply = LocalPlayer()
if infall and !BodyAnimArmCopy and ply:Alive() and ply:GetMoveType()!=MOVETYPE_NOCLIP then
if infall and not BodyAnimArmCopy and ply:Alive() and ply:GetMoveType() ~= MOVETYPE_NOCLIP then
mouseang.x, mouseang.y = y * 0.01, x * -0.01 mouseang.x, mouseang.y = y * 0.01, x * -0.01
fallang:Add(mouseang) fallang:Add(mouseang)
cmd:SetViewAngles(fallang) cmd:SetViewAngles(fallang)
didfallang = true didfallang = true
util.ScreenShake(vector_origin, 5 * (math.abs(ply:GetVelocity().z) / 1000), 5, 0.05, 5000) util.ScreenShake(vector_origin, 5 * (math.abs(ply:GetVelocity().z) / 1000), 5, 0.05, 5000)
return true return true
elseif didfallang then elseif didfallang then
fallang.z = 0 fallang.z = 0
fallang.x = math.Clamp(fallang.x, -89, 89) fallang.x = math.Clamp(fallang.x, -89, 89)
if ply:Alive() then cmd:SetViewAngles(fallang) end
if ply:Alive() then
cmd:SetViewAngles(fallang)
end
didfallang = false didfallang = false
end end
end) end)
@ -322,6 +371,7 @@ function SWEP:Holster()
self.RunWind1:Stop() self.RunWind1:Stop()
self.RunWind2:Stop() self.RunWind2:Stop()
end end
return true return true
end end
@ -334,15 +384,18 @@ end
function SWEP:Reload() function SWEP:Reload()
if GetGlobalBool(GM_DATATHEFT) then return end if GetGlobalBool(GM_DATATHEFT) then return end
if !TUTORIALMODE and CurTime() > self.RespawnDelay and self.Owner:GetClimbing() == 0 and !IsValid(self.Owner:GetSwingbar()) and !self.Owner.BuildMode then
self.Owner:Spawn() if not TUTORIALMODE and CurTime() > self.RespawnDelay and self:GetOwner():GetClimbing() == 0 and not IsValid(self:GetOwner():GetSwingbar()) and not self:GetOwner().BuildMode then
if self.Owner:KeyDown(IN_USE) then self:GetOwner():Spawn()
if self:GetOwner():KeyDown(IN_USE) then
if game.SinglePlayer() then if game.SinglePlayer() then
RunConsoleCommand("toggleblindness") RunConsoleCommand("toggleblindness")
elseif CLIENT then elseif CLIENT then
ToggleBlindness(!blinded) ToggleBlindness(not blinded)
end end
end end
self.RespawnDelay = CurTime() + 0.5 self.RespawnDelay = CurTime() + 0.5
end end
end end
@ -353,21 +406,20 @@ local tr_result = {}
local allow_overdrive = CreateConVar("Beatrun_AllowOvedriveInMultiplayer", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE}) local allow_overdrive = CreateConVar("Beatrun_AllowOvedriveInMultiplayer", 0, {FCVAR_REPLICATED, FCVAR_ARCHIVE})
function SWEP:PrimaryAttack() function SWEP:PrimaryAttack()
local ply = self.Owner local ply = self:GetOwner()
if ply:KeyDown(IN_USE) and (game.SinglePlayer() or allow_overdrive:GetBool()) then if ply:KeyDown(IN_USE) and (game.SinglePlayer() or allow_overdrive:GetBool()) then
local mult = (ply:InOverdrive() and 1) or 1.25 local mult = (ply:InOverdrive() and 1) or 1.25
local fovmult = (mult == 1 and 1) or 1.1 local fovmult = (mult == 1 and 1) or 1.1
ply:SetMEMoveLimit(ply:GetMEMoveLimit() * 0.75) ply:SetMEMoveLimit(ply:GetMEMoveLimit() * 0.75)
ply:SetOverdriveMult(mult) ply:SetOverdriveMult(mult)
ply:SetFOV(ply:GetInfoNum("Beatrun_FOV", 120) * fovmult, 0.125) ply:SetFOV(ply:GetInfoNum("Beatrun_FOV", 120) * fovmult, 0.125)
return return
end end
if !ply:OnGround() or ply:Crouching() or ply:GetSliding() or ply:GetGrappling() or ply:GetWallrun() != 0 then if not ply:OnGround() or ply:Crouching() or ply:GetSliding() or ply:GetGrappling() or ply:GetWallrun() ~= 0 then return end
return
end
local curseq = self:GetSequence() local curseq = self:GetSequence()
local infall = curseq == 19 local infall = curseq == 19
@ -376,14 +428,18 @@ function SWEP:PrimaryAttack()
if CurTime() > self:GetPunchReset() then if CurTime() > self:GetPunchReset() then
self:SetPunch(1) self:SetPunch(1)
end end
local punch = self:GetPunch() local punch = self:GetPunch()
self:SendWeaponAnim(self.punchanims[punch]) self:SendWeaponAnim(self.punchanims[punch])
if CLIENT and IsFirstTimePredicted() then if CLIENT and IsFirstTimePredicted() then
ArmInterrupt(self.punchanimsfb[punch]) ArmInterrupt(self.punchanimsfb[punch])
elseif game.SinglePlayer() then elseif game.SinglePlayer() then
ply:SendLua("ArmInterrupt('" .. self.punchanimsfb[punch] .. "')") ply:SendLua("ArmInterrupt('" .. self.punchanimsfb[punch] .. "')")
end end
ply:ViewPunch(self.punchangles[punch]) ply:ViewPunch(self.punchangles[punch])
self:SetNextPrimaryFire(CurTime() + self.punchdelays[punch]) self:SetNextPrimaryFire(CurTime() + self.punchdelays[punch])
self:SetPunchReset(CurTime() + 0.5) self:SetPunchReset(CurTime() + 0.5)
@ -396,11 +452,14 @@ function SWEP:PrimaryAttack()
if ply:IsPlayer() then if ply:IsPlayer() then
ply:LagCompensation(true) ply:LagCompensation(true)
self:SetHoldType("fist") self:SetHoldType("fist")
ply:AnimRestartGesture(GESTURE_SLOT_ATTACK_AND_RELOAD, ACT_HL2MP_GESTURE_RANGE_ATTACK_FIST, true) ply:AnimRestartGesture(GESTURE_SLOT_ATTACK_AND_RELOAD, ACT_HL2MP_GESTURE_RANGE_ATTACK_FIST, true)
end end
util.TraceHull(tr) util.TraceHull(tr)
self:EmitSound("mirrorsedge/Melee/armswoosh" .. math.random(1, 6) .. ".wav") self:EmitSound("mirrorsedge/Melee/armswoosh" .. math.random(1, 6) .. ".wav")
if ply:IsPlayer() then if ply:IsPlayer() then
@ -409,11 +468,13 @@ function SWEP:PrimaryAttack()
if tr_result.Hit then if tr_result.Hit then
self:EmitSound("mirrorsedge/Melee/fist" .. math.random(1, 5) .. ".wav") self:EmitSound("mirrorsedge/Melee/fist" .. math.random(1, 5) .. ".wav")
local ent = tr_result.Entity local ent = tr_result.Entity
if SERVER and IsValid(ent) then if SERVER and IsValid(ent) then
if !ply:IsPlayer() or (Course_Name == "" and !GetGlobalBool(GM_INFECTION)) then if not ply:IsPlayer() or (Course_Name == "" and not GetGlobalBool(GM_INFECTION)) then
local d = DamageInfo() local d = DamageInfo()
d:SetDamage( (punch != 3 and 10) or 20 ) d:SetDamage((punch ~= 3 and 10) or 20)
d:SetAttacker(ply) d:SetAttacker(ply)
d:SetInflictor(self) d:SetInflictor(self)
d:SetDamageType(DMG_CLUB) d:SetDamageType(DMG_CLUB)
@ -421,23 +482,24 @@ function SWEP:PrimaryAttack()
d:SetDamageForce(ply:EyeAngles():Forward() * 7000) d:SetDamageForce(ply:EyeAngles():Forward() * 7000)
ent:TakeDamageInfo(d) ent:TakeDamageInfo(d)
if ent:IsNPC() then if ent:IsNPC() then
ent:SetActivity(ACT_FLINCH_HEAD) ent:SetActivity(ACT_FLINCH_HEAD)
end end
end end
end end
if game.SinglePlayer() or (CLIENT and IsFirstTimePredicted()) then if game.SinglePlayer() or (CLIENT and IsFirstTimePredicted()) then
util.ScreenShake(Vector(0, 0, 0), 2.5, 10, 0.25, 0) util.ScreenShake(Vector(0, 0, 0), 2.5, 10, 0.25, 0)
end end
end end
self:SetPunch(punch + 1) self:SetPunch(punch + 1)
if punch + 1 > 3 then if punch + 1 > 3 then
self:SetPunch(1) self:SetPunch(1)
end end
end end
function SWEP:SecondaryAttack() function SWEP:SecondaryAttack()
end end

View file

@ -23,7 +23,7 @@ SWEP.UseHands = true
SWEP.ViewModel = "models/weapons/c_crossbow.mdl" SWEP.ViewModel = "models/weapons/c_crossbow.mdl"
SWEP.WorldModel = "models/weapons/w_crossbow.mdl" SWEP.WorldModel = "models/weapons/w_crossbow.mdl"
SWEP.ViewModelFOV = 75 -- 65 SWEP.ViewModelFOV = 55 -- 75
SWEP.Primary.ClipSize = -1 SWEP.Primary.ClipSize = -1
SWEP.Primary.DefaultClip = -1 SWEP.Primary.DefaultClip = -1
@ -35,6 +35,8 @@ SWEP.Secondary.DefaultClip = -1
SWEP.Secondary.Automatic = false SWEP.Secondary.Automatic = false
SWEP.Secondary.Ammo = "none" SWEP.Secondary.Ammo = "none"
local ziplines = {}
function SWEP:SetupDataTables() function SWEP:SetupDataTables()
end end
@ -63,12 +65,16 @@ function SWEP:PrimaryAttack()
local ply = self:GetOwner() local ply = self:GetOwner()
if SERVER then if SERVER then
CreateZipline(ply:EyePos(), ply:GetEyeTrace().HitPos) local zip = CreateZipline(ply:EyePos(), ply:GetEyeTrace().HitPos)
table.insert(ziplines, zip)
end end
end end
function SWEP:SecondaryAttack() function SWEP:SecondaryAttack()
-- for k, v in pairs(ziplines) do for k, v in pairs(ziplines) do
-- v:Remove() v:Remove()
-- end end
table.Empty(ziplines)
end end

View file

@ -891,10 +891,8 @@ if CLIENT then
local save = {{}, {}, Course_StartPos, Course_StartAng, name or "Unnamed", {}} local save = {{}, {}, Course_StartPos, Course_StartAng, name or "Unnamed", {}}
for k, v in pairs(buildmode_placed) do for k, v in pairs(buildmode_placed) do
if not IsValid(v) then if not IsValid(v) then -- Nothing
return
elseif v:GetNW2Bool("BRProtected") then elseif v:GetNW2Bool("BRProtected") then
-- Nothing
print("ignoring protected ent") print("ignoring protected ent")
else else
local class = v:GetClass() local class = v:GetClass()
@ -936,7 +934,8 @@ if CLIENT then
local jsonsave = util.TableToJSON(save) local jsonsave = util.TableToJSON(save)
local crc = util.CRC(jsonsave) local crc = util.CRC(jsonsave)
local dir = "beatrun/courses/" .. game.GetMap() .. "/" local dir = "beatrun/courses/" .. game.GetMap() .. "/"
compress = compress or true
if compress == nil then compress = true end
file.CreateDir(dir) file.CreateDir(dir)
@ -946,16 +945,16 @@ if CLIENT then
file.Write(dir .. crc .. ".txt", jsonsave) file.Write(dir .. crc .. ".txt", jsonsave)
end end
print("Save created:", crc) print("Save created: " .. crc .. ".txt")
end end
concommand.Add("Beatrun_SaveCourse", function(ply, cmd, args, argstr) concommand.Add("Beatrun_SaveCourse", function(ply, cmd, args, argstr)
local name = args[1] or "Unnamed" local name = args[1] or "Unnamed"
local compress = not args[2] -- local compress = not args[2]
print(compress) print(args[2])
SaveCourse(name, compress) SaveCourse(name, args[2])
end) end)
function LoadCourse(id) function LoadCourse(id)