MCV deploy and FIX.

This commit is contained in:
Paul Chote
2010-07-23 20:34:55 +12:00
parent 4016b81208
commit 7f640fd701
3 changed files with 42 additions and 16 deletions

View File

@@ -13,12 +13,12 @@ using OpenRA.Traits;
namespace OpenRA.Mods.RA namespace OpenRA.Mods.RA
{ {
class LimitedAmmoInfo : ITraitInfo public class LimitedAmmoInfo : ITraitInfo
{ {
public readonly int Ammo = 0; public readonly int Ammo = 0;
public readonly int PipCount = 0; public readonly int PipCount = 0;
public object Create(ActorInitializer init) { return new LimitedAmmo(init.self); } public object Create(ActorInitializer init) { return new LimitedAmmo(init.self, this); }
} }
public class LimitedAmmo : INotifyAttack, IPips public class LimitedAmmo : INotifyAttack, IPips
@@ -26,17 +26,20 @@ namespace OpenRA.Mods.RA
[Sync] [Sync]
int ammo; int ammo;
Actor self; Actor self;
LimitedAmmoInfo Info;
public LimitedAmmo(Actor self)
public LimitedAmmo(Actor self, LimitedAmmoInfo info)
{ {
ammo = self.Info.Traits.Get<LimitedAmmoInfo>().Ammo; ammo = info.Ammo;
this.self = self; this.self = self;
Info = info;
} }
public bool FullAmmo() { return ammo == Info.Ammo; }
public bool HasAmmo() { return ammo > 0; } public bool HasAmmo() { return ammo > 0; }
public bool GiveAmmo() public bool GiveAmmo()
{ {
if (ammo >= self.Info.Traits.Get<LimitedAmmoInfo>().Ammo) return false; if (ammo >= Info.Ammo) return false;
++ammo; ++ammo;
return true; return true;
} }
@@ -45,10 +48,9 @@ namespace OpenRA.Mods.RA
public IEnumerable<PipType> GetPips(Actor self) public IEnumerable<PipType> GetPips(Actor self)
{ {
var info = self.Info.Traits.Get<LimitedAmmoInfo>(); var pips = Info.PipCount != 0 ? Info.PipCount : Info.Ammo;
var pips = info.PipCount != 0 ? info.PipCount : info.Ammo;
return Graphics.Util.MakeArray(pips, return Graphics.Util.MakeArray(pips,
i => (ammo * pips) / info.Ammo > i ? PipType.Green : PipType.Transparent); i => (ammo * pips) / Info.Ammo > i ? PipType.Green : PipType.Transparent);
} }
} }
} }

View File

@@ -10,6 +10,7 @@
using System.Linq; using System.Linq;
using OpenRA.Mods.RA.Activities; using OpenRA.Mods.RA.Activities;
using OpenRA.Effects;
using OpenRA.Traits; using OpenRA.Traits;
using OpenRA.Traits.Activities; using OpenRA.Traits.Activities;
@@ -17,7 +18,7 @@ namespace OpenRA.Mods.RA
{ {
class RepairableInfo : TraitInfo<Repairable> { public readonly string[] RepairBuildings = { "fix" }; } class RepairableInfo : TraitInfo<Repairable> { public readonly string[] RepairBuildings = { "fix" }; }
class Repairable : IIssueOrder, IResolveOrder, IOrderCursor class Repairable : IIssueOrder, IResolveOrder, IOrderCursor, IOrderVoice
{ {
public Order IssueOrder(Actor self, int2 xy, MouseInput mi, Actor underCursor) public Order IssueOrder(Actor self, int2 xy, MouseInput mi, Actor underCursor)
{ {
@@ -26,22 +27,40 @@ namespace OpenRA.Mods.RA
if (self.Info.Traits.Get<RepairableInfo>().RepairBuildings.Contains(underCursor.Info.Name) if (self.Info.Traits.Get<RepairableInfo>().RepairBuildings.Contains(underCursor.Info.Name)
&& underCursor.Owner == self.Owner) && underCursor.Owner == self.Owner)
return new Order("Enter", self, underCursor); return new Order("Repair", self, underCursor);
return null; return null;
} }
bool CanRepair(Actor self)
{
var li = self.traits.GetOrDefault<LimitedAmmo>();
return (self.Health < self.GetMaxHP() || (li != null && !li.FullAmmo()) );
}
public string CursorForOrder(Actor self, Order order) public string CursorForOrder(Actor self, Order order)
{ {
return (order.OrderString == "Enter") ? "enter" : null; if (order.OrderString != "Repair") return null;
return CanRepair(self) ? "enter" : "enter-blocked";
}
public string VoicePhraseForOrder(Actor self, Order order)
{
return (order.OrderString == "Repair" && CanRepair(self)) ? "Move" : null;
} }
public void ResolveOrder(Actor self, Order order) public void ResolveOrder(Actor self, Order order)
{ {
if (order.OrderString == "Enter") if (order.OrderString == "Repair")
{ {
var rp = order.TargetActor.traits.GetOrDefault<RallyPoint>(); if (!CanRepair(self))
return;
var rp = order.TargetActor.traits.GetOrDefault<RallyPoint>();
if (self.Owner == self.World.LocalPlayer)
self.World.AddFrameEndTask(w => w.Add(new FlashTarget(order.TargetActor)));
self.CancelActivity(); self.CancelActivity();
self.QueueActivity(new Move(Util.CellContaining(order.TargetActor.CenterLocation), order.TargetActor)); self.QueueActivity(new Move(Util.CellContaining(order.TargetActor.CenterLocation), order.TargetActor));
self.QueueActivity(new Rearm()); self.QueueActivity(new Rearm());

View File

@@ -25,7 +25,7 @@ namespace OpenRA.Mods.RA
public readonly string[] NoTransformSounds = null; public readonly string[] NoTransformSounds = null;
} }
class TransformsOnDeploy : IIssueOrder, IResolveOrder, IOrderCursor class TransformsOnDeploy : IIssueOrder, IResolveOrder, IOrderCursor, IOrderVoice
{ {
public Order IssueOrder(Actor self, int2 xy, MouseInput mi, Actor underCursor) public Order IssueOrder(Actor self, int2 xy, MouseInput mi, Actor underCursor)
{ {
@@ -35,6 +35,11 @@ namespace OpenRA.Mods.RA
return null; return null;
} }
public string VoicePhraseForOrder(Actor self, Order order)
{
return (order.OrderString == "DeployTransform") ? "Move" : null;
}
public void ResolveOrder( Actor self, Order order ) public void ResolveOrder( Actor self, Order order )
{ {
if (order.OrderString == "DeployTransform") if (order.OrderString == "DeployTransform")