Create abstract class AffectsShroud[Info] with RevealsShroud core logic also used by CreatesShroud
This commit is contained in:
@@ -695,6 +695,7 @@
|
|||||||
<Compile Include="Traits\Modifiers\HiddenUnderShroud.cs" />
|
<Compile Include="Traits\Modifiers\HiddenUnderShroud.cs" />
|
||||||
<Compile Include="Lint\CheckDefaultVisibility.cs" />
|
<Compile Include="Lint\CheckDefaultVisibility.cs" />
|
||||||
<Compile Include="Traits\Modifiers\AlwaysVisible.cs" />
|
<Compile Include="Traits\Modifiers\AlwaysVisible.cs" />
|
||||||
|
<Compile Include="Traits\AffectsShroud.cs" />
|
||||||
<Compile Include="Traits\CreatesShroud.cs" />
|
<Compile Include="Traits\CreatesShroud.cs" />
|
||||||
<Compile Include="Traits\RevealsShroud.cs" />
|
<Compile Include="Traits\RevealsShroud.cs" />
|
||||||
<Compile Include="Lint\CheckRevealFootprint.cs" />
|
<Compile Include="Lint\CheckRevealFootprint.cs" />
|
||||||
|
|||||||
101
OpenRA.Mods.Common/Traits/AffectsShroud.cs
Normal file
101
OpenRA.Mods.Common/Traits/AffectsShroud.cs
Normal file
@@ -0,0 +1,101 @@
|
|||||||
|
#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 System;
|
||||||
|
using System.Linq;
|
||||||
|
using OpenRA.Traits;
|
||||||
|
|
||||||
|
namespace OpenRA.Mods.Common.Traits
|
||||||
|
{
|
||||||
|
public abstract class AffectsShroudInfo : ITraitInfo
|
||||||
|
{
|
||||||
|
public readonly WDist Range = WDist.Zero;
|
||||||
|
|
||||||
|
[Desc("Possible values are CenterPosition (measure range from the center) and ",
|
||||||
|
"Footprint (measure range from the footprint)")]
|
||||||
|
public readonly VisibilityType Type = VisibilityType.Footprint;
|
||||||
|
|
||||||
|
public abstract object Create(ActorInitializer init);
|
||||||
|
}
|
||||||
|
|
||||||
|
public abstract class AffectsShroud : ITick, ISync, INotifyAddedToWorld, INotifyRemovedFromWorld
|
||||||
|
{
|
||||||
|
static readonly PPos[] NoCells = { };
|
||||||
|
|
||||||
|
readonly AffectsShroudInfo info;
|
||||||
|
[Sync] CPos cachedLocation;
|
||||||
|
[Sync] bool cachedDisabled;
|
||||||
|
|
||||||
|
protected abstract void AddCellsToPlayerShroud(Actor self, Player player, PPos[] uv);
|
||||||
|
protected abstract void RemoveCellsFromPlayerShroud(Actor self, Player player);
|
||||||
|
protected virtual bool IsDisabled(Actor self) { return false; }
|
||||||
|
|
||||||
|
public AffectsShroud(Actor self, AffectsShroudInfo info) { this.info = info; }
|
||||||
|
|
||||||
|
PPos[] ProjectedCells(Actor self)
|
||||||
|
{
|
||||||
|
var map = self.World.Map;
|
||||||
|
var range = Range;
|
||||||
|
if (range == WDist.Zero)
|
||||||
|
return NoCells;
|
||||||
|
|
||||||
|
if (info.Type == VisibilityType.Footprint)
|
||||||
|
return self.OccupiesSpace.OccupiedCells()
|
||||||
|
.SelectMany(kv => Shroud.ProjectedCellsInRange(map, kv.First, range))
|
||||||
|
.Distinct().ToArray();
|
||||||
|
|
||||||
|
return Shroud.ProjectedCellsInRange(map, self.CenterPosition, range)
|
||||||
|
.ToArray();
|
||||||
|
}
|
||||||
|
|
||||||
|
public void Tick(Actor self)
|
||||||
|
{
|
||||||
|
if (!self.IsInWorld)
|
||||||
|
return;
|
||||||
|
|
||||||
|
var centerPosition = self.CenterPosition;
|
||||||
|
var projectedPos = centerPosition - new WVec(0, centerPosition.Z, centerPosition.Z);
|
||||||
|
var projectedLocation = self.World.Map.CellContaining(projectedPos);
|
||||||
|
var disabled = IsDisabled(self);
|
||||||
|
|
||||||
|
if (cachedLocation == projectedLocation && cachedDisabled == disabled)
|
||||||
|
return;
|
||||||
|
|
||||||
|
cachedLocation = projectedLocation;
|
||||||
|
cachedDisabled = disabled;
|
||||||
|
|
||||||
|
var cells = ProjectedCells(self);
|
||||||
|
foreach (var p in self.World.Players)
|
||||||
|
{
|
||||||
|
RemoveCellsFromPlayerShroud(self, p);
|
||||||
|
AddCellsToPlayerShroud(self, p, cells);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public void AddedToWorld(Actor self)
|
||||||
|
{
|
||||||
|
var centerPosition = self.CenterPosition;
|
||||||
|
var projectedPos = centerPosition - new WVec(0, centerPosition.Z, centerPosition.Z);
|
||||||
|
cachedLocation = self.World.Map.CellContaining(projectedPos);
|
||||||
|
cachedDisabled = IsDisabled(self);
|
||||||
|
var cells = ProjectedCells(self);
|
||||||
|
foreach (var p in self.World.Players)
|
||||||
|
AddCellsToPlayerShroud(self, p, cells);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void RemovedFromWorld(Actor self)
|
||||||
|
{
|
||||||
|
foreach (var p in self.World.Players)
|
||||||
|
RemoveCellsFromPlayerShroud(self, p);
|
||||||
|
}
|
||||||
|
|
||||||
|
public WDist Range { get { return cachedDisabled ? WDist.Zero : info.Range; } }
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -10,19 +10,17 @@
|
|||||||
|
|
||||||
namespace OpenRA.Mods.Common.Traits
|
namespace OpenRA.Mods.Common.Traits
|
||||||
{
|
{
|
||||||
public class CreatesShroudInfo : RevealsShroudInfo
|
public class CreatesShroudInfo : AffectsShroudInfo
|
||||||
{
|
{
|
||||||
public override object Create(ActorInitializer init) { return new CreatesShroud(init.Self, this); }
|
public override object Create(ActorInitializer init) { return new CreatesShroud(init.Self, this); }
|
||||||
}
|
}
|
||||||
|
|
||||||
public class CreatesShroud : RevealsShroud
|
public class CreatesShroud : AffectsShroud
|
||||||
{
|
{
|
||||||
public CreatesShroud(Actor self, CreatesShroudInfo info)
|
public CreatesShroud(Actor self, CreatesShroudInfo info)
|
||||||
: base(self, info)
|
: base(self, info) { }
|
||||||
{
|
protected override void AddCellsToPlayerShroud(Actor self, Player p, PPos[] uv) { p.Shroud.AddProjectedShroudGeneration(self, uv); }
|
||||||
addCellsToPlayerShroud = (p, uv) => p.Shroud.AddProjectedShroudGeneration(self, uv);
|
protected override void RemoveCellsFromPlayerShroud(Actor self, Player p) { p.Shroud.RemoveShroudGeneration(self); }
|
||||||
removeCellsFromPlayerShroud = p => p.Shroud.RemoveShroudGeneration(self);
|
protected override bool IsDisabled(Actor self) { return self.IsDisabled(); }
|
||||||
isDisabled = () => self.IsDisabled();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@@ -8,101 +8,18 @@
|
|||||||
*/
|
*/
|
||||||
#endregion
|
#endregion
|
||||||
|
|
||||||
using System;
|
|
||||||
using System.Linq;
|
|
||||||
using OpenRA.Traits;
|
|
||||||
|
|
||||||
namespace OpenRA.Mods.Common.Traits
|
namespace OpenRA.Mods.Common.Traits
|
||||||
{
|
{
|
||||||
public class RevealsShroudInfo : ITraitInfo
|
public class RevealsShroudInfo : AffectsShroudInfo
|
||||||
{
|
{
|
||||||
public readonly WDist Range = WDist.Zero;
|
public override object Create(ActorInitializer init) { return new RevealsShroud(init.Self, this); }
|
||||||
|
|
||||||
[Desc("Possible values are CenterPosition (measure range from the center) and ",
|
|
||||||
"Footprint (measure range from the footprint)")]
|
|
||||||
public readonly VisibilityType Type = VisibilityType.Footprint;
|
|
||||||
|
|
||||||
public virtual object Create(ActorInitializer init) { return new RevealsShroud(init.Self, this); }
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public class RevealsShroud : ITick, ISync, INotifyAddedToWorld, INotifyRemovedFromWorld
|
public class RevealsShroud : AffectsShroud
|
||||||
{
|
{
|
||||||
static readonly PPos[] NoCells = { };
|
|
||||||
|
|
||||||
readonly RevealsShroudInfo info;
|
|
||||||
[Sync] CPos cachedLocation;
|
|
||||||
[Sync] bool cachedDisabled;
|
|
||||||
|
|
||||||
protected Action<Player, PPos[]> addCellsToPlayerShroud;
|
|
||||||
protected Action<Player> removeCellsFromPlayerShroud;
|
|
||||||
protected Func<bool> isDisabled;
|
|
||||||
|
|
||||||
public RevealsShroud(Actor self, RevealsShroudInfo info)
|
public RevealsShroud(Actor self, RevealsShroudInfo info)
|
||||||
{
|
: base(self, info) { }
|
||||||
this.info = info;
|
protected override void AddCellsToPlayerShroud(Actor self, Player p, PPos[] uv) { p.Shroud.AddProjectedVisibility(self, uv); }
|
||||||
|
protected override void RemoveCellsFromPlayerShroud(Actor self, Player p) { p.Shroud.RemoveVisibility(self); }
|
||||||
addCellsToPlayerShroud = (p, uv) => p.Shroud.AddProjectedVisibility(self, uv);
|
|
||||||
removeCellsFromPlayerShroud = p => p.Shroud.RemoveVisibility(self);
|
|
||||||
isDisabled = () => false;
|
|
||||||
}
|
|
||||||
|
|
||||||
PPos[] ProjectedCells(Actor self)
|
|
||||||
{
|
|
||||||
var map = self.World.Map;
|
|
||||||
var range = Range;
|
|
||||||
if (range == WDist.Zero)
|
|
||||||
return NoCells;
|
|
||||||
|
|
||||||
if (info.Type == VisibilityType.Footprint)
|
|
||||||
return self.OccupiesSpace.OccupiedCells()
|
|
||||||
.SelectMany(kv => Shroud.ProjectedCellsInRange(map, kv.First, range))
|
|
||||||
.Distinct().ToArray();
|
|
||||||
|
|
||||||
return Shroud.ProjectedCellsInRange(map, self.CenterPosition, range)
|
|
||||||
.ToArray();
|
|
||||||
}
|
|
||||||
|
|
||||||
public void Tick(Actor self)
|
|
||||||
{
|
|
||||||
if (!self.IsInWorld)
|
|
||||||
return;
|
|
||||||
|
|
||||||
var centerPosition = self.CenterPosition;
|
|
||||||
var projectedPos = centerPosition - new WVec(0, centerPosition.Z, centerPosition.Z);
|
|
||||||
var projectedLocation = self.World.Map.CellContaining(projectedPos);
|
|
||||||
var disabled = isDisabled();
|
|
||||||
|
|
||||||
if (cachedLocation == projectedLocation && cachedDisabled == disabled)
|
|
||||||
return;
|
|
||||||
|
|
||||||
cachedLocation = projectedLocation;
|
|
||||||
cachedDisabled = disabled;
|
|
||||||
|
|
||||||
var cells = ProjectedCells(self);
|
|
||||||
foreach (var p in self.World.Players)
|
|
||||||
{
|
|
||||||
removeCellsFromPlayerShroud(p);
|
|
||||||
addCellsToPlayerShroud(p, cells);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
public void AddedToWorld(Actor self)
|
|
||||||
{
|
|
||||||
var centerPosition = self.CenterPosition;
|
|
||||||
var projectedPos = centerPosition - new WVec(0, centerPosition.Z, centerPosition.Z);
|
|
||||||
cachedLocation = self.World.Map.CellContaining(projectedPos);
|
|
||||||
cachedDisabled = isDisabled();
|
|
||||||
var cells = ProjectedCells(self);
|
|
||||||
foreach (var p in self.World.Players)
|
|
||||||
addCellsToPlayerShroud(p, cells);
|
|
||||||
}
|
|
||||||
|
|
||||||
public void RemovedFromWorld(Actor self)
|
|
||||||
{
|
|
||||||
foreach (var p in self.World.Players)
|
|
||||||
removeCellsFromPlayerShroud(p);
|
|
||||||
}
|
|
||||||
|
|
||||||
public WDist Range { get { return cachedDisabled ? WDist.Zero : info.Range; } }
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user