minor tidying
This commit is contained in:
@@ -23,7 +23,8 @@ namespace OpenRa
|
||||
|
||||
public int2 Sign() { return new int2(Math.Sign(X), Math.Sign(Y)); }
|
||||
public int2 Abs() { return new int2( Math.Abs( X ), Math.Abs( Y ) ); }
|
||||
public int Length { get { return (int)Math.Sqrt(X * X + Y * Y); } }
|
||||
public int LengthSquared { get { return X * X + Y * Y; } }
|
||||
public int Length { get { return (int)Math.Sqrt(LengthSquared); } }
|
||||
public override int GetHashCode() { return X.GetHashCode() ^ Y.GetHashCode(); }
|
||||
|
||||
public override bool Equals(object obj)
|
||||
|
||||
@@ -13,26 +13,15 @@ namespace OpenRa.Game.Traits
|
||||
int primaryFireDelay = 0;
|
||||
int secondaryFireDelay = 0;
|
||||
|
||||
public AttackTurreted( Actor self )
|
||||
{
|
||||
self.traits.Get<Turreted>();
|
||||
}
|
||||
public AttackTurreted( Actor self ) { self.traits.Get<Turreted>(); }
|
||||
|
||||
public void Tick(Actor self)
|
||||
{
|
||||
if( primaryFireDelay > 0 )
|
||||
--primaryFireDelay;
|
||||
if( secondaryFireDelay > 0 )
|
||||
--secondaryFireDelay;
|
||||
if (primaryFireDelay > 0) --primaryFireDelay;
|
||||
if (secondaryFireDelay > 0) --secondaryFireDelay;
|
||||
|
||||
if( target == null )
|
||||
return;
|
||||
|
||||
if (target.IsDead) /* stop firing on targets after we've killed them */
|
||||
{
|
||||
target = null;
|
||||
return;
|
||||
}
|
||||
if (target != null && target.IsDead) target = null; /* he's dead, jim. */
|
||||
if (target == null) return;
|
||||
|
||||
var turreted = self.traits.Get<Turreted>();
|
||||
turreted.desiredFacing = Util.GetFacing(target.CenterLocation - self.CenterLocation, turreted.turretFacing);
|
||||
@@ -50,12 +39,9 @@ namespace OpenRa.Game.Traits
|
||||
|
||||
bool CheckFire( Actor self, string weaponName, ref int fireDelay )
|
||||
{
|
||||
if( fireDelay > 0 )
|
||||
return false;
|
||||
if( fireDelay > 0 ) return false;
|
||||
var weapon = Rules.WeaponInfo[ weaponName ];
|
||||
var d = target.Location - self.Location;
|
||||
if( weapon.Range * weapon.Range < d.X * d.X + d.Y * d.Y )
|
||||
return false;
|
||||
if( weapon.Range * weapon.Range < (target.Location - self.Location).LengthSquared ) return false;
|
||||
|
||||
// FIXME: rules specifies ROF in 1/15 sec units; ticks are 1/25 sec
|
||||
fireDelay = weapon.ROF;
|
||||
|
||||
Reference in New Issue
Block a user