mirror of
https://github.com/misternebula/quantum-space-buddies.git
synced 2025-01-11 09:38:48 +00:00
233 lines
5.3 KiB
C#
233 lines
5.3 KiB
C#
using QSB.Player;
|
|
using QSB.SectorSync;
|
|
using QSB.SectorSync.WorldObjects;
|
|
using QSB.Utility;
|
|
using QSB.WorldSync;
|
|
using QuantumUNET.Transport;
|
|
|
|
namespace QSB.Syncs.Sectored
|
|
{
|
|
public abstract class BaseSectoredSync : SyncBase
|
|
{
|
|
public override bool IgnoreDisabledAttachedObject => false;
|
|
public override bool IgnoreNullReferenceTransform => true;
|
|
|
|
public QSBSector ReferenceSector { get; set; }
|
|
public SectorSync.SectorSync SectorSync { get; private set; }
|
|
|
|
private int _sectorIdWaitingSlot = int.MinValue;
|
|
|
|
public override void Start()
|
|
{
|
|
SectorSync = gameObject.AddComponent<SectorSync.SectorSync>();
|
|
QSBSectorManager.Instance.SectoredSyncs.Add(this);
|
|
base.Start();
|
|
}
|
|
|
|
protected override void OnDestroy()
|
|
{
|
|
base.OnDestroy();
|
|
QSBSectorManager.Instance.SectoredSyncs.Remove(this);
|
|
if (SectorSync != null)
|
|
{
|
|
Destroy(SectorSync);
|
|
}
|
|
}
|
|
|
|
protected override void OnSceneLoaded(OWScene oldScene, OWScene newScene, bool isInUniverse)
|
|
{
|
|
base.OnSceneLoaded(oldScene, newScene, isInUniverse);
|
|
SetReferenceSector(null);
|
|
}
|
|
|
|
protected override void Init()
|
|
{
|
|
base.Init();
|
|
if (!QSBSectorManager.Instance.IsReady)
|
|
{
|
|
return;
|
|
}
|
|
|
|
if (!HasAuthority)
|
|
{
|
|
return;
|
|
}
|
|
|
|
QSBCore.UnityEvents.RunWhen(() => SectorSync.IsReady, InitSector);
|
|
}
|
|
|
|
private void InitSector()
|
|
{
|
|
var closestSector = SectorSync.GetClosestSector(AttachedObject.transform);
|
|
if (closestSector != null)
|
|
{
|
|
SetReferenceSector(closestSector);
|
|
}
|
|
else
|
|
{
|
|
DebugLog.ToConsole($"Warning - {_logName}'s initial sector was null.", OWML.Common.MessageType.Warning);
|
|
}
|
|
}
|
|
|
|
public override void Update()
|
|
{
|
|
if (_sectorIdWaitingSlot == int.MinValue)
|
|
{
|
|
if (ReferenceSector != null && ReferenceSector.Transform != ReferenceTransform)
|
|
{
|
|
DebugLog.ToConsole($"Warning - {_logName} : ReferenceSector.Transform was different to ReferenceTransform. Correcting...", OWML.Common.MessageType.Warning);
|
|
SetReferenceTransform(ReferenceSector.Transform);
|
|
}
|
|
|
|
base.Update();
|
|
return;
|
|
}
|
|
|
|
if (!WorldObjectManager.AllReady)
|
|
{
|
|
base.Update();
|
|
return;
|
|
}
|
|
|
|
var sector = _sectorIdWaitingSlot == -1
|
|
? null
|
|
: QSBWorldSync.GetWorldFromId<QSBSector>(_sectorIdWaitingSlot);
|
|
|
|
if (sector != ReferenceSector)
|
|
{
|
|
if (sector == null)
|
|
{
|
|
DebugLog.ToConsole($"Error - {PlayerId}.{GetType().Name} got sector of ID -1.", OWML.Common.MessageType.Error);
|
|
base.Update();
|
|
return;
|
|
}
|
|
|
|
SetReferenceSector(sector);
|
|
}
|
|
|
|
_sectorIdWaitingSlot = int.MinValue;
|
|
|
|
base.Update();
|
|
}
|
|
|
|
public override void SerializeTransform(QNetworkWriter writer, bool initialState)
|
|
{
|
|
if (_intermediaryTransform == null)
|
|
{
|
|
_intermediaryTransform = new IntermediaryTransform(transform);
|
|
}
|
|
|
|
if (!QSBPlayerManager.PlayerExists(PlayerId))
|
|
{
|
|
writer.Write(-1);
|
|
}
|
|
else if (!Player.PlayerStates.IsReady)
|
|
{
|
|
writer.Write(-1);
|
|
}
|
|
else if (ReferenceSector != null)
|
|
{
|
|
writer.Write(ReferenceSector.ObjectId);
|
|
}
|
|
else
|
|
{
|
|
if (_isInitialized)
|
|
{
|
|
DebugLog.ToConsole($"Warning - ReferenceSector of {PlayerId}.{GetType().Name} is null.", OWML.Common.MessageType.Warning);
|
|
}
|
|
|
|
writer.Write(-1);
|
|
}
|
|
}
|
|
|
|
public override void DeserializeTransform(QNetworkReader reader, bool initialState)
|
|
{
|
|
int sectorId;
|
|
if (!QSBCore.WorldObjectsReady)
|
|
{
|
|
sectorId = reader.ReadInt32();
|
|
if (initialState && sectorId != -1)
|
|
{
|
|
DebugLog.DebugWrite($"{_logName} set waiting sector id:{sectorId}");
|
|
_sectorIdWaitingSlot = sectorId;
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
sectorId = reader.ReadInt32();
|
|
var sector = sectorId == -1
|
|
? null
|
|
: QSBWorldSync.GetWorldFromId<QSBSector>(sectorId);
|
|
|
|
if (sector != ReferenceSector)
|
|
{
|
|
if (sector == null)
|
|
{
|
|
DebugLog.ToConsole($"Error - {PlayerId}.{GetType().Name} got sector of ID -1.", OWML.Common.MessageType.Error);
|
|
return;
|
|
}
|
|
|
|
SetReferenceSector(sector);
|
|
}
|
|
}
|
|
|
|
protected bool UpdateSectors()
|
|
{
|
|
var referenceNull = ReferenceTransform == null || ReferenceSector == null || _intermediaryTransform.GetReferenceTransform() == null;
|
|
var sectorManagerReady = QSBSectorManager.Instance.IsReady;
|
|
|
|
if (!sectorManagerReady)
|
|
{
|
|
if (referenceNull && HasAuthority)
|
|
{
|
|
DebugLog.ToConsole($"Warning - Reference was null, but sector manager wasn't ready. " +
|
|
$"Transform:{ReferenceTransform == null}, Sector:{ReferenceSector == null}, Intermediary:{_intermediaryTransform.GetReferenceTransform() == null}",
|
|
OWML.Common.MessageType.Warning);
|
|
}
|
|
|
|
DebugLog.DebugWrite($"{_logName} : Sector Manager not ready.");
|
|
return false;
|
|
}
|
|
|
|
if (!HasAuthority)
|
|
{
|
|
return true;
|
|
}
|
|
|
|
if (referenceNull)
|
|
{
|
|
if (SectorSync.IsReady)
|
|
{
|
|
var closestSector = SectorSync.GetClosestSector(AttachedObject.transform);
|
|
if (closestSector != null)
|
|
{
|
|
SetReferenceTransform(closestSector.Transform);
|
|
return true;
|
|
}
|
|
else
|
|
{
|
|
DebugLog.ToConsole($"Error - No closest sector found to {PlayerId}.{GetType().Name}!", OWML.Common.MessageType.Error);
|
|
return false;
|
|
}
|
|
}
|
|
else
|
|
{
|
|
return false;
|
|
}
|
|
}
|
|
|
|
return true;
|
|
}
|
|
|
|
protected override bool UpdateTransform()
|
|
=> UpdateSectors();
|
|
|
|
public void SetReferenceSector(QSBSector sector)
|
|
{
|
|
ReferenceSector = sector;
|
|
SetReferenceTransform(sector?.Transform);
|
|
}
|
|
}
|
|
}
|