mirror of
https://github.com/misternebula/quantum-space-buddies.git
synced 2025-01-26 09:35:26 +00:00
149 lines
4.6 KiB
C#
149 lines
4.6 KiB
C#
using Mirror;
|
|
using OWML.Common;
|
|
using QSB.Messaging;
|
|
using QSB.MeteorSync.WorldObjects;
|
|
using QSB.Utility;
|
|
using UnityEngine;
|
|
|
|
namespace QSB.MeteorSync.Messages
|
|
{
|
|
/// called when we request a resync on client join
|
|
/// pain
|
|
public class FragmentInitialStateMessage : QSBWorldObjectMessage<QSBFragment>
|
|
{
|
|
private float Integrity;
|
|
private float OrigIntegrity;
|
|
private float LeashLength;
|
|
private bool IsDetached;
|
|
|
|
private bool IsThruWhiteHole;
|
|
private Vector3 RelPos;
|
|
private Quaternion RelRot;
|
|
private Vector3 RelVel;
|
|
private Vector3 RelAngVel;
|
|
|
|
public FragmentInitialStateMessage(QSBFragment qsbFragment)
|
|
{
|
|
Integrity = qsbFragment.AttachedObject._integrity;
|
|
OrigIntegrity = qsbFragment.AttachedObject._origIntegrity;
|
|
LeashLength = qsbFragment.LeashLength;
|
|
IsDetached = qsbFragment.IsDetached;
|
|
|
|
if (IsDetached)
|
|
{
|
|
IsThruWhiteHole = qsbFragment.IsThruWhiteHole;
|
|
|
|
var body = qsbFragment.Body;
|
|
var refBody = qsbFragment.RefBody;
|
|
var pos = body.GetPosition();
|
|
RelPos = refBody.transform.ToRelPos(pos);
|
|
RelRot = refBody.transform.ToRelRot(body.GetRotation());
|
|
RelVel = refBody.ToRelVel(body.GetVelocity(), pos);
|
|
RelAngVel = refBody.ToRelAngVel(body.GetAngularVelocity());
|
|
}
|
|
}
|
|
|
|
public override void Serialize(NetworkWriter writer)
|
|
{
|
|
base.Serialize(writer);
|
|
writer.Write(Integrity);
|
|
writer.Write(OrigIntegrity);
|
|
writer.Write(LeashLength);
|
|
writer.Write(IsDetached);
|
|
if (IsDetached)
|
|
{
|
|
writer.Write(IsThruWhiteHole);
|
|
writer.Write(RelPos);
|
|
writer.Write(RelRot);
|
|
writer.Write(RelVel);
|
|
writer.Write(RelAngVel);
|
|
}
|
|
}
|
|
|
|
public override void Deserialize(NetworkReader reader)
|
|
{
|
|
base.Deserialize(reader);
|
|
Integrity = reader.Read<float>();
|
|
OrigIntegrity = reader.Read<float>();
|
|
LeashLength = reader.Read<float>();
|
|
IsDetached = reader.Read<bool>();
|
|
if (IsDetached)
|
|
{
|
|
IsThruWhiteHole = reader.Read<bool>();
|
|
RelPos = reader.ReadVector3();
|
|
RelRot = reader.ReadQuaternion();
|
|
RelVel = reader.ReadVector3();
|
|
RelAngVel = reader.ReadVector3();
|
|
}
|
|
}
|
|
|
|
public override void OnReceiveRemote()
|
|
{
|
|
WorldObject.AttachedObject._origIntegrity = OrigIntegrity;
|
|
WorldObject.LeashLength = LeashLength;
|
|
if (!OWMath.ApproxEquals(WorldObject.AttachedObject._integrity, Integrity))
|
|
{
|
|
WorldObject.AttachedObject._integrity = Integrity;
|
|
WorldObject.AttachedObject.CallOnTakeDamage();
|
|
}
|
|
|
|
if (IsDetached && !WorldObject.IsDetached)
|
|
{
|
|
// the detach is delayed, so wait until that happens
|
|
UnityEvents.RunWhen(() => WorldObject.IsDetached, () =>
|
|
{
|
|
var body = WorldObject.Body;
|
|
|
|
if (IsThruWhiteHole && !WorldObject.IsThruWhiteHole)
|
|
{
|
|
var whiteHoleVolume = MeteorManager.WhiteHoleVolume;
|
|
var attachedFluidDetector = body.GetAttachedFluidDetector();
|
|
var attachedForceDetector = body.GetAttachedForceDetector();
|
|
if (attachedFluidDetector is ConstantFluidDetector constantFluidDetector)
|
|
{
|
|
constantFluidDetector.SetDetectableFluid(whiteHoleVolume._fluidVolume);
|
|
}
|
|
|
|
if (attachedForceDetector is ConstantForceDetector constantForceDetector)
|
|
{
|
|
constantForceDetector.ClearAllFields();
|
|
}
|
|
|
|
WorldObject.DetachableFragment.ChangeFragmentSector(whiteHoleVolume._whiteHoleSector,
|
|
whiteHoleVolume._whiteHoleProxyShadowSuperGroup);
|
|
|
|
WorldObject.DetachableFragment.EndWarpScaling();
|
|
body.gameObject.AddComponent<DebrisLeash>().Init(whiteHoleVolume._whiteHoleBody, WorldObject.LeashLength);
|
|
whiteHoleVolume._ejectedBodyList.Add(body);
|
|
}
|
|
else if (!IsThruWhiteHole && WorldObject.IsThruWhiteHole)
|
|
{
|
|
// should only happen if client is way too far ahead and they try to connect. we fail here.
|
|
DebugLog.ToConsole($"{WorldObject} is thru white hole, but msg is not. fuck", MessageType.Error);
|
|
return;
|
|
}
|
|
|
|
if (WorldObject.IsThruWhiteHole)
|
|
{
|
|
var debrisLeash = body.GetComponent<DebrisLeash>();
|
|
debrisLeash._deccelerating = false;
|
|
debrisLeash.enabled = true;
|
|
}
|
|
|
|
var refBody = WorldObject.RefBody;
|
|
var pos = refBody.transform.FromRelPos(RelPos);
|
|
body.SetPosition(pos);
|
|
body.SetRotation(refBody.transform.FromRelRot(RelRot));
|
|
body.SetVelocity(refBody.FromRelVel(RelVel, pos));
|
|
body.SetAngularVelocity(refBody.FromRelAngVel(RelAngVel));
|
|
});
|
|
}
|
|
else if (!IsDetached && WorldObject.IsDetached)
|
|
{
|
|
// should only happen if client is way too far ahead and they try to connect. we fail here.
|
|
DebugLog.ToConsole($"{WorldObject} is detached, but msg is not. fuck", MessageType.Error);
|
|
}
|
|
}
|
|
}
|
|
}
|