//------------------------------------------------------------ // Game Framework v3.x // Copyright © 2013-2017 Jiang Yin. All rights reserved. // Homepage: http://gameframework.cn/ // Feedback: mailto:i@jiangyin.me //------------------------------------------------------------ using GameFramework.Debugger; using System.Collections.Generic; using UnityEngine; namespace UnityGameFramework.Runtime { /// /// 调试组件。 /// [DisallowMultipleComponent] [AddComponentMenu("Game Framework/Debugger")] public sealed partial class DebuggerComponent : MonoBehaviour { /// /// 默认调试器漂浮框大小。 /// internal static readonly Rect DefaultIconRect = new Rect(10f, 10f, 60f, 60f); /// /// 默认调试器窗口大小。 /// internal static readonly Rect DefaultWindowRect = new Rect(10f, 10f, 640f, 480f); /// /// 默认调试器窗口缩放比例。 /// internal static readonly float DefaultWindowScale = 1f; private DebuggerManager m_DebuggerManager = null; private Rect m_DragRect = new Rect(0f, 0f, float.MaxValue, 25f); private Rect m_IconRect = DefaultIconRect; private Rect m_WindowRect = DefaultWindowRect; private float m_WindowScale = DefaultWindowScale; [SerializeField] private GUISkin m_Skin = null; [SerializeField] private DebuggerActiveWindowType m_ActiveWindow = DebuggerActiveWindowType.Auto; [SerializeField] private bool m_ShowFullWindow = true; [SerializeField] private ConsoleWindow m_ConsoleWindow = new ConsoleWindow(); private SystemInformationWindow m_SystemInformationWindow = new SystemInformationWindow(); private EnvironmentInformationWindow m_EnvironmentInformationWindow = new EnvironmentInformationWindow(); private ScreenInformationWindow m_ScreenInformationWindow = new ScreenInformationWindow(); private GraphicsInformationWindow m_GraphicsInformationWindow = new GraphicsInformationWindow(); private InputSummaryInformationWindow m_InputSummaryInformationWindow = new InputSummaryInformationWindow(); private InputTouchInformationWindow m_InputTouchInformationWindow = new InputTouchInformationWindow(); private InputLocationInformationWindow m_InputLocationInformationWindow = new InputLocationInformationWindow(); private InputAccelerationInformationWindow m_InputAccelerationInformationWindow = new InputAccelerationInformationWindow(); private InputGyroscopeInformationWindow m_InputGyroscopeInformationWindow = new InputGyroscopeInformationWindow(); private InputCompassInformationWindow m_InputCompassInformationWindow = new InputCompassInformationWindow(); private PathInformationWindow m_PathInformationWindow = new PathInformationWindow(); private SceneInformationWindow m_SceneInformationWindow = new SceneInformationWindow(); private TimeInformationWindow m_TimeInformationWindow = new TimeInformationWindow(); private QualityInformationWindow m_QualityInformationWindow = new QualityInformationWindow(); private ProfilerInformationWindow m_ProfilerInformationWindow = new ProfilerInformationWindow(); private WebPlayerInformationWindow m_WebPlayerInformationWindow = new WebPlayerInformationWindow(); private RuntimeMemoryInformationWindow m_RuntimeMemoryAllInformationWindow = new RuntimeMemoryInformationWindow(); private RuntimeMemoryInformationWindow m_RuntimeMemoryTextureInformationWindow = new RuntimeMemoryInformationWindow(); private RuntimeMemoryInformationWindow m_RuntimeMemoryMeshInformationWindow = new RuntimeMemoryInformationWindow(); private RuntimeMemoryInformationWindow m_RuntimeMemoryMaterialInformationWindow = new RuntimeMemoryInformationWindow(); private RuntimeMemoryInformationWindow m_RuntimeMemoryAnimationClipInformationWindow = new RuntimeMemoryInformationWindow(); private RuntimeMemoryInformationWindow m_RuntimeMemoryAudioClipInformationWindow = new RuntimeMemoryInformationWindow(); private RuntimeMemoryInformationWindow m_RuntimeMemoryFontInformationWindow = new RuntimeMemoryInformationWindow(); private RuntimeMemoryInformationWindow m_RuntimeMemoryGameObjectInformationWindow = new RuntimeMemoryInformationWindow(); private RuntimeMemoryInformationWindow m_RuntimeMemoryComponentInformationWindow = new RuntimeMemoryInformationWindow(); private GeneralSettingsWindow m_GeneralSettingsWindow = new GeneralSettingsWindow(); private QualitySettingsWindow m_QualitySettingsWindow = new QualitySettingsWindow(); private FpsCounter m_FpsCounter = null; /// /// 获取或设置调试窗口是否激活。 /// public bool ActiveWindow { get { return m_DebuggerManager.ActiveWindow; } set { m_DebuggerManager.ActiveWindow = value; enabled = value; } } /// /// 获取或设置是否显示完整调试器界面。 /// public bool ShowFullWindow { get { return m_ShowFullWindow; } set { m_ShowFullWindow = value; } } /// /// 获取或设置调试器漂浮框大小。 /// public Rect IconRect { get { return m_IconRect; } set { m_IconRect = value; } } /// /// 获取或设置调试器窗口大小。 /// public Rect WindowRect { get { return m_WindowRect; } set { m_WindowRect = value; } } /// /// 获取或设置调试器窗口缩放比例。 /// public float WindowScale { get { return m_WindowScale; } set { m_WindowScale = value; } } /// /// 游戏框架组件初始化。 /// private void Awake() { DontDestroyOnLoad(gameObject); m_DebuggerManager = new DebuggerManager(); if (m_ActiveWindow == DebuggerActiveWindowType.Auto) { ActiveWindow = Debug.isDebugBuild; } else { ActiveWindow = (m_ActiveWindow == DebuggerActiveWindowType.Open); } m_FpsCounter = new FpsCounter(0.5f); } private void Start() { RegisterDebuggerWindow("Console", m_ConsoleWindow); RegisterDebuggerWindow("Information/System", m_SystemInformationWindow); RegisterDebuggerWindow("Information/Environment", m_EnvironmentInformationWindow); RegisterDebuggerWindow("Information/Screen", m_ScreenInformationWindow); RegisterDebuggerWindow("Information/Graphics", m_GraphicsInformationWindow); RegisterDebuggerWindow("Information/Input/Summary", m_InputSummaryInformationWindow); RegisterDebuggerWindow("Information/Input/Touch", m_InputTouchInformationWindow); RegisterDebuggerWindow("Information/Input/Location", m_InputLocationInformationWindow); RegisterDebuggerWindow("Information/Input/Acceleration", m_InputAccelerationInformationWindow); RegisterDebuggerWindow("Information/Input/Gyroscope", m_InputGyroscopeInformationWindow); RegisterDebuggerWindow("Information/Input/Compass", m_InputCompassInformationWindow); RegisterDebuggerWindow("Information/Other/Scene", m_SceneInformationWindow); RegisterDebuggerWindow("Information/Other/Path", m_PathInformationWindow); RegisterDebuggerWindow("Information/Other/Time", m_TimeInformationWindow); RegisterDebuggerWindow("Information/Other/Quality", m_QualityInformationWindow); RegisterDebuggerWindow("Information/Other/Web Player", m_WebPlayerInformationWindow); RegisterDebuggerWindow("Profiler/Summary", m_ProfilerInformationWindow); RegisterDebuggerWindow("Profiler/Memory/All", m_RuntimeMemoryAllInformationWindow); RegisterDebuggerWindow("Profiler/Memory/Texture", m_RuntimeMemoryTextureInformationWindow); RegisterDebuggerWindow("Profiler/Memory/Mesh", m_RuntimeMemoryMeshInformationWindow); RegisterDebuggerWindow("Profiler/Memory/Material", m_RuntimeMemoryMaterialInformationWindow); RegisterDebuggerWindow("Profiler/Memory/AnimationClip", m_RuntimeMemoryAnimationClipInformationWindow); RegisterDebuggerWindow("Profiler/Memory/AudioClip", m_RuntimeMemoryAudioClipInformationWindow); RegisterDebuggerWindow("Profiler/Memory/Font", m_RuntimeMemoryFontInformationWindow); RegisterDebuggerWindow("Profiler/Memory/GameObject", m_RuntimeMemoryGameObjectInformationWindow); RegisterDebuggerWindow("Profiler/Memory/Component", m_RuntimeMemoryComponentInformationWindow); RegisterDebuggerWindow("Settings/General", m_GeneralSettingsWindow, this); RegisterDebuggerWindow("Settings/Quality", m_QualitySettingsWindow); RegisterExtensionWindows(); } private void OnDestroy() { if (m_DebuggerManager != null) { m_DebuggerManager.Shutdown(); m_DebuggerManager = null; } } private void Update() { if (m_DebuggerManager == null || !m_DebuggerManager.ActiveWindow) { return; } m_DebuggerManager.Update(Time.deltaTime, Time.unscaledDeltaTime); m_FpsCounter.Update(Time.deltaTime, Time.unscaledDeltaTime); } private void OnGUI() { if (m_DebuggerManager == null || !m_DebuggerManager.ActiveWindow) { return; } GUISkin cachedGuiSkin = GUI.skin; Matrix4x4 cachedMatrix = GUI.matrix; GUI.skin = m_Skin; GUI.matrix = Matrix4x4.Scale(new Vector3(m_WindowScale, m_WindowScale, 1f)); if (m_ShowFullWindow) { m_WindowRect = GUILayout.Window(0, m_WindowRect, DrawWindow, "GAME FRAMEWORK DEBUGGER"); } else { m_IconRect = GUILayout.Window(0, m_IconRect, DrawDebuggerWindowIcon, "DEBUGGER"); } GUI.matrix = cachedMatrix; GUI.skin = cachedGuiSkin; } /// /// 注册调试窗口。 /// /// 调试窗口路径。 /// 要注册的调试窗口。 /// 初始化调试窗口参数。 public void RegisterDebuggerWindow(string path, IDebuggerWindow debuggerWindow, params object[] args) { m_DebuggerManager.RegisterDebuggerWindow(path, debuggerWindow, args); } /// /// 获取调试窗口。 /// /// 调试窗口路径。 /// 要获取的调试窗口。 public IDebuggerWindow GetDebuggerWindow(string path) { return m_DebuggerManager.GetDebuggerWindow(path); } private void DrawWindow(int windowId) { GUI.DragWindow(m_DragRect); DrawDebuggerWindowGroup(m_DebuggerManager.DebuggerWindowRoot); } private void DrawDebuggerWindowGroup(IDebuggerWindowGroup debuggerWindowGroup) { if (debuggerWindowGroup == null) { return; } List names = new List(); string[] debuggerWindowNames = debuggerWindowGroup.GetDebuggerWindowNames(); for (int i = 0; i < debuggerWindowNames.Length; i++) { names.Add(string.Format("{0}", debuggerWindowNames[i])); } if (debuggerWindowGroup == m_DebuggerManager.DebuggerWindowRoot) { names.Add("Close"); } int toolbarIndex = GUILayout.Toolbar(debuggerWindowGroup.SelectedIndex, names.ToArray(), GUILayout.Height(30f), GUILayout.MaxWidth(Screen.width)); if (toolbarIndex >= debuggerWindowGroup.DebuggerWindowCount) { m_ShowFullWindow = false; return; } if (debuggerWindowGroup.SelectedIndex != toolbarIndex) { debuggerWindowGroup.SelectedWindow.OnLeave(); debuggerWindowGroup.SelectedIndex = toolbarIndex; debuggerWindowGroup.SelectedWindow.OnEnter(); } IDebuggerWindowGroup subDebuggerWindowGroup = debuggerWindowGroup.SelectedWindow as IDebuggerWindowGroup; if (subDebuggerWindowGroup != null) { DrawDebuggerWindowGroup(subDebuggerWindowGroup); } if (debuggerWindowGroup.SelectedWindow != null) { debuggerWindowGroup.SelectedWindow.OnDraw(); } } private void DrawDebuggerWindowIcon(int windowId) { GUI.DragWindow(m_DragRect); GUILayout.Space(5); Color32 color = Color.white; m_ConsoleWindow.RefreshCount(); if (m_ConsoleWindow.FatalCount > 0) { color = m_ConsoleWindow.GetLogStringColor(LogType.Exception); } else if (m_ConsoleWindow.ErrorCount > 0) { color = m_ConsoleWindow.GetLogStringColor(LogType.Error); } else if (m_ConsoleWindow.WarningCount > 0) { color = m_ConsoleWindow.GetLogStringColor(LogType.Warning); } else { color = m_ConsoleWindow.GetLogStringColor(LogType.Log); } string title = string.Format("FPS: {4}", color.r.ToString("x2"), color.g.ToString("x2"), color.b.ToString("x2"), color.a.ToString("x2"), m_FpsCounter.CurrentFps.ToString("F2")); if (GUILayout.Button(title, GUILayout.Width(100f), GUILayout.Height(40f))) { m_ShowFullWindow = true; } } } }