mirror of
https://github.com/GrahamKracker/UnityExplorer.git
synced 2025-01-10 10:59:36 +08:00
Rewriting everything from scratch, added generic ObjectPool system
This commit is contained in:
parent
9f8d53f55a
commit
af3ee07143
487
src/Inspectors_OLD/Reflection/ReflectionInspector.cs
Normal file
487
src/Inspectors_OLD/Reflection/ReflectionInspector.cs
Normal file
@ -0,0 +1,487 @@
|
||||
//using System;
|
||||
//using System.Collections.Generic;
|
||||
//using System.Linq;
|
||||
//using System.Reflection;
|
||||
//using System.Text;
|
||||
//using UnityEngine;
|
||||
//using UnityEngine.UI;
|
||||
//using UnityExplorer.Core;
|
||||
//using UnityExplorer.Core.Config;
|
||||
//using UnityExplorer.Core.Runtime;
|
||||
//using UnityExplorer.UI.CacheObject;
|
||||
//using UnityExplorer.UI.Panels;
|
||||
//using UnityExplorer.UI.Utility;
|
||||
//using UnityExplorer.UI.Widgets;
|
||||
|
||||
//namespace UnityExplorer.Inspectors.Reflection
|
||||
//{
|
||||
// public class ReflectionInspector : InspectorBase
|
||||
// {
|
||||
// #region STATIC
|
||||
|
||||
// public static ReflectionInspector ActiveInstance { get; private set; }
|
||||
|
||||
// //static ReflectionInspector()
|
||||
// //{
|
||||
// // PanelDragger.OnFinishResize += (RectTransform _) => OnContainerResized();
|
||||
// // SceneExplorer.OnToggleShow += OnContainerResized;
|
||||
// //}
|
||||
|
||||
// //private static void OnContainerResized(bool _ = false)
|
||||
// //{
|
||||
// // if (ActiveInstance == null)
|
||||
// // return;
|
||||
|
||||
// // ActiveInstance.m_widthUpdateWanted = true;
|
||||
// //}
|
||||
|
||||
// // Blacklists
|
||||
// private static readonly HashSet<string> bl_typeAndMember = new HashSet<string>
|
||||
// {
|
||||
//#if CPP
|
||||
// // these cause a crash in IL2CPP
|
||||
// "Type.DeclaringMethod",
|
||||
// "Rigidbody2D.Cast",
|
||||
// "Collider2D.Cast",
|
||||
// "Collider2D.Raycast",
|
||||
// "Texture2D.SetPixelDataImpl",
|
||||
// "Camera.CalculateProjectionMatrixFromPhysicalProperties",
|
||||
//#endif
|
||||
// };
|
||||
// private static readonly HashSet<string> bl_methodNameStartsWith = new HashSet<string>
|
||||
// {
|
||||
// // these are redundant, just adds noise, properties are supported directly
|
||||
// "get_",
|
||||
// "set_",
|
||||
// };
|
||||
|
||||
// #endregion
|
||||
|
||||
// #region INSTANCE
|
||||
|
||||
// public override string TabLabel => m_targetTypeShortName;
|
||||
|
||||
// public CacheObjectBase ParentMember { get; internal set; }
|
||||
|
||||
// public ScrollPool ScrollPool { get; private set; }
|
||||
// public CacheMemberList CacheMemberList { get; private set; }
|
||||
|
||||
// public GameObject InactiveHolder => m_inactiveHolder;
|
||||
// private GameObject m_inactiveHolder;
|
||||
|
||||
// internal readonly Type m_targetType;
|
||||
// internal readonly string m_targetTypeShortName;
|
||||
|
||||
// // all cached members of the target
|
||||
// internal CacheMember[] allMembers;
|
||||
// // filtered members based on current filters
|
||||
// internal readonly List<CacheMember> filteredMembers = new List<CacheMember>();
|
||||
// // actual shortlist of displayed members
|
||||
// internal readonly List<CacheMember> displayedMembers = new List<CacheMember>();
|
||||
|
||||
// // index: Index in filter list, Value: Actual real index in allMembers list.
|
||||
// internal readonly List<int> filteredToRealIndices = new List<int>();
|
||||
|
||||
// internal bool autoUpdate;
|
||||
|
||||
// public override void OnPanelResized()
|
||||
// {
|
||||
// foreach (var member in displayedMembers)
|
||||
// {
|
||||
// member.memberLabelElement.minWidth = 0.4f * InspectorPanel.CurrentPanelWidth;
|
||||
// }
|
||||
// }
|
||||
|
||||
// public ReflectionInspector(object target) : base(target)
|
||||
// {
|
||||
// if (this is StaticInspector)
|
||||
// m_targetType = target as Type;
|
||||
// else
|
||||
// m_targetType = ReflectionUtility.GetActualType(target);
|
||||
|
||||
// m_targetTypeShortName = SignatureHighlighter.ParseFullSyntax(m_targetType, false);
|
||||
|
||||
// ConstructUI();
|
||||
|
||||
// CacheMembers(m_targetType);
|
||||
|
||||
// FilterMembers();
|
||||
// }
|
||||
|
||||
// public override void SetActive()
|
||||
// {
|
||||
// base.SetActive();
|
||||
// ActiveInstance = this;
|
||||
// }
|
||||
|
||||
// public override void SetInactive()
|
||||
// {
|
||||
// base.SetInactive();
|
||||
// ActiveInstance = null;
|
||||
// }
|
||||
|
||||
// public override void Destroy()
|
||||
// {
|
||||
// base.Destroy();
|
||||
|
||||
// if (this.Content)
|
||||
// {
|
||||
// GameObject.Destroy(this.InactiveHolder);
|
||||
// GameObject.Destroy(this.Content);
|
||||
// }
|
||||
// }
|
||||
|
||||
// internal bool IsBlacklisted(string sig) => bl_typeAndMember.Any(it => sig.Contains(it));
|
||||
// internal bool IsBlacklisted(MethodInfo method) => bl_methodNameStartsWith.Any(it => method.Name.StartsWith(it));
|
||||
|
||||
// internal string GetSig(MemberInfo member) => $"{member.DeclaringType.Name}.{member.Name}";
|
||||
// internal string AppendArgsToSig(ParameterInfo[] args)
|
||||
// {
|
||||
// string ret = " (";
|
||||
// foreach (var param in args)
|
||||
// ret += $"{param.ParameterType.Name} {param.Name}, ";
|
||||
// ret += ")";
|
||||
// return ret;
|
||||
// }
|
||||
|
||||
// public void CacheMembers(Type type)
|
||||
// {
|
||||
// var list = new List<CacheMember>();
|
||||
// var cachedSigs = new HashSet<string>();
|
||||
|
||||
// var types = ReflectionUtility.GetAllBaseTypes(type);
|
||||
|
||||
// var flags = BindingFlags.NonPublic | BindingFlags.Public | BindingFlags.Static;
|
||||
// if (this is InstanceInspector)
|
||||
// flags |= BindingFlags.Instance;
|
||||
|
||||
// foreach (var declaringType in types)
|
||||
// {
|
||||
// var target = Target;
|
||||
// target = target.TryCast(declaringType);
|
||||
|
||||
// IEnumerable<MemberInfo> infos = declaringType.GetMethods(flags);
|
||||
// infos = infos.Concat(declaringType.GetProperties(flags));
|
||||
// infos = infos.Concat(declaringType.GetFields(flags));
|
||||
|
||||
// foreach (var member in infos)
|
||||
// {
|
||||
// try
|
||||
// {
|
||||
// var sig = GetSig(member);
|
||||
|
||||
// //ExplorerCore.Log($"Trying to cache member {sig}...");
|
||||
// //ExplorerCore.Log(member.DeclaringType.FullName + "." + member.Name);
|
||||
|
||||
// var mi = member as MethodInfo;
|
||||
// var pi = member as PropertyInfo;
|
||||
// var fi = member as FieldInfo;
|
||||
|
||||
// if (IsBlacklisted(sig) || (mi != null && IsBlacklisted(mi)))
|
||||
// continue;
|
||||
|
||||
// var args = mi?.GetParameters() ?? pi?.GetIndexParameters();
|
||||
// if (args != null)
|
||||
// {
|
||||
// if (!CacheMember.CanProcessArgs(args))
|
||||
// continue;
|
||||
|
||||
// sig += AppendArgsToSig(args);
|
||||
// }
|
||||
|
||||
// if (cachedSigs.Contains(sig))
|
||||
// continue;
|
||||
|
||||
// cachedSigs.Add(sig);
|
||||
|
||||
// if (mi != null)
|
||||
// list.Add(new CacheMethod(mi, target, InactiveHolder));
|
||||
// else if (pi != null)
|
||||
// list.Add(new CacheProperty(pi, target, InactiveHolder));
|
||||
// else
|
||||
// list.Add(new CacheField(fi, target, InactiveHolder));
|
||||
|
||||
// var cached = list[list.Count - 1];
|
||||
// cached.ParentInspector = this;
|
||||
// }
|
||||
// catch (Exception e)
|
||||
// {
|
||||
// ExplorerCore.LogWarning($"Exception caching member {member.DeclaringType.FullName}.{member.Name}!");
|
||||
// ExplorerCore.Log(e.ToString());
|
||||
// }
|
||||
// }
|
||||
// }
|
||||
|
||||
// var typeList = types.ToList();
|
||||
|
||||
// var sorted = new List<CacheMember>();
|
||||
// sorted.AddRange(list.Where(it => it is CacheProperty)
|
||||
// .OrderBy(it => typeList.IndexOf(it.DeclaringType))
|
||||
// .ThenBy(it => it.NameForFiltering));
|
||||
// sorted.AddRange(list.Where(it => it is CacheField)
|
||||
// .OrderBy(it => typeList.IndexOf(it.DeclaringType))
|
||||
// .ThenBy(it => it.NameForFiltering));
|
||||
// sorted.AddRange(list.Where(it => it is CacheMethod)
|
||||
// .OrderBy(it => typeList.IndexOf(it.DeclaringType))
|
||||
// .ThenBy(it => it.NameForFiltering));
|
||||
|
||||
// allMembers = sorted.ToArray();
|
||||
// }
|
||||
|
||||
// public override void Update()
|
||||
// {
|
||||
// base.Update();
|
||||
|
||||
// if (autoUpdate)
|
||||
// {
|
||||
// foreach (var member in displayedMembers)
|
||||
// {
|
||||
// if (member == null) break;
|
||||
// member.UpdateValue();
|
||||
// }
|
||||
// }
|
||||
|
||||
// //if (m_widthUpdateWanted)
|
||||
// //{
|
||||
// // if (!m_widthUpdateWaiting)
|
||||
// // m_widthUpdateWaiting = true;
|
||||
// // else
|
||||
// // {
|
||||
// // UpdateWidths();
|
||||
// // m_widthUpdateWaiting = false;
|
||||
// // m_widthUpdateWanted = false;
|
||||
// // }
|
||||
// //}
|
||||
// }
|
||||
|
||||
// internal void OnMemberFilterClicked(MemberTypes type, Button button)
|
||||
// {
|
||||
// if (m_lastActiveMemButton)
|
||||
// RuntimeProvider.Instance.SetColorBlock(m_lastActiveMemButton, new Color(0.2f, 0.2f, 0.2f));
|
||||
|
||||
// m_memberFilter = type;
|
||||
// m_lastActiveMemButton = button;
|
||||
|
||||
// RuntimeProvider.Instance.SetColorBlock(m_lastActiveMemButton, new Color(0.2f, 0.6f, 0.2f));
|
||||
|
||||
// FilterMembers(null, true);
|
||||
// ScrollPool.RecreateHeightCache();
|
||||
// ScrollPool.Rebuild();
|
||||
// }
|
||||
|
||||
// public void FilterMembers(string nameFilter = null, bool force = false)
|
||||
// {
|
||||
// int lastCount = filteredMembers.Count;
|
||||
// filteredMembers.Clear();
|
||||
|
||||
// nameFilter = nameFilter?.ToLower() ?? m_nameFilterText.text.ToLower();
|
||||
|
||||
// filteredToRealIndices.Clear();
|
||||
|
||||
// for (int i = 0; i < allMembers.Length; i++)
|
||||
// {
|
||||
// var mem = allMembers[i];
|
||||
|
||||
// // membertype filter
|
||||
// if (m_memberFilter != MemberTypes.All && mem.MemInfo.MemberType != m_memberFilter)
|
||||
// continue;
|
||||
|
||||
// if (this is InstanceInspector ii && ii.m_scopeFilter != MemberScopes.All)
|
||||
// {
|
||||
// if (mem.IsStatic && ii.m_scopeFilter != MemberScopes.Static)
|
||||
// continue;
|
||||
// else if (!mem.IsStatic && ii.m_scopeFilter != MemberScopes.Instance)
|
||||
// continue;
|
||||
// }
|
||||
|
||||
// // name filter
|
||||
// if (!string.IsNullOrEmpty(nameFilter) && !mem.NameForFiltering.Contains(nameFilter))
|
||||
// continue;
|
||||
|
||||
// filteredMembers.Add(mem);
|
||||
// filteredToRealIndices.Add(i);
|
||||
// }
|
||||
|
||||
// //if (force || lastCount != filteredMembers.Count)
|
||||
// //{
|
||||
// // ScrollPool.EnableTempCache();
|
||||
// // ScrollPool.Rebuild();
|
||||
// //}
|
||||
// }
|
||||
|
||||
// #endregion
|
||||
|
||||
// #region UI
|
||||
|
||||
// private GameObject m_content;
|
||||
// public override GameObject Content
|
||||
// {
|
||||
// get => m_content;
|
||||
// set => m_content = value;
|
||||
// }
|
||||
|
||||
// internal Text m_nameFilterText;
|
||||
// internal MemberTypes m_memberFilter;
|
||||
// internal Button m_lastActiveMemButton;
|
||||
|
||||
// internal GameObject m_filterAreaObj;
|
||||
// internal GameObject m_updateRowObj;
|
||||
|
||||
// internal void ConstructUI()
|
||||
// {
|
||||
// var parent = InspectorPanel.Instance.ContentHolder;
|
||||
|
||||
// this.Content = UIFactory.CreateVerticalGroup(parent, "ReflectionInspector", true, false, true, true, 5, new Vector4(4, 4, 4, 4),
|
||||
// new Color(0.15f, 0.15f, 0.15f));
|
||||
|
||||
// this.m_inactiveHolder = new GameObject("InactiveContentHolder");
|
||||
// m_inactiveHolder.transform.SetParent(Content.transform, false);
|
||||
// m_inactiveHolder.SetActive(false);
|
||||
|
||||
// ConstructTopArea();
|
||||
|
||||
// ConstructMemberList();
|
||||
// }
|
||||
|
||||
// internal void ConstructTopArea()
|
||||
// {
|
||||
// var nameRowObj = UIFactory.CreateHorizontalGroup(Content, "NameRowObj", true, true, true, true, 2, default, new Color(1, 1, 1, 0));
|
||||
// UIFactory.SetLayoutElement(nameRowObj, minHeight: 25, flexibleHeight: 0, minWidth: 200, flexibleWidth: 5000);
|
||||
|
||||
// var typeLabelText = UIFactory.CreateLabel(nameRowObj, "TypeLabel", "Type:", TextAnchor.MiddleLeft);
|
||||
// typeLabelText.horizontalOverflow = HorizontalWrapMode.Overflow;
|
||||
// UIFactory.SetLayoutElement(typeLabelText.gameObject, minWidth: 40, flexibleWidth: 0, minHeight: 25);
|
||||
|
||||
// var typeDisplay = UIFactory.CreateLabel(nameRowObj, "TypeDisplayText", SignatureHighlighter.ParseFullSyntax(m_targetType, true),
|
||||
// TextAnchor.MiddleLeft);
|
||||
|
||||
// UIFactory.SetLayoutElement(typeDisplay.gameObject, minHeight: 25, flexibleWidth: 5000);
|
||||
|
||||
// // instance helper tools
|
||||
|
||||
// if (this is InstanceInspector instanceInspector)
|
||||
// {
|
||||
// instanceInspector.ConstructUnityInstanceHelpers();
|
||||
// }
|
||||
|
||||
// ConstructFilterArea();
|
||||
|
||||
// ConstructUpdateRow();
|
||||
// }
|
||||
|
||||
// internal void ConstructFilterArea()
|
||||
// {
|
||||
// // Filters
|
||||
|
||||
// m_filterAreaObj = UIFactory.CreateVerticalGroup(Content, "FilterGroup", true, true, true, true, 4, new Vector4(4, 4, 4, 4),
|
||||
// new Color(0.1f, 0.1f, 0.1f));
|
||||
// UIFactory.SetLayoutElement(m_filterAreaObj, minHeight: 60);
|
||||
|
||||
// // name filter
|
||||
|
||||
// var nameFilterRowObj = UIFactory.CreateHorizontalGroup(m_filterAreaObj, "NameFilterRow", false, false, true, true, 5, default,
|
||||
// new Color(1, 1, 1, 0));
|
||||
// UIFactory.SetLayoutElement(nameFilterRowObj, minHeight: 25, flexibleHeight: 0, flexibleWidth: 5000);
|
||||
|
||||
// var nameLabel = UIFactory.CreateLabel(nameFilterRowObj, "NameLabel", "Filter names:", TextAnchor.MiddleLeft, Color.grey);
|
||||
// UIFactory.SetLayoutElement(nameLabel.gameObject, minWidth: 100, minHeight: 25, flexibleWidth: 0);
|
||||
|
||||
// var nameInputObj = UIFactory.CreateInputField(nameFilterRowObj, "NameInput", "...", out InputField nameInput, 14, (int)TextAnchor.MiddleLeft,
|
||||
// (int)HorizontalWrapMode.Overflow);
|
||||
// UIFactory.SetLayoutElement(nameInputObj, flexibleWidth: 5000, minWidth: 100, minHeight: 25);
|
||||
// nameInput.onValueChanged.AddListener((string val) =>
|
||||
// {
|
||||
// FilterMembers(val, true);
|
||||
// ScrollPool.RecreateHeightCache();
|
||||
// ScrollPool.Rebuild();
|
||||
// });
|
||||
// m_nameFilterText = nameInput.textComponent;
|
||||
|
||||
// // membertype filter
|
||||
|
||||
// var memberFilterRowObj = UIFactory.CreateHorizontalGroup(m_filterAreaObj, "MemberFilter", false, false, true, true, 5, default,
|
||||
// new Color(1, 1, 1, 0));
|
||||
// UIFactory.SetLayoutElement(memberFilterRowObj, minHeight: 25, flexibleHeight: 0, flexibleWidth: 5000);
|
||||
|
||||
// var memLabel = UIFactory.CreateLabel(memberFilterRowObj, "MemberFilterLabel", "Filter members:", TextAnchor.MiddleLeft, Color.grey);
|
||||
// UIFactory.SetLayoutElement(memLabel.gameObject, minWidth: 100, minHeight: 25, flexibleWidth: 0);
|
||||
|
||||
// AddFilterButton(memberFilterRowObj, MemberTypes.All, true);
|
||||
// AddFilterButton(memberFilterRowObj, MemberTypes.Method);
|
||||
// AddFilterButton(memberFilterRowObj, MemberTypes.Property);
|
||||
// AddFilterButton(memberFilterRowObj, MemberTypes.Field);
|
||||
|
||||
// // Instance filters
|
||||
|
||||
// if (this is InstanceInspector instanceInspector)
|
||||
// {
|
||||
// instanceInspector.ConstructInstanceScopeFilters(m_filterAreaObj);
|
||||
// }
|
||||
// }
|
||||
|
||||
// private void AddFilterButton(GameObject parent, MemberTypes type, bool setEnabled = false)
|
||||
// {
|
||||
// var btn = UIFactory.CreateButton(parent,
|
||||
// "FilterButton_" + type,
|
||||
// type.ToString(),
|
||||
// null,
|
||||
// new Color(0.2f, 0.2f, 0.2f));
|
||||
// UIFactory.SetLayoutElement(btn.gameObject, minHeight: 25, minWidth: 70);
|
||||
// btn.onClick.AddListener(() => { OnMemberFilterClicked(type, btn); });
|
||||
|
||||
// RuntimeProvider.Instance.SetColorBlock(btn, highlighted: new Color(0.3f, 0.7f, 0.3f));
|
||||
|
||||
// if (setEnabled)
|
||||
// {
|
||||
// RuntimeProvider.Instance.SetColorBlock(btn, new Color(0.2f, 0.6f, 0.2f));
|
||||
// m_memberFilter = type;
|
||||
// m_lastActiveMemButton = btn;
|
||||
// }
|
||||
// }
|
||||
|
||||
// internal void ConstructUpdateRow()
|
||||
// {
|
||||
// m_updateRowObj = UIFactory.CreateHorizontalGroup(Content, "UpdateRow", false, true, true, true, 10, default, new Color(1, 1, 1, 0));
|
||||
// UIFactory.SetLayoutElement(m_updateRowObj, minHeight: 25);
|
||||
|
||||
// // update button
|
||||
|
||||
// var updateBtn = UIFactory.CreateButton(m_updateRowObj, "UpdateButton", "Update Values", null, new Color(0.2f, 0.2f, 0.2f));
|
||||
// UIFactory.SetLayoutElement(updateBtn.gameObject, minWidth: 110, flexibleWidth: 0);
|
||||
// updateBtn.onClick.AddListener(() =>
|
||||
// {
|
||||
// bool orig = autoUpdate;
|
||||
// autoUpdate = true;
|
||||
// Update();
|
||||
// if (!orig)
|
||||
// autoUpdate = orig;
|
||||
// });
|
||||
|
||||
// // auto update
|
||||
|
||||
// var autoUpdateObj = UIFactory.CreateToggle(m_updateRowObj, "UpdateToggle", out Toggle autoUpdateToggle, out Text autoUpdateText);
|
||||
// var autoUpdateLayout = autoUpdateObj.AddComponent<LayoutElement>();
|
||||
// autoUpdateLayout.minWidth = 150;
|
||||
// autoUpdateLayout.minHeight = 25;
|
||||
// autoUpdateText.text = "Auto-update?";
|
||||
// autoUpdateToggle.isOn = false;
|
||||
// autoUpdateToggle.onValueChanged.AddListener((bool val) => { autoUpdate = val; });
|
||||
// }
|
||||
|
||||
// internal void ConstructMemberList()
|
||||
// {
|
||||
// ScrollPool = UIFactory.CreateScrollPool(Content, "MemberList", out GameObject scrollRoot, out GameObject scrollContent,
|
||||
// new Color(0.05f, 0.05f, 0.05f));
|
||||
// UIFactory.SetLayoutElement(scrollRoot, flexibleHeight: 9999);
|
||||
// UIFactory.SetLayoutElement(scrollContent, flexibleHeight: 9999);
|
||||
|
||||
// CacheMemberList = new CacheMemberList(ScrollPool, this);
|
||||
|
||||
// ScrollPool.Initialize(CacheMemberList, CellViewHolder.CreatePrototypeCell(scrollRoot));
|
||||
|
||||
// // ScrollPool.Viewport.GetComponent<Mask>().enabled = false;
|
||||
// }
|
||||
// }
|
||||
|
||||
// #endregion
|
||||
//}
|
14
src/Inspectors_OLD/Reflection/StaticInspector.cs
Normal file
14
src/Inspectors_OLD/Reflection/StaticInspector.cs
Normal file
@ -0,0 +1,14 @@
|
||||
//using System;
|
||||
//using System.Collections.Generic;
|
||||
//using System.Linq;
|
||||
//using System.Text;
|
||||
|
||||
//namespace UnityExplorer.Inspectors.Reflection
|
||||
//{
|
||||
// public class StaticInspector : ReflectionInspector
|
||||
// {
|
||||
// public override string TabLabel => $" <color=cyan>[S]</color> {base.TabLabel}";
|
||||
|
||||
// public StaticInspector(Type type) : base(type) { }
|
||||
// }
|
||||
//}
|
Loading…
x
Reference in New Issue
Block a user