Add support for not displaying target lines

This commit is contained in:
Gustas
2024-02-19 12:11:10 +02:00
committed by Paul Chote
parent b72d4ab7c6
commit f06d7d29ef
3 changed files with 16 additions and 6 deletions

View File

@@ -24,6 +24,7 @@ namespace OpenRA.Mods.Common.Activities
readonly HarvesterInfo harvInfo;
readonly Mobile mobile;
readonly ResourceClaimLayer claimLayer;
readonly DockClientManager dockClient;
readonly MoveCooldownHelper moveCooldownHelper;
CPos? orderLocation;
CPos? lastHarvestedCell;
@@ -37,6 +38,8 @@ namespace OpenRA.Mods.Common.Activities
{
harv = self.Trait<Harvester>();
harvInfo = self.Info.TraitInfo<HarvesterInfo>();
dockClient = self.Trait<DockClientManager>();
mobile = self.Trait<Mobile>();
claimLayer = self.World.WorldActor.Trait<ResourceClaimLayer>();
moveCooldownHelper = new MoveCooldownHelper(self.World, mobile) { RetryIfDestinationBlocked = true };
@@ -56,7 +59,7 @@ namespace OpenRA.Mods.Common.Activities
// We have to make sure the actual "harvest" order is not skipped if a third order is queued,
// so we keep deliveredLoad false.
if (harv.IsFull)
QueueChild(new MoveToDock(self));
QueueChild(new MoveToDock(self, dockLineColor: dockClient.DockLineColor));
}
}
@@ -83,7 +86,7 @@ namespace OpenRA.Mods.Common.Activities
if (harv.DockClientManager.ReservedHost != null)
return false;
QueueChild(new MoveToDock(self));
QueueChild(new MoveToDock(self, dockLineColor: dockClient.DockLineColor));
hasDeliveredLoad = true;
}

View File

@@ -13,6 +13,7 @@ using System.Collections.Generic;
using System.Linq;
using OpenRA.Activities;
using OpenRA.Mods.Common.Traits;
using OpenRA.Primitives;
using OpenRA.Traits;
namespace OpenRA.Mods.Common.Activities
@@ -23,18 +24,20 @@ namespace OpenRA.Mods.Common.Activities
Actor dockHostActor;
IDockHost dockHost;
readonly INotifyDockClientMoving[] notifyDockClientMoving;
readonly Color? dockLineColor;
readonly MoveCooldownHelper moveCooldownHelper;
readonly bool forceEnter;
readonly bool ignoreOccupancy;
public MoveToDock(Actor self, Actor dockHostActor = null, IDockHost dockHost = null,
bool forceEnter = false, bool ignoreOccupancy = false)
bool forceEnter = false, bool ignoreOccupancy = false, Color? dockLineColor = null)
{
dockClient = self.Trait<DockClientManager>();
this.dockHostActor = dockHostActor;
this.dockHost = dockHost;
this.forceEnter = forceEnter;
this.ignoreOccupancy = ignoreOccupancy;
this.dockLineColor = dockLineColor;
notifyDockClientMoving = self.TraitsImplementing<INotifyDockClientMoving>().ToArray();
moveCooldownHelper = new MoveCooldownHelper(self.World, self.Trait<IMove>() as Mobile) { RetryIfDestinationBlocked = true };
}
@@ -119,12 +122,15 @@ namespace OpenRA.Mods.Common.Activities
public override IEnumerable<TargetLineNode> TargetLineNodes(Actor self)
{
if (!dockLineColor.HasValue)
yield break;
if (dockHostActor != null)
yield return new TargetLineNode(Target.FromActor(dockHostActor), dockClient.DockLineColor);
yield return new TargetLineNode(Target.FromActor(dockHostActor), dockLineColor.Value);
else
{
if (dockClient.ReservedHostActor != null)
yield return new TargetLineNode(Target.FromActor(dockClient.ReservedHostActor), dockClient.DockLineColor);
yield return new TargetLineNode(Target.FromActor(dockClient.ReservedHostActor), dockLineColor.Value);
}
}
}

View File

@@ -182,7 +182,8 @@ namespace OpenRA.Mods.Common.Traits
target.Actor,
null,
order.OrderString == "ForceDock",
true));
true,
DockLineColor));
self.ShowTargetLines();
}