mirror of
https://github.com/FlightControl-Master/MOOSE.git
synced 2025-08-15 10:47:21 +00:00
Progress
This commit is contained in:
parent
81b0c3a050
commit
31fba973e5
@ -83,12 +83,12 @@ AI_CARGO = {
|
|||||||
-- @param Core.Set#SET_CARGO CargoSet
|
-- @param Core.Set#SET_CARGO CargoSet
|
||||||
-- @param #number CombatRadius
|
-- @param #number CombatRadius
|
||||||
-- @return #AI_CARGO
|
-- @return #AI_CARGO
|
||||||
function AI_CARGO:New( Carrier, CargoSet, CombatRadius )
|
function AI_CARGO:New( Carrier, CargoSet )
|
||||||
|
|
||||||
local self = BASE:Inherit( self, FSM_CONTROLLABLE:New() ) -- #AI_CARGO
|
local self = BASE:Inherit( self, FSM_CONTROLLABLE:New( Carrier ) ) -- #AI_CARGO
|
||||||
|
|
||||||
self.CargoSet = CargoSet -- Core.Set#SET_CARGO
|
self.CargoSet = CargoSet -- Core.Set#SET_CARGO
|
||||||
self.CombatRadius = CombatRadius
|
self.CargoCarrier = Carrier -- Wrapper.Group#GROUP
|
||||||
|
|
||||||
self:SetStartState( "Unloaded" )
|
self:SetStartState( "Unloaded" )
|
||||||
|
|
||||||
@ -105,14 +105,6 @@ function AI_CARGO:New( Carrier, CargoSet, CombatRadius )
|
|||||||
self:AddTransition( "Unboarding", "Unloaded", "Unboarding" )
|
self:AddTransition( "Unboarding", "Unloaded", "Unboarding" )
|
||||||
self:AddTransition( "Unboarding", "Deployed", "Unloaded" )
|
self:AddTransition( "Unboarding", "Deployed", "Unloaded" )
|
||||||
|
|
||||||
self:AddTransition( "*", "Monitor", "*" )
|
|
||||||
self:AddTransition( "*", "Follow", "Following" )
|
|
||||||
self:AddTransition( "*", "Guard", "Unloaded" )
|
|
||||||
self:AddTransition( "*", "Home", "*" )
|
|
||||||
|
|
||||||
self:AddTransition( "*", "Destroyed", "Destroyed" )
|
|
||||||
|
|
||||||
|
|
||||||
--- Pickup Handler OnBefore for AI_CARGO
|
--- Pickup Handler OnBefore for AI_CARGO
|
||||||
-- @function [parent=#AI_CARGO] OnBeforePickup
|
-- @function [parent=#AI_CARGO] OnBeforePickup
|
||||||
-- @param #AI_CARGO self
|
-- @param #AI_CARGO self
|
||||||
@ -194,11 +186,6 @@ function AI_CARGO:New( Carrier, CargoSet, CombatRadius )
|
|||||||
-- @param #string Event
|
-- @param #string Event
|
||||||
-- @param #string To
|
-- @param #string To
|
||||||
|
|
||||||
|
|
||||||
self:__Monitor( 1 )
|
|
||||||
|
|
||||||
self:SetCarrier( Carrier )
|
|
||||||
|
|
||||||
for _, CarrierUnit in pairs( Carrier:GetUnits() ) do
|
for _, CarrierUnit in pairs( Carrier:GetUnits() ) do
|
||||||
CarrierUnit:SetCargoBayWeightLimit()
|
CarrierUnit:SetCargoBayWeightLimit()
|
||||||
end
|
end
|
||||||
@ -210,53 +197,6 @@ function AI_CARGO:New( Carrier, CargoSet, CombatRadius )
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
--- Set the Carrier.
|
|
||||||
-- @param #AI_CARGO self
|
|
||||||
-- @param Wrapper.Group#GROUP CargoCarrier
|
|
||||||
-- @return #AI_CARGO
|
|
||||||
function AI_CARGO:SetCarrier( CargoCarrier )
|
|
||||||
|
|
||||||
self.CargoCarrier = CargoCarrier -- Wrapper.Group#GROUP
|
|
||||||
self.CargoCarrier:SetState( self.CargoCarrier, "AI_CARGO", self )
|
|
||||||
|
|
||||||
CargoCarrier:HandleEvent( EVENTS.Dead )
|
|
||||||
CargoCarrier:HandleEvent( EVENTS.Hit )
|
|
||||||
|
|
||||||
function CargoCarrier:OnEventDead( EventData )
|
|
||||||
self:F({"dead"})
|
|
||||||
local AICargoTroops = self:GetState( self, "AI_CARGO" )
|
|
||||||
self:F({AICargoTroops=AICargoTroops})
|
|
||||||
if AICargoTroops then
|
|
||||||
self:F({})
|
|
||||||
if not AICargoTroops:Is( "Loaded" ) then
|
|
||||||
-- There are enemies within combat range. Unload the CargoCarrier.
|
|
||||||
AICargoTroops:Destroyed()
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
function CargoCarrier:OnEventHit( EventData )
|
|
||||||
self:F({"hit"})
|
|
||||||
local AICargoTroops = self:GetState( self, "AI_CARGO" )
|
|
||||||
if AICargoTroops then
|
|
||||||
self:F( { OnHitLoaded = AICargoTroops:Is( "Loaded" ) } )
|
|
||||||
if AICargoTroops:Is( "Loaded" ) or AICargoTroops:Is( "Boarding" ) then
|
|
||||||
-- There are enemies within combat range. Unload the CargoCarrier.
|
|
||||||
AICargoTroops:Unload( false )
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
self.Zone = ZONE_UNIT:New( self.CargoCarrier:GetName() .. "-Zone", self.CargoCarrier, self.CombatRadius )
|
|
||||||
self.Coalition = self.CargoCarrier:GetCoalition()
|
|
||||||
|
|
||||||
self:SetControllable( CargoCarrier )
|
|
||||||
|
|
||||||
self:Guard()
|
|
||||||
|
|
||||||
return self
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
function AI_CARGO:IsTransporting()
|
function AI_CARGO:IsTransporting()
|
||||||
|
|
||||||
@ -268,144 +208,6 @@ function AI_CARGO:IsRelocating()
|
|||||||
return self.Relocating == true
|
return self.Relocating == true
|
||||||
end
|
end
|
||||||
|
|
||||||
--- Find a free Carrier within a range.
|
|
||||||
-- @param #AI_CARGO self
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate
|
|
||||||
-- @param #number Radius
|
|
||||||
-- @return Wrapper.Group#GROUP NewCarrier
|
|
||||||
function AI_CARGO:FindCarrier( Coordinate, Radius )
|
|
||||||
|
|
||||||
local CoordinateZone = ZONE_RADIUS:New( "Zone" , Coordinate:GetVec2(), Radius )
|
|
||||||
CoordinateZone:Scan( { Object.Category.UNIT } )
|
|
||||||
for _, DCSUnit in pairs( CoordinateZone:GetScannedUnits() ) do
|
|
||||||
local NearUnit = UNIT:Find( DCSUnit )
|
|
||||||
self:F({NearUnit=NearUnit})
|
|
||||||
if not NearUnit:GetState( NearUnit, "AI_CARGO" ) then
|
|
||||||
local Attributes = NearUnit:GetDesc()
|
|
||||||
self:F({Desc=Attributes})
|
|
||||||
if NearUnit:HasAttribute( "Trucks" ) then
|
|
||||||
return NearUnit:GetGroup()
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return nil
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--- Follow Infantry to the Carrier.
|
|
||||||
-- @param #AI_CARGO self
|
|
||||||
-- @param #AI_CARGO Me
|
|
||||||
-- @param Wrapper.Unit#UNIT CarrierUnit
|
|
||||||
-- @param Cargo.CargoGroup#CARGO_GROUP Cargo
|
|
||||||
-- @return #AI_CARGO
|
|
||||||
function AI_CARGO:FollowToCarrier( Me, CarrierUnit, CargoGroup )
|
|
||||||
|
|
||||||
local InfantryGroup = CargoGroup:GetGroup()
|
|
||||||
|
|
||||||
self:F( { self = self:GetClassNameAndID(), InfantryGroup = InfantryGroup:GetName() } )
|
|
||||||
|
|
||||||
--if self:Is( "Following" ) then
|
|
||||||
|
|
||||||
if CarrierUnit:IsAlive() then
|
|
||||||
-- We check if the Cargo is near to the CargoCarrier.
|
|
||||||
if InfantryGroup:IsPartlyInZone( ZONE_UNIT:New( "Radius", CarrierUnit, 25 ) ) then
|
|
||||||
|
|
||||||
-- The Cargo does not need to follow the Carrier.
|
|
||||||
Me:Guard()
|
|
||||||
|
|
||||||
else
|
|
||||||
|
|
||||||
self:F( { InfantryGroup = InfantryGroup:GetName() } )
|
|
||||||
|
|
||||||
if InfantryGroup:IsAlive() then
|
|
||||||
|
|
||||||
self:F( { InfantryGroup = InfantryGroup:GetName() } )
|
|
||||||
|
|
||||||
local Waypoints = {}
|
|
||||||
|
|
||||||
-- Calculate the new Route.
|
|
||||||
local FromCoord = InfantryGroup:GetCoordinate()
|
|
||||||
local FromGround = FromCoord:WaypointGround( 10, "Diamond" )
|
|
||||||
self:F({FromGround=FromGround})
|
|
||||||
table.insert( Waypoints, FromGround )
|
|
||||||
|
|
||||||
local ToCoord = CarrierUnit:GetCoordinate():GetRandomCoordinateInRadius( 10, 5 )
|
|
||||||
local ToGround = ToCoord:WaypointGround( 10, "Diamond" )
|
|
||||||
self:F({ToGround=ToGround})
|
|
||||||
table.insert( Waypoints, ToGround )
|
|
||||||
|
|
||||||
local TaskRoute = InfantryGroup:TaskFunction( "AI_CARGO.FollowToCarrier", Me, CarrierUnit, CargoGroup )
|
|
||||||
|
|
||||||
self:F({Waypoints = Waypoints})
|
|
||||||
local Waypoint = Waypoints[#Waypoints]
|
|
||||||
InfantryGroup:SetTaskWaypoint( Waypoint, TaskRoute ) -- Set for the given Route at Waypoint 2 the TaskRouteToZone.
|
|
||||||
|
|
||||||
InfantryGroup:Route( Waypoints, 1 ) -- Move after a random seconds to the Route. See the Route method for details.
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--- On after Monitor event.
|
|
||||||
-- @param #AI_CARGO self
|
|
||||||
-- @param Wrapper.Group#GROUP Carrier
|
|
||||||
-- @param #string From From state.
|
|
||||||
-- @param #string Event Event.
|
|
||||||
-- @param #string To To state.
|
|
||||||
function AI_CARGO:onafterMonitor( Carrier, From, Event, To )
|
|
||||||
self:F( { Carrier, From, Event, To } )
|
|
||||||
|
|
||||||
if Carrier and Carrier:IsAlive() then
|
|
||||||
if self.CarrierCoordinate then
|
|
||||||
if self:IsRelocating() == true then
|
|
||||||
local Coordinate = Carrier:GetCoordinate()
|
|
||||||
self.Zone:Scan( { Object.Category.UNIT } )
|
|
||||||
if self.Zone:IsAllInZoneOfCoalition( self.Coalition ) then
|
|
||||||
if self:Is( "Unloaded" ) or self:Is( "Following" ) then
|
|
||||||
-- There are no enemies within combat range. Load the CargoCarrier.
|
|
||||||
self:Load()
|
|
||||||
end
|
|
||||||
else
|
|
||||||
if self:Is( "Loaded" ) then
|
|
||||||
-- There are enemies within combat range. Unload the CargoCarrier.
|
|
||||||
self:__Unload( 1 )
|
|
||||||
else
|
|
||||||
if self:Is( "Unloaded" ) then
|
|
||||||
self:Follow()
|
|
||||||
end
|
|
||||||
if self:Is( "Following" ) then
|
|
||||||
for Cargo, CarrierUnit in pairs( self.Carrier_Cargo ) do
|
|
||||||
local Cargo = Cargo -- Cargo.Cargo#CARGO
|
|
||||||
if Cargo:IsAlive() then
|
|
||||||
if not Cargo:IsNear( CarrierUnit, 40 ) then
|
|
||||||
CarrierUnit:RouteStop()
|
|
||||||
self.CarrierStopped = true
|
|
||||||
else
|
|
||||||
if self.CarrierStopped then
|
|
||||||
if Cargo:IsNear( CarrierUnit, 25 ) then
|
|
||||||
CarrierUnit:RouteResume()
|
|
||||||
self.CarrierStopped = nil
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
self.CarrierCoordinate = Carrier:GetCoordinate()
|
|
||||||
end
|
|
||||||
|
|
||||||
self:__Monitor( -5 )
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--- On before Load event.
|
--- On before Load event.
|
||||||
@ -489,7 +291,6 @@ function AI_CARGO:onbeforeLoad( Carrier, From, Event, To, PickupZone )
|
|||||||
|
|
||||||
if not Loaded then
|
if not Loaded then
|
||||||
-- If the cargo wasn't loaded in one of the carriers, then we need to stop the loading.
|
-- If the cargo wasn't loaded in one of the carriers, then we need to stop the loading.
|
||||||
break
|
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
@ -678,146 +479,3 @@ function AI_CARGO:onafterDeployed( Carrier, From, Event, To, DeployZone )
|
|||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
--- On after Follow event.
|
|
||||||
-- @param #AI_CARGO self
|
|
||||||
-- @param Wrapper.Group#GROUP Carrier
|
|
||||||
-- @param #string From From state.
|
|
||||||
-- @param #string Event Event.
|
|
||||||
-- @param #string To To state.
|
|
||||||
function AI_CARGO:onafterFollow( Carrier, From, Event, To )
|
|
||||||
self:F( { Carrier, From, Event, To } )
|
|
||||||
|
|
||||||
self:F( "Follow" )
|
|
||||||
if Carrier and Carrier:IsAlive() then
|
|
||||||
for Cargo, CarrierUnit in pairs( self.Carrier_Cargo ) do
|
|
||||||
local Cargo = Cargo -- Cargo.Cargo#CARGO
|
|
||||||
if Cargo:IsUnLoaded() then
|
|
||||||
self:FollowToCarrier( self, CarrierUnit, Cargo )
|
|
||||||
CarrierUnit:RouteResume()
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--- @param #AI_CARGO
|
|
||||||
-- @param Wrapper.Group#GROUP Carrier
|
|
||||||
function AI_CARGO._Pickup( Carrier, self, PickupZone )
|
|
||||||
|
|
||||||
Carrier:F( { "AI_CARGO._Pickup:", Carrier:GetName() } )
|
|
||||||
|
|
||||||
if Carrier:IsAlive() then
|
|
||||||
self:Load( PickupZone)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
function AI_CARGO._Deploy( Carrier, self, Coordinate, DeployZone )
|
|
||||||
|
|
||||||
Carrier:F( { "AI_CARGO._Deploy:", Carrier } )
|
|
||||||
|
|
||||||
if Carrier:IsAlive() then
|
|
||||||
self:Unload( DeployZone )
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--- On after Pickup event.
|
|
||||||
-- @param #AI_CARGO self
|
|
||||||
-- @param Wrapper.Group#GROUP Carrier
|
|
||||||
-- @param From
|
|
||||||
-- @param Event
|
|
||||||
-- @param To
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate of the pickup point.
|
|
||||||
-- @param #number Speed Speed in km/h to drive to the pickup coordinate. Default is 50% of max possible speed the unit can go.
|
|
||||||
-- @param Core.Zone#ZONE PickupZone (optional) The zone where the cargo will be picked up. The PickupZone can be nil, if there wasn't any PickupZoneSet provided.
|
|
||||||
function AI_CARGO:onafterPickup( Carrier, From, Event, To, Coordinate, Speed, PickupZone )
|
|
||||||
|
|
||||||
if Carrier and Carrier:IsAlive() then
|
|
||||||
|
|
||||||
if Coordinate then
|
|
||||||
self.RoutePickup = true
|
|
||||||
|
|
||||||
local _speed=Speed or Carrier:GetSpeedMax()*0.5
|
|
||||||
|
|
||||||
local Waypoints = Carrier:TaskGroundOnRoad( Coordinate, _speed, "Line abreast", true )
|
|
||||||
|
|
||||||
local TaskFunction = Carrier:TaskFunction( "AI_CARGO._Pickup", self, PickupZone )
|
|
||||||
|
|
||||||
self:F({Waypoints = Waypoints})
|
|
||||||
local Waypoint = Waypoints[#Waypoints]
|
|
||||||
Carrier:SetTaskWaypoint( Waypoint, TaskFunction ) -- Set for the given Route at Waypoint 2 the TaskRouteToZone.
|
|
||||||
|
|
||||||
Carrier:Route( Waypoints, 1 ) -- Move after a random seconds to the Route. See the Route method for details.
|
|
||||||
else
|
|
||||||
AI_CARGO._Pickup( Carrier, self, PickupZone )
|
|
||||||
end
|
|
||||||
|
|
||||||
self.Relocating = true
|
|
||||||
self.Transporting = false
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--- On after Deploy event.
|
|
||||||
-- @param #AI_CARGO self
|
|
||||||
-- @param Wrapper.Group#GROUP Carrier
|
|
||||||
-- @param From
|
|
||||||
-- @param Event
|
|
||||||
-- @param To
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate Deploy place.
|
|
||||||
-- @param #number Speed Speed in km/h to drive to the depoly coordinate. Default is 50% of max possible speed the unit can go.
|
|
||||||
function AI_CARGO:onafterDeploy( Carrier, From, Event, To, Coordinate, Speed, DeployZone )
|
|
||||||
|
|
||||||
if Carrier and Carrier:IsAlive() then
|
|
||||||
|
|
||||||
self.RouteDeploy = true
|
|
||||||
|
|
||||||
local _speed=Speed or Carrier:GetSpeedMax()*0.5
|
|
||||||
|
|
||||||
local Waypoints = Carrier:TaskGroundOnRoad( Coordinate, _speed, "Line abreast", true )
|
|
||||||
|
|
||||||
local TaskFunction = Carrier:TaskFunction( "AI_CARGO._Deploy", self, Coordinate, DeployZone )
|
|
||||||
|
|
||||||
self:F({Waypoints = Waypoints})
|
|
||||||
local Waypoint = Waypoints[#Waypoints]
|
|
||||||
Carrier:SetTaskWaypoint( Waypoint, TaskFunction ) -- Set for the given Route at Waypoint 2 the TaskRouteToZone.
|
|
||||||
|
|
||||||
Carrier:Route( Waypoints, 1 ) -- Move after a random seconds to the Route. See the Route method for details.
|
|
||||||
|
|
||||||
self.Relocating = false
|
|
||||||
self.Transporting = true
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
--- On after Home event.
|
|
||||||
-- @param #AI_CARGO self
|
|
||||||
-- @param Wrapper.Group#GROUP Carrier
|
|
||||||
-- @param From
|
|
||||||
-- @param Event
|
|
||||||
-- @param To
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate Home place.
|
|
||||||
-- @param #number Speed Speed in km/h to drive to the pickup coordinate. Default is 50% of max possible speed the unit can go.
|
|
||||||
function AI_CARGO:onafterHome( Carrier, From, Event, To, Coordinate, Speed )
|
|
||||||
|
|
||||||
if Carrier and Carrier:IsAlive() ~= nil then
|
|
||||||
|
|
||||||
self.RouteHome = true
|
|
||||||
|
|
||||||
local _speed=Speed or Carrier:GetSpeedMax()*0.5
|
|
||||||
|
|
||||||
local Waypoints = Carrier:TaskGroundOnRoad( Coordinate, _speed, "Line abreast", true )
|
|
||||||
|
|
||||||
self:F({Waypoints = Waypoints})
|
|
||||||
local Waypoint = Waypoints[#Waypoints]
|
|
||||||
|
|
||||||
Carrier:Route( Waypoints, 1 ) -- Move after a random seconds to the Route. See the Route method for details.
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|||||||
@ -10,7 +10,7 @@
|
|||||||
-- @image AI_Cargo_Dispatching_For_APC.JPG
|
-- @image AI_Cargo_Dispatching_For_APC.JPG
|
||||||
|
|
||||||
--- @type AI_CARGO_APC
|
--- @type AI_CARGO_APC
|
||||||
-- @extends Core.Fsm#FSM_CONTROLLABLE
|
-- @extends AI.AI_Cargo#AI_CARGO
|
||||||
|
|
||||||
|
|
||||||
--- Brings a dynamic cargo handling capability for AI groups.
|
--- Brings a dynamic cargo handling capability for AI groups.
|
||||||
@ -74,7 +74,6 @@
|
|||||||
AI_CARGO_APC = {
|
AI_CARGO_APC = {
|
||||||
ClassName = "AI_CARGO_APC",
|
ClassName = "AI_CARGO_APC",
|
||||||
Coordinate = nil, -- Core.Point#COORDINATE,
|
Coordinate = nil, -- Core.Point#COORDINATE,
|
||||||
APC_Cargo = {},
|
|
||||||
}
|
}
|
||||||
|
|
||||||
--- Creates a new AI_CARGO_APC object.
|
--- Creates a new AI_CARGO_APC object.
|
||||||
@ -85,26 +84,10 @@ AI_CARGO_APC = {
|
|||||||
-- @return #AI_CARGO_APC
|
-- @return #AI_CARGO_APC
|
||||||
function AI_CARGO_APC:New( APC, CargoSet, CombatRadius )
|
function AI_CARGO_APC:New( APC, CargoSet, CombatRadius )
|
||||||
|
|
||||||
local self = BASE:Inherit( self, FSM_CONTROLLABLE:New() ) -- #AI_CARGO_APC
|
local self = BASE:Inherit( self, AI_CARGO:New( APC, CargoSet ) ) -- #AI_CARGO_APC
|
||||||
|
|
||||||
self.CargoSet = CargoSet -- Core.Set#SET_CARGO
|
|
||||||
self.CombatRadius = CombatRadius
|
self.CombatRadius = CombatRadius
|
||||||
|
|
||||||
self:SetStartState( "Unloaded" )
|
|
||||||
|
|
||||||
self:AddTransition( "Unloaded", "Pickup", "*" )
|
|
||||||
self:AddTransition( "Loaded", "Deploy", "*" )
|
|
||||||
|
|
||||||
self:AddTransition( "*", "Load", "Boarding" )
|
|
||||||
self:AddTransition( { "Boarding", "Loaded" }, "Board", "Boarding" )
|
|
||||||
self:AddTransition( "Boarding", "Loaded", "Boarding" )
|
|
||||||
self:AddTransition( "Boarding", "PickedUp", "Loaded" )
|
|
||||||
|
|
||||||
self:AddTransition( "Loaded", "Unload", "Unboarding" )
|
|
||||||
self:AddTransition( "Unboarding", "Unboard", "Unboarding" )
|
|
||||||
self:AddTransition( "Unboarding", "Unloaded", "Unboarding" )
|
|
||||||
self:AddTransition( "Unboarding", "Deployed", "Unloaded" )
|
|
||||||
|
|
||||||
self:AddTransition( "*", "Monitor", "*" )
|
self:AddTransition( "*", "Monitor", "*" )
|
||||||
self:AddTransition( "*", "Follow", "Following" )
|
self:AddTransition( "*", "Follow", "Following" )
|
||||||
self:AddTransition( "*", "Guard", "Unloaded" )
|
self:AddTransition( "*", "Guard", "Unloaded" )
|
||||||
@ -112,100 +95,10 @@ function AI_CARGO_APC:New( APC, CargoSet, CombatRadius )
|
|||||||
|
|
||||||
self:AddTransition( "*", "Destroyed", "Destroyed" )
|
self:AddTransition( "*", "Destroyed", "Destroyed" )
|
||||||
|
|
||||||
|
|
||||||
--- Pickup Handler OnBefore for AI_CARGO_APC
|
|
||||||
-- @function [parent=#AI_CARGO_APC] OnBeforePickup
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param #string From
|
|
||||||
-- @param #string Event
|
|
||||||
-- @param #string To
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate
|
|
||||||
-- @param #number Speed Speed in km/h. Default is 50% of max possible speed the group can do.
|
|
||||||
-- @return #boolean
|
|
||||||
|
|
||||||
--- Pickup Handler OnAfter for AI_CARGO_APC
|
|
||||||
-- @function [parent=#AI_CARGO_APC] OnAfterPickup
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param #string From
|
|
||||||
-- @param #string Event
|
|
||||||
-- @param #string To
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate
|
|
||||||
-- @param #number Speed Speed in km/h. Default is 50% of max possible speed the group can do.
|
|
||||||
|
|
||||||
--- Pickup Trigger for AI_CARGO_APC
|
|
||||||
-- @function [parent=#AI_CARGO_APC] Pickup
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate
|
|
||||||
-- @param #number Speed Speed in km/h. Default is 50% of max possible speed the group can do.
|
|
||||||
|
|
||||||
--- Pickup Asynchronous Trigger for AI_CARGO_APC
|
|
||||||
-- @function [parent=#AI_CARGO_APC] __Pickup
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param #number Delay
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate Pickup place. If not given, loading starts at the current location.
|
|
||||||
-- @param #number Speed Speed in km/h. Default is 50% of max possible speed the group can do.
|
|
||||||
|
|
||||||
--- Deploy Handler OnBefore for AI_CARGO_APC
|
|
||||||
-- @function [parent=#AI_CARGO_APC] OnBeforeDeploy
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param #string From
|
|
||||||
-- @param #string Event
|
|
||||||
-- @param #string To
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate
|
|
||||||
-- @param #number Speed Speed in km/h. Default is 50% of max possible speed the group can do.
|
|
||||||
-- @return #boolean
|
|
||||||
|
|
||||||
--- Deploy Handler OnAfter for AI_CARGO_APC
|
|
||||||
-- @function [parent=#AI_CARGO_APC] OnAfterDeploy
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param #string From
|
|
||||||
-- @param #string Event
|
|
||||||
-- @param #string To
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate
|
|
||||||
-- @param #number Speed Speed in km/h. Default is 50% of max possible speed the group can do.
|
|
||||||
|
|
||||||
--- Deploy Trigger for AI_CARGO_APC
|
|
||||||
-- @function [parent=#AI_CARGO_APC] Deploy
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate
|
|
||||||
-- @param #number Speed Speed in km/h. Default is 50% of max possible speed the group can do.
|
|
||||||
|
|
||||||
--- Deploy Asynchronous Trigger for AI_CARGO_APC
|
|
||||||
-- @function [parent=#AI_CARGO_APC] __Deploy
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param #number Delay
|
|
||||||
-- @param Core.Point#COORDINATE Coordinate
|
|
||||||
-- @param #number Speed Speed in km/h. Default is 50% of max possible speed the group can do.
|
|
||||||
|
|
||||||
|
|
||||||
--- Loaded Handler OnAfter for AI_CARGO_APC
|
|
||||||
-- @function [parent=#AI_CARGO_APC] OnAfterLoaded
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Wrapper.Group#GROUP APC
|
|
||||||
-- @param #string From
|
|
||||||
-- @param #string Event
|
|
||||||
-- @param #string To
|
|
||||||
|
|
||||||
--- Unloaded Handler OnAfter for AI_CARGO_APC
|
|
||||||
-- @function [parent=#AI_CARGO_APC] OnAfterUnloaded
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Wrapper.Group#GROUP APC
|
|
||||||
-- @param #string From
|
|
||||||
-- @param #string Event
|
|
||||||
-- @param #string To
|
|
||||||
|
|
||||||
|
|
||||||
self:__Monitor( 1 )
|
self:__Monitor( 1 )
|
||||||
|
|
||||||
self:SetCarrier( APC )
|
self:SetCarrier( APC )
|
||||||
|
|
||||||
for _, APCUnit in pairs( APC:GetUnits() ) do
|
|
||||||
APCUnit:SetCargoBayWeightLimit()
|
|
||||||
end
|
|
||||||
|
|
||||||
self.Transporting = false
|
|
||||||
self.Relocating = false
|
|
||||||
|
|
||||||
return self
|
return self
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -258,16 +151,6 @@ function AI_CARGO_APC:SetCarrier( CargoCarrier )
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
function AI_CARGO_APC:IsTransporting()
|
|
||||||
|
|
||||||
return self.Transporting == true
|
|
||||||
end
|
|
||||||
|
|
||||||
function AI_CARGO_APC:IsRelocating()
|
|
||||||
|
|
||||||
return self.Relocating == true
|
|
||||||
end
|
|
||||||
|
|
||||||
--- Find a free Carrier within a range.
|
--- Find a free Carrier within a range.
|
||||||
-- @param #AI_CARGO_APC self
|
-- @param #AI_CARGO_APC self
|
||||||
-- @param Core.Point#COORDINATE Coordinate
|
-- @param Core.Point#COORDINATE Coordinate
|
||||||
@ -361,7 +244,7 @@ function AI_CARGO_APC:onafterMonitor( APC, From, Event, To )
|
|||||||
|
|
||||||
if APC and APC:IsAlive() then
|
if APC and APC:IsAlive() then
|
||||||
if self.CarrierCoordinate then
|
if self.CarrierCoordinate then
|
||||||
if self:IsRelocating() == true then
|
if self:IsTransporting() == true then
|
||||||
local Coordinate = APC:GetCoordinate()
|
local Coordinate = APC:GetCoordinate()
|
||||||
self.Zone:Scan( { Object.Category.UNIT } )
|
self.Zone:Scan( { Object.Category.UNIT } )
|
||||||
if self.Zone:IsAllInZoneOfCoalition( self.Coalition ) then
|
if self.Zone:IsAllInZoneOfCoalition( self.Coalition ) then
|
||||||
@ -378,7 +261,7 @@ function AI_CARGO_APC:onafterMonitor( APC, From, Event, To )
|
|||||||
self:Follow()
|
self:Follow()
|
||||||
end
|
end
|
||||||
if self:Is( "Following" ) then
|
if self:Is( "Following" ) then
|
||||||
for Cargo, APCUnit in pairs( self.APC_Cargo ) do
|
for Cargo, APCUnit in pairs( self.Carrier_Cargo ) do
|
||||||
local Cargo = Cargo -- Cargo.Cargo#CARGO
|
local Cargo = Cargo -- Cargo.Cargo#CARGO
|
||||||
if Cargo:IsAlive() then
|
if Cargo:IsAlive() then
|
||||||
if not Cargo:IsNear( APCUnit, 40 ) then
|
if not Cargo:IsNear( APCUnit, 40 ) then
|
||||||
@ -408,276 +291,6 @@ function AI_CARGO_APC:onafterMonitor( APC, From, Event, To )
|
|||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
--- On before Load event.
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Wrapper.Group#GROUP APC
|
|
||||||
-- @param #string From From state.
|
|
||||||
-- @param #string Event Event.
|
|
||||||
-- @param #string To To state.
|
|
||||||
-- @param Core.Zone#ZONE PickupZone (optional) The zone where the cargo will be picked up. The PickupZone can be nil, if there wasn't any PickupZoneSet provided.
|
|
||||||
function AI_CARGO_APC:onbeforeLoad( APC, From, Event, To, PickupZone )
|
|
||||||
self:F( { APC, From, Event, To } )
|
|
||||||
|
|
||||||
local Boarding = false
|
|
||||||
|
|
||||||
local LoadInterval = 10
|
|
||||||
local LoadDelay = 10
|
|
||||||
local APC_List = {}
|
|
||||||
local APC_Weight = {}
|
|
||||||
|
|
||||||
if APC and APC:IsAlive() then
|
|
||||||
self.APC_Cargo = {}
|
|
||||||
for _, APCUnit in pairs( APC:GetUnits() ) do
|
|
||||||
local APCUnit = APCUnit -- Wrapper.Unit#UNIT
|
|
||||||
|
|
||||||
local CargoBayFreeWeight = APCUnit:GetCargoBayFreeWeight()
|
|
||||||
self:F({CargoBayFreeWeight=CargoBayFreeWeight})
|
|
||||||
|
|
||||||
APC_List[#APC_List+1] = APCUnit
|
|
||||||
APC_Weight[APCUnit] = CargoBayFreeWeight
|
|
||||||
end
|
|
||||||
|
|
||||||
local APC_Count = #APC_List
|
|
||||||
local APC_Index = 1
|
|
||||||
|
|
||||||
for _, Cargo in UTILS.spairs( self.CargoSet:GetSet(), function( t, a, b ) return t[a]:GetWeight() > t[b]:GetWeight() end ) do
|
|
||||||
local Cargo = Cargo -- Cargo.Cargo#CARGO
|
|
||||||
|
|
||||||
self:F( { IsUnLoaded = Cargo:IsUnLoaded(), IsDeployed = Cargo:IsDeployed(), Cargo:GetName(), APC:GetName() } )
|
|
||||||
|
|
||||||
local Loaded = false
|
|
||||||
|
|
||||||
-- Try all APCs, but start from the one according the APC_Index
|
|
||||||
for APC_Loop = 1, #APC_List do
|
|
||||||
|
|
||||||
local APCUnit = APC_List[APC_Index] -- Wrapper.Unit#UNIT
|
|
||||||
|
|
||||||
-- This counters loop through the available APCs.
|
|
||||||
APC_Index = APC_Index + 1
|
|
||||||
if APC_Index > APC_Count then
|
|
||||||
APC_Index = 1
|
|
||||||
end
|
|
||||||
|
|
||||||
if Cargo:IsUnLoaded() then -- and not Cargo:IsDeployed() then
|
|
||||||
if Cargo:IsInLoadRadius( APCUnit:GetCoordinate() ) then
|
|
||||||
self:F( { "In radius", APCUnit:GetName() } )
|
|
||||||
|
|
||||||
local CargoWeight = Cargo:GetWeight()
|
|
||||||
|
|
||||||
-- Only when there is space within the bay to load the next cargo item!
|
|
||||||
if APC_Weight[APCUnit] > CargoWeight then --and CargoBayFreeVolume > CargoVolume then
|
|
||||||
APC:RouteStop()
|
|
||||||
--Cargo:Ungroup()
|
|
||||||
Cargo:__Board( LoadDelay, APCUnit, 25 )
|
|
||||||
LoadDelay = LoadDelay + LoadInterval
|
|
||||||
self:__Board( LoadDelay, Cargo, APCUnit, PickupZone )
|
|
||||||
|
|
||||||
-- So now this APCUnit has Cargo that is being loaded.
|
|
||||||
-- This will be used further in the logic to follow and to check cargo status.
|
|
||||||
self.APC_Cargo[Cargo] = APCUnit
|
|
||||||
Boarding = true
|
|
||||||
APC_Weight[APCUnit] = APC_Weight[APCUnit] - CargoWeight
|
|
||||||
Loaded = true
|
|
||||||
|
|
||||||
-- Ok, we loaded a cargo, now we can stop the loop.
|
|
||||||
break
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
if not Loaded then
|
|
||||||
-- If the cargo wasn't loaded in one of the carriers, then we need to stop the loading.
|
|
||||||
break
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
return Boarding
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
--- On after Board event.
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Wrapper.Group#GROUP APC
|
|
||||||
-- @param #string From From state.
|
|
||||||
-- @param #string Event Event.
|
|
||||||
-- @param #string To To state.
|
|
||||||
-- @param Cargo.Cargo#CARGO Cargo Cargo object.
|
|
||||||
-- @param Wrapper.Unit#UNIT APCUnit
|
|
||||||
-- @param Core.Zone#ZONE PickupZone (optional) The zone where the cargo will be picked up. The PickupZone can be nil, if there wasn't any PickupZoneSet provided.
|
|
||||||
function AI_CARGO_APC:onafterBoard( APC, From, Event, To, Cargo, APCUnit, PickupZone )
|
|
||||||
self:F( { APC, From, Event, To, Cargo, APCUnit:GetName() } )
|
|
||||||
|
|
||||||
if APC and APC:IsAlive() then
|
|
||||||
self:F({ IsLoaded = Cargo:IsLoaded(), Cargo:GetName(), APC:GetName() } )
|
|
||||||
if not Cargo:IsLoaded() then
|
|
||||||
self:__Board( 10, Cargo, APCUnit, PickupZone )
|
|
||||||
return
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
self:__Loaded( 10, Cargo, APCUnit, PickupZone )
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
--- On after Loaded event.
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Wrapper.Group#GROUP APC
|
|
||||||
-- @param #string From From state.
|
|
||||||
-- @param #string Event Event.
|
|
||||||
-- @param #string To To state.
|
|
||||||
-- @return #boolean Cargo loaded.
|
|
||||||
-- @param Core.Zone#ZONE PickupZone (optional) The zone where the cargo will be picked up. The PickupZone can be nil, if there wasn't any PickupZoneSet provided.
|
|
||||||
function AI_CARGO_APC:onafterLoaded( APC, From, Event, To, Cargo, PickupZone )
|
|
||||||
self:F( { APC, From, Event, To } )
|
|
||||||
|
|
||||||
local Loaded = true
|
|
||||||
|
|
||||||
if APC and APC:IsAlive() then
|
|
||||||
for Cargo, APCUnit in pairs( self.APC_Cargo ) do
|
|
||||||
local Cargo = Cargo -- Cargo.Cargo#CARGO
|
|
||||||
self:F( { IsLoaded = Cargo:IsLoaded(), IsDestroyed = Cargo:IsDestroyed(), Cargo:GetName(), APC:GetName() } )
|
|
||||||
if not Cargo:IsLoaded() and not Cargo:IsDestroyed() then
|
|
||||||
Loaded = false
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if Loaded then
|
|
||||||
self:PickedUp( PickupZone )
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
--- On after PickedUp event.
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Wrapper.Group#GROUP APC
|
|
||||||
-- @param #string From From state.
|
|
||||||
-- @param #string Event Event.
|
|
||||||
-- @param #string To To state.
|
|
||||||
-- @param Core.Zone#ZONE PickupZone (optional) The zone where the cargo will be picked up. The PickupZone can be nil, if there wasn't any PickupZoneSet provided.
|
|
||||||
function AI_CARGO_APC:onafterPickedUp( APC, From, Event, To, PickupZone )
|
|
||||||
self:F( { APC, From, Event, To } )
|
|
||||||
|
|
||||||
self.Transporting = true
|
|
||||||
APC:RouteResume()
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
--- On after Unload event.
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Wrapper.Group#GROUP APC
|
|
||||||
-- @param #string From From state.
|
|
||||||
-- @param #string Event Event.
|
|
||||||
-- @param #string To To state.
|
|
||||||
-- @param Core.Zone#ZONE DeployZone The zone wherein the cargo is deployed. This can be any zone type, like a ZONE, ZONE_GROUP, ZONE_AIRBASE.
|
|
||||||
function AI_CARGO_APC:onafterUnload( APC, From, Event, To, DeployZone )
|
|
||||||
self:F( { APC, From, Event, To, DeployZone } )
|
|
||||||
|
|
||||||
local UnboardInterval = 10
|
|
||||||
local UnboardDelay = 10
|
|
||||||
|
|
||||||
if APC and APC:IsAlive() then
|
|
||||||
for _, APCUnit in pairs( APC:GetUnits() ) do
|
|
||||||
local APCUnit = APCUnit -- Wrapper.Unit#UNIT
|
|
||||||
APC:RouteStop()
|
|
||||||
for _, Cargo in pairs( APCUnit:GetCargo() ) do
|
|
||||||
if Cargo:IsLoaded() then
|
|
||||||
Cargo:__UnBoard( UnboardDelay )
|
|
||||||
UnboardDelay = UnboardDelay + UnboardInterval
|
|
||||||
Cargo:SetDeployed( true )
|
|
||||||
self:__Unboard( UnboardDelay, Cargo, APCUnit, DeployZone )
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
--- On after Unboard event.
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Wrapper.Group#GROUP APC
|
|
||||||
-- @param #string From From state.
|
|
||||||
-- @param #string Event Event.
|
|
||||||
-- @param #string To To state.
|
|
||||||
-- @param #string Cargo.Cargo#CARGO Cargo Cargo object.
|
|
||||||
-- @param Core.Zone#ZONE DeployZone The zone wherein the cargo is deployed. This can be any zone type, like a ZONE, ZONE_GROUP, ZONE_AIRBASE.
|
|
||||||
function AI_CARGO_APC:onafterUnboard( APC, From, Event, To, Cargo, APCUnit, DeployZone )
|
|
||||||
self:F( { APC, From, Event, To, Cargo:GetName() } )
|
|
||||||
|
|
||||||
if APC and APC:IsAlive() then
|
|
||||||
if not Cargo:IsUnLoaded() then
|
|
||||||
self:__Unboard( 10, Cargo, APCUnit, DeployZone )
|
|
||||||
return
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
self:Unloaded( Cargo, APCUnit, DeployZone )
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
--- On after Unloaded event.
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Wrapper.Group#GROUP APC
|
|
||||||
-- @param #string From From state.
|
|
||||||
-- @param #string Event Event.
|
|
||||||
-- @param #string To To state.
|
|
||||||
-- @param #string Cargo.Cargo#CARGO Cargo Cargo object.
|
|
||||||
-- @param #boolean Deployed Cargo is deployed.
|
|
||||||
-- @param Core.Zone#ZONE DeployZone The zone wherein the cargo is deployed. This can be any zone type, like a ZONE, ZONE_GROUP, ZONE_AIRBASE.
|
|
||||||
function AI_CARGO_APC:onafterUnloaded( APC, From, Event, To, Cargo, APCUnit, DeployZone )
|
|
||||||
self:F( { APC, From, Event, To, Cargo:GetName(), DeployZone = DeployZone } )
|
|
||||||
|
|
||||||
local AllUnloaded = true
|
|
||||||
|
|
||||||
--Cargo:Regroup()
|
|
||||||
|
|
||||||
if APC and APC:IsAlive() then
|
|
||||||
for _, APCUnit in pairs( APC:GetUnits() ) do
|
|
||||||
local APCUnit = APCUnit -- Wrapper.Unit#UNIT
|
|
||||||
local IsEmpty = APCUnit:IsCargoEmpty()
|
|
||||||
self:I({ IsEmpty = IsEmpty })
|
|
||||||
if not IsEmpty then
|
|
||||||
AllUnloaded = false
|
|
||||||
break
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if AllUnloaded == true then
|
|
||||||
if DeployZone == true then
|
|
||||||
self.APC_Cargo = {}
|
|
||||||
end
|
|
||||||
self.CargoCarrier = APC
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if AllUnloaded == true then
|
|
||||||
self:Deployed( DeployZone )
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
--- On after Deployed event.
|
|
||||||
-- @param #AI_CARGO_APC self
|
|
||||||
-- @param Wrapper.Group#GROUP APC
|
|
||||||
-- @param #string From From state.
|
|
||||||
-- @param #string Event Event.
|
|
||||||
-- @param #string To To state.
|
|
||||||
-- @param Core.Zone#ZONE DeployZone The zone wherein the cargo is deployed. This can be any zone type, like a ZONE, ZONE_GROUP, ZONE_AIRBASE.
|
|
||||||
function AI_CARGO_APC:onafterDeployed( APC, From, Event, To, DeployZone )
|
|
||||||
self:F( { APC, From, Event, To, DeployZone = DeployZone } )
|
|
||||||
|
|
||||||
self.Transporting = false
|
|
||||||
self:__Guard( 0.1 )
|
|
||||||
|
|
||||||
end
|
|
||||||
|
|
||||||
--- On after Follow event.
|
--- On after Follow event.
|
||||||
-- @param #AI_CARGO_APC self
|
-- @param #AI_CARGO_APC self
|
||||||
-- @param Wrapper.Group#GROUP APC
|
-- @param Wrapper.Group#GROUP APC
|
||||||
@ -689,7 +302,7 @@ function AI_CARGO_APC:onafterFollow( APC, From, Event, To )
|
|||||||
|
|
||||||
self:F( "Follow" )
|
self:F( "Follow" )
|
||||||
if APC and APC:IsAlive() then
|
if APC and APC:IsAlive() then
|
||||||
for Cargo, APCUnit in pairs( self.APC_Cargo ) do
|
for Cargo, APCUnit in pairs( self.Carrier_Cargo ) do
|
||||||
local Cargo = Cargo -- Cargo.Cargo#CARGO
|
local Cargo = Cargo -- Cargo.Cargo#CARGO
|
||||||
if Cargo:IsUnLoaded() then
|
if Cargo:IsUnLoaded() then
|
||||||
self:FollowToCarrier( self, APCUnit, Cargo )
|
self:FollowToCarrier( self, APCUnit, Cargo )
|
||||||
@ -709,6 +322,7 @@ function AI_CARGO_APC._Pickup( APC, self, PickupZone )
|
|||||||
|
|
||||||
if APC:IsAlive() then
|
if APC:IsAlive() then
|
||||||
self:Load( PickupZone)
|
self:Load( PickupZone)
|
||||||
|
self.Relocating = false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -719,6 +333,7 @@ function AI_CARGO_APC._Deploy( APC, self, Coordinate, DeployZone )
|
|||||||
|
|
||||||
if APC:IsAlive() then
|
if APC:IsAlive() then
|
||||||
self:Unload( DeployZone )
|
self:Unload( DeployZone )
|
||||||
|
self.Transporting = false
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@ -70,6 +70,7 @@ AI/AI_Cap.lua
|
|||||||
AI/AI_Cas.lua
|
AI/AI_Cas.lua
|
||||||
AI/AI_Bai.lua
|
AI/AI_Bai.lua
|
||||||
AI/AI_Formation.lua
|
AI/AI_Formation.lua
|
||||||
|
AI/AI_Cargo.lua
|
||||||
AI/AI_Cargo_APC.lua
|
AI/AI_Cargo_APC.lua
|
||||||
AI/AI_Cargo_Helicopter.lua
|
AI/AI_Cargo_Helicopter.lua
|
||||||
AI/AI_Cargo_Airplane.lua
|
AI/AI_Cargo_Airplane.lua
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user