137 lines
3.9 KiB
C#
Raw Normal View History

2021-04-12 10:37:20 +01:00
using OWML.Common;
using OWML.Utils;
2021-06-19 13:22:05 +01:00
using QSB.Player;
using QSB.ShipSync.TransformSync;
using QSB.ShipSync.WorldObjects;
2021-04-12 10:37:20 +01:00
using QSB.Utility;
using QSB.WorldSync;
2021-04-16 11:40:13 +01:00
using QuantumUNET;
2021-06-19 13:22:05 +01:00
using System.Collections.Generic;
2021-04-12 10:37:20 +01:00
using System.Linq;
using UnityEngine;
namespace QSB.ShipSync
{
internal class ShipManager : WorldObjectManager
2021-04-12 10:37:20 +01:00
{
public static ShipManager Instance;
2021-04-13 18:50:15 +01:00
public InteractZone HatchInteractZone;
public HatchController HatchController;
public ShipTractorBeamSwitch ShipTractorBeam;
public ShipCockpitController CockpitController;
public ShipElectricalComponent ShipElectricalComponent;
public bool HasAuthority
=> ShipTransformSync.LocalInstance.HasAuthority;
2021-04-12 10:37:20 +01:00
public uint CurrentFlyer
{
get => _currentFlyer;
set
{
if (_currentFlyer != uint.MaxValue && value != uint.MaxValue)
{
DebugLog.ToConsole($"Warning - Trying to set current flyer while someone is still flying? Current:{_currentFlyer}, New:{value}", MessageType.Warning);
}
2021-06-18 22:38:32 +01:00
2021-04-12 10:37:20 +01:00
_currentFlyer = value;
}
}
2021-04-13 17:25:00 +01:00
2021-06-19 13:22:05 +01:00
private List<PlayerInfo> _playersInShip = new List<PlayerInfo>();
private uint _currentFlyer = uint.MaxValue;
2021-04-13 17:25:00 +01:00
public void Start()
=> Instance = this;
2021-04-13 21:09:26 +01:00
protected override void RebuildWorldObjects(OWScene scene)
{
2021-04-13 21:09:26 +01:00
var shipTransform = GameObject.Find("Ship_Body");
if (shipTransform == null)
{
DebugLog.ToConsole($"Error - Couldn't find ship!", MessageType.Error);
return;
}
2021-04-13 21:09:26 +01:00
HatchController = shipTransform.GetComponentInChildren<HatchController>();
if (HatchController == null)
{
DebugLog.ToConsole($"Error - Couldn't find hatch controller!", MessageType.Error);
return;
}
2021-04-13 21:09:26 +01:00
HatchInteractZone = HatchController.GetComponent<InteractZone>();
ShipTractorBeam = Resources.FindObjectsOfTypeAll<ShipTractorBeamSwitch>().First();
CockpitController = Resources.FindObjectsOfTypeAll<ShipCockpitController>().First();
ShipElectricalComponent = Resources.FindObjectsOfTypeAll<ShipElectricalComponent>().First();
2021-04-13 17:25:00 +01:00
2021-04-13 18:50:15 +01:00
var sphereShape = HatchController.GetComponent<SphereShape>();
2021-04-13 17:25:00 +01:00
sphereShape.radius = 2.5f;
sphereShape.center = new Vector3(0, 0, 1);
2021-04-16 11:40:13 +01:00
2021-08-08 19:53:55 +01:00
if (QSBCore.IsHost)
2021-04-16 11:40:13 +01:00
{
if (ShipTransformSync.LocalInstance != null)
{
if (ShipTransformSync.LocalInstance.gameObject == null)
{
DebugLog.ToConsole($"Warning - ShipTransformSync's LocalInstance is not null, but it's gameobject is null!", MessageType.Warning);
return;
}
QNetworkServer.Destroy(ShipTransformSync.LocalInstance.gameObject);
}
2021-06-18 22:38:32 +01:00
if (QSBPlayerManager.LocalPlayer.TransformSync == null)
{
DebugLog.ToConsole($"Error - Tried to spawn ship, but LocalPlayer's TransformSync is null!", MessageType.Error);
}
2021-08-19 16:37:29 +01:00
Instantiate(QSBNetworkManager.Instance.ShipPrefab).SpawnWithServerAuthority();
2021-04-16 11:40:13 +01:00
}
2021-06-18 16:40:05 +01:00
QSBWorldSync.Init<QSBShipComponent, ShipComponent>();
QSBWorldSync.Init<QSBShipHull, ShipHull>();
2021-06-18 16:40:05 +01:00
}
2021-06-19 13:22:05 +01:00
public void AddPlayerToShip(PlayerInfo player)
{
DebugLog.DebugWrite($"{player.PlayerId} enter ship.");
2021-06-19 13:22:05 +01:00
_playersInShip.Add(player);
UpdateElectricalComponent();
2021-06-19 13:22:05 +01:00
}
public void RemovePlayerFromShip(PlayerInfo player)
{
DebugLog.DebugWrite($"{player.PlayerId} leave ship.");
2021-06-19 13:22:05 +01:00
_playersInShip.Remove(player);
UpdateElectricalComponent();
}
2021-08-19 23:15:20 +01:00
public bool IsPlayerInShip(PlayerInfo player)
=> _playersInShip.Contains(player);
private void UpdateElectricalComponent()
{
var electricalSystem = ShipElectricalComponent.GetValue<ElectricalSystem>("_electricalSystem");
var damaged = ShipElectricalComponent.GetValue<bool>("_damaged");
if (_playersInShip.Count == 0)
{
if (!damaged)
{
DebugLog.DebugWrite($"No players left in ship - turning off electricals.");
electricalSystem.SetPowered(false);
}
}
else
{
if (!damaged)
{
DebugLog.DebugWrite($"Player in ship - turning on electricals.");
electricalSystem.SetPowered(true);
}
}
2021-06-19 13:22:05 +01:00
}
2021-04-12 10:37:20 +01:00
}
}