Car/Assets/StompyRobot/SRDebugger/Scripts/UI/Other/DockConsoleController.cs

267 lines
7.6 KiB
C#
Raw Normal View History

2025-01-02 11:32:58 +08:00
namespace SRDebugger.UI.Other
{
using Controls;
using Internal;
using Services;
using SRF;
using UnityEngine;
using UnityEngine.EventSystems;
using UnityEngine.UI;
public class DockConsoleController : SRMonoBehaviourEx, IPointerEnterHandler, IPointerExitHandler
{
public const float NonFocusOpacity = 0.65f;
private bool _isDirty;
private bool _isDragging;
private int _pointersOver;
[Import]
public IConsoleFilterState FilterState;
[RequiredField] public GameObject BottomHandle;
[RequiredField] public CanvasGroup CanvasGroup;
[RequiredField] public ConsoleLogControl Console;
[RequiredField] public GameObject Dropdown;
[RequiredField] public Image DropdownToggleSprite;
[RequiredField] public Text TextErrors;
[RequiredField] public Text TextInfo;
[RequiredField] public Text TextWarnings;
[RequiredField] public Toggle ToggleErrors;
[RequiredField] public Toggle ToggleInfo;
[RequiredField] public Toggle ToggleWarnings;
[RequiredField] public GameObject TopBar;
[RequiredField] public GameObject TopHandle;
[RequiredField] public GameObject TopSafeAreaSpacer;
[RequiredField] public GameObject BottomSafeAreaSpacer;
public bool IsVisible
{
get { return CachedGameObject.activeSelf; }
set { CachedGameObject.SetActive(value); }
}
protected override void Start()
{
base.Start();
//_canvasScaler = Canvas.GetComponent<CanvasScaler>();
Service.Console.Updated += ConsoleOnUpdated;
ToggleErrors.isOn = FilterState.GetConsoleFilterState(LogType.Error);
ToggleWarnings.isOn = FilterState.GetConsoleFilterState(LogType.Warning);
ToggleInfo.isOn = FilterState.GetConsoleFilterState(LogType.Log);
ToggleErrors.onValueChanged.AddListener(isOn =>
{
FilterState.SetConsoleFilterState(LogType.Error, isOn);
_isDirty = true;
});
ToggleWarnings.onValueChanged.AddListener(isOn =>
{
FilterState.SetConsoleFilterState(LogType.Warning, isOn);
_isDirty = true;
});
ToggleInfo.onValueChanged.AddListener(isOn =>
{
FilterState.SetConsoleFilterState(LogType.Log, isOn);
_isDirty = true;
});
FilterState.FilterStateChange += OnFilterStateChange;
Refresh();
RefreshAlpha();
}
protected override void OnDestroy()
{
base.OnDestroy();
if (Service.Console != null)
{
Service.Console.Updated -= ConsoleOnUpdated;
}
FilterState.FilterStateChange -= OnFilterStateChange;
}
protected override void OnEnable()
{
base.OnEnable();
_pointersOver = 0;
_isDragging = false;
RefreshAlpha();
}
protected override void OnDisable()
{
base.OnDisable();
_pointersOver = 0;
}
protected override void Update()
{
base.Update();
if (_isDirty)
{
Refresh();
}
}
private void OnFilterStateChange(LogType logType, bool newState)
{
switch (logType)
{
case LogType.Error:
ToggleErrors.isOn = newState;
break;
case LogType.Warning:
ToggleWarnings.isOn = newState;
break;
case LogType.Log:
ToggleInfo.isOn = newState;
break;
}
}
private void ConsoleOnUpdated(IConsoleService console)
{
_isDirty = true;
}
public void SetDropdownVisibility(bool visible)
{
Dropdown.SetActive(visible);
DropdownToggleSprite.rectTransform.localRotation = Quaternion.Euler(0, 0, visible ? 0f : 180f);
}
public void SetAlignmentMode(ConsoleAlignment alignment)
{
switch (alignment)
{
case ConsoleAlignment.Top:
{
TopBar.transform.SetSiblingIndex(0);
Dropdown.transform.SetSiblingIndex(2);
TopHandle.SetActive(false);
BottomHandle.SetActive(true);
transform.SetSiblingIndex(0);
DropdownToggleSprite.rectTransform.parent.localRotation = Quaternion.Euler(0, 0, 0f);
TopSafeAreaSpacer.SetActive(true);
BottomSafeAreaSpacer.SetActive(false);
break;
}
case ConsoleAlignment.Bottom:
{
Dropdown.transform.SetSiblingIndex(0);
TopBar.transform.SetSiblingIndex(2);
TopHandle.SetActive(true);
BottomHandle.SetActive(false);
transform.SetSiblingIndex(1);
DropdownToggleSprite.rectTransform.parent.localRotation = Quaternion.Euler(0, 0, 180f);
TopSafeAreaSpacer.SetActive(false);
BottomSafeAreaSpacer.SetActive(true);
break;
}
}
}
private void Refresh()
{
// Update total counts labels
TextInfo.text = SRDebuggerUtil.GetNumberString(Service.Console.InfoCount, 999, "999+");
TextWarnings.text = SRDebuggerUtil.GetNumberString(Service.Console.WarningCount, 999, "999+");
TextErrors.text = SRDebuggerUtil.GetNumberString(Service.Console.ErrorCount, 999, "999+");
ToggleErrors.isOn = FilterState.GetConsoleFilterState(LogType.Error);
ToggleWarnings.isOn = FilterState.GetConsoleFilterState(LogType.Warning);
ToggleInfo.isOn = FilterState.GetConsoleFilterState(LogType.Log);
_isDirty = false;
}
private void RefreshAlpha()
{
if (_isDragging || _pointersOver > 0)
{
CanvasGroup.alpha = 1.0f;
}
else
{
CanvasGroup.alpha = NonFocusOpacity;
}
}
#region Event Callbacks
public void ToggleDropdownVisible()
{
SetDropdownVisibility(!Dropdown.activeSelf);
}
public void MenuButtonPressed()
{
SRDebug.Instance.ShowDebugPanel(DefaultTabs.Console);
}
public void ClearButtonPressed()
{
Service.Console.Clear();
}
public void TogglesUpdated()
{
Console.ShowErrors = ToggleErrors.isOn;
Console.ShowWarnings = ToggleWarnings.isOn;
Console.ShowInfo = ToggleInfo.isOn;
SetDropdownVisibility(true);
}
public void OnPointerEnter(PointerEventData e)
{
_pointersOver = 1;
RefreshAlpha();
}
public void OnPointerExit(PointerEventData e)
{
_pointersOver = 0; //Mathf.Max(0, _pointersOver - 1);
RefreshAlpha();
}
public void OnBeginDrag()
{
_isDragging = true;
RefreshAlpha();
}
public void OnEndDrag()
{
_isDragging = false;
_pointersOver = 0;
RefreshAlpha();
}
#endregion
}
}