using System.Collections.Generic; using System.Linq; using UnityEngine; using UnityEngine.UI; namespace QSB { public class DebugLog : MonoBehaviour { private const int ScreenLinesMax = 6; private static Text _screenText; private static List _lines; private void Awake() { var assetBundle = QSB.Helper.Assets.LoadBundle("assets/debug"); var logCanvas = Instantiate(assetBundle.LoadAsset("assets/logcanvas.prefab")); DontDestroyOnLoad(logCanvas); DontDestroyOnLoad(this); logCanvas.GetComponent().sortingOrder = 9999; _screenText = logCanvas.GetComponentInChildren(); _lines = new List(ScreenLinesMax); for (var i = 0; i < ScreenLinesMax; i++) { _lines.Add("."); } } private static string JoinAll(params object[] logObjects) { return string.Join(" ", logObjects.Select(o => o.ToString()).ToArray()); } public static void Console(params object[] logObjects) { QSB.Helper.Console.WriteLine(logObjects); } public static void Screen(params object[] logObjects) { for (var i = 1; i < ScreenLinesMax; i++) { _lines[i - 1] = _lines[i]; } _lines.Insert(ScreenLinesMax - 1, JoinAll(logObjects)); _screenText.text = string.Join("\n", _lines.ToArray()); } public static void HUD(params object[] logObjects) { if (Locator.GetPlayerBody() == null) { Console("Warning: tried to log to HUD but player is not ready."); Console(logObjects); return; } var data = new NotificationData(NotificationTarget.Player, JoinAll(logObjects), 5f, true); NotificationManager.SharedInstance.PostNotification(data, false); } public static void All(params object[] logObjects) { Console(logObjects); Screen(logObjects); HUD(logObjects); } } }