mirror of
https://github.com/misternebula/quantum-space-buddies.git
synced 2025-01-27 12:35:28 +00:00
Merge branch 'dev' of https://github.com/Raicuparta/quantum-space-buddies into dev
This commit is contained in:
commit
fe447990b1
@ -1,6 +1,8 @@
|
||||
using OWML.ModHelper.Events;
|
||||
using QSB.Events;
|
||||
using System.Linq;
|
||||
using OWML.Common;
|
||||
using QSB.Utility;
|
||||
using UnityEngine;
|
||||
|
||||
namespace QSB.DeathSync
|
||||
@ -28,7 +30,6 @@ namespace QSB.DeathSync
|
||||
private HatchController _hatchController;
|
||||
private ShipCockpitController _cockpitController;
|
||||
private PlayerSpacesuit _spaceSuit;
|
||||
private bool _isSetUp;
|
||||
|
||||
private void Awake()
|
||||
{
|
||||
@ -48,11 +49,6 @@ namespace QSB.DeathSync
|
||||
|
||||
public void Init()
|
||||
{
|
||||
if (_isSetUp)
|
||||
{
|
||||
return;
|
||||
}
|
||||
_isSetUp = true;
|
||||
var playerTransform = Locator.GetPlayerTransform();
|
||||
_playerResources = playerTransform.GetComponent<PlayerResources>();
|
||||
_spaceSuit = playerTransform.GetComponentInChildren<PlayerSpacesuit>(true);
|
||||
@ -84,6 +80,11 @@ namespace QSB.DeathSync
|
||||
}
|
||||
|
||||
// Reset ship position.
|
||||
if (_shipSpawnPoint == null)
|
||||
{
|
||||
DebugLog.ToConsole("_shipSpawnPoint is null!", MessageType.Warning);
|
||||
return;
|
||||
}
|
||||
_shipBody.SetVelocity(_shipSpawnPoint.GetPointVelocity());
|
||||
_shipBody.WarpToPositionRotation(_shipSpawnPoint.transform.position, _shipSpawnPoint.transform.rotation);
|
||||
|
||||
@ -132,9 +133,7 @@ namespace QSB.DeathSync
|
||||
{
|
||||
return _playerSpawner
|
||||
.GetValue<SpawnPoint[]>("_spawnList")
|
||||
.FirstOrDefault(spawnPoint =>
|
||||
spawnPoint.GetSpawnLocation() == SpawnLocation.TimberHearth && spawnPoint.IsShipSpawn() == isShip
|
||||
);
|
||||
.FirstOrDefault(spawnPoint => spawnPoint.GetSpawnLocation() == SpawnLocation.TimberHearth && spawnPoint.IsShipSpawn() == isShip);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -29,11 +29,11 @@ namespace QSB.GeyserSync
|
||||
{
|
||||
if (state)
|
||||
{
|
||||
_geyserController.ActivateGeyser();
|
||||
_geyserController?.ActivateGeyser();
|
||||
}
|
||||
else
|
||||
{
|
||||
_geyserController.DeactivateGeyser();
|
||||
_geyserController?.DeactivateGeyser();
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -4,6 +4,7 @@ using QSB.TransformSync;
|
||||
using QSB.Utility;
|
||||
using System.Collections.Generic;
|
||||
using System.Linq;
|
||||
using UnityEngine.Networking;
|
||||
|
||||
namespace QSB
|
||||
{
|
||||
@ -11,7 +12,7 @@ namespace QSB
|
||||
{
|
||||
public const int NetworkObjectCount = 4;
|
||||
|
||||
public static uint LocalPlayerId => PlayerTransformSync.LocalInstance.netId.Value;
|
||||
public static uint LocalPlayerId => PlayerTransformSync.LocalInstance.GetComponent<NetworkIdentity>()?.netId.Value ?? 0;
|
||||
public static PlayerInfo LocalPlayer => GetPlayer(LocalPlayerId);
|
||||
public static List<PlayerInfo> PlayerList { get; } = new List<PlayerInfo>();
|
||||
|
||||
|
@ -1,34 +1,13 @@
|
||||
using OWML.Common;
|
||||
using QSB.Utility;
|
||||
using System;
|
||||
using UnityEngine.Networking;
|
||||
using UnityEngine.Networking;
|
||||
|
||||
namespace QSB
|
||||
{
|
||||
public abstract class PlayerSyncObject : NetworkBehaviour
|
||||
{
|
||||
protected abstract uint PlayerIdOffset { get; }
|
||||
|
||||
public uint NetId => netId.Value;
|
||||
public uint NetId => GetComponent<NetworkIdentity>()?.netId.Value ?? 0;
|
||||
public bool IsLocal => hasAuthority;
|
||||
public uint PlayerId => GetPlayerId();
|
||||
public uint PlayerId => NetId - PlayerIdOffset;
|
||||
public PlayerInfo Player => PlayerRegistry.GetPlayer(PlayerId);
|
||||
|
||||
private uint GetPlayerId()
|
||||
{
|
||||
try
|
||||
{
|
||||
return NetId - PlayerIdOffset;
|
||||
}
|
||||
catch
|
||||
{
|
||||
DebugLog.ToConsole($"Error while getting netId of {GetType().Name}! " +
|
||||
$"{Environment.NewLine} - Did you destroy the TransformSync without destroying the {GetType().Name}?" +
|
||||
$"{Environment.NewLine} - Did a destroyed TransformSync/{GetType().Name} still have an active action/event listener?" +
|
||||
$"{Environment.NewLine} If you are a user seeing this, please report this error.", MessageType.Error);
|
||||
return uint.MaxValue;
|
||||
}
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
@ -150,7 +150,16 @@ namespace QSB
|
||||
|
||||
private void CleanupConnection(NetworkConnection connection)
|
||||
{
|
||||
var playerId = connection.playerControllers[0].gameObject.GetComponent<PlayerTransformSync>().netId.Value;
|
||||
uint playerId;
|
||||
try
|
||||
{
|
||||
playerId = connection.playerControllers[0].gameObject.GetComponent<PlayerTransformSync>().netId.Value;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
DebugLog.ToConsole("Error when getting playerId in CleanupConnection: " + ex.Message, MessageType.Error);
|
||||
return;
|
||||
}
|
||||
if (!PlayerRegistry.PlayerExists(playerId))
|
||||
{
|
||||
return;
|
||||
@ -161,7 +170,7 @@ namespace QSB
|
||||
|
||||
if (playerId != PlayerRegistry.LocalPlayerId) // We don't want to delete the local player!
|
||||
{
|
||||
var netIds = connection.clientOwnedObjects.Select(x => x.Value).ToList();
|
||||
var netIds = connection.clientOwnedObjects?.Select(x => x.Value).ToList();
|
||||
netIds.ForEach(CleanupNetworkBehaviour);
|
||||
}
|
||||
}
|
||||
|
@ -1,7 +1,4 @@
|
||||
using OWML.Common;
|
||||
using QSB.Utility;
|
||||
using System;
|
||||
using UnityEngine;
|
||||
using UnityEngine;
|
||||
|
||||
namespace QSB.TransformSync
|
||||
{
|
||||
@ -50,17 +47,13 @@ namespace QSB.TransformSync
|
||||
public void Remove()
|
||||
{
|
||||
// do N O T destroy the parent - it completely breaks the ENTIRE GAME
|
||||
try
|
||||
if (_canvasMarker?.gameObject != null)
|
||||
{
|
||||
_canvasMarker.DestroyMarker();
|
||||
Destroy(_markerTarget.gameObject);
|
||||
Destroy(this);
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
DebugLog.ToConsole($"Warning - Failed to remove PlayerHUDMarker for {_player.Name} ({_player.NetId}) : {ex}", MessageType.Warning);
|
||||
}
|
||||
|
||||
Destroy(_markerTarget.gameObject);
|
||||
Destroy(this);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
|
@ -51,7 +51,7 @@ namespace QSB.TransformSync
|
||||
protected override void UpdateTransform()
|
||||
{
|
||||
base.UpdateTransform();
|
||||
if (Player.GetState(State.ProbeActive))
|
||||
if (Player.GetState(State.ProbeActive) || ReferenceSector.Sector == null)
|
||||
{
|
||||
return;
|
||||
}
|
||||
|
@ -2,7 +2,7 @@
|
||||
"enabled": true,
|
||||
"settings": {
|
||||
"defaultServerIP": "localhost",
|
||||
"debugMode": true,
|
||||
"port": 7777
|
||||
"port": 7777,
|
||||
"debugMode": false
|
||||
}
|
||||
}
|
||||
|
Loading…
x
Reference in New Issue
Block a user