Tidy transformation trait/activity.

This commit is contained in:
Paul Chote
2014-06-21 15:24:49 +12:00
parent 6536f92b12
commit 7dfc822d76
2 changed files with 32 additions and 30 deletions

View File

@@ -1,6 +1,6 @@
#region Copyright & License Information #region Copyright & License Information
/* /*
* Copyright 2007-2011 The OpenRA Developers (see AUTHORS) * Copyright 2007-2014 The OpenRA Developers (see AUTHORS)
* This file is part of OpenRA, which is free software. It is made * 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 * available to you under the terms of the GNU General Public License
* as published by the Free Software Foundation. For more information, * as published by the Free Software Foundation. For more information,
@@ -16,21 +16,22 @@ namespace OpenRA.Mods.RA.Activities
{ {
class Transform : Activity class Transform : Activity
{ {
public readonly string ToActor = null; public readonly string ToActor;
public CVec Offset = new CVec(0, 0); public CVec Offset = CVec.Zero;
public int Facing = 96; public int Facing = 96;
public string[] Sounds = {}; public string[] Sounds = { };
public int ForceHealthPercentage = 0; public int ForceHealthPercentage = 0;
public bool SkipMakeAnims = false; public bool SkipMakeAnims = false;
public Transform(Actor self, string toActor) public Transform(Actor self, string toActor)
{ {
this.ToActor = toActor; ToActor = toActor;
} }
public override Activity Tick( Actor self ) public override Activity Tick(Actor self)
{ {
if (IsCanceled) return NextActivity; if (IsCanceled)
return NextActivity;
self.World.AddFrameEndTask(w => self.World.AddFrameEndTask(w =>
{ {
@@ -48,12 +49,13 @@ namespace OpenRA.Mods.RA.Activities
var init = new TypeDictionary var init = new TypeDictionary
{ {
new LocationInit( self.Location + Offset ), new LocationInit(self.Location + Offset),
new OwnerInit( self.Owner ), new OwnerInit(self.Owner),
new FacingInit( Facing ), new FacingInit(Facing),
}; };
if (SkipMakeAnims) init.Add(new SkipMakeAnimsInit()); if (SkipMakeAnims)
init.Add(new SkipMakeAnimsInit());
var health = self.TraitOrDefault<Health>(); var health = self.TraitOrDefault<Health>();
if (health != null) if (health != null)
@@ -62,15 +64,14 @@ namespace OpenRA.Mods.RA.Activities
? ForceHealthPercentage / 100f ? ForceHealthPercentage / 100f
: (float)health.HP / health.MaxHP; : (float)health.HP / health.MaxHP;
init.Add( new HealthInit(newHP) ); init.Add(new HealthInit(newHP));
} }
var cargo = self.TraitOrDefault<Cargo>(); var cargo = self.TraitOrDefault<Cargo>();
if (cargo != null) if (cargo != null)
init.Add( new RuntimeCargoInit( cargo.Passengers.ToArray() ) ); init.Add(new RuntimeCargoInit(cargo.Passengers.ToArray()));
var a = w.CreateActor( ToActor, init );
var a = w.CreateActor(ToActor, init);
foreach (var nt in self.TraitsImplementing<INotifyTransformed>()) foreach (var nt in self.TraitsImplementing<INotifyTransformed>())
nt.OnTransformed(a); nt.OnTransformed(a);

View File

@@ -22,22 +22,22 @@ namespace OpenRA.Mods.RA
[ActorReference] public readonly string IntoActor = null; [ActorReference] public readonly string IntoActor = null;
public readonly int2 Offset = int2.Zero; public readonly int2 Offset = int2.Zero;
public readonly int Facing = 96; public readonly int Facing = 96;
public readonly string[] TransformSounds = {}; public readonly string[] TransformSounds = { };
public readonly string[] NoTransformSounds = {}; public readonly string[] NoTransformSounds = { };
public virtual object Create(ActorInitializer init) { return new Transforms(init.self, this); } public virtual object Create(ActorInitializer init) { return new Transforms(init.self, this); }
} }
class Transforms : IIssueOrder, IResolveOrder, IOrderVoice class Transforms : IIssueOrder, IResolveOrder, IOrderVoice
{ {
Actor self; readonly Actor self;
TransformsInfo Info; readonly TransformsInfo info;
BuildingInfo bi; readonly BuildingInfo bi;
public Transforms(Actor self, TransformsInfo info) public Transforms(Actor self, TransformsInfo info)
{ {
this.self = self; this.self = self;
Info = info; this.info = info;
bi = self.World.Map.Rules.Actors[info.IntoActor].Traits.GetOrDefault<BuildingInfo>(); bi = self.World.Map.Rules.Actors[info.IntoActor].Traits.GetOrDefault<BuildingInfo>();
} }
@@ -52,18 +52,18 @@ namespace OpenRA.Mods.RA
if (b != null && b.Locked) if (b != null && b.Locked)
return false; return false;
return (bi == null || self.World.CanPlaceBuilding(Info.IntoActor, bi, self.Location + (CVec)Info.Offset, self)); return bi == null || self.World.CanPlaceBuilding(info.IntoActor, bi, self.Location + (CVec)info.Offset, self);
} }
public IEnumerable<IOrderTargeter> Orders public IEnumerable<IOrderTargeter> Orders
{ {
get { yield return new DeployOrderTargeter( "DeployTransform", 5, () => CanDeploy() ); } get { yield return new DeployOrderTargeter("DeployTransform", 5, () => CanDeploy()); }
} }
public Order IssueOrder( Actor self, IOrderTargeter order, Target target, bool queued ) public Order IssueOrder(Actor self, IOrderTargeter order, Target target, bool queued)
{ {
if( order.OrderID == "DeployTransform" ) if (order.OrderID == "DeployTransform")
return new Order( order.OrderID, self, queued ); return new Order(order.OrderID, self, queued);
return null; return null;
} }
@@ -74,8 +74,9 @@ namespace OpenRA.Mods.RA
if (!CanDeploy() || (b != null && !b.Lock())) if (!CanDeploy() || (b != null && !b.Lock()))
{ {
foreach (var s in Info.NoTransformSounds) foreach (var s in info.NoTransformSounds)
Sound.PlayToPlayer(self.Owner, s); Sound.PlayToPlayer(self.Owner, s);
return; return;
} }
@@ -83,16 +84,16 @@ namespace OpenRA.Mods.RA
self.CancelActivity(); self.CancelActivity();
if (self.HasTrait<IFacing>()) if (self.HasTrait<IFacing>())
self.QueueActivity(new Turn(Info.Facing)); self.QueueActivity(new Turn(info.Facing));
var rb = self.TraitOrDefault<RenderBuilding>(); var rb = self.TraitOrDefault<RenderBuilding>();
if (rb != null && self.Info.Traits.Get<RenderBuildingInfo>().HasMakeAnimation) if (rb != null && self.Info.Traits.Get<RenderBuildingInfo>().HasMakeAnimation)
self.QueueActivity(new MakeAnimation(self, true, () => rb.PlayCustomAnim(self, "make"))); self.QueueActivity(new MakeAnimation(self, true, () => rb.PlayCustomAnim(self, "make")));
self.QueueActivity(new Transform(self, Info.IntoActor) { Offset = (CVec)Info.Offset, Facing = Info.Facing, Sounds = Info.TransformSounds }); self.QueueActivity(new Transform(self, info.IntoActor) { Offset = (CVec)info.Offset, Facing = info.Facing, Sounds = info.TransformSounds });
} }
public void ResolveOrder( Actor self, Order order ) public void ResolveOrder(Actor self, Order order)
{ {
if (order.OrderString == "DeployTransform") if (order.OrderString == "DeployTransform")
DeployTransform(order.Queued); DeployTransform(order.Queued);