1
0
mirror of https://github.com/metrostroi-repo/MetrostroiAddon.git synced 2026-05-02 00:42:29 +00:00
Files
MetrostroiAddon/lua/entities/gmod_subway_81-502/init.lua
2022-07-25 13:03:55 +03:00

635 lines
23 KiB
Lua

AddCSLuaFile("cl_init.lua")
AddCSLuaFile("shared.lua")
include("shared.lua")
ENT.BogeyDistance = 650 -- Needed for gm trainspawner
--"DURASelectMain","DURASelectAlternate","DURAToggleChannel","DURAPowerToggle",
ENT.SyncTable = {
"VB","VBA","AV","VU","VU1","VU2","VU3",
"VRD","VR",
"VRU","KAD","KAH","OVT","KSD","KPVU","VKF",
"KOS","VZP","KRZD","KDL","KDLK","KDPK","LOn","LOff","VozvratRP","KSN","KDP","VMK","Ring","VUS","VAK","Autodrive","VZD","PB","VUD","VAKK",
"RCAV3","RCAV4","RCAV5","RCARS","RCBPS",
"VDL","KDPH",
"ALS","ARS","Headlights","VSOSD","KB","DriverValveBLDisconnect","DriverValveTLDisconnect",
"GV",
"R_UPO",
"UAVA","UAVAC","EmergencyBrakeValve"
}
ENT.SyncFunctions = {
""
}
function ENT:Initialize()
self.Plombs = {
VRU=true,
KAH=true,
KAD=true,
OVT=true,
KPVU=true,
UAVA=true,
RCAV3=true,
RCAV4=true,
RCAV5=true,
RCARS=true,
RCBPS=true,
Init=true,
}
-- Set model and initialize
self:SetModel("models/metrostroi_train/81-502/81-502.mdl")
self.BaseClass.Initialize(self)
self:SetPos(self:GetPos() + Vector(0,0,140))
-- Create seat entities
self.DriverSeat = self:CreateSeat("driver",Vector(425+3,-39.4,-31.5),Angle(0,0,0))
self.InstructorsSeat = self:CreateSeat("instructor",Vector(430,40,-48+6+2.5),Angle(0,90,0),"models/vehicles/prisoner_pod_inner.mdl")
self.ExtraSeat1 = self:CreateSeat("instructor",Vector(443,0,-48+6+2.5),Angle(0,90,0),"models/vehicles/prisoner_pod_inner.mdl")
self.ExtraSeat2 = self:CreateSeat("instructor",Vector(420,-20,-48+6),Angle(0,90,0),"models/vehicles/prisoner_pod_inner.mdl")
-- Hide seats
self.DriverSeat:SetColor(Color(0,0,0,0))
self.DriverSeat:SetRenderMode(RENDERMODE_TRANSALPHA)
self.InstructorsSeat:SetColor(Color(0,0,0,0))
self.InstructorsSeat:SetRenderMode(RENDERMODE_TRANSALPHA)
self.ExtraSeat1:SetColor(Color(0,0,0,0))
self.ExtraSeat1:SetRenderMode(RENDERMODE_TRANSALPHA)
self.ExtraSeat2:SetColor(Color(0,0,0,0))
self.ExtraSeat2:SetRenderMode(RENDERMODE_TRANSALPHA)
-- Create bogeys
if Metrostroi.BogeyOldMap then
self.FrontBogey = self:CreateBogey(Vector( 317-5,0,-89),Angle(0,180,0),true,"717")
self.RearBogey = self:CreateBogey(Vector(-317+0,0,-89),Angle(0,0,0),false,"717")
self.FrontCouple = self:CreateCouple(Vector( 419.5+3.5,0,-75),Angle(0,0,0),true,"722")
self.RearCouple = self:CreateCouple(Vector(-421.5-3.5,0,-75),Angle(0,180,0),false,"702")
else
self.FrontBogey = self:CreateBogey(Vector( 317-11,1.0,-85),Angle(0,180,0),true,"717")
self.RearBogey = self:CreateBogey(Vector(-317+0,1.3,-85),Angle(0,0,0),false,"717")
self.FrontCouple = self:CreateCouple(Vector( 421-4-3.6+4.5,1.0,-72),Angle(0,0,0),true,"722")
self.RearCouple = self:CreateCouple(Vector(-421+2+3.6-4.5,1.3,-72),Angle(0,180,0),false,"702")
end
self.FrontBogey:SetNWInt("MotorSoundType",0)
self.RearBogey:SetNWInt("MotorSoundType",0)
self.FrontCouple.EKKDisconnected = true
self.LeftAutoCoil = self:AddAutodriveCoil(self.FrontBogey,false)
self.RightAutoCoil = self:AddAutodriveCoil(self.FrontBogey,true)
-- Initialize key mapping
self.KeyMap = {
[KEY_1] = "KVSetX1B",
[KEY_2] = "KVSetX2",
[KEY_3] = "KVSetX3",
[KEY_4] = "KVSet0",
[KEY_5] = "KVSetT1B",
[KEY_6] = "KVSetT1AB",
[KEY_7] = "KVSetT2",
[KEY_G] = "VozvratRPSet",
[KEY_0] = "KVReverserUp",
[KEY_9] = "KVReverserDown",
[KEY_PAD_PLUS] = "KVReverserUp",
[KEY_PAD_MINUS] = "KVReverserDown",
[KEY_W] = "KVUp",
[KEY_S] = "KVDown",
[KEY_F] = "PneumaticBrakeUp",
[KEY_R] = "PneumaticBrakeDown",
[KEY_A] = {"KDL",helper="VDLSet"},
[KEY_D] = "KDP",
[KEY_V] = "VUDToggle",
[KEY_L] = "HornEngage",
[KEY_PAD_1] = "PneumaticBrakeSet1",
[KEY_PAD_2] = "PneumaticBrakeSet2",
[KEY_PAD_3] = "PneumaticBrakeSet3",
[KEY_PAD_4] = "PneumaticBrakeSet4",
[KEY_PAD_5] = "PneumaticBrakeSet5",
[KEY_BACKSPACE] = {"EmergencyBrake",helper="EmergencyBrakeValveToggle"},
[KEY_SPACE] = "KB",
[KEY_PAD_DIVIDE] = "VAKSet",
[KEY_PAD_ENTER] = "KVWrenchKV",
[KEY_PAD_0] = "DriverValveDisconnect",
[KEY_LSHIFT] = {
[KEY_W] = "KVUp_Unlocked",
[KEY_1] = "LOnSet",
[KEY_2] = "LOffSet",
[KEY_4] = "KVSet0Fast",
[KEY_L] = "DriverValveDisconnect",
[KEY_7] = "KVWrenchNone",
[KEY_9] = "KVWrenchKV9",
[KEY_0] = "KVWrenchKV",
[KEY_6] = "KVSetT1A",
[KEY_SPACE] = "PB",
[KEY_PAD_ENTER] = "KVWrenchNone",
},
}
self.KeyMap[KEY_RALT] = self.KeyMap[KEY_LALT]
self.KeyMap[KEY_RSHIFT] = self.KeyMap[KEY_LSHIFT]
self.KeyMap[KEY_RCONTROL] = self.KeyMap[KEY_LCONTROL]
self.InteractionZones = {
{
ID = "FrontBrakeLineIsolationToggle",
Pos = Vector(469, -29, -62), Radius = 8,
},
{
ID = "FrontTrainLineIsolationToggle",
Pos = Vector(469, 29, -62), Radius = 8,
},
{
ID = "RearTrainLineIsolationToggle",
Pos = Vector(-474, -30, -62), Radius = 8,
},
{
ID = "RearBrakeLineIsolationToggle",
Pos = Vector(-474, 30, -62), Radius = 8,
},
{
ID = "FrontDoor",
Pos = Vector(469,32,-10), Radius = 12,
},
{
ID = "CabinDoor",
Pos = Vector(469,58,-10), Radius = 10,
},
{
ID = "CabinDoor",
Pos = Vector(469,58,-30), Radius = 10,
},
{
ID = "CabinDoor",
Pos = Vector(390,64,-10), Radius = 16,
},
{
ID = "PassengerDoor",
Pos = Vector(389,35,8), Radius = 16,
},
{
ID = "RearDoor",
Pos = Vector(-469,-35,-10), Radius = 20,
},
{
ID = "GVToggle",
Pos = Vector(155,63.7,-75), Radius = 10,
},
{
ID = "AirDistributorDisconnectToggle",
Pos = Vector(-224.5, 50, -66), Radius = 20,
},
}
-- Cross connections in train wires
self.TrainWireInverts = {
[15] = true,
}
self.TrainWireCrossConnections = {
[5] = 4, -- Reverser F<->B
[30] = 29, -- Reverser F<->B
[31] = 32, -- Doors L<->R
}
-- KV wrench mode
self:OnButtonPress("KVWrenchNone")
-- Parking brake ratio
self.ManualBrake = 0.0
self.RearDoor = false
self.FrontDoor = false
self.CabinDoor = false
self.PassengerDoor = false
-- self.A5:TriggerInput("Set",0)
self:SetNW2Float("UPONoiseVolume",math.Rand(0,0.3))
self:SetNW2Float("UPOVolume",math.Rand(0.8,1))
self.EMAType = self.EMAType or 1
self:TrainSpawnerUpdate()
end
function ENT:TrainSpawnerUpdate()
if IsValid(self.FrontBogey) then
self.FrontBogey:SetNW2Int("SquealType",math.floor(math.random()*7)+1)
end
if IsValid(self.RearBogey) then
self.RearBogey:SetNW2Int("SquealType",math.floor(math.random()*7)+1)
end
end
function ENT:NonSupportTrigger()
self.RCAV3:TriggerInput("Set",0)
self.RCAV4:TriggerInput("Set",0)
self.RCAV5:TriggerInput("Set",0)
self.RCARS:TriggerInput("Set",0)
self.OVT:TriggerInput("Set",0)
self.KAH:TriggerInput("Set",1)
self.VBA:TriggerInput("Set",0)
self.ARS:TriggerInput("Set",0)
self.Plombs.RCAV3 = nil
self.Plombs.RCAV4 = nil
self.Plombs.RCAV5 = nil
self.Plombs.RCARS = nil
self.Plombs.OVT = nil
self.Plombs.KAH = nil
end
--------------------------------------------------------------------------------
function ENT:Think()
local RetVal = self.BaseClass.Think(self)
local Panel = self.Panel
local Pneumatic = self.Pneumatic
self:SetPackedBool("PanelLights",self.PanelLamp.Value > 0.5)
self:SetPackedBool("RedLight",Panel.RedLights>0)
self:SetPackedBool("Headlights1",Panel.Headlights1 > 0)
self:SetPackedBool("Headlights2",Panel.Headlights2 > 0)
local lightsActive2 = math.min(1,Panel.MainLights2)
local lightsActive1 = math.min(1,Panel.MainLights1)^2
local emerActive1 = Panel.EmergencyLights1
local emerActive2 = Panel.EmergencyLights2
self:SetPackedBool("Lamps_emer1",emerActive1 > 0)
self:SetPackedBool("Lamps_emer2",emerActive2 > 0)
self:SetPackedBool("Lamps_half1",lightsActive1 > 0)
self:SetPackedBool("Lamps_half2",lightsActive2 > 0)
self:SetPackedRatio("LampsStrength",lightsActive1)
-- Signal if doors are open or no to platform simulation
self.LeftDoorsOpen =
(Pneumatic.LeftDoorState[1] > 0.5) or
(Pneumatic.LeftDoorState[2] > 0.5) or
(Pneumatic.LeftDoorState[3] > 0.5) or
(Pneumatic.LeftDoorState[4] > 0.5)
self.RightDoorsOpen =
(Pneumatic.RightDoorState[1] > 0.5) or
(Pneumatic.RightDoorState[2] > 0.5) or
(Pneumatic.RightDoorState[3] > 0.5) or
(Pneumatic.RightDoorState[4] > 0.5)
local TW18 = 0
if Panel.SSN > 0 then
local wags = #self.WagonList
for _,v in ipairs(self.WagonList) do
TW18 = TW18+(v.Panel.TW18 or 0)/wags
end
end
if self.EMAType == 1 then
self:SetPackedBool("CPS_AV",Panel.SSD > 0)
self:SetPackedBool("BPSon",self.BPS.PowerLamp > 0)
self:SetPackedBool("BPSErr",self.BPS.ErrorLamp > 0)
self:SetPackedBool("BPSFail",self.BPS.FailLamp > 0)
self:SetPackedBool("ARS_04",self.MARS.NoFreq > 0)
self:SetPackedBool("ARS_00",self.MARS.F5 > 0)
self:SetPackedBool("CPS_Pd",self.MARS.F6 > 0)
self:SetPackedBool("ARS_40",self.MARS.F4 > 0)
self:SetPackedBool("ARS_60",self.MARS.F3 > 0)
self:SetPackedBool("ARS_70",self.MARS.F2 > 0)
self:SetPackedBool("ARS_80",self.MARS.F1 > 0)
self:SetPackedBool("KSRing",false)
self:SetPackedBool("MRing",Panel.Ring > 0)
self:SetPackedBool("LKVD",self.MARS.KVD > 0)
self:SetPackedBool("NMLow",Panel.NMLow > 0)
self:SetPackedBool("UAVATriggered",Panel.UAVATriggered > 0 and CurTime()%0.4>0.2)
else
self:SetPackedBool("CPS_AV",false)
self:SetPackedBool("ARS_04",self.ALSCoil.NoFreq)
self:SetPackedBool("ARS_00",self.ALSCoil.F5)
self:SetPackedBool("CPS_Pd",self.ALSCoil.F6)
self:SetPackedBool("ARS_40",self.ALSCoil.F4)
self:SetPackedBool("ARS_60",self.ALSCoil.F3)
self:SetPackedBool("ARS_70",self.ALSCoil.F2)
self:SetPackedBool("ARS_80",self.ALSCoil.F1)
self:SetPackedBool("KSRing",Panel.Ring > 0)
self:SetPackedBool("MRing",false)
if self.PB.Value > 0 and not self:GetDriver() then self.PB:TriggerInput("Set",0) end
end
--print(self.Electric.Itotal,self.LK1.Value,self.LK5.Value,self.TSH.Value,self.PR.Value)
self:SetPackedBool("CPS_SN2",TW18 > 0.5)
--print(self.RRT.Value,self.RUT.Value)--self.Scheme["25A"],self["RRTpod"])
self:SetPackedRatio("CPS_SN1",math.Clamp(TW18^0.7,0,1))
self:SetPackedBool("CPS_KS",self.KSAUP.Power > 0)
self:SetPackedBool("CPS_4",Panel.S4 > 0)
self:SetPackedBool("CPS_5",Panel.S5 > 0)
self:SetPackedBool("CPS_20",Panel.S20 > 0)
self:SetPackedBool("CPS_6",Panel.S6 > 0)
self:SetPackedBool("CPS_1",Panel.S1 > 0)
self:SetPackedBool("CPS_1P",Panel.S1P > 0)
self:SetPackedBool("CPS_3",Panel.S3 > 0)
self:SetPackedBool("CPS_2",Panel.S2 > 0)
self:SetPackedBool("CPS_RP",Panel.GreenRP > 0)
self:SetPackedBool("CPS_SD",Panel.SSD > 0)
self:SetPackedBool("CPS_DT",Panel.SDT > 0)
--print(self.Electric.Cosume)
self:SetPackedRatio("LampsCount",math.Clamp(1-self.Electric.Cosume,0.3,1))
self:SetPackedBool("LMK",Panel.LMK > 0)
self:SetPackedBool("L16",Panel.L16 > 0)
self:SetPackedBool("LRU",Panel.LRU > 0)
self:SetPackedBool("LVRD",Panel.RD > 0)
self.SOSD = Panel.SOSD > 0
self:SetPackedBool("SOSD",self.SOSD)
self:SetPackedBool("DoorsW",Panel.DoorsW > 0)
self:SetPackedBool("GRP",Panel.GreenRP > 0)
self:SetPackedBool("BrY",Panel.BrY > 0)
self:SetPackedBool("DoorsWC",Panel.DoorsWC > 0)
self:SetPackedBool("CPS_4",Panel.S4 > 0)
self:SetPackedBool("CPS_4",Panel.S4 > 0)
self.TrueBrakeAngle = self.TrueBrakeAngle or 0
if self.TrueBrakeAngle < 0.001 and self.ManualBrake < self.TrueBrakeAngle then self.TrueBrakeAngle = self.ManualBrake end
if self.TrueBrakeAngle > 0.999 and self.ManualBrake > self.TrueBrakeAngle then self.TrueBrakeAngle = self.ManualBrake end
self.TrueBrakeAngle = self.TrueBrakeAngle + (self.ManualBrake - self.TrueBrakeAngle)*2.0*(self.DeltaTime or 0)
self:SetPackedRatio("ManualBrake",self.TrueBrakeAngle)
self.BD2:TriggerInput("Set",self.PassengerDoor and 1 or 0)
self:SetPackedBool("Compressor",Pneumatic.Compressor == 1.0)
self:SetPackedBool("RK",(self.RheostatController.Velocity ~= 0.0))
self:SetPackedBool("RearDoor",self.RearDoor)
self:SetPackedBool("FrontDoor",self.FrontDoor)
self:SetPackedBool("PassengerDoor",self.PassengerDoor)
self:SetPackedBool("CabinDoor",self.CabinDoor)
self:SetPackedBool("AnnPlay",Panel.AnnouncerPlaying > 0)
self:SetPackedBool("VPR",Panel.VPR > 0)
self:SetPackedBool("LUDS",Panel.V1 > 0)
self:SetNW2Int("WrenchMode",self.KVWrenchMode)
self:SetPackedRatio("CranePosition", Pneumatic.DriverValvePosition/7)
self:SetPackedRatio("ControllerPosition", (self.KV.ControllerPosition+3)/7)
self:SetPackedRatio("ReverserPosition", 1-(self.KV.ReverserPosition+1)/2)
self:SetPackedBool("RCUPosition", self.KV.RCU > 0)
self:SetPackedRatio("BLPressure", Pneumatic.ReservoirPressure/16.0)
self:SetPackedRatio("TLPressure", Pneumatic.TrainLinePressure/16.0)
self:SetPackedRatio("BCPressure", Pneumatic.BrakeCylinderPressure/6.0)
self:SetPackedRatio("BatteryVoltage",Panel["V1"]*self.Battery.Voltage/150.0)
self:SetPackedRatio("EnginesVoltage", self.Engines.E24/2000.0)
self:SetPackedRatio("EnginesCurrent", 0.5 + 0.5*(self.Electric.I24/500.0))
self:SetPackedRatio("Speed", self.ALSCoil.Speed/100)
self:SetPackedRatio("CPS_Speed", self.KSAUP.Speed/100)
self:SetNW2Bool("UPOPlaying",self:ReadTrainWire(47) > 0)
-- Exchange some parameters between engines, pneumatic system, and real world
self.Engines:TriggerInput("Speed",self.Speed)
if IsValid(self.FrontBogey) and IsValid(self.RearBogey) and not self.IgnoreEngine then
local A = 2*self.Engines.BogeyMoment
self.FrontBogey.MotorForce = 22050+3000*(A < 0 and 1 or 0)
self.FrontBogey.Reversed = (self.Reverser.NZ > 0.5)
self.RearBogey.MotorForce = 22050+3000*(A < 0 and 1 or 0)
self.RearBogey.Reversed = (self.Reverser.VP > 0.5)
-- These corrections are required to beat source engine friction at very low values of motor power
local P = math.max(0,0.04449 + 1.06879*math.abs(A) - 0.465729*A^2)
if math.abs(A) > 0.4 then P = math.abs(A) end
if math.abs(A) < 0.05 then P = 0 end
if self.Speed < 10 then P = P*(1.0 + 0.5*(10.0-self.Speed)/10.0) end
self.RearBogey.MotorPower = P*0.5*((A > 0) and 1 or -1)
self.FrontBogey.MotorPower = P*0.5*((A > 0) and 1 or -1)
-- Apply brakes
local add = 1
if math.abs(self:GetAngles().pitch) > 4 then
add = math.min((math.abs(self:GetAngles().pitch)-4)/2,1)*2
end
self.FrontBogey.PneumaticBrakeForce = 50000.0-2000
self.FrontBogey.BrakeCylinderPressure = Pneumatic.BrakeCylinderPressure*add
self.FrontBogey.BrakeCylinderPressure_dPdT = -Pneumatic.BrakeCylinderPressure_dPdT
self.FrontBogey.ParkingBrakePressure = self.ManualBrake
self.RearBogey.PneumaticBrakeForce = 50000.0-2000
self.RearBogey.BrakeCylinderPressure = Pneumatic.BrakeCylinderPressure*add
self.RearBogey.BrakeCylinderPressure_dPdT = -Pneumatic.BrakeCylinderPressure_dPdT
end
self:GenerateJerks()
return RetVal
end
--------------------------------------------------------------------------------
function ENT:OnButtonPress(button,ply)
if string.find(button,"PneumaticBrakeSet") then
self.Pneumatic:TriggerInput("BrakeSet",tonumber(button:sub(-1,-1)))
return
end
-- Parking brake
if button == "ParkingBrakeLeft" then
self.ManualBrake = math.max(0.0,(self.ManualBrake or 0) - 0.05)
if self.ManualBrake == 0.0 then return end
end
if button == "ParkingBrakeRight" then
self.ManualBrake = math.min(1.0,(self.ManualBrake or 0) + 0.05)
if self.ManualBrake == 1.0 then return end
end
if string.find(button,"PneumaticBrakeSet") then
self.Pneumatic:TriggerInput("BrakeSet",tonumber(button:sub(-1,-1)))
return
end
if button == "FrontDoor" then self.FrontDoor = not self.FrontDoor end
if button == "RearDoor" then self.RearDoor = not self.RearDoor end
if button == "PassengerDoor" then self.PassengerDoor = not self.PassengerDoor end
if button == "CabinDoor" then self.CabinDoor = not self.CabinDoor end
-- Parking brake
if button == "ManualBrakeLeft" then
self.ManualBrake = math.max(0.0,self.ManualBrake - 0.008)
if self.ManualBrake == 0.0 then return end
--print(self.ManualBrake)
end
if button == "ManualBrakeRight" then
self.ManualBrake = math.min(1.0,self.ManualBrake + 0.008)
if self.ManualBrake == 1.0 then return end
--print(self.ManualBrake)
end
if button == "KVUp" then
if self.KV.ControllerPosition ~= -1 then
self.KV:TriggerInput("ControllerUp",1.0)
end
end
if button == "KVUp_Unlocked" then self.KV:TriggerInput("ControllerUp",1.0) end
if button == "KVDown" then self.KV:TriggerInput("ControllerDown",1.0) end
if button == "KVSetT1B" then
if self.KV.ControllerPosition == -1 then
self.KV:TriggerInput("ControllerSet",-2)
else
self.KV:TriggerInput("ControllerSet",-1)
end
end
if button == "KVSetX1B" then
if self.KV.ControllerPosition == 1 then
self.KV:TriggerInput("ControllerSet",2)
else
self.KV:TriggerInput("ControllerSet",1)
end
end
if button == "KVSetT1AB" then
if self.KV.ControllerPosition == -2 then
self.KV:TriggerInput("ControllerSet",-1)
else
self.KV:TriggerInput("ControllerSet",-2)
end
end
if button == "KVWrenchKV" or button == "KVWrenchKV9" then
if self.KVWrenchMode == 0 then
self:PlayOnce("revers_in","cabin",0.7)
self.KVWrenchMode = 1
self.KV:TriggerInput("Enabled",1)
else
self:TriggerInput(button == "KVWrenchKV9" and "KVReverserDown" or "KVReverserUp",1)
end
end
if button == "KVWrenchNone" then
if self.KVWrenchMode == 0 then
self:PlayOnce("revers_in","cabin",0.7)
self.KVWrenchMode = 3
elseif self.KVWrenchMode ~= 0 and self.KV.ReverserPosition == 0 then
self:PlayOnce("revers_out","cabin",0.7)
self.KVWrenchMode = 0
self.KV:TriggerInput("Enabled",0)
end
end
if (self.KVWrenchMode == 3) and (button == "KVReverserUp") then
self.KV:TriggerInput("RCU",1)
end
if (self.KVWrenchMode == 3) and (button == "KVReverserDown") then
self.KV:TriggerInput("RCU",0)
end
if button == "KDL" then self.KDPK:TriggerInput("Open",1) end
if button == "KDP" then self.KDPK:TriggerInput("Close",1) end
if button == "KDL" and self.VUD.Value < 1 then self.KDL:TriggerInput("Close",1) end
if button == "KDP" and self.VUD.Value < 1 then self.KDP:TriggerInput("Close",1) end
if button == "EmergencyBrake" then
self.KV:TriggerInput("ControllerSet",-3)
self.Pneumatic:TriggerInput("BrakeSet",7)
self.DriverValveBLDisconnect:TriggerInput("Set",1)
return
end
if button == "DriverValveDisconnect" then
if self.DriverValveBLDisconnect.Value == 0 or self.DriverValveTLDisconnect.Value == 0 then
self.DriverValveBLDisconnect:TriggerInput("Set",1)
self.DriverValveTLDisconnect:TriggerInput("Set",1)
else
--self:PlayOnce("pneumo_disconnect1","cabin",0.9)
self.DriverValveBLDisconnect:TriggerInput("Set",0)
self.DriverValveTLDisconnect:TriggerInput("Set",0)
end
end
if button == "VUDToggle" then
self.VDL:TriggerInput("Open",1)
self.KDL:TriggerInput("Open",1)
self.KDP:TriggerInput("Open",1)
end
if button == "GVToggle" then
if self.GV.Value > 0.5 then
self:PlayOnce("revers_f",nil,0.7)
else
self:PlayOnce("revers_b",nil,0.7)
end
return
end
if button == "KB" then
if self.EMAType == 1 then
self.PB:TriggerInput("Set",1)
else
self.KOS:TriggerInput("Set",1)
end
end
if button == "PB" then
if self.EMAType == 1 then
self.KB:TriggerInput("Set",1)
else
self.PB:TriggerInput("Set",1-self.PB.Value)
end
end
--[[if (button == "UAVAToggle") then
if self.UAVA then
if self.UAVA.Value > 0.5 then
self:PlayOnce("uava_off","cabin")
else
self:PlayOnce("uava_off","cabin")
end
end
return
end]]
if button == "EPKToggle" and self.DriverValveBLDisconnect.Value == 1.0 then
if self.EPK.Value == 0.0 then
self:PlayOnce("epv_off","cabin",0.9)
else
self:PlayOnce("epv_on","cabin",0.9)
end
return
end
end
function ENT:OnButtonRelease(button)
if string.find(button,"PneumaticBrakeSet") then
if button == "PneumaticBrakeSet1" and (self.Pneumatic.DriverValvePosition == 1) then
self.Pneumatic:TriggerInput("BrakeSet",2)
end
return
end
if button == "KB" then
if self.EMAType == 1 then
self.PB:TriggerInput("Set",0)
else
self.KOS:TriggerInput("Set",0)
end
end
if button == "PB" then
self.KB:TriggerInput("Set",0)
end
--if button == "KVT2Set" then self.KVT:TriggerInput("Open",1) end
if button == "KDL" and self.VUD.Value < 1 then self.KDL:TriggerInput("Open",1) self:OnButtonRelease("KDLSet") end
if button == "KDP" and self.VUD.Value < 1 then self.KDP:TriggerInput("Open",1) self:OnButtonRelease("KDPSet") end
if button == "KVSetT1AB" then
if self.KV.ControllerPosition > -2 then
self.KV:TriggerInput("ControllerSet",-2)
end
end
if button == "KVSetX1B" then
if self.KV.ControllerPosition > 1 then
self.KV:TriggerInput("ControllerSet",1)
end
end
if button == "KVSetT1B" then
if self.KV.ControllerPosition < -1 then
self.KV:TriggerInput("ControllerSet",-1)
end
end
end
function ENT:OnCouple(train,isfront)
if isfront and self.FrontAutoCouple then
self.FrontBrakeLineIsolation:TriggerInput("Open",1.0)
self.FrontTrainLineIsolation:TriggerInput("Open",1.0)
self.FrontAutoCouple = false
elseif not isfront and self.RearAutoCouple then
self.RearBrakeLineIsolation:TriggerInput("Open",1.0)
self.RearTrainLineIsolation:TriggerInput("Open",1.0)
self.RearAutoCouple = false
end
self.BaseClass.OnCouple(self,train,isfront)
end