Merge pull request #10795 from Mailaender/screenmap-bounds-crash
Fixed screen map updates for invisible mobile actors
This commit is contained in:
@@ -194,6 +194,35 @@ namespace OpenRA
|
|||||||
player.Shroud.ExploreAll(this);
|
player.Shroud.ExploreAll(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void AddToMaps(Actor self, IOccupySpace ios)
|
||||||
|
{
|
||||||
|
ActorMap.AddInfluence(self, ios);
|
||||||
|
ActorMap.AddPosition(self, ios);
|
||||||
|
|
||||||
|
if (!self.Bounds.Size.IsEmpty)
|
||||||
|
ScreenMap.Add(self);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void UpdateMaps(Actor self, IOccupySpace ios)
|
||||||
|
{
|
||||||
|
if (!self.IsInWorld)
|
||||||
|
return;
|
||||||
|
|
||||||
|
if (!self.Bounds.Size.IsEmpty)
|
||||||
|
ScreenMap.Update(self);
|
||||||
|
|
||||||
|
ActorMap.UpdatePosition(self, ios);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void RemoveFromMaps(Actor self, IOccupySpace ios)
|
||||||
|
{
|
||||||
|
ActorMap.RemoveInfluence(self, ios);
|
||||||
|
ActorMap.RemovePosition(self, ios);
|
||||||
|
|
||||||
|
if (!self.Bounds.Size.IsEmpty)
|
||||||
|
ScreenMap.Remove(self);
|
||||||
|
}
|
||||||
|
|
||||||
public void LoadComplete(WorldRenderer wr)
|
public void LoadComplete(WorldRenderer wr)
|
||||||
{
|
{
|
||||||
// ScreenMap must be initialized before anything else
|
// ScreenMap must be initialized before anything else
|
||||||
|
|||||||
@@ -134,9 +134,8 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
|
|
||||||
public void AddedToWorld(Actor self)
|
public void AddedToWorld(Actor self)
|
||||||
{
|
{
|
||||||
self.World.ActorMap.AddInfluence(self, this);
|
self.World.AddToMaps(self, this);
|
||||||
self.World.ActorMap.AddPosition(self, this);
|
|
||||||
self.World.ScreenMap.Add(self);
|
|
||||||
var altitude = self.World.Map.DistanceAboveTerrain(CenterPosition);
|
var altitude = self.World.Map.DistanceAboveTerrain(CenterPosition);
|
||||||
if (altitude.Length >= Info.MinAirborneAltitude)
|
if (altitude.Length >= Info.MinAirborneAltitude)
|
||||||
OnAirborneAltitudeReached();
|
OnAirborneAltitudeReached();
|
||||||
@@ -353,8 +352,8 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
if (!self.IsInWorld)
|
if (!self.IsInWorld)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
self.World.ScreenMap.Update(self);
|
self.World.UpdateMaps(self, this);
|
||||||
self.World.ActorMap.UpdatePosition(self, this);
|
|
||||||
var altitude = self.World.Map.DistanceAboveTerrain(CenterPosition);
|
var altitude = self.World.Map.DistanceAboveTerrain(CenterPosition);
|
||||||
var isAirborne = altitude.Length >= Info.MinAirborneAltitude;
|
var isAirborne = altitude.Length >= Info.MinAirborneAltitude;
|
||||||
if (isAirborne && !airborne)
|
if (isAirborne && !airborne)
|
||||||
@@ -603,9 +602,8 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
public void RemovedFromWorld(Actor self)
|
public void RemovedFromWorld(Actor self)
|
||||||
{
|
{
|
||||||
UnReserve();
|
UnReserve();
|
||||||
self.World.ActorMap.RemoveInfluence(self, this);
|
self.World.RemoveFromMaps(self, this);
|
||||||
self.World.ActorMap.RemovePosition(self, this);
|
|
||||||
self.World.ScreenMap.Remove(self);
|
|
||||||
OnCruisingAltitudeLeft();
|
OnCruisingAltitudeLeft();
|
||||||
OnAirborneAltitudeLeft();
|
OnAirborneAltitudeLeft();
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -157,11 +157,7 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
public void SetVisualPosition(Actor self, WPos pos)
|
public void SetVisualPosition(Actor self, WPos pos)
|
||||||
{
|
{
|
||||||
CenterPosition = pos;
|
CenterPosition = pos;
|
||||||
if (self.IsInWorld)
|
self.World.UpdateMaps(self, this);
|
||||||
{
|
|
||||||
self.World.ScreenMap.Update(self);
|
|
||||||
self.World.ActorMap.UpdatePosition(self, this);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// Sets only the location (Location)
|
// Sets only the location (Location)
|
||||||
@@ -207,9 +203,7 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
|
|
||||||
public void AddedToWorld(Actor self)
|
public void AddedToWorld(Actor self)
|
||||||
{
|
{
|
||||||
self.World.ActorMap.AddInfluence(self, this);
|
self.World.AddToMaps(self, this);
|
||||||
self.World.ActorMap.AddPosition(self, this);
|
|
||||||
self.World.ScreenMap.Add(self);
|
|
||||||
|
|
||||||
var cs = self.World.WorldActor.TraitOrDefault<CrateSpawner>();
|
var cs = self.World.WorldActor.TraitOrDefault<CrateSpawner>();
|
||||||
if (cs != null)
|
if (cs != null)
|
||||||
@@ -218,9 +212,7 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
|
|
||||||
public void RemovedFromWorld(Actor self)
|
public void RemovedFromWorld(Actor self)
|
||||||
{
|
{
|
||||||
self.World.ActorMap.RemoveInfluence(self, this);
|
self.World.RemoveFromMaps(self, this);
|
||||||
self.World.ActorMap.RemovePosition(self, this);
|
|
||||||
self.World.ScreenMap.Remove(self);
|
|
||||||
|
|
||||||
var cs = self.World.WorldActor.TraitOrDefault<CrateSpawner>();
|
var cs = self.World.WorldActor.TraitOrDefault<CrateSpawner>();
|
||||||
if (cs != null)
|
if (cs != null)
|
||||||
|
|||||||
@@ -106,22 +106,18 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
CenterPosition = pos;
|
CenterPosition = pos;
|
||||||
TopLeft = self.World.Map.CellContaining(pos);
|
TopLeft = self.World.Map.CellContaining(pos);
|
||||||
self.World.ActorMap.AddInfluence(self, this);
|
self.World.ActorMap.AddInfluence(self, this);
|
||||||
self.World.ActorMap.UpdatePosition(self, this);
|
|
||||||
self.World.ScreenMap.Update(self);
|
self.World.UpdateMaps(self, this);
|
||||||
}
|
}
|
||||||
|
|
||||||
public void AddedToWorld(Actor self)
|
public void AddedToWorld(Actor self)
|
||||||
{
|
{
|
||||||
self.World.ActorMap.AddInfluence(self, this);
|
self.World.AddToMaps(self, this);
|
||||||
self.World.ActorMap.AddPosition(self, this);
|
|
||||||
self.World.ScreenMap.Add(self);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void RemovedFromWorld(Actor self)
|
public void RemovedFromWorld(Actor self)
|
||||||
{
|
{
|
||||||
self.World.ActorMap.RemoveInfluence(self, this);
|
self.World.RemoveFromMaps(self, this);
|
||||||
self.World.ActorMap.RemovePosition(self, this);
|
|
||||||
self.World.ScreenMap.Remove(self);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public bool Disabled
|
public bool Disabled
|
||||||
|
|||||||
@@ -430,25 +430,17 @@ namespace OpenRA.Mods.Common.Traits
|
|||||||
public void SetVisualPosition(Actor self, WPos pos)
|
public void SetVisualPosition(Actor self, WPos pos)
|
||||||
{
|
{
|
||||||
CenterPosition = pos;
|
CenterPosition = pos;
|
||||||
if (self.IsInWorld)
|
self.World.UpdateMaps(self, this);
|
||||||
{
|
|
||||||
self.World.ScreenMap.Update(self);
|
|
||||||
self.World.ActorMap.UpdatePosition(self, this);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void AddedToWorld(Actor self)
|
public void AddedToWorld(Actor self)
|
||||||
{
|
{
|
||||||
self.World.ActorMap.AddInfluence(self, this);
|
self.World.AddToMaps(self, this);
|
||||||
self.World.ActorMap.AddPosition(self, this);
|
|
||||||
self.World.ScreenMap.Add(self);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public void RemovedFromWorld(Actor self)
|
public void RemovedFromWorld(Actor self)
|
||||||
{
|
{
|
||||||
self.World.ActorMap.RemoveInfluence(self, this);
|
self.World.RemoveFromMaps(self, this);
|
||||||
self.World.ActorMap.RemovePosition(self, this);
|
|
||||||
self.World.ScreenMap.Remove(self);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public IEnumerable<IOrderTargeter> Orders { get { yield return new MoveOrderTargeter(self, this); } }
|
public IEnumerable<IOrderTargeter> Orders { get { yield return new MoveOrderTargeter(self, this); } }
|
||||||
|
|||||||
Reference in New Issue
Block a user