Merge pull request #9706 from reaperrr/block-height
Add Height property to BlocksProjectiles
This commit is contained in:
@@ -13,10 +13,11 @@ using OpenRA.Traits;
|
||||
|
||||
namespace OpenRA.Mods.Common.Traits
|
||||
{
|
||||
// TODO: Add functionality like a customizable Height that is compared to projectile altitude
|
||||
[Desc("This actor blocks bullets and missiles with 'Blockable' property.")]
|
||||
public class BlocksProjectilesInfo : UpgradableTraitInfo
|
||||
{
|
||||
public readonly WDist Height = WDist.FromCells(1);
|
||||
|
||||
public override object Create(ActorInitializer init) { return new BlocksProjectiles(init.Self, this); }
|
||||
}
|
||||
|
||||
@@ -27,8 +28,11 @@ namespace OpenRA.Mods.Common.Traits
|
||||
|
||||
public static bool AnyBlockingActorAt(World world, WPos pos)
|
||||
{
|
||||
var dat = world.Map.DistanceAboveTerrain(pos);
|
||||
return world.ActorMap.GetActorsAt(world.Map.CellContaining(pos))
|
||||
.Any(a => a.TraitsImplementing<BlocksProjectiles>().Any(Exts.IsTraitEnabled));
|
||||
.Any(a => a.TraitsImplementing<BlocksProjectiles>()
|
||||
.Where(t => t.Info.Height.Length >= dat.Length)
|
||||
.Any(Exts.IsTraitEnabled));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -27,12 +27,14 @@ namespace OpenRA.Mods.Common.Traits
|
||||
readonly DeveloperMode devMode;
|
||||
|
||||
readonly HealthInfo healthInfo;
|
||||
readonly BlocksProjectilesInfo blockInfo;
|
||||
Lazy<AttackBase> attack;
|
||||
Lazy<BodyOrientation> coords;
|
||||
|
||||
public CombatDebugOverlay(Actor self)
|
||||
{
|
||||
healthInfo = self.Info.TraitInfoOrDefault<HealthInfo>();
|
||||
blockInfo = self.Info.TraitInfoOrDefault<BlocksProjectilesInfo>();
|
||||
attack = Exts.Lazy(() => self.TraitOrDefault<AttackBase>());
|
||||
coords = Exts.Lazy(() => self.Trait<BodyOrientation>());
|
||||
|
||||
@@ -48,11 +50,23 @@ namespace OpenRA.Mods.Common.Traits
|
||||
if (healthInfo != null)
|
||||
wr.DrawRangeCircle(self.CenterPosition, healthInfo.Radius, Color.Red);
|
||||
|
||||
var wlr = Game.Renderer.WorldLineRenderer;
|
||||
|
||||
if (blockInfo != null)
|
||||
{
|
||||
var hc = Color.Orange;
|
||||
var height = new WVec(0, 0, blockInfo.Height.Length);
|
||||
var ha = wr.ScreenPosition(self.CenterPosition);
|
||||
var hb = wr.ScreenPosition(self.CenterPosition + height);
|
||||
wlr.DrawLine(ha, hb, hc);
|
||||
wr.DrawTargetMarker(hc, ha);
|
||||
wr.DrawTargetMarker(hc, hb);
|
||||
}
|
||||
|
||||
// No armaments to draw
|
||||
if (attack.Value == null)
|
||||
return;
|
||||
|
||||
var wlr = Game.Renderer.WorldLineRenderer;
|
||||
var c = Color.White;
|
||||
|
||||
// Fire ports on garrisonable structures
|
||||
|
||||
@@ -546,6 +546,7 @@
|
||||
|
||||
^Wall:
|
||||
Inherits@1: ^SpriteActor
|
||||
CombatDebugOverlay:
|
||||
AppearsOnRadar:
|
||||
Building:
|
||||
Dimensions: 1,1
|
||||
|
||||
@@ -503,6 +503,7 @@ starport:
|
||||
|
||||
wall:
|
||||
Inherits@1: ^SpriteActor
|
||||
CombatDebugOverlay:
|
||||
HiddenUnderShroud:
|
||||
Buildable:
|
||||
Queue: Building
|
||||
|
||||
@@ -177,6 +177,7 @@
|
||||
|
||||
^Wall:
|
||||
Inherits@1: ^SpriteActor
|
||||
CombatDebugOverlay:
|
||||
HiddenUnderShroud:
|
||||
AppearsOnRadar:
|
||||
Building:
|
||||
|
||||
@@ -19,6 +19,7 @@ GAWALL:
|
||||
Armor:
|
||||
Type: Concrete
|
||||
BlocksProjectiles:
|
||||
Height: 640
|
||||
Crushable:
|
||||
CrushClasses: heavywall
|
||||
LineBuild:
|
||||
@@ -46,6 +47,8 @@ GACTWR:
|
||||
HP: 500
|
||||
Armor:
|
||||
Type: Light
|
||||
BlocksProjectiles:
|
||||
Height: 768
|
||||
BodyOrientation:
|
||||
QuantizedFacings: 32
|
||||
DetectCloaked:
|
||||
|
||||
@@ -19,6 +19,7 @@ NAWALL:
|
||||
Armor:
|
||||
Type: Concrete
|
||||
BlocksProjectiles:
|
||||
Height: 640
|
||||
Crushable:
|
||||
CrushClasses: heavywall
|
||||
LineBuild:
|
||||
|
||||
@@ -6,7 +6,7 @@
|
||||
Speed: 682
|
||||
Image: 120mm
|
||||
Shadow: true
|
||||
Angle: 62
|
||||
Angle: 75
|
||||
Palette: ra
|
||||
Warhead@1Dam: SpreadDamage
|
||||
Spread: 128
|
||||
|
||||
Reference in New Issue
Block a user