mirror of
https://github.com/misternebula/quantum-space-buddies.git
synced 2025-01-25 15:35:22 +00:00
290 lines
7.3 KiB
C#
290 lines
7.3 KiB
C#
using QuantumUNET.Components;
|
|
using System.Collections.Generic;
|
|
using UnityEngine;
|
|
using UnityEngine.Networking;
|
|
|
|
namespace QuantumUNET
|
|
{
|
|
internal class QSBNetworkScene
|
|
{
|
|
internal static Dictionary<NetworkHash128, GameObject> guidToPrefab { get; } = new Dictionary<NetworkHash128, GameObject>();
|
|
|
|
internal static Dictionary<NetworkHash128, QSBSpawnDelegate> spawnHandlers { get; } = new Dictionary<NetworkHash128, QSBSpawnDelegate>();
|
|
|
|
internal static Dictionary<NetworkHash128, UnSpawnDelegate> unspawnHandlers { get; } = new Dictionary<NetworkHash128, UnSpawnDelegate>();
|
|
|
|
internal Dictionary<NetworkInstanceId, QSBNetworkIdentity> localObjects { get; } = new Dictionary<NetworkInstanceId, QSBNetworkIdentity>();
|
|
|
|
internal void Shutdown()
|
|
{
|
|
ClearLocalObjects();
|
|
ClearSpawners();
|
|
}
|
|
|
|
internal void SetLocalObject(NetworkInstanceId netId, GameObject obj, bool isClient, bool isServer)
|
|
{
|
|
if (obj == null)
|
|
{
|
|
localObjects[netId] = null;
|
|
}
|
|
else
|
|
{
|
|
QSBNetworkIdentity networkIdentity = null;
|
|
if (localObjects.ContainsKey(netId))
|
|
{
|
|
networkIdentity = localObjects[netId];
|
|
}
|
|
if (networkIdentity == null)
|
|
{
|
|
networkIdentity = obj.GetComponent<QSBNetworkIdentity>();
|
|
localObjects[netId] = networkIdentity;
|
|
}
|
|
networkIdentity.UpdateClientServer(isClient, isServer);
|
|
}
|
|
}
|
|
|
|
internal GameObject FindLocalObject(NetworkInstanceId netId)
|
|
{
|
|
if (localObjects.ContainsKey(netId))
|
|
{
|
|
var networkIdentity = localObjects[netId];
|
|
if (networkIdentity != null)
|
|
{
|
|
return networkIdentity.gameObject;
|
|
}
|
|
}
|
|
return null;
|
|
}
|
|
|
|
internal bool GetNetworkIdentity(NetworkInstanceId netId, out QSBNetworkIdentity uv)
|
|
{
|
|
bool result;
|
|
if (localObjects.ContainsKey(netId) && localObjects[netId] != null)
|
|
{
|
|
uv = localObjects[netId];
|
|
result = true;
|
|
}
|
|
else
|
|
{
|
|
uv = null;
|
|
result = false;
|
|
}
|
|
return result;
|
|
}
|
|
|
|
internal bool RemoveLocalObject(NetworkInstanceId netId) => localObjects.Remove(netId);
|
|
|
|
internal bool RemoveLocalObjectAndDestroy(NetworkInstanceId netId)
|
|
{
|
|
bool result;
|
|
if (localObjects.ContainsKey(netId))
|
|
{
|
|
var networkIdentity = localObjects[netId];
|
|
Object.Destroy(networkIdentity.gameObject);
|
|
result = localObjects.Remove(netId);
|
|
}
|
|
else
|
|
{
|
|
result = false;
|
|
}
|
|
return result;
|
|
}
|
|
|
|
internal void ClearLocalObjects() => localObjects.Clear();
|
|
|
|
internal static void RegisterPrefab(GameObject prefab, NetworkHash128 newAssetId)
|
|
{
|
|
var component = prefab.GetComponent<QSBNetworkIdentity>();
|
|
if (component)
|
|
{
|
|
component.SetDynamicAssetId(newAssetId);
|
|
guidToPrefab[component.AssetId] = prefab;
|
|
}
|
|
else
|
|
{
|
|
Debug.LogError("Could not register '" + prefab.name + "' since it contains no NetworkIdentity component");
|
|
}
|
|
}
|
|
|
|
internal static void RegisterPrefab(GameObject prefab)
|
|
{
|
|
var component = prefab.GetComponent<QSBNetworkIdentity>();
|
|
if (component)
|
|
{
|
|
guidToPrefab[component.AssetId] = prefab;
|
|
var componentsInChildren = prefab.GetComponentsInChildren<NetworkIdentity>();
|
|
if (componentsInChildren.Length > 1)
|
|
{
|
|
Debug.LogWarning("The prefab '" + prefab.name + "' has multiple NetworkIdentity components. There can only be one NetworkIdentity on a prefab, and it must be on the root object.");
|
|
}
|
|
}
|
|
else
|
|
{
|
|
Debug.LogError("Could not register '" + prefab.name + "' since it contains no NetworkIdentity component");
|
|
}
|
|
}
|
|
|
|
internal static bool GetPrefab(NetworkHash128 assetId, out GameObject prefab)
|
|
{
|
|
bool result;
|
|
if (!assetId.IsValid())
|
|
{
|
|
prefab = null;
|
|
result = false;
|
|
}
|
|
else if (guidToPrefab.ContainsKey(assetId) && guidToPrefab[assetId] != null)
|
|
{
|
|
prefab = guidToPrefab[assetId];
|
|
result = true;
|
|
}
|
|
else
|
|
{
|
|
prefab = null;
|
|
result = false;
|
|
}
|
|
return result;
|
|
}
|
|
|
|
internal static void ClearSpawners()
|
|
{
|
|
guidToPrefab.Clear();
|
|
spawnHandlers.Clear();
|
|
unspawnHandlers.Clear();
|
|
}
|
|
|
|
public static void UnregisterSpawnHandler(NetworkHash128 assetId)
|
|
{
|
|
spawnHandlers.Remove(assetId);
|
|
unspawnHandlers.Remove(assetId);
|
|
}
|
|
|
|
internal static void RegisterSpawnHandler(NetworkHash128 assetId, QSBSpawnDelegate spawnHandler, UnSpawnDelegate unspawnHandler)
|
|
{
|
|
if (spawnHandler == null || unspawnHandler == null)
|
|
{
|
|
Debug.LogError("RegisterSpawnHandler custom spawn function null for " + assetId);
|
|
}
|
|
else
|
|
{
|
|
spawnHandlers[assetId] = spawnHandler;
|
|
unspawnHandlers[assetId] = unspawnHandler;
|
|
}
|
|
}
|
|
|
|
internal static void UnregisterPrefab(GameObject prefab)
|
|
{
|
|
var component = prefab.GetComponent<QSBNetworkIdentity>();
|
|
if (component == null)
|
|
{
|
|
Debug.LogError("Could not unregister '" + prefab.name + "' since it contains no NetworkIdentity component");
|
|
}
|
|
else
|
|
{
|
|
spawnHandlers.Remove(component.AssetId);
|
|
unspawnHandlers.Remove(component.AssetId);
|
|
}
|
|
}
|
|
|
|
internal static void RegisterPrefab(GameObject prefab, QSBSpawnDelegate spawnHandler, UnSpawnDelegate unspawnHandler)
|
|
{
|
|
var component = prefab.GetComponent<QSBNetworkIdentity>();
|
|
if (component == null)
|
|
{
|
|
Debug.LogError("Could not register '" + prefab.name + "' since it contains no NetworkIdentity component");
|
|
}
|
|
else if (spawnHandler == null || unspawnHandler == null)
|
|
{
|
|
Debug.LogError("RegisterPrefab custom spawn function null for " + component.AssetId);
|
|
}
|
|
else if (!component.AssetId.IsValid())
|
|
{
|
|
Debug.LogError("RegisterPrefab game object " + prefab.name + " has no prefab. Use RegisterSpawnHandler() instead?");
|
|
}
|
|
else
|
|
{
|
|
spawnHandlers[component.AssetId] = spawnHandler;
|
|
unspawnHandlers[component.AssetId] = unspawnHandler;
|
|
}
|
|
}
|
|
|
|
internal static bool GetSpawnHandler(NetworkHash128 assetId, out QSBSpawnDelegate handler)
|
|
{
|
|
bool result;
|
|
if (spawnHandlers.ContainsKey(assetId))
|
|
{
|
|
handler = spawnHandlers[assetId];
|
|
result = true;
|
|
}
|
|
else
|
|
{
|
|
handler = null;
|
|
result = false;
|
|
}
|
|
return result;
|
|
}
|
|
|
|
internal static bool InvokeUnSpawnHandler(NetworkHash128 assetId, GameObject obj)
|
|
{
|
|
bool result;
|
|
if (unspawnHandlers.ContainsKey(assetId) && unspawnHandlers[assetId] != null)
|
|
{
|
|
var unSpawnDelegate = unspawnHandlers[assetId];
|
|
unSpawnDelegate(obj);
|
|
result = true;
|
|
}
|
|
else
|
|
{
|
|
result = false;
|
|
}
|
|
return result;
|
|
}
|
|
|
|
internal void DestroyAllClientObjects()
|
|
{
|
|
foreach (var key in localObjects.Keys)
|
|
{
|
|
var networkIdentity = localObjects[key];
|
|
if (networkIdentity != null && networkIdentity.gameObject != null)
|
|
{
|
|
if (!InvokeUnSpawnHandler(networkIdentity.AssetId, networkIdentity.gameObject))
|
|
{
|
|
if (networkIdentity.SceneId.IsEmpty())
|
|
{
|
|
Object.Destroy(networkIdentity.gameObject);
|
|
}
|
|
else
|
|
{
|
|
networkIdentity.MarkForReset();
|
|
networkIdentity.gameObject.SetActive(false);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
ClearLocalObjects();
|
|
}
|
|
|
|
internal void DumpAllClientObjects()
|
|
{
|
|
foreach (var networkInstanceId in localObjects.Keys)
|
|
{
|
|
var networkIdentity = localObjects[networkInstanceId];
|
|
if (networkIdentity != null)
|
|
{
|
|
Debug.Log(string.Concat(new object[]
|
|
{
|
|
"ID:",
|
|
networkInstanceId,
|
|
" OBJ:",
|
|
networkIdentity.gameObject,
|
|
" AS:",
|
|
networkIdentity.AssetId
|
|
}));
|
|
}
|
|
else
|
|
{
|
|
Debug.Log("ID:" + networkInstanceId + " OBJ: null");
|
|
}
|
|
}
|
|
}
|
|
}
|
|
} |