166 lines
6.5 KiB
C#
166 lines
6.5 KiB
C#
|
using Axibug.Procedure;
|
|||
|
using System.Collections.Generic;
|
|||
|
using System.Linq;
|
|||
|
using UnityEditor;
|
|||
|
using UnityEngine;
|
|||
|
using Axibug.Runtime;
|
|||
|
|
|||
|
namespace Axibug.Editor
|
|||
|
{
|
|||
|
[CustomEditor(typeof(ProcedureComponent))]
|
|||
|
internal sealed class ProcedureComponentInspector : GameInspector
|
|||
|
{
|
|||
|
private SerializedProperty m_AvailableProcedureTypeNames = null;
|
|||
|
private SerializedProperty m_EntranceProcedureTypeName = null;
|
|||
|
|
|||
|
private string[] m_ProcedureTypeNames = null;
|
|||
|
private List<string> m_CurrentAvailableProcedureTypeNames = null;
|
|||
|
private int m_EntranceProcedureIndex = -1;
|
|||
|
|
|||
|
public override void OnInspectorGUI()
|
|||
|
{
|
|||
|
base.OnInspectorGUI();
|
|||
|
|
|||
|
serializedObject.Update();
|
|||
|
|
|||
|
ProcedureComponent t = (ProcedureComponent)target;
|
|||
|
|
|||
|
if (string.IsNullOrEmpty(m_EntranceProcedureTypeName.stringValue))
|
|||
|
{
|
|||
|
EditorGUILayout.HelpBox("Entrance procedure is invalid.", MessageType.Error);
|
|||
|
}
|
|||
|
else if (EditorApplication.isPlaying)
|
|||
|
{
|
|||
|
EditorGUILayout.LabelField("Current Procedure", t.CurrentProcedure == null ? "None" : t.CurrentProcedure.GetType().ToString());
|
|||
|
}
|
|||
|
|
|||
|
EditorGUI.BeginDisabledGroup(EditorApplication.isPlayingOrWillChangePlaymode);
|
|||
|
{
|
|||
|
GUILayout.Label("Available Procedures", EditorStyles.boldLabel);
|
|||
|
if (m_ProcedureTypeNames.Length > 0)
|
|||
|
{
|
|||
|
EditorGUILayout.BeginVertical("box");
|
|||
|
{
|
|||
|
foreach (string procedureTypeName in m_ProcedureTypeNames)
|
|||
|
{
|
|||
|
bool selected = m_CurrentAvailableProcedureTypeNames.Contains(procedureTypeName);
|
|||
|
if (selected != EditorGUILayout.ToggleLeft(procedureTypeName, selected))
|
|||
|
{
|
|||
|
if (!selected)
|
|||
|
{
|
|||
|
m_CurrentAvailableProcedureTypeNames.Add(procedureTypeName);
|
|||
|
WriteAvailableProcedureTypeNames();
|
|||
|
}
|
|||
|
else if (procedureTypeName != m_EntranceProcedureTypeName.stringValue)
|
|||
|
{
|
|||
|
m_CurrentAvailableProcedureTypeNames.Remove(procedureTypeName);
|
|||
|
WriteAvailableProcedureTypeNames();
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
EditorGUILayout.EndVertical();
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
EditorGUILayout.HelpBox("There is no available procedure.", MessageType.Warning);
|
|||
|
}
|
|||
|
|
|||
|
if (m_CurrentAvailableProcedureTypeNames.Count > 0)
|
|||
|
{
|
|||
|
EditorGUILayout.Separator();
|
|||
|
|
|||
|
int selectedIndex = EditorGUILayout.Popup("Entrance Procedure", m_EntranceProcedureIndex, m_CurrentAvailableProcedureTypeNames.ToArray());
|
|||
|
if (selectedIndex != m_EntranceProcedureIndex)
|
|||
|
{
|
|||
|
m_EntranceProcedureIndex = selectedIndex;
|
|||
|
m_EntranceProcedureTypeName.stringValue = m_CurrentAvailableProcedureTypeNames[selectedIndex];
|
|||
|
}
|
|||
|
}
|
|||
|
else
|
|||
|
{
|
|||
|
EditorGUILayout.HelpBox("Select available procedures first.", MessageType.Info);
|
|||
|
}
|
|||
|
}
|
|||
|
EditorGUI.EndDisabledGroup();
|
|||
|
|
|||
|
serializedObject.ApplyModifiedProperties();
|
|||
|
|
|||
|
Repaint();
|
|||
|
}
|
|||
|
|
|||
|
protected override void OnCompileComplete()
|
|||
|
{
|
|||
|
base.OnCompileComplete();
|
|||
|
|
|||
|
RefreshTypeNames();
|
|||
|
}
|
|||
|
|
|||
|
private void OnEnable()
|
|||
|
{
|
|||
|
m_AvailableProcedureTypeNames = serializedObject.FindProperty("m_AvailableProcedureTypeNames");
|
|||
|
m_EntranceProcedureTypeName = serializedObject.FindProperty("m_EntranceProcedureTypeName");
|
|||
|
|
|||
|
RefreshTypeNames();
|
|||
|
}
|
|||
|
|
|||
|
private void RefreshTypeNames()
|
|||
|
{
|
|||
|
m_ProcedureTypeNames = Type.GetRuntimeTypeNames(typeof(ProcedureBase));
|
|||
|
ReadAvailableProcedureTypeNames();
|
|||
|
int oldCount = m_CurrentAvailableProcedureTypeNames.Count;
|
|||
|
m_CurrentAvailableProcedureTypeNames = m_CurrentAvailableProcedureTypeNames.Where(x => m_ProcedureTypeNames.Contains(x)).ToList();
|
|||
|
if (m_CurrentAvailableProcedureTypeNames.Count != oldCount)
|
|||
|
{
|
|||
|
WriteAvailableProcedureTypeNames();
|
|||
|
}
|
|||
|
else if (!string.IsNullOrEmpty(m_EntranceProcedureTypeName.stringValue))
|
|||
|
{
|
|||
|
m_EntranceProcedureIndex = m_CurrentAvailableProcedureTypeNames.IndexOf(m_EntranceProcedureTypeName.stringValue);
|
|||
|
if (m_EntranceProcedureIndex < 0)
|
|||
|
{
|
|||
|
m_EntranceProcedureTypeName.stringValue = null;
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
serializedObject.ApplyModifiedProperties();
|
|||
|
}
|
|||
|
|
|||
|
private void ReadAvailableProcedureTypeNames()
|
|||
|
{
|
|||
|
m_CurrentAvailableProcedureTypeNames = new List<string>();
|
|||
|
int count = m_AvailableProcedureTypeNames.arraySize;
|
|||
|
for (int i = 0; i < count; i++)
|
|||
|
{
|
|||
|
m_CurrentAvailableProcedureTypeNames.Add(m_AvailableProcedureTypeNames.GetArrayElementAtIndex(i).stringValue);
|
|||
|
}
|
|||
|
}
|
|||
|
|
|||
|
private void WriteAvailableProcedureTypeNames()
|
|||
|
{
|
|||
|
m_AvailableProcedureTypeNames.ClearArray();
|
|||
|
if (m_CurrentAvailableProcedureTypeNames == null)
|
|||
|
{
|
|||
|
return;
|
|||
|
}
|
|||
|
|
|||
|
m_CurrentAvailableProcedureTypeNames.Sort();
|
|||
|
int count = m_CurrentAvailableProcedureTypeNames.Count;
|
|||
|
for (int i = 0; i < count; i++)
|
|||
|
{
|
|||
|
m_AvailableProcedureTypeNames.InsertArrayElementAtIndex(i);
|
|||
|
m_AvailableProcedureTypeNames.GetArrayElementAtIndex(i).stringValue = m_CurrentAvailableProcedureTypeNames[i];
|
|||
|
}
|
|||
|
|
|||
|
if (!string.IsNullOrEmpty(m_EntranceProcedureTypeName.stringValue))
|
|||
|
{
|
|||
|
m_EntranceProcedureIndex = m_CurrentAvailableProcedureTypeNames.IndexOf(m_EntranceProcedureTypeName.stringValue);
|
|||
|
if (m_EntranceProcedureIndex < 0)
|
|||
|
{
|
|||
|
m_EntranceProcedureTypeName.stringValue = null;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
}
|