#region Copyright & License Information /* * Copyright 2007-2011 The OpenRA Developers (see AUTHORS) * This file is part of OpenRA, which is free software. It is made * available to you under the terms of the GNU General Public License * as published by the Free Software Foundation. For more information, * see COPYING. */ #endregion using System.Collections.Generic; using OpenRA.Mods.RA.Activities; using OpenRA.Mods.RA.Air; using OpenRA.Mods.RA.Effects; using OpenRA.Traits; namespace OpenRA.Mods.RA { public class ParaDropInfo : TraitInfo { public readonly int LZRange = 4; public readonly string ChuteSound = "chute1.aud"; } public class ParaDrop : ITick { bool checkForSuitableCell; readonly List droppedAt = new List(); CPos lz; public void SetLZ(CPos lz, bool checkLandingCell) { this.lz = lz; droppedAt.Clear(); checkForSuitableCell = checkLandingCell; } public void Tick(Actor self) { var info = self.Info.Traits.Get(); var r = info.LZRange; if ((self.Location - lz).LengthSquared <= r * r && !droppedAt.Contains(self.Location)) { var cargo = self.Trait(); if (cargo.IsEmpty(self)) FinishedDropping(self); else { if (checkForSuitableCell && !IsSuitableCell(cargo.Peek(self), self.Location)) return; // unload a dude here droppedAt.Add(self.Location); var a = cargo.Unload(self); self.World.AddFrameEndTask(w => w.Add(new Parachute(a, self.CenterPosition))); Sound.Play(info.ChuteSound, self.CenterPosition); } } } static bool IsSuitableCell(Actor actorToDrop, CPos p) { return actorToDrop.Trait().CanEnterCell(p); } static void FinishedDropping(Actor self) { self.CancelActivity(); self.QueueActivity(new FlyOffMap()); self.QueueActivity(new RemoveSelf()); } } }