This commit is contained in:
2026-05-30 09:16:35 +07:00
parent 2f87ce19a7
commit 1c0ee6efb7
4001 changed files with 3363438 additions and 1738 deletions

View File

@@ -0,0 +1,96 @@
#if UNITY_EDITOR
using System;
using System.Collections.Generic;
using System.Linq;
using System.Reflection;
using UnityEditor;
using UnityEngine;
namespace Invector.DefineSymbolsManager
{
[InitializeOnLoad]
public class InvectorDefineSymbolsManager
{
static InvectorDefineSymbolsManager()
{
CreateDefinitions();
}
public static void CreateDefinitions()
{
string definesString = PlayerSettings.GetScriptingDefineSymbolsForGroup(EditorUserBuildSettings.selectedBuildTargetGroup);
List<string> allDefines = definesString.Split(';').ToList();
List<string> allInvectorDefines = new List<string>();
var denitionsType = GetAllDefinitions();
foreach (var t in denitionsType)
{
var value = t.InvokeMember(null, BindingFlags.DeclaredOnly |
BindingFlags.Public | BindingFlags.NonPublic |
BindingFlags.Instance | BindingFlags.CreateInstance, null, null, null);
List<string> list = null;
try
{
list = (List<string>)t.InvokeMember("GetSymbols", BindingFlags.DeclaredOnly |
BindingFlags.Public | BindingFlags.NonPublic |
BindingFlags.Instance | BindingFlags.GetProperty, null, value, null);
if (list != null)
{
allInvectorDefines.AddRange(list.Except(allInvectorDefines));
}
}
catch
{
}
}
var allDefiniesToRemove = allDefines.FindAll(s => s.ToUpper().Contains("INVECTOR") && !allInvectorDefines.Contains(s));
var allDefiniesToAdd = allInvectorDefines.FindAll(s => !allDefines.Contains(s));
var needUpdate = allDefiniesToRemove.Count > 0 || allDefiniesToAdd.Count > 0;
if (needUpdate)
{
for (int i = 0; i < allDefiniesToRemove.Count; i++)
if (allDefines.Contains(allDefiniesToRemove[i])) allDefines.Remove(allDefiniesToRemove[i]);
AddDefinitionSymbols(allDefiniesToAdd, allDefines);
}
}
static void AddDefinitionSymbols(List<string> targetDefineSymbols, List<string> currentDefineSymbols)
{
bool needUpdate = false;
for (int i = 0; i < targetDefineSymbols.Count; i++)
{
if (!currentDefineSymbols.Contains(targetDefineSymbols[i]))
{
needUpdate = true; break;
}
}
currentDefineSymbols.AddRange(targetDefineSymbols.Except(currentDefineSymbols));
if (needUpdate)
PlayerSettings.SetScriptingDefineSymbolsForGroup(
EditorUserBuildSettings.selectedBuildTargetGroup,
string.Join(";", currentDefineSymbols.ToArray()));
}
static List<System.Type> GetAllDefinitions()
{
return AppDomain.CurrentDomain.GetAssemblies().SelectMany(x => x.GetTypes())
.Where(x => typeof(InvectorDefineSymbols).IsAssignableFrom(x) && !x.IsInterface && !x.IsAbstract).ToList();
}
}
}
#endif
namespace Invector.DefineSymbolsManager
{
public abstract class InvectorDefineSymbols
{
public abstract List<string> GetSymbols
{
get;
}
}
}

View File

@@ -0,0 +1,12 @@
fileFormatVersion: 2
guid: a1fc48817c2614c40a4adb7df19203db
timeCreated: 1529571218
licenseType: Store
MonoImporter:
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant:

View File

@@ -0,0 +1,14 @@
using System.Collections.Generic;
namespace Invector.DefineSymbolsManager
{
public class vBasicControllerDefineSymbols : InvectorDefineSymbols
{
public override List<string> GetSymbols
{
get
{
return new List<string>() { "INVECTOR_BASIC" };
}
}
}
}

View File

@@ -0,0 +1,12 @@
fileFormatVersion: 2
guid: 4b70a81becfb33e4881ade0a83cf66e4
timeCreated: 1529360983
licenseType: Store
MonoImporter:
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant:

View File

@@ -0,0 +1,383 @@
using System;
using System.Collections.Generic;
using System.Linq;
using System.Linq.Expressions;
using System.Reflection;
using UnityEditor;
using UnityEngine;
namespace Invector
{
public class vEditorHelper : UnityEditor.Editor
{
/// <summary>
/// Get PropertyName
/// </summary>
/// <typeparam name="T"></typeparam>
/// <param name="propertyLambda">You must pass a lambda of the form: '() => Class.Property' or '() => object.Property'</param>
/// <returns></returns>
public static string GetPropertyName<T>(Expression<Func<T>> propertyLambda)
{
var me = propertyLambda.Body as MemberExpression;
if (me == null)
{
throw new ArgumentException("You must pass a lambda of the form: '() => Class.Property' or '() => object.Property'");
}
return me.Member.Name;
}
/// <summary>
/// Check if type is a <see cref="UnityEngine.Events.UnityEvent"/>
/// </summary>
/// <param name="type"></param>
/// <returns></returns>
public static bool IsUnityEventyType(Type type)
{
if (type.Equals(typeof(UnityEngine.Events.UnityEvent))) return true;
if (type.BaseType.Equals(typeof(UnityEngine.Events.UnityEvent))) return true;
if (type.Name.Contains("UnityEvent") || type.BaseType.Name.Contains("UnityEvent")) return true;
return false;
}
}
[CanEditMultipleObjects]
[CustomEditor(typeof(vMonoBehaviour), true)]
public class vEditorBase : UnityEditor.Editor
{
#region Variables
public string[] ignoreEvents;
public string[] notEventProperties;
public virtual string[] ignore_vMono => new string[] { "openCloseWindow", "openCloseEvents", "selectedToolbar" };
public vClassHeaderAttribute headerAttribute;
public GUISkin skin;
public Texture2D m_Logo;
public List<vToolBar> toolbars;
#endregion
public class vToolBar
{
public string title;
public bool useIcon;
public string iconName;
public List<string> variables;
public int order;
public vToolBar()
{
title = string.Empty;
variables = new List<string>();
}
}
protected virtual void OnEnable()
{
var targetObject = serializedObject.targetObject;
var hasAttributeHeader = targetObject.GetType().IsDefined(typeof(vClassHeaderAttribute), true);
if (hasAttributeHeader)
{
var attributes = Attribute.GetCustomAttributes(targetObject.GetType(), typeof(vClassHeaderAttribute), true);
if (attributes.Length > 0)
headerAttribute = (vClassHeaderAttribute)attributes[0];
}
skin = Resources.Load("vSkin") as GUISkin;
m_Logo = Resources.Load("icon_v2") as Texture2D;
var prop = serializedObject.GetIterator();
if (((vMonoBehaviour)target) != null)
{
List<string> events = new List<string>();
toolbars = new List<vToolBar>();
var toolbar = new vToolBar();
toolbar.title = "Default";
toolbars.Add(toolbar);
var index = 0;
bool needReorder = false;
int oldOrder = 0;
while (prop.NextVisible(true))
{
FieldInfo fieldInfo = null;
if (!targetObject.TryGetField( prop.name,out fieldInfo))
{
continue;
}
if (fieldInfo != null)
{
var toolBarAttributes = fieldInfo.GetCustomAttributes(typeof(vEditorToolbarAttribute), true);
if (toolBarAttributes.Length > 0)
{
var attribute = toolBarAttributes[0] as vEditorToolbarAttribute;
var _toolbar = toolbars.Find(tool => tool != null && tool.title == attribute.title);
if (_toolbar == null)
{
toolbar = new vToolBar();
toolbar.title = attribute.title;
toolbar.useIcon = attribute.useIcon;
toolbar.iconName = attribute.icon;
toolbars.Add(toolbar);
toolbar.order = attribute.order;
if (oldOrder < attribute.order) needReorder = true;
index = toolbars.Count - 1;
}
else
{
index = toolbars.IndexOf(_toolbar);
if (index < toolbars.Count)
{
if (attribute.overrideChildOrder)
{
if (oldOrder < attribute.order) needReorder = true;
toolbars[index].order = attribute.order;
}
if (attribute.overrideIcon)
{
toolbars[index].useIcon = true;
toolbars[index].iconName = attribute.icon;
}
}
}
}
if (index < toolbars.Count)
{
toolbars[index].variables.Add(prop.name);
}
if ((vEditorHelper.IsUnityEventyType(fieldInfo.FieldType) && !events.Contains(fieldInfo.Name)))
{
events.Add(fieldInfo.Name);
}
}
}
if (needReorder)
toolbars.Sort((a, b) => a.order.CompareTo(b.order));
var nullToolBar = toolbars.FindAll(tool => tool != null && (tool.variables == null || tool.variables.Count == 0));
for (int i = 0; i < nullToolBar.Count; i++)
{
if (toolbars.Contains(nullToolBar[i]))
toolbars.Remove(nullToolBar[i]);
}
ignoreEvents = events.vToArray();
if (headerAttribute != null)
m_Logo = Resources.Load(headerAttribute.iconName) as Texture2D;
//else headerAttribute = new vClassHeaderAttribute(target.GetType().Name);
}
}
protected virtual bool openCloseWindow
{
get
{
return serializedObject.FindProperty("openCloseWindow").boolValue;
}
set
{
var _openClose = serializedObject.FindProperty("openCloseWindow");
if (_openClose != null && value != _openClose.boolValue)
{
_openClose.boolValue = value;
serializedObject.ApplyModifiedProperties();
}
}
}
protected virtual bool openCloseEvents
{
get
{
var _openCloseEvents = serializedObject.FindProperty("openCloseEvents");
return _openCloseEvents != null ? _openCloseEvents.boolValue : false;
}
set
{
var _openCloseEvents = serializedObject.FindProperty("openCloseEvents");
if (_openCloseEvents != null && value != _openCloseEvents.boolValue)
{
_openCloseEvents.boolValue = value;
serializedObject.ApplyModifiedProperties();
}
}
}
protected virtual int selectedToolBar
{
get
{
var _selectedToolBar = serializedObject.FindProperty("selectedToolbar");
return _selectedToolBar != null ? _selectedToolBar.intValue : 0;
}
set
{
var _selectedToolBar = serializedObject.FindProperty("selectedToolbar");
if (_selectedToolBar != null && value != _selectedToolBar.intValue)
{
_selectedToolBar.intValue = value;
serializedObject.ApplyModifiedProperties();
}
}
}
public override bool UseDefaultMargins()
{
return false;
}
public override void OnInspectorGUI()
{
serializedObject.Update();
if (toolbars != null && toolbars.Count > 1)
{
GUILayout.BeginVertical(headerAttribute != null ? headerAttribute.header : target.GetType().Name, skin.window);
GUILayout.Label(m_Logo, skin.label, GUILayout.MaxHeight(25));
if (headerAttribute.openClose)
{
openCloseWindow = GUILayout.Toggle(openCloseWindow, openCloseWindow ? "Close Properties" : "Open Properties", EditorStyles.toolbarButton);
}
if (!headerAttribute.openClose || openCloseWindow)
{
var titles = getToobarTitles();
EditorGUILayout.PropertyField(serializedObject.FindProperty("m_Script"));
var customToolbar = skin.GetStyle("customToolbar");
if (headerAttribute.useHelpBox)
{
EditorStyles.helpBox.richText = true;
EditorGUILayout.HelpBox(headerAttribute.helpBoxText, MessageType.Info);
}
GUILayout.Space(10);
selectedToolBar = GUILayout.SelectionGrid(selectedToolBar, titles, titles.Length > 2 ? 3 : titles.Length, customToolbar, GUILayout.MinWidth(250));
if (!(selectedToolBar < toolbars.Count)) selectedToolBar = 0;
GUILayout.Space(10);
//GUILayout.Box(toolbars[selectedToolBar].title, skin.box, GUILayout.ExpandWidth(true));
var ignore = getIgnoreProperties(toolbars[selectedToolBar]);
var ignoreProperties = ignore.Append(ignore_vMono);
DrawPropertiesExcluding(serializedObject, ignoreProperties);
AdditionalGUI();
}
GUILayout.EndVertical();
}
else
{
if (headerAttribute == null)
{
if (((vMonoBehaviour)target) != null)
DrawPropertiesExcluding(serializedObject, ignore_vMono);
else
base.OnInspectorGUI();
AdditionalGUI();
}
else
{
GUILayout.BeginVertical(headerAttribute.header, skin.window);
GUILayout.Label(m_Logo, skin.label, GUILayout.MaxHeight(25));
if (headerAttribute.openClose)
{
openCloseWindow = GUILayout.Toggle(openCloseWindow, openCloseWindow ? "Close Properties" : "Open Properties", EditorStyles.toolbarButton);
}
if (!headerAttribute.openClose || openCloseWindow)
{
if (headerAttribute.useHelpBox)
{
EditorStyles.helpBox.richText = true;
EditorGUILayout.HelpBox(headerAttribute.helpBoxText, MessageType.Info);
}
if (ignoreEvents != null && ignoreEvents.Length > 0)
{
var ignoreProperties = ignoreEvents.Append(ignore_vMono);
DrawPropertiesExcluding(serializedObject, ignoreProperties);
openCloseEvents = GUILayout.Toggle(openCloseEvents, (openCloseEvents ? "Close " : "Open ") + "Events ", skin.button);
if (openCloseEvents)
{
foreach (string propName in ignoreEvents)
{
var prop = serializedObject.FindProperty(propName);
if (prop != null)
EditorGUILayout.PropertyField(prop);
}
}
}
else
{
var ignoreProperties = ignoreEvents.Append(ignore_vMono);
DrawPropertiesExcluding(serializedObject, ignoreProperties);
}
}
AdditionalGUI();
EditorGUILayout.EndVertical();
}
}
if (GUI.changed)
{
serializedObject.ApplyModifiedProperties();
EditorUtility.SetDirty(serializedObject.targetObject);
}
}
public virtual GUIContent[] getToobarTitles()
{
List<GUIContent> props = new List<GUIContent>();
for (int i = 0; i < toolbars.Count; i++)
{
if (toolbars[i] != null)
{
Texture icon = null;
var _icon = Resources.Load(toolbars[i].iconName);
if (_icon) icon = _icon as Texture;
GUIContent content = new GUIContent(toolbars[i].useIcon ? "" : toolbars[i].title, icon, "");
props.Add(content);
}
}
return props.vToArray();
}
public virtual string[] getIgnoreProperties(vToolBar toolbar)
{
List<string> props = new List<string>();
for (int i = 0; i < toolbars.Count; i++)
{
if (toolbars[i] != null && toolbar != null && toolbar.variables != null)
{
for (int a = 0; a < toolbars[i].variables.Count; a++)
{
if (!props.Contains(toolbars[i].variables[a]) && !toolbar.variables.Contains(toolbars[i].variables[a]))
{
props.Add(toolbars[i].variables[a]);
}
}
}
}
props.Add("m_Script");
return props.vToArray();
}
protected virtual void AdditionalGUI()
{
}
}
}

View File

@@ -0,0 +1,12 @@
fileFormatVersion: 2
guid: 52dd722ad90f2744e8010be349426064
timeCreated: 1484055770
licenseType: Store
MonoImporter:
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant:

View File

@@ -0,0 +1,79 @@
using UnityEngine;
using System.Linq;
using UnityEditor;
[InitializeOnLoad]
static class vInspectorSearchTool
{
static vInspectorSearchTool()
{
Editor.finishedDefaultHeaderGUI -= DrawInpectorSearchTool;
Editor.finishedDefaultHeaderGUI += DrawInpectorSearchTool;
}
public static string search;
public static GameObject lastSelection;
static void DrawInpectorSearchTool(UnityEditor.Editor editor)
{
if(editor.target.GetType()!= typeof(GameObject))
{
return;
}
if (Selection.activeGameObject)
{
if(lastSelection!=Selection.activeGameObject)
{
lastSelection = Selection.activeGameObject;
search = "";
}
var components = Selection.activeGameObject.GetComponents<MonoBehaviour>().ToList();
var totalRect = EditorGUILayout.GetControlRect();
try
{
EditorGUI.LabelField(totalRect, $"vInspector Search Tool | Hided Components : {components.FindAll(c => c.hideFlags == HideFlags.HideInInspector).Count.ToString("00")} | {components.Count.ToString("00")}", EditorStyles.toolbar);
totalRect = EditorGUILayout.GetControlRect();
search = EditorGUI.TextField(totalRect, search, EditorStyles.toolbarSearchField);
totalRect = EditorGUILayout.GetControlRect();
if (GUI.Button(totalRect, "Fold All Scripts"))
{
for (int i = 0; i < components.Count; i++)
{
UnityEditorInternal.InternalEditorUtility.SetIsInspectorExpanded(components[i], false);
}
ActiveEditorTracker.sharedTracker.ForceRebuild();
}
if (string.IsNullOrEmpty(search))
{
for (int i = 0; i < components.Count; i++)
{
var targetState = HideFlags.None;
if (targetState != components[i].hideFlags)
components[i].hideFlags = targetState;
}
}
else
{
for (int i = 0; i < components.Count; i++)
{
if (components[i].GetType().Name.ToUpper().Contains(search.ToUpper()))
{
var targetState = HideFlags.None;
if (targetState != components[i].hideFlags)
components[i].hideFlags = targetState;
}
else
{
var targetState = HideFlags.HideInInspector;
if (targetState != components[i].hideFlags)
components[i].hideFlags = targetState;
}
}
}
}catch
{
///DO Nothing
}
}
}
}

View File

@@ -0,0 +1,11 @@
fileFormatVersion: 2
guid: fbfefcfb44083f34e8609eb11209fc5e
MonoImporter:
externalObjects: {}
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant:

View File

@@ -0,0 +1,47 @@
using UnityEngine;
using System.Collections;
using System.Collections.Generic;
using UnityEditor;
namespace Invector
{
[InitializeOnLoad]
public class vInvectorIcon
{
static Texture2D texturePanel;
static List<int> markedObjects;
static vInvectorIcon()
{
EditorApplication.hierarchyWindowItemOnGUI += ThirdPersonControllerIcon;
EditorApplication.hierarchyWindowItemOnGUI += ThirPersonCameraIcon;
}
static void ThirPersonCameraIcon(int instanceId, Rect selectionRect)
{
GameObject go = EditorUtility.InstanceIDToObject(instanceId) as GameObject;
if (go == null) return;
var tpCamera = go.GetComponent<vCamera.vThirdPersonCamera>();
if (tpCamera != null) DrawIcon("tp_camera", selectionRect);
}
static void ThirdPersonControllerIcon(int instanceId, Rect selectionRect)
{
GameObject go = EditorUtility.InstanceIDToObject(instanceId) as GameObject;
if (go == null) return;
var controller = go.GetComponent<Invector.vCharacterController.vThirdPersonController>();
if (controller != null) DrawIcon("controllerIcon", selectionRect);
}
private static void DrawIcon(string texName, Rect rect)
{
Rect r = new Rect(rect.x + rect.width - 16f, rect.y, 16f, 16f);
GUI.DrawTexture(r, GetTex(texName));
}
private static Texture2D GetTex(string name)
{
return (Texture2D)Resources.Load(name);
}
}
}

View File

@@ -0,0 +1,12 @@
fileFormatVersion: 2
guid: c063f86c7e7b0b54687ffa4deb9e3c94
timeCreated: 1500506016
licenseType: Store
MonoImporter:
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant: