#region Copyright & License Information /* * Copyright 2007-2010 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 LICENSE. */ #endregion using System; using System.Linq; using OpenRA.Traits; namespace OpenRA.Mods.RA.Activities { public class Fly : IActivity { public readonly float2 Pos; bool isCanceled; public Fly(float2 pos) { Pos = pos; } public Fly(int2 pos) { Pos = Util.CenterOfCell(pos); } public IActivity NextActivity { get; set; } public IActivity Tick(Actor self) { var cruiseAltitude = self.Info.Traits.Get().CruiseAltitude; if (isCanceled) return NextActivity; var d = Pos - self.CenterLocation; if (d.LengthSquared < 50) /* close enough */ return NextActivity; var aircraft = self.Trait(); var desiredFacing = Util.GetFacing(d, aircraft.Facing); if (aircraft.Altitude == cruiseAltitude) aircraft.Facing = Util.TickFacing(aircraft.Facing, desiredFacing, aircraft.ROT); if (aircraft.Altitude < cruiseAltitude) ++aircraft.Altitude; FlyUtil.Fly(self, cruiseAltitude); return this; } public void Cancel(Actor self) { isCanceled = true; NextActivity = null; } } public static class FlyUtil { public static void Fly(Actor self, int desiredAltitude ) { var aircraft = self.Trait(); var speed = .2f * aircraft.MovementSpeedForCell(self, self.Location); var angle = aircraft.Facing / 128f * Math.PI; self.CenterLocation += speed * -float2.FromAngle((float)angle); aircraft.Location = Util.CellContaining(self.CenterLocation); aircraft.Altitude += Math.Sign(desiredAltitude - aircraft.Altitude); } } }