192 lines
7.2 KiB
C#
Raw Normal View History

2020-02-10 23:03:28 +01:00
using OWML.Common;
using OWML.ModHelper;
2020-12-20 10:56:15 +00:00
using OWML.Utils;
2020-09-22 21:11:29 +01:00
using QSB.ConversationSync;
2020-08-12 21:58:29 +02:00
using QSB.ElevatorSync;
2020-08-13 14:32:58 +01:00
using QSB.GeyserSync;
using QSB.OrbSync;
2020-11-03 21:11:10 +00:00
using QSB.Patches;
2021-02-18 15:36:11 +00:00
using QSB.Player;
2020-12-22 21:39:53 +00:00
using QSB.QuantumSync;
2020-11-03 22:29:23 +00:00
using QSB.SectorSync;
2020-11-26 13:09:34 +00:00
using QSB.TimeSync;
using QSB.TranslationSync;
using QSB.Utility;
2021-02-18 15:36:11 +00:00
using QSB.WorldSync;
2020-12-11 13:14:58 +00:00
using QuantumUNET;
2020-12-07 21:19:16 +00:00
using QuantumUNET.Components;
2020-12-24 15:57:25 +00:00
using System.Linq;
2021-02-18 15:36:11 +00:00
using System.Reflection;
2020-02-10 23:03:28 +01:00
using UnityEngine;
2020-12-17 23:18:47 +00:00
/*
2021-02-01 10:15:04 +00:00
Copyright (C) 2020 - 2021
2020-12-19 21:14:05 +00:00
Henry Pointer (_nebula / misternebula),
Aleksander Waage (AmazingAlek),
Ricardo Lopes (Raicuparta)
2020-12-19 16:17:50 +00:00
2020-12-19 21:14:05 +00:00
This program is free software: you can redistribute it and/or
modify it under the terms of the GNU Affero General Public License
as published by the Free Software Foundation, either version 3 of
the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
See the GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License along with this program. If not, see https://www.gnu.org/licenses/.
2020-12-17 23:18:47 +00:00
*/
2020-02-15 20:48:02 +01:00
namespace QSB
{
2020-12-14 16:24:52 +00:00
public class QSBCore : ModBehaviour
2020-12-02 21:29:53 +00:00
{
public static IModHelper Helper { get; private set; }
public static string DefaultServerIP { get; private set; }
public static int Port { get; private set; }
public static bool DebugMode { get; private set; }
2021-01-31 16:14:17 +00:00
public static bool ShowLinesInDebug { get; private set; }
2020-12-02 21:29:53 +00:00
public static AssetBundle NetworkAssetBundle { get; private set; }
public static AssetBundle InstrumentAssetBundle { get; private set; }
2020-12-24 15:57:25 +00:00
public static AssetBundle ConversationAssetBundle { get; private set; }
2020-12-02 21:29:53 +00:00
public static bool HasWokenUp { get; set; }
2020-12-23 12:58:45 +00:00
public static bool IsServer => QNetworkServer.active;
2021-02-10 19:34:41 +00:00
public static bool IsInMultiplayer => QNetworkManager.singleton.isNetworkActive;
2021-02-01 15:44:21 +00:00
public static GameObject GameObjectInstance => _thisInstance.gameObject;
private static QSBCore _thisInstance;
2020-02-10 23:03:28 +01:00
2020-12-14 21:41:56 +01:00
public void Awake()
2020-12-02 21:29:53 +00:00
{
Application.runInBackground = true;
2020-11-06 22:05:43 +00:00
2021-02-01 15:44:21 +00:00
_thisInstance = this;
2020-12-02 21:29:53 +00:00
var instance = TextTranslation.Get().GetValue<TextTranslation.TranslationTable>("m_table");
instance.theUITable[(int)UITextType.PleaseUseController] =
"<color=orange>Quantum Space Buddies</color> is best experienced with friends...";
}
2020-02-10 23:03:28 +01:00
2020-12-14 21:41:56 +01:00
public void Start()
2020-12-02 21:29:53 +00:00
{
Helper = ModHelper;
DebugLog.ToConsole($"* Start of QSB version {Helper.Manifest.Version} - authored by {Helper.Manifest.Author}", MessageType.Info);
2020-08-20 19:31:10 +01:00
2020-12-02 21:29:53 +00:00
NetworkAssetBundle = Helper.Assets.LoadBundle("assets/network");
InstrumentAssetBundle = Helper.Assets.LoadBundle("assets/instruments");
2020-12-24 15:57:25 +00:00
ConversationAssetBundle = Helper.Assets.LoadBundle("assets/conversation");
2020-08-23 15:51:45 +02:00
2020-12-02 21:29:53 +00:00
QSBPatchManager.Init();
QSBPatchManager.DoPatchType(QSBPatchTypes.OnModStart);
2020-02-10 23:03:28 +01:00
2020-12-02 21:29:53 +00:00
gameObject.AddComponent<QSBNetworkManager>();
2020-12-23 12:58:45 +00:00
gameObject.AddComponent<QNetworkManagerHUD>();
2020-12-02 21:29:53 +00:00
gameObject.AddComponent<DebugActions>();
gameObject.AddComponent<ElevatorManager>();
gameObject.AddComponent<GeyserManager>();
gameObject.AddComponent<OrbManager>();
gameObject.AddComponent<QSBSectorManager>();
gameObject.AddComponent<ConversationManager>();
gameObject.AddComponent<QSBInputManager>();
gameObject.AddComponent<TimeSyncUI>();
2020-12-22 21:39:53 +00:00
gameObject.AddComponent<QuantumManager>();
gameObject.AddComponent<SpiralManager>();
2021-02-19 10:09:14 +00:00
gameObject.AddComponent<RepeatingManager>();
2020-12-24 15:57:25 +00:00
DebugBoxManager.Init();
2020-12-02 21:29:53 +00:00
// Stop players being able to pause
Helper.HarmonyHelper.EmptyMethod(typeof(OWTime).GetMethod("Pause"));
}
2020-12-14 21:20:53 +00:00
public void Update() =>
2020-12-23 12:58:45 +00:00
QNetworkIdentity.UNetStaticUpdate();
2020-12-02 18:40:38 +00:00
2021-02-18 15:36:11 +00:00
public void OnGUI()
{
GUI.Label(new Rect(220, 10, 200f, 20f), $"Rough FPS : {1f / Time.smoothDeltaTime}");
GUI.Label(new Rect(220, 40, 200f, 20f), $"HasWokenUp : {QSBCore.HasWokenUp}");
if (!QSBCore.HasWokenUp || !QSBCore.DebugMode)
{
return;
}
if (QSBSceneManager.CurrentScene != OWScene.SolarSystem)
{
return;
}
var offset = 70f;
GUI.Label(new Rect(220, offset, 200f, 20f), $"QM Visible : {Locator.GetQuantumMoon().IsVisible()}");
offset += 30f;
GUI.Label(new Rect(220, offset, 200f, 20f), $"QM Locked : {Locator.GetQuantumMoon().IsLocked()}");
offset += 30f;
GUI.Label(new Rect(220, offset, 200f, 20f), $"QM Illuminated : {Locator.GetQuantumMoon().IsIlluminated()}");
offset += 30f;
//GUI.Label(new Rect(220, offset, 200f, 20f), $"Shrine player in dark? : {QuantumManager.Instance.Shrine.IsPlayerInDarkness()}");
//offset += 30f;
var tracker = Locator.GetQuantumMoon().GetValue<ShapeVisibilityTracker>("_visibilityTracker");
foreach (var camera in QSBPlayerManager.GetPlayerCameras())
{
GUI.Label(new Rect(220, offset, 200f, 20f), $"- {camera.name} : {tracker.GetType().GetMethod("IsInFrustum", BindingFlags.NonPublic | BindingFlags.Instance).Invoke(tracker, new object[] { camera.GetFrustumPlanes() })}");
offset += 30f;
}
// Used for diagnosing specific socketed objects. Just set <index> to be the correct index.
/*
var index = 110;
var socketedObject = QSBWorldSync.GetWorldObject<QSBSocketedQuantumObject>(index);
GUI.Label(new Rect(220, offset, 200f, 20f), $"{index} Controller : {socketedObject.ControllingPlayer}");
offset += 30f;
GUI.Label(new Rect(220, offset, 200f, 20f), $"{index} Visible : {socketedObject.AttachedObject.IsVisible()}");
offset += 30f;
GUI.Label(new Rect(220, offset, 200f, 20f), $"{index} Locked : {socketedObject.AttachedObject.IsLocked()}");
offset += 30f;
GUI.Label(new Rect(220, offset, 200f, 20f), $"{index} Illuminated : {socketedObject.AttachedObject.IsIlluminated()}");
offset += 30f;
var socketedTrackers = socketedObject.AttachedObject.GetComponentsInChildren<ShapeVisibilityTracker>();
if (socketedTrackers == null || socketedTrackers.Length == 0)
{
GUI.Label(new Rect(220, offset, 200f, 20f), $"- List is null or empty.");
return;
}
if (socketedTrackers.Any(x => x is null))
{
GUI.Label(new Rect(220, offset, 200f, 20f), $"- Uses a null.");
return;
}
foreach (var camera in QSBPlayerManager.GetPlayerCameras())
{
GUI.Label(new Rect(220, offset, 200f, 20f), $"- {camera.name} : {socketedTrackers.Any(x => (bool)x.GetType().GetMethod("IsInFrustum", BindingFlags.NonPublic | BindingFlags.Instance).Invoke(x, new object[] { camera.GetFrustumPlanes() }))}");
offset += 30f;
}
*/
offset = 10f;
GUI.Label(new Rect(440, offset, 200f, 20f), $"Owned Objects :");
offset += 30f;
foreach (var obj in QSBWorldSync.GetWorldObjects<IQSBQuantumObject>().Where(x => x.ControllingPlayer == QSBPlayerManager.LocalPlayerId))
{
GUI.Label(new Rect(440, offset, 200f, 20f), $"- {(obj as IWorldObject).Name}");
offset += 30f;
}
}
2020-12-14 21:20:53 +00:00
public override void Configure(IModConfig config)
2020-12-02 21:29:53 +00:00
{
DefaultServerIP = config.GetSettingsValue<string>("defaultServerIP");
Port = config.GetSettingsValue<int>("port");
if (QSBNetworkManager.Instance != null)
{
QSBNetworkManager.Instance.networkPort = Port;
}
DebugMode = config.GetSettingsValue<bool>("debugMode");
2020-12-24 15:57:25 +00:00
if (!DebugMode)
{
FindObjectsOfType<DebugZOverride>().ToList().ForEach(x => Destroy(x.gameObject));
}
2021-01-31 16:14:17 +00:00
ShowLinesInDebug = config.GetSettingsValue<bool>("showLinesInDebug");
2020-12-02 21:29:53 +00:00
}
}
2020-12-03 08:28:05 +00:00
}