Allow maps to define custom initial cargo and fix initial notification.
This commit is contained in:
@@ -67,7 +67,7 @@ namespace OpenRA.Mods.RA.Activities
|
|||||||
|
|
||||||
var cargo = self.TraitOrDefault<Cargo>();
|
var cargo = self.TraitOrDefault<Cargo>();
|
||||||
if (cargo != null)
|
if (cargo != null)
|
||||||
init.Add( new CargoInit( cargo.Passengers.ToArray() ) );
|
init.Add( new RuntimeCargoInit( cargo.Passengers.ToArray() ) );
|
||||||
|
|
||||||
var a = w.CreateActor( ToActor, init );
|
var a = w.CreateActor( ToActor, init );
|
||||||
|
|
||||||
|
|||||||
@@ -44,9 +44,21 @@ namespace OpenRA.Mods.RA
|
|||||||
self = init.self;
|
self = init.self;
|
||||||
Info = info;
|
Info = info;
|
||||||
|
|
||||||
if (init.Contains<CargoInit>())
|
if (init.Contains<RuntimeCargoInit>())
|
||||||
{
|
{
|
||||||
cargo = init.Get<CargoInit, Actor[]>().ToList();
|
cargo = init.Get<RuntimeCargoInit, Actor[]>().ToList();
|
||||||
|
totalWeight = cargo.Sum(c => GetWeight(c));
|
||||||
|
}
|
||||||
|
else if (init.Contains<CargoInit>())
|
||||||
|
{
|
||||||
|
foreach (var u in init.Get<CargoInit, string[]>())
|
||||||
|
{
|
||||||
|
var unit = self.World.CreateActor(false, u.ToLowerInvariant(),
|
||||||
|
new TypeDictionary { new OwnerInit(self.Owner) });
|
||||||
|
|
||||||
|
cargo.Add(unit);
|
||||||
|
}
|
||||||
|
|
||||||
totalWeight = cargo.Sum(c => GetWeight(c));
|
totalWeight = cargo.Sum(c => GetWeight(c));
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@@ -56,9 +68,10 @@ namespace OpenRA.Mods.RA
|
|||||||
var unit = self.World.CreateActor(false, u.ToLowerInvariant(),
|
var unit = self.World.CreateActor(false, u.ToLowerInvariant(),
|
||||||
new TypeDictionary { new OwnerInit(self.Owner) });
|
new TypeDictionary { new OwnerInit(self.Owner) });
|
||||||
|
|
||||||
if (CanLoad(self, unit))
|
cargo.Add(unit);
|
||||||
Load(self, unit);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
totalWeight = cargo.Sum(c => GetWeight(c));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -186,8 +199,19 @@ namespace OpenRA.Mods.RA
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool initialized;
|
||||||
public void Tick(Actor self)
|
public void Tick(Actor self)
|
||||||
{
|
{
|
||||||
|
// Notify initial cargo load
|
||||||
|
if (!initialized)
|
||||||
|
{
|
||||||
|
foreach (var npe in self.TraitsImplementing<INotifyPassengerEntered>())
|
||||||
|
foreach (var c in cargo)
|
||||||
|
npe.PassengerEntered(self, c);
|
||||||
|
|
||||||
|
initialized = true;
|
||||||
|
}
|
||||||
|
|
||||||
var cell = self.CenterPosition.ToCPos();
|
var cell = self.CenterPosition.ToCPos();
|
||||||
if (currentCell != cell)
|
if (currentCell != cell)
|
||||||
{
|
{
|
||||||
@@ -200,12 +224,21 @@ namespace OpenRA.Mods.RA
|
|||||||
public interface INotifyPassengerEntered { void PassengerEntered(Actor self, Actor passenger); }
|
public interface INotifyPassengerEntered { void PassengerEntered(Actor self, Actor passenger); }
|
||||||
public interface INotifyPassengerExited { void PassengerExited(Actor self, Actor passenger); }
|
public interface INotifyPassengerExited { void PassengerExited(Actor self, Actor passenger); }
|
||||||
|
|
||||||
public class CargoInit : IActorInit<Actor[]>
|
public class RuntimeCargoInit : IActorInit<Actor[]>
|
||||||
{
|
{
|
||||||
[FieldFromYamlKey]
|
[FieldFromYamlKey]
|
||||||
public readonly Actor[] value = { };
|
public readonly Actor[] value = { };
|
||||||
public CargoInit() { }
|
public RuntimeCargoInit() { }
|
||||||
public CargoInit(Actor[] init) { value = init; }
|
public RuntimeCargoInit(Actor[] init) { value = init; }
|
||||||
public Actor[] Value(World world) { return value; }
|
public Actor[] Value(World world) { return value; }
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public class CargoInit : IActorInit<string[]>
|
||||||
|
{
|
||||||
|
[FieldFromYamlKey]
|
||||||
|
public readonly string[] value = { };
|
||||||
|
public CargoInit() { }
|
||||||
|
public CargoInit(string[] init) { value = init; }
|
||||||
|
public string[] Value(World world) { return value; }
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user