Aircraft/Helicopter move/dock flashing and cursor fixes
This commit is contained in:
@@ -14,11 +14,20 @@ using OpenRA.Traits;
|
|||||||
|
|
||||||
namespace OpenRA.Effects
|
namespace OpenRA.Effects
|
||||||
{
|
{
|
||||||
class MoveFlash : IEffect
|
public class MoveFlash : IEffect
|
||||||
{
|
{
|
||||||
Animation anim = new Animation("moveflsh");
|
Animation anim = new Animation("moveflsh");
|
||||||
float2 pos;
|
float2 pos;
|
||||||
|
|
||||||
|
|
||||||
|
public MoveFlash( World world, int2 cell )
|
||||||
|
{
|
||||||
|
this.pos = Game.CellSize * (cell + new float2(0.5f, 0.5f));
|
||||||
|
anim.PlayThen( "idle",
|
||||||
|
() => world.AddFrameEndTask(
|
||||||
|
w => w.Remove( this ) ) );
|
||||||
|
}
|
||||||
|
|
||||||
public MoveFlash( World world, float2 pos )
|
public MoveFlash( World world, float2 pos )
|
||||||
{
|
{
|
||||||
this.pos = pos;
|
this.pos = pos;
|
||||||
|
|||||||
@@ -11,6 +11,7 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using OpenRA.Effects;
|
||||||
using OpenRA.Traits.Activities;
|
using OpenRA.Traits.Activities;
|
||||||
using OpenRA.FileFormats;
|
using OpenRA.FileFormats;
|
||||||
|
|
||||||
@@ -97,6 +98,7 @@ namespace OpenRA.Traits
|
|||||||
}
|
}
|
||||||
if (MovementSpeedForCell(self, self.Location) == 0) return null; /* allow disabling move orders from modifiers */
|
if (MovementSpeedForCell(self, self.Location) == 0) return null; /* allow disabling move orders from modifiers */
|
||||||
if (xy == toCell) return null;
|
if (xy == toCell) return null;
|
||||||
|
|
||||||
return new Order("Move", self, xy, mi.Modifiers.HasModifier(Modifiers.Shift));
|
return new Order("Move", self, xy, mi.Modifiers.HasModifier(Modifiers.Shift));
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -106,11 +108,11 @@ namespace OpenRA.Traits
|
|||||||
{
|
{
|
||||||
if (self.traits.GetOrDefault<IMove>().CanEnterCell(order.TargetLocation))
|
if (self.traits.GetOrDefault<IMove>().CanEnterCell(order.TargetLocation))
|
||||||
{
|
{
|
||||||
|
if (self.Owner == self.World.LocalPlayer)
|
||||||
|
self.World.AddFrameEndTask(w => w.Add(new MoveFlash(self.World, order.TargetLocation)));
|
||||||
|
|
||||||
if( !order.Queued ) self.CancelActivity();
|
if( !order.Queued ) self.CancelActivity();
|
||||||
self.QueueActivity(new Activities.Move(order.TargetLocation, 8));
|
self.QueueActivity(new Activities.Move(order.TargetLocation, 8));
|
||||||
|
|
||||||
if (self.Owner == self.World.LocalPlayer)
|
|
||||||
self.World.Add(new Effects.MoveFlash(self.World, Game.CellSize * (order.TargetLocation + new float2(0.5f, 0.5f))));
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,6 +11,7 @@
|
|||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using OpenRA.Effects;
|
||||||
using OpenRA.Mods.RA.Activities;
|
using OpenRA.Mods.RA.Activities;
|
||||||
using OpenRA.Traits;
|
using OpenRA.Traits;
|
||||||
using OpenRA.Traits.Activities;
|
using OpenRA.Traits.Activities;
|
||||||
@@ -38,27 +39,28 @@ namespace OpenRA.Mods.RA
|
|||||||
if (mi.Button == MouseButton.Left) return null;
|
if (mi.Button == MouseButton.Left) return null;
|
||||||
|
|
||||||
if (underCursor == null)
|
if (underCursor == null)
|
||||||
{
|
|
||||||
if (self.traits.GetOrDefault<IMove>().CanEnterCell(xy))
|
if (self.traits.GetOrDefault<IMove>().CanEnterCell(xy))
|
||||||
return new Order("Move", self, xy);
|
return new Order("Move", self, xy);
|
||||||
}
|
|
||||||
|
|
||||||
if (AircraftCanEnter(self, underCursor)
|
if (AircraftCanEnter(self, underCursor)
|
||||||
&& underCursor.Owner == self.Owner
|
&& underCursor.Owner == self.Owner)
|
||||||
&& !Reservable.IsReserved(underCursor))
|
|
||||||
return new Order("Enter", self, underCursor);
|
return new Order("Enter", self, underCursor);
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public string CursorForOrder(Actor self, Order order)
|
public string CursorForOrder(Actor self, Order order)
|
||||||
{
|
{
|
||||||
return (order.OrderString == "Enter") ? "enter" : null;
|
if (order.OrderString == "Move") return "move";
|
||||||
|
if (order.OrderString == "Enter")
|
||||||
|
return Reservable.IsReserved(order.TargetActor) ? "enter-blocked" : "enter";
|
||||||
|
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public string VoicePhraseForOrder(Actor self, Order order)
|
public string VoicePhraseForOrder(Actor self, Order order)
|
||||||
{
|
{
|
||||||
return (order.OrderString == "Move") ? "Move" : null;
|
return (order.OrderString == "Move" || order.OrderString == "Enter") ? "Move" : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ResolveOrder(Actor self, Order order)
|
public void ResolveOrder(Actor self, Order order)
|
||||||
@@ -71,6 +73,9 @@ namespace OpenRA.Mods.RA
|
|||||||
|
|
||||||
if (order.OrderString == "Move")
|
if (order.OrderString == "Move")
|
||||||
{
|
{
|
||||||
|
if (self.Owner == self.World.LocalPlayer)
|
||||||
|
self.World.AddFrameEndTask(w => w.Add(new MoveFlash(self.World, order.TargetLocation)));
|
||||||
|
|
||||||
self.CancelActivity();
|
self.CancelActivity();
|
||||||
self.QueueActivity(new HeliFly(Util.CenterOfCell(order.TargetLocation)));
|
self.QueueActivity(new HeliFly(Util.CenterOfCell(order.TargetLocation)));
|
||||||
|
|
||||||
@@ -91,7 +96,10 @@ namespace OpenRA.Mods.RA
|
|||||||
var productionInfo = order.TargetActor.Info.Traits.GetOrDefault<ProductionInfo>();
|
var productionInfo = order.TargetActor.Info.Traits.GetOrDefault<ProductionInfo>();
|
||||||
var offset = productionInfo != null ? productionInfo.SpawnOffset : null;
|
var offset = productionInfo != null ? productionInfo.SpawnOffset : null;
|
||||||
var offsetVec = offset != null ? new float2(offset[0], offset[1]) : float2.Zero;
|
var offsetVec = offset != null ? new float2(offset[0], offset[1]) : float2.Zero;
|
||||||
|
|
||||||
|
if (self.Owner == self.World.LocalPlayer)
|
||||||
|
self.World.AddFrameEndTask(w => w.Add(new FlashTarget(order.TargetActor)));
|
||||||
|
|
||||||
self.CancelActivity();
|
self.CancelActivity();
|
||||||
self.QueueActivity(new HeliFly(order.TargetActor.CenterLocation + offsetVec));
|
self.QueueActivity(new HeliFly(order.TargetActor.CenterLocation + offsetVec));
|
||||||
self.QueueActivity(new Turn(self.Info.Traits.GetOrDefault<UnitInfo>().InitialFacing));
|
self.QueueActivity(new Turn(self.Info.Traits.GetOrDefault<UnitInfo>().InitialFacing));
|
||||||
|
|||||||
@@ -10,6 +10,7 @@
|
|||||||
|
|
||||||
using System;
|
using System;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using OpenRA.Effects;
|
||||||
using OpenRA.Mods.RA.Activities;
|
using OpenRA.Mods.RA.Activities;
|
||||||
using OpenRA.Traits;
|
using OpenRA.Traits;
|
||||||
|
|
||||||
@@ -32,10 +33,9 @@ namespace OpenRA.Mods.RA
|
|||||||
|
|
||||||
if (underCursor == null)
|
if (underCursor == null)
|
||||||
return new Order("Move", self, xy);
|
return new Order("Move", self, xy);
|
||||||
|
|
||||||
if (AircraftCanEnter(self, underCursor)
|
if (AircraftCanEnter(self, underCursor)
|
||||||
&& underCursor.Owner == self.Owner
|
&& underCursor.Owner == self.Owner)
|
||||||
&& !Reservable.IsReserved(underCursor))
|
|
||||||
return new Order("Enter", self, underCursor);
|
return new Order("Enter", self, underCursor);
|
||||||
|
|
||||||
return null;
|
return null;
|
||||||
@@ -43,12 +43,16 @@ namespace OpenRA.Mods.RA
|
|||||||
|
|
||||||
public string CursorForOrder(Actor self, Order order)
|
public string CursorForOrder(Actor self, Order order)
|
||||||
{
|
{
|
||||||
return (order.OrderString == "Enter") ? "enter" : null;
|
if (order.OrderString == "Move") return "move";
|
||||||
|
if (order.OrderString == "Enter")
|
||||||
|
return Reservable.IsReserved(order.TargetActor) ? "enter-blocked" : "enter";
|
||||||
|
|
||||||
|
return null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public string VoicePhraseForOrder(Actor self, Order order)
|
public string VoicePhraseForOrder(Actor self, Order order)
|
||||||
{
|
{
|
||||||
return (order.OrderString == "Move") ? "Move" : null;
|
return (order.OrderString == "Move" || order.OrderString == "Enter") ? "Move" : null;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void ResolveOrder(Actor self, Order order)
|
public void ResolveOrder(Actor self, Order order)
|
||||||
@@ -61,6 +65,9 @@ namespace OpenRA.Mods.RA
|
|||||||
|
|
||||||
if (order.OrderString == "Move")
|
if (order.OrderString == "Move")
|
||||||
{
|
{
|
||||||
|
if (self.Owner == self.World.LocalPlayer)
|
||||||
|
self.World.AddFrameEndTask(w => w.Add(new MoveFlash(self.World, order.TargetLocation)));
|
||||||
|
|
||||||
self.CancelActivity();
|
self.CancelActivity();
|
||||||
self.QueueActivity(new Fly(Util.CenterOfCell(order.TargetLocation)));
|
self.QueueActivity(new Fly(Util.CenterOfCell(order.TargetLocation)));
|
||||||
}
|
}
|
||||||
@@ -74,6 +81,9 @@ namespace OpenRA.Mods.RA
|
|||||||
|
|
||||||
var info = self.Info.Traits.Get<PlaneInfo>();
|
var info = self.Info.Traits.Get<PlaneInfo>();
|
||||||
|
|
||||||
|
if (self.Owner == self.World.LocalPlayer)
|
||||||
|
self.World.AddFrameEndTask(w => w.Add(new FlashTarget(order.TargetActor)));
|
||||||
|
|
||||||
self.CancelActivity();
|
self.CancelActivity();
|
||||||
self.QueueActivity(new ReturnToBase(self, order.TargetActor));
|
self.QueueActivity(new ReturnToBase(self, order.TargetActor));
|
||||||
self.QueueActivity(
|
self.QueueActivity(
|
||||||
|
|||||||
Reference in New Issue
Block a user