mirror of
https://github.com/metrostroi-repo/MetrostroiAddon.git
synced 2026-05-02 00:42:29 +00:00
init
This commit is contained in:
75
lua/metrostroi/systems/sys_81_718_route_number.lua
Normal file
75
lua/metrostroi/systems/sys_81_718_route_number.lua
Normal file
@@ -0,0 +1,75 @@
|
||||
--------------------------------------------------------------------------------
|
||||
-- 81-718 Route number helper system
|
||||
--------------------------------------------------------------------------------
|
||||
-- Copyright (C) 2013-2018 Metrostroi Team & FoxWorks Aerospace s.r.o.
|
||||
-- Contains proprietary code. See license.txt for additional information.
|
||||
--------------------------------------------------------------------------------
|
||||
Metrostroi.DefineSystem("81_718_RouteNumber")
|
||||
TRAIN_SYSTEM.DontAccelerateSimulation = true
|
||||
if TURBOSTROI then return end
|
||||
|
||||
function TRAIN_SYSTEM:Initialize(parameter)
|
||||
self.Max = parameter or 2
|
||||
if not TURBOSTROI then
|
||||
local num = IsValid(self.Train.Owner) and (tonumber(self.Train.Owner:GetInfo("metrostroi_route_number","61")) or 0)
|
||||
self.RouteNumber = Format("%03d",num*(10^(3-self.Max))%1000)
|
||||
self.Train:SetNW2String("RouteNumber",self.RouteNumber)
|
||||
end
|
||||
end
|
||||
|
||||
function TRAIN_SYSTEM:Outputs()
|
||||
return {}
|
||||
end
|
||||
|
||||
function TRAIN_SYSTEM:Inputs()
|
||||
return {"1+","2+","1-","2-"}
|
||||
end
|
||||
|
||||
if SERVER then
|
||||
function TRAIN_SYSTEM:TriggerInput(name,value)
|
||||
local Train = self.Train
|
||||
local id = tonumber(name[1])
|
||||
if name[2]=="+" and value>0 then
|
||||
local num = tonumber(self.RouteNumber[id])+1
|
||||
if num > 9 then num = 0 end
|
||||
self.RouteNumber = self.RouteNumber:SetChar(id,num)
|
||||
Train:SetNW2String("RouteNumber",self.RouteNumber)
|
||||
end
|
||||
if name[2]=="-" and value>0 then
|
||||
local num = tonumber(self.RouteNumber[id])-1
|
||||
if num < 0 then num = 9 end
|
||||
self.RouteNumber = self.RouteNumber:SetChar(id,num)
|
||||
Train:SetNW2String("RouteNumber",self.RouteNumber)
|
||||
end
|
||||
end
|
||||
else
|
||||
function TRAIN_SYSTEM:ClientInitialize(parameter)
|
||||
self.Reloaded = false
|
||||
end
|
||||
|
||||
function TRAIN_SYSTEM:ClientThink()
|
||||
local Train = self.Train
|
||||
local scents = Train.ClientEnts
|
||||
|
||||
if self.RouteNumber ~= Train:GetNW2String("RouteNumber","00") then
|
||||
self.RouteNumber = Train:GetNW2String("RouteNumber","00")
|
||||
self.Reloaded = false
|
||||
end
|
||||
if not scents["route1"] or self.Reloaded then return end
|
||||
|
||||
self.Reloaded = true
|
||||
local rn = Format("%03d",self.RouteNumber)
|
||||
print(self.RouteNumber)
|
||||
for i=1,2 do
|
||||
if IsValid(scents["route"..i]) then
|
||||
scents["route"..i]:SetSkin(rn[i])
|
||||
end
|
||||
if IsValid(scents["route"..i.."_s"]) then
|
||||
scents["route"..i.."_s"]:SetSkin(rn[i])
|
||||
end
|
||||
if IsValid(scents["route"..i.."_r"]) then
|
||||
scents["route"..i.."_r"]:SetSkin(rn[i])
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
Reference in New Issue
Block a user