implement order targeter for passenger
This commit is contained in:
@@ -25,7 +25,7 @@ namespace OpenRA.Mods.RA
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
yield return new EnterBuildingOrderTargeter<Building>( "CaptureBuilding", 5, true, false,
|
yield return new EnterOrderTargeter<Building>( "CaptureBuilding", 5, true, false,
|
||||||
_ => true, target => target.Info.Traits.Get<BuildingInfo>().Capturable );
|
_ => true, target => target.Info.Traits.Get<BuildingInfo>().Capturable );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -98,7 +98,7 @@ namespace OpenRA.Mods.RA
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
yield return new EnterBuildingOrderTargeter<IAcceptOre>( "Deliver", 5, false, true, _ => true, _ => !IsEmpty );
|
yield return new EnterOrderTargeter<IAcceptOre>( "Deliver", 5, false, true, _ => true, _ => !IsEmpty );
|
||||||
yield return new HarvestOrderTargeter();
|
yield return new HarvestOrderTargeter();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -6,12 +6,12 @@ using OpenRA.Traits;
|
|||||||
|
|
||||||
namespace OpenRA.Mods.RA.Orders
|
namespace OpenRA.Mods.RA.Orders
|
||||||
{
|
{
|
||||||
class EnterBuildingOrderTargeter<T> : UnitTraitOrderTargeter<T>
|
class EnterOrderTargeter<T> : UnitTraitOrderTargeter<T>
|
||||||
{
|
{
|
||||||
readonly Func<Actor, bool> canTarget;
|
readonly Func<Actor, bool> canTarget;
|
||||||
readonly Func<Actor, bool> useEnterCursor;
|
readonly Func<Actor, bool> useEnterCursor;
|
||||||
|
|
||||||
public EnterBuildingOrderTargeter( string order, int priority, bool targetEnemy, bool targetAlly,
|
public EnterOrderTargeter( string order, int priority, bool targetEnemy, bool targetAlly,
|
||||||
Func<Actor, bool> canTarget, Func<Actor, bool> useEnterCursor )
|
Func<Actor, bool> canTarget, Func<Actor, bool> useEnterCursor )
|
||||||
: base( order, priority, "enter", targetEnemy, targetAlly )
|
: base( order, priority, "enter", targetEnemy, targetAlly )
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -14,58 +14,58 @@ using OpenRA.Mods.RA.Activities;
|
|||||||
using OpenRA.Traits;
|
using OpenRA.Traits;
|
||||||
using OpenRA.Traits.Activities;
|
using OpenRA.Traits.Activities;
|
||||||
using System.Linq;
|
using System.Linq;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using OpenRA.Mods.RA.Orders;
|
||||||
|
|
||||||
namespace OpenRA.Mods.RA
|
namespace OpenRA.Mods.RA
|
||||||
{
|
{
|
||||||
class PassengerInfo : TraitInfo<Passenger>
|
class PassengerInfo : ITraitInfo
|
||||||
{
|
{
|
||||||
public readonly string CargoType = null;
|
public readonly string CargoType = null;
|
||||||
public readonly PipType PipType = PipType.Green;
|
public readonly PipType PipType = PipType.Green;
|
||||||
|
|
||||||
|
public object Create( ActorInitializer init ) { return new Passenger( init.self ); }
|
||||||
}
|
}
|
||||||
|
|
||||||
class Passenger : IIssueOrder, IResolveOrder, IOrderCursor, IOrderVoice
|
class Passenger : IIssueOrder2, IResolveOrder, IOrderVoice
|
||||||
{
|
{
|
||||||
public int OrderPriority(Actor self, int2 xy, MouseInput mi, Actor underCursor)
|
readonly Actor self;
|
||||||
|
public Passenger( Actor self ) { this.self = self; }
|
||||||
|
|
||||||
|
public IEnumerable<IOrderTargeter> Orders
|
||||||
{
|
{
|
||||||
return 5;
|
get
|
||||||
|
{
|
||||||
|
yield return new EnterOrderTargeter<Cargo>( "EnterTransport", 6, false, true,
|
||||||
|
target => IsCorrectCargoType( target ), target => CanEnter( target ) );
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public Order IssueOrder(Actor self, int2 xy, MouseInput mi, Actor underCursor)
|
|
||||||
{
|
|
||||||
if (mi.Button != MouseButton.Right)
|
|
||||||
return null;
|
|
||||||
|
|
||||||
if (underCursor == null || underCursor.Owner != self.Owner)
|
public Order IssueOrder( Actor self, IOrderTargeter order, Target target )
|
||||||
return null;
|
{
|
||||||
|
if( order.OrderID == "EnterTransport" )
|
||||||
|
return new Order( order.OrderID, self, target.Actor );
|
||||||
|
|
||||||
var cargo = underCursor.TraitOrDefault<Cargo>();
|
return null;
|
||||||
if (cargo == null)
|
}
|
||||||
return null;
|
|
||||||
|
bool IsCorrectCargoType( Actor target )
|
||||||
|
{
|
||||||
var pi = self.Info.Traits.Get<PassengerInfo>();
|
var pi = self.Info.Traits.Get<PassengerInfo>();
|
||||||
var ci = underCursor.Info.Traits.Get<CargoInfo>();
|
var ci = target.Info.Traits.Get<CargoInfo>();
|
||||||
if (!ci.Types.Contains(pi.CargoType))
|
return ci.Types.Contains( pi.CargoType );
|
||||||
return null;
|
|
||||||
|
|
||||||
return new Order("EnterTransport", self, underCursor);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool CanEnter(Actor self, Actor a)
|
|
||||||
{
|
|
||||||
var cargo = a.TraitOrDefault<Cargo>();
|
|
||||||
return (cargo != null && !cargo.IsFull(a));
|
|
||||||
}
|
|
||||||
|
|
||||||
public string CursorForOrder(Actor self, Order order)
|
|
||||||
{
|
|
||||||
if (order.OrderString != "EnterTransport") return null;
|
|
||||||
return CanEnter(self, order.TargetActor) ? "enter" : "enter-blocked";
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
bool CanEnter( Actor target )
|
||||||
|
{
|
||||||
|
var cargo = target.TraitOrDefault<Cargo>();
|
||||||
|
return (cargo != null && !cargo.IsFull(target));
|
||||||
|
}
|
||||||
|
|
||||||
public string VoicePhraseForOrder(Actor self, Order order)
|
public string VoicePhraseForOrder(Actor self, Order order)
|
||||||
{
|
{
|
||||||
if (order.OrderString != "EnterTransport" ||
|
if (order.OrderString != "EnterTransport" ||
|
||||||
!CanEnter(self, order.TargetActor)) return null;
|
!CanEnter(order.TargetActor)) return null;
|
||||||
return "Move";
|
return "Move";
|
||||||
}
|
}
|
||||||
|
|
||||||
@@ -73,7 +73,7 @@ namespace OpenRA.Mods.RA
|
|||||||
{
|
{
|
||||||
if (order.OrderString == "EnterTransport")
|
if (order.OrderString == "EnterTransport")
|
||||||
{
|
{
|
||||||
if (!CanEnter(self, order.TargetActor)) return;
|
if (!CanEnter(order.TargetActor)) return;
|
||||||
|
|
||||||
if (self.Owner == self.World.LocalPlayer)
|
if (self.Owner == self.World.LocalPlayer)
|
||||||
self.World.AddFrameEndTask(w =>
|
self.World.AddFrameEndTask(w =>
|
||||||
|
|||||||
@@ -38,7 +38,7 @@ namespace OpenRA.Mods.RA
|
|||||||
|
|
||||||
public IEnumerable<IOrderTargeter> Orders
|
public IEnumerable<IOrderTargeter> Orders
|
||||||
{
|
{
|
||||||
get { yield return new EnterBuildingOrderTargeter<Building>( "Repair", 5, false, true, target => CanRepairAt( target ), _ => CanRepair() ); }
|
get { yield return new EnterOrderTargeter<Building>( "Repair", 5, false, true, target => CanRepairAt( target ), _ => CanRepair() ); }
|
||||||
}
|
}
|
||||||
|
|
||||||
public Order IssueOrder( Actor self, IOrderTargeter order, Target target )
|
public Order IssueOrder( Actor self, IOrderTargeter order, Target target )
|
||||||
|
|||||||
@@ -36,7 +36,7 @@ namespace OpenRA.Mods.RA
|
|||||||
{
|
{
|
||||||
get
|
get
|
||||||
{
|
{
|
||||||
yield return new EnterBuildingOrderTargeter<Building>( "RepairNear", 5, false, true,
|
yield return new EnterOrderTargeter<Building>( "RepairNear", 5, false, true,
|
||||||
target => CanRepairAt( target ), _ => ShouldRepair() );
|
target => CanRepairAt( target ), _ => ShouldRepair() );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user