Merge pull request #12305 from reaperrr/gps-remove-delayedaction

Replace DelayedAction in GpsWatcher with Tick-based solution
This commit is contained in:
Paul Chote
2016-12-18 14:13:48 +00:00
committed by GitHub
4 changed files with 19 additions and 16 deletions

View File

@@ -48,30 +48,26 @@ namespace OpenRA.Mods.RA.Traits
public void GpsRemove(Actor atek)
{
actors.Remove(atek);
RefreshGps(atek);
RefreshGps(atek.Owner);
}
public void GpsAdd(Actor atek)
{
actors.Add(atek);
RefreshGps(atek);
RefreshGps(atek.Owner);
}
public void Launch(Actor atek, GpsPowerInfo info)
public void ReachedOrbit(Player launcher)
{
atek.World.Add(new DelayedAction(info.RevealDelay * 25,
() =>
{
Launched = true;
RefreshGps(atek);
}));
Launched = true;
RefreshGps(launcher);
}
public void RefreshGps(Actor atek)
public void RefreshGps(Player launcher)
{
RefreshGranted();
foreach (var i in atek.World.ActorsWithTrait<GpsWatcher>())
foreach (var i in launcher.World.ActorsWithTrait<GpsWatcher>())
i.Trait.RefreshGranted();
}

View File

@@ -79,8 +79,6 @@ namespace OpenRA.Mods.RA.Traits
Info.LaunchSpeechNotification, self.Owner.Faction.InternalName);
w.Add(new SatelliteLaunch(self, info));
owner.Launch(self, info);
});
}