Make RenderShroud/JammerCircle conditional.
This commit is contained in:
committed by
Paul Chote
parent
475468ccc7
commit
46caa2d889
@@ -18,7 +18,7 @@ using OpenRA.Traits;
|
||||
namespace OpenRA.Mods.Common.Traits
|
||||
{
|
||||
// TODO: remove all the Render*Circle duplication
|
||||
class RenderJammerCircleInfo : TraitInfo, IPlaceBuildingDecorationInfo
|
||||
class RenderJammerCircleInfo : ConditionalTraitInfo, IPlaceBuildingDecorationInfo
|
||||
{
|
||||
[Desc("Range circle color.")]
|
||||
public readonly Color Color = Color.FromArgb(128, Color.Red);
|
||||
@@ -34,6 +34,9 @@ namespace OpenRA.Mods.Common.Traits
|
||||
|
||||
public IEnumerable<IRenderable> RenderAnnotations(WorldRenderer wr, World w, ActorInfo ai, WPos centerPosition)
|
||||
{
|
||||
if (!EnabledByDefault)
|
||||
yield break;
|
||||
|
||||
var jamsMissiles = ai.TraitInfoOrDefault<JamsMissilesInfo>();
|
||||
if (jamsMissiles != null)
|
||||
{
|
||||
@@ -56,17 +59,21 @@ namespace OpenRA.Mods.Common.Traits
|
||||
public override object Create(ActorInitializer init) { return new RenderJammerCircle(this); }
|
||||
}
|
||||
|
||||
class RenderJammerCircle : IRenderAnnotationsWhenSelected
|
||||
class RenderJammerCircle : ConditionalTrait<RenderJammerCircleInfo>, IRenderAnnotationsWhenSelected
|
||||
{
|
||||
readonly RenderJammerCircleInfo info;
|
||||
|
||||
public RenderJammerCircle(RenderJammerCircleInfo info)
|
||||
: base(info)
|
||||
{
|
||||
this.info = info;
|
||||
}
|
||||
|
||||
public IEnumerable<IRenderable> RenderAnnotations(Actor self, WorldRenderer wr)
|
||||
{
|
||||
if (IsTraitDisabled)
|
||||
yield break;
|
||||
|
||||
if (!self.Owner.IsAlliedWith(self.World.RenderPlayer))
|
||||
yield break;
|
||||
|
||||
|
||||
@@ -18,7 +18,7 @@ using OpenRA.Traits;
|
||||
|
||||
namespace OpenRA.Mods.Common.Traits
|
||||
{
|
||||
class RenderShroudCircleInfo : TraitInfo, IPlaceBuildingDecorationInfo
|
||||
class RenderShroudCircleInfo : ConditionalTraitInfo, IPlaceBuildingDecorationInfo
|
||||
{
|
||||
[Desc("Color of the circle.")]
|
||||
public readonly Color Color = Color.FromArgb(128, Color.Cyan);
|
||||
@@ -34,6 +34,9 @@ namespace OpenRA.Mods.Common.Traits
|
||||
|
||||
public IEnumerable<IRenderable> RenderAnnotations(WorldRenderer wr, World w, ActorInfo ai, WPos centerPosition)
|
||||
{
|
||||
if (!EnabledByDefault)
|
||||
return Enumerable.Empty<IRenderable>();
|
||||
|
||||
var localRange = ai.TraitInfos<CreatesShroudInfo>()
|
||||
.Where(csi => csi.EnabledByDefault)
|
||||
.Select(csi => csi.Range)
|
||||
@@ -58,26 +61,32 @@ namespace OpenRA.Mods.Common.Traits
|
||||
public override object Create(ActorInitializer init) { return new RenderShroudCircle(this); }
|
||||
}
|
||||
|
||||
class RenderShroudCircle : INotifyCreated, IRenderAnnotationsWhenSelected
|
||||
class RenderShroudCircle : ConditionalTrait<RenderShroudCircleInfo>, INotifyCreated, IRenderAnnotationsWhenSelected
|
||||
{
|
||||
readonly RenderShroudCircleInfo info;
|
||||
WDist range;
|
||||
|
||||
public RenderShroudCircle(RenderShroudCircleInfo info)
|
||||
: base(info)
|
||||
{
|
||||
this.info = info;
|
||||
}
|
||||
|
||||
void INotifyCreated.Created(Actor self)
|
||||
protected override void Created(Actor self)
|
||||
{
|
||||
range = self.TraitsImplementing<CreatesShroud>()
|
||||
.Select(cs => cs.Info.Range)
|
||||
.DefaultIfEmpty(WDist.Zero)
|
||||
.Max();
|
||||
|
||||
base.Created(self);
|
||||
}
|
||||
|
||||
public IEnumerable<IRenderable> RangeCircleRenderables(Actor self)
|
||||
{
|
||||
if (IsTraitDisabled)
|
||||
yield break;
|
||||
|
||||
if (!self.Owner.IsAlliedWith(self.World.RenderPlayer))
|
||||
yield break;
|
||||
|
||||
|
||||
Reference in New Issue
Block a user