diff --git a/Concealment/ConcealGroup.cs b/Concealment/ConcealGroup.cs
index 5eb7b09..05a36cd 100644
--- a/Concealment/ConcealGroup.cs
+++ b/Concealment/ConcealGroup.cs
@@ -3,11 +3,14 @@
using System.Linq;
using System.Reflection;
using NLog;
+using Sandbox.Engine.Physics;
using Sandbox.Game.Entities;
using Sandbox.Game.Entities.Blocks;
using Sandbox.Game.World;
using SpaceEngineers.Game.Entities.Blocks;
+using VRage.Game.Entity;
using VRage.Groups;
+using VRage.ModAPI;
using VRageMath;
namespace Concealment
@@ -120,6 +123,89 @@ public bool IsCryoOccupied(ulong steamId)
return false;
}
+
+ ///
+ /// Conceals this group from game and physics logic.
+ ///
+ public void Conceal()
+ {
+ foreach (var body in Grids)
+ if (body.Parent == null)
+ UnregisterRecursive(body);
+
+ foreach (var body in Grids)
+ body.Physics?.UnweldAll(false);
+ foreach (var body in Grids)
+ body.Physics?.Deactivate();
+
+ foreach (var entity in Grids)
+ if (entity.Parent == null)
+ MyGamePruningStructure.Remove(entity);
+
+ void UnregisterRecursive(IMyEntity e)
+ {
+ MyEntities.UnregisterForUpdate((MyEntity)e);
+ if (e.Hierarchy == null)
+ return;
+
+ foreach (var child in e.Hierarchy.Children)
+ UnregisterRecursive(child.Container.Entity);
+ }
+ }
+
+ ///
+ /// Reveals this group to game and physics logic.
+ ///
+ public void Reveal()
+ {
+ foreach (var entity in Grids)
+ if (entity.Parent == null)
+ MyGamePruningStructure.Add(entity);
+
+
+ var weldGroups = new HashSet.Group>();
+ foreach (var body in Grids)
+ {
+ if (body.Physics == null)
+ continue;
+ var group = MyWeldingGroups.Static.GetGroup(body);
+ if (group == null)
+ body.Physics.Activate();
+ else
+ weldGroups.Add(group);
+ }
+ foreach (var group in weldGroups)
+ {
+ var body = group.GroupData.Parent;
+ if (!(body.Physics is MyPhysicsBody bodyPhysics))
+ continue;
+ bodyPhysics.Activate();
+
+ foreach (var child in group.Nodes)
+ if (child.NodeData != body &&
+ !child.NodeData.MarkedForClose &&
+ child.NodeData.Physics is MyPhysicsBody physBody)
+ bodyPhysics.Weld(physBody);
+
+ body.RaisePhysicsChanged();
+ }
+
+
+ foreach (var entity in Grids)
+ if (entity.Parent == null)
+ RegisterRecursive(entity);
+
+ void RegisterRecursive(IMyEntity e)
+ {
+ MyEntities.RegisterForUpdate((MyEntity)e);
+ if (e.Hierarchy == null)
+ return;
+
+ foreach (var child in e.Hierarchy.Children)
+ RegisterRecursive(child.Container.Entity);
+ }
+ }
+
}
}
diff --git a/Concealment/ConcealmentPlugin.cs b/Concealment/ConcealmentPlugin.cs
index 0f23f1b..5b5c063 100644
--- a/Concealment/ConcealmentPlugin.cs
+++ b/Concealment/ConcealmentPlugin.cs
@@ -7,7 +7,6 @@
using System.Threading;
using System.Threading.Tasks;
using System.Windows.Controls;
-using Havok;
using NLog;
using Sandbox.Definitions;
using Sandbox.Engine.Multiplayer;
@@ -23,7 +22,6 @@
using VRage.Game;
using VRage.Game.Components;
using VRage.Game.Definitions;
-using VRage.Game.Entity;
using VRage.Game.ModAPI;
using VRage.Game.ObjectBuilders.ComponentSystem;
using VRage.ModAPI;
@@ -54,7 +52,7 @@ public ConcealmentPlugin()
UserControl IWpfPlugin.GetControl()
{
- return _control ?? (_control = new ConcealmentControl {DataContext = this});
+ return _control ?? (_control = new ConcealmentControl { DataContext = this });
}
public override void Init(ITorchBase torch)
@@ -198,47 +196,6 @@ private void RevealSpawns(PlayerRequestArgs args)
});
}
- private void ConcealEntity(IMyEntity entity)
- {
- if (entity != entity.GetTopMostParent())
- return;
-
- entity.GetStorage().SetValue(Id, "True");
- MyGamePruningStructure.Remove((MyEntity)entity);
- entity.Physics?.Deactivate();
- UnregisterRecursive(entity);
-
- void UnregisterRecursive(IMyEntity e)
- {
- MyEntities.UnregisterForUpdate((MyEntity)e);
- if (e.Hierarchy == null)
- return;
-
- foreach (var child in e.Hierarchy.Children)
- UnregisterRecursive(child.Container.Entity);
- }
- }
-
- private void RevealEntity(IMyEntity entity)
- {
- if (entity != entity.GetTopMostParent())
- return;
-
- entity.GetStorage().SetValue(Id, "False");
- MyGamePruningStructure.Add((MyEntity)entity);
- entity.Physics?.Activate();
- RegisterRecursive(entity);
-
- void RegisterRecursive(IMyEntity e)
- {
- MyEntities.RegisterForUpdate((MyEntity)e);
- if (e.Hierarchy == null)
- return;
-
- foreach (var child in e.Hierarchy.Children)
- RegisterRecursive(child.Container.Entity);
- }
- }
private int ConcealGroup(ConcealGroup group)
{
@@ -246,7 +203,10 @@ private int ConcealGroup(ConcealGroup group)
return 0;
Log.Debug($"Concealing grids: {group.GridNames}");
- group.Grids.ForEach(ConcealEntity);
+ group.Conceal();
+ foreach (var entity in group.Grids)
+ entity.GetStorage().SetValue(Id, "True");
+
group.UpdateAABB();
var aabb = group.WorldAABB;
group.ProxyId = _concealedAabbTree.AddProxy(ref aabb, group, 0);
@@ -277,7 +237,10 @@ public int RevealGroup(ConcealGroup group)
var count = group.Grids.Count;
Log.Debug($"Revealing grids: {group.GridNames}");
- group.Grids.ForEach(RevealEntity);
+ group.Reveal();
+ foreach (var entity in group.Grids)
+ entity.GetStorage().SetValue(Id, "False");
+
ConcealedGroups.Remove(group);
_concealedAabbTree.RemoveProxy(group.ProxyId);
group.UpdatePostReveal();