Create #9435 DisableMovementOnUpgrade, rename DisableUpgrade to DisableOnUpgrade and Fixed not showing the blocked move cursor when movement is disabled.
This commit is contained in:
@@ -485,7 +485,8 @@
|
|||||||
<Compile Include="Traits\Turreted.cs" />
|
<Compile Include="Traits\Turreted.cs" />
|
||||||
<Compile Include="Traits\ProducibleWithLevel.cs" />
|
<Compile Include="Traits\ProducibleWithLevel.cs" />
|
||||||
<Compile Include="Traits\Upgrades\DeployToUpgrade.cs" />
|
<Compile Include="Traits\Upgrades\DeployToUpgrade.cs" />
|
||||||
<Compile Include="Traits\Upgrades\DisableUpgrade.cs" />
|
<Compile Include="Traits\Upgrades\DisableOnUpgrade.cs" />
|
||||||
|
<Compile Include="Traits\Upgrades\DisableMovementOnUpgrade.cs" />
|
||||||
<Compile Include="Traits\Upgrades\UpgradableTrait.cs" />
|
<Compile Include="Traits\Upgrades\UpgradableTrait.cs" />
|
||||||
<Compile Include="Traits\Upgrades\UpgradeActorsNear.cs" />
|
<Compile Include="Traits\Upgrades\UpgradeActorsNear.cs" />
|
||||||
<Compile Include="Traits\Upgrades\UpgradeManager.cs" />
|
<Compile Include="Traits\Upgrades\UpgradeManager.cs" />
|
||||||
@@ -720,4 +721,4 @@ cd "$(SolutionDir)"</PostBuildEvent>
|
|||||||
<Target Name="AfterBuild">
|
<Target Name="AfterBuild">
|
||||||
</Target>
|
</Target>
|
||||||
-->
|
-->
|
||||||
</Project>
|
</Project>
|
||||||
|
|||||||
@@ -692,12 +692,14 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
{
|
{
|
||||||
readonly MobileInfo unitType;
|
readonly MobileInfo unitType;
|
||||||
readonly bool rejectMove;
|
readonly bool rejectMove;
|
||||||
|
readonly IDisableMove[] moveDisablers;
|
||||||
public bool OverrideSelection { get { return false; } }
|
public bool OverrideSelection { get { return false; } }
|
||||||
|
|
||||||
public MoveOrderTargeter(Actor self, MobileInfo unitType)
|
public MoveOrderTargeter(Actor self, MobileInfo unitType)
|
||||||
{
|
{
|
||||||
this.unitType = unitType;
|
this.unitType = unitType;
|
||||||
rejectMove = !self.AcceptsOrder("Move");
|
rejectMove = !self.AcceptsOrder("Move");
|
||||||
|
moveDisablers = self.TraitsImplementing<IDisableMove>().ToArray();
|
||||||
}
|
}
|
||||||
|
|
||||||
public string OrderID { get { return "Move"; } }
|
public string OrderID { get { return "Move"; } }
|
||||||
@@ -716,7 +718,9 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
cursor = self.World.Map.Contains(location) ?
|
cursor = self.World.Map.Contains(location) ?
|
||||||
(self.World.Map.GetTerrainInfo(location).CustomCursor ?? unitType.Cursor) : unitType.BlockedCursor;
|
(self.World.Map.GetTerrainInfo(location).CustomCursor ?? unitType.Cursor) : unitType.BlockedCursor;
|
||||||
|
|
||||||
if ((!explored && !unitType.MoveIntoShroud) || (explored && unitType.MovementCostForCell(self.World, location) == int.MaxValue))
|
if ((!explored && !unitType.MoveIntoShroud)
|
||||||
|
|| (explored && unitType.MovementCostForCell(self.World, location) == int.MaxValue)
|
||||||
|
|| moveDisablers.Any(d => d.MoveDisabled(self)))
|
||||||
cursor = unitType.BlockedCursor;
|
cursor = unitType.BlockedCursor;
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
|
|||||||
@@ -0,0 +1,28 @@
|
|||||||
|
#region Copyright & License Information
|
||||||
|
/*
|
||||||
|
* Copyright 2007-2015 The OpenRA Developers (see AUTHORS)
|
||||||
|
* 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
|
||||||
|
* as published by the Free Software Foundation. For more information,
|
||||||
|
* see COPYING.
|
||||||
|
*/
|
||||||
|
#endregion
|
||||||
|
|
||||||
|
using OpenRA.Traits;
|
||||||
|
|
||||||
|
namespace OpenRA.Mods.Common.Traits
|
||||||
|
{
|
||||||
|
[Desc("Disable the ability to move and turn of the actor when this trait is enabled by an upgrade.")]
|
||||||
|
public class DisableMovementInfo : UpgradableTraitInfo
|
||||||
|
{
|
||||||
|
public override object Create(ActorInitializer init) { return new DisableMovementOnUpgrade(this); }
|
||||||
|
}
|
||||||
|
|
||||||
|
public class DisableMovementOnUpgrade : UpgradableTrait<DisableMovementInfo>, IDisableMove
|
||||||
|
{
|
||||||
|
public DisableMovementOnUpgrade(DisableMovementInfo info)
|
||||||
|
: base(info) { }
|
||||||
|
|
||||||
|
public bool MoveDisabled(Actor self) { return !IsTraitDisabled; }
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -13,14 +13,14 @@ using OpenRA.Traits;
|
|||||||
namespace OpenRA.Mods.Common.Traits
|
namespace OpenRA.Mods.Common.Traits
|
||||||
{
|
{
|
||||||
[Desc("Disable the actor when this trait is enabled by an upgrade.")]
|
[Desc("Disable the actor when this trait is enabled by an upgrade.")]
|
||||||
public class DisableUpgradeInfo : UpgradableTraitInfo
|
public class DisableOnUpgradeInfo : UpgradableTraitInfo
|
||||||
{
|
{
|
||||||
public override object Create(ActorInitializer init) { return new DisableUpgrade(this); }
|
public override object Create(ActorInitializer init) { return new DisableOnUpgrade(this); }
|
||||||
}
|
}
|
||||||
|
|
||||||
public class DisableUpgrade : UpgradableTrait<DisableUpgradeInfo>, IDisable, IDisableMove
|
public class DisableOnUpgrade : UpgradableTrait<DisableOnUpgradeInfo>, IDisable, IDisableMove
|
||||||
{
|
{
|
||||||
public DisableUpgrade(DisableUpgradeInfo info)
|
public DisableOnUpgrade(DisableOnUpgradeInfo info)
|
||||||
: base(info) { }
|
: base(info) { }
|
||||||
|
|
||||||
public bool Disabled { get { return !IsTraitDisabled; } }
|
public bool Disabled { get { return !IsTraitDisabled; } }
|
||||||
@@ -2724,6 +2724,12 @@ namespace OpenRA.Mods.Common.UtilityCommands
|
|||||||
node.Value.Value = RenameD2kActors(node.Value.Value);
|
node.Value.Value = RenameD2kActors(node.Value.Value);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (engineVersion < 20150925)
|
||||||
|
{
|
||||||
|
if (node.Key == "DisableUpgrade")
|
||||||
|
node.Key = "DisableOnUpgrade";
|
||||||
|
}
|
||||||
|
|
||||||
UpgradeActors(engineVersion, ref node.Value.Nodes, node, depth + 1);
|
UpgradeActors(engineVersion, ref node.Value.Nodes, node, depth + 1);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -54,7 +54,7 @@
|
|||||||
UpgradeTypes: empdisable
|
UpgradeTypes: empdisable
|
||||||
UpgradeMinEnabledLevel: 1
|
UpgradeMinEnabledLevel: 1
|
||||||
Palette: disabled
|
Palette: disabled
|
||||||
DisableUpgrade@EMPDISABLE:
|
DisableOnUpgrade@EMPDISABLE:
|
||||||
UpgradeTypes: empdisable
|
UpgradeTypes: empdisable
|
||||||
UpgradeMinEnabledLevel: 1
|
UpgradeMinEnabledLevel: 1
|
||||||
TimedUpgradeBar@EMPDISABLE:
|
TimedUpgradeBar@EMPDISABLE:
|
||||||
|
|||||||
@@ -140,7 +140,7 @@ LPST:
|
|||||||
StartSequence: make
|
StartSequence: make
|
||||||
UpgradeTypes: deployed
|
UpgradeTypes: deployed
|
||||||
UpgradeMinEnabledLevel: 1
|
UpgradeMinEnabledLevel: 1
|
||||||
DisableUpgrade:
|
DisableOnUpgrade:
|
||||||
UpgradeTypes: deployed
|
UpgradeTypes: deployed
|
||||||
UpgradeMinEnabledLevel: 1
|
UpgradeMinEnabledLevel: 1
|
||||||
DetectCloaked:
|
DetectCloaked:
|
||||||
|
|||||||
Reference in New Issue
Block a user