自定义ProjectSettings设置项

2024-03-08 04:30

本文主要是介绍自定义ProjectSettings设置项,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

基于ScriptableObject资源和SettingsProvider特性方式实现

1.实现ScriptableObject数据设计


/// <summary>
/// 用于存储我们的设置配置
/// </summary>
public class EditorLearnSettings : ScriptableObject
{/// <summary>/// 用于我们设置的保存位置/// </summary>private const string SettingsFile= "Assets/Settings/EditorLearnSetting.asset";#region 此处可以存储我们自定义的配置信息/// <summary>/// 模拟我们的配置/// </summary>public int m_ConfigVersionCode = 1;#endregion
}

2.提供配置文件内容的全局实例方法 

在我们的EditorLearnSettings类提供以下方法,为我们提供全局配置信息。

    /// <summary>/// 这里提供一个配置对象/// </summary>/// <returns></returns>public static EditorLearnSettings GetOrCreateSettings(){var settings = AssetDatabase.LoadAssetAtPath<EditorLearnSettings>(SettingsFile);if (settings == null){settings = ScriptableObject.CreateInstance<EditorLearnSettings>();settings.m_ConfigVersionCode = 0;if (!Directory.Exists(Path.GetDirectoryName(SettingsFile))){Directory.CreateDirectory(Path.GetDirectoryName(SettingsFile));}AssetDatabase.CreateAsset(settings, SettingsFile);AssetDatabase.SaveAssets();}return settings;}/// <summary>/// 提供一个SerializedObject的对象/// </summary>/// <returns></returns>public static SerializedObject GetSerializedSettings(){return new SerializedObject(GetOrCreateSettings());}
  • 当资源配置被创建出来我们可以直接进行配置,如果不想通过资源配置文件配置,可以为其制定一个CustomEditor。
[CustomEditor(typeof(EditorLearnSettings))]
public class EditorLearnSettingsView:Editor
{protected override void OnHeaderGUI(){GUILayout.Label("请从Project Settings配置");}public override void OnInspectorGUI() { }
}

3.编写一个提供SettingsProvider数据的静态方法。

我们继续在EditorLearnSettings类提供以下方法。

    /// <summary>/// 这里主要是制定我们的Settings路径/// </summary>private const string ProjectSettingPtah = "Project/编辑器学习";/// <summary>/// 将我们的Setting提供给Unity/// </summary>/// <returns></returns>[SettingsProvider]public static SettingsProvider CreateEditorLearnSettingsProvider(){///创建一个SettingsProvidervar provider = new SettingsProvider(ProjectSettingPtah, SettingsScope.Project){guiHandler = (searchContext) =>{///searchContext:提供用户搜索的信息///这里是一个gui的处理行为var settings = EditorLearnSettings.GetSerializedSettings();EditorGUILayout.PropertyField(settings.FindProperty("m_ConfigVersionCode"), new GUIContent("版本码:"));settings.ApplyModifiedPropertiesWithoutUndo();},// 用于搜索的关键字,在Project 可以搜索对应的配置keywords = new HashSet<string>(new[] { "Learn", "KTGame" })};return provider;}

 4.到此我们就可以在Project Setting看见我们自定义的配置模块了。

5.完整代码

using System.Collections.Generic;
using UnityEditor;
using UnityEngine;
using System.IO;[CustomEditor(typeof(EditorLearnSettings))]
public class EditorLearnSettingsView:Editor
{protected override void OnHeaderGUI(){GUILayout.Label("请从Project Settings配置");}public override void OnInspectorGUI() { }
}/// <summary>
/// 用于存储我们的设置配置
/// </summary>
public class EditorLearnSettings : ScriptableObject
{/// <summary>/// 用于我们设置的保存位置/// </summary>private const string SettingsFile= "Assets/Settings/EditorLearnSetting.asset";#region 此处可以存储我们自定义的配置信息/// <summary>/// 模拟我们的配置/// </summary>public int m_ConfigVersionCode = 1;#endregion/// <summary>/// 这里提供一个全局的设置获取方式/// </summary>/// <returns></returns>public static EditorLearnSettings GetOrCreateSettings(){var settings = AssetDatabase.LoadAssetAtPath<EditorLearnSettings>(SettingsFile);if (settings == null){settings = ScriptableObject.CreateInstance<EditorLearnSettings>();settings.m_ConfigVersionCode = 0;if (!Directory.Exists(Path.GetDirectoryName(SettingsFile))){Directory.CreateDirectory(Path.GetDirectoryName(SettingsFile));}AssetDatabase.CreateAsset(settings, SettingsFile);AssetDatabase.SaveAssets();}return settings;}/// <summary>/// 提供一个SerializedObject的获取/// </summary>/// <returns></returns>public static SerializedObject GetSerializedSettings(){return new SerializedObject(GetOrCreateSettings());}/// <summary>/// 这里主要是制定我们的Settings路径/// </summary>private const string ProjectSettingPtah = "Project/编辑器学习";/// <summary>/// 将我们的Setting提供给Unity/// </summary>/// <returns></returns>[SettingsProvider]public static SettingsProvider CreateEditorLearnSettingsProvider(){///创建一个SettingsProvidervar provider = new SettingsProvider(ProjectSettingPtah, SettingsScope.Project){guiHandler = (searchContext) =>{///searchContext:提供用户搜索的信息///这里是一个gui的处理行为var settings = EditorLearnSettings.GetSerializedSettings();EditorGUILayout.PropertyField(settings.FindProperty("m_ConfigVersionCode"), new GUIContent("版本码:"));settings.ApplyModifiedPropertiesWithoutUndo();},// 用于搜索的关键字,在Project 可以搜索对应的配置keywords = new HashSet<string>(new[] { "Learn", "KTGame" })};return provider;}
}

基于继承SettingsProvider的实现方式。

1.同样需要一个配置文件。

配置文件我们直接使用上面的文件。

/// <summary>
/// 用于存储我们的设置配置
/// </summary>
public class EditorLearnSettings : ScriptableObject
{/// <summary>/// 用于我们设置的保存位置/// </summary>private const string SettingsFile= "Assets/Settings/EditorLearnSetting.asset";#region 此处可以存储我们自定义的配置信息/// <summary>/// 模拟我们的配置/// </summary>public int m_ConfigVersionCode = 1;#endregion/// <summary>/// 这里提供一个全局的设置获取方式/// </summary>/// <returns></returns>public static EditorLearnSettings GetOrCreateSettings(){var settings = AssetDatabase.LoadAssetAtPath<EditorLearnSettings>(SettingsFile);if (settings == null){settings = ScriptableObject.CreateInstance<EditorLearnSettings>();settings.m_ConfigVersionCode = 0;if (!Directory.Exists(Path.GetDirectoryName(SettingsFile))){Directory.CreateDirectory(Path.GetDirectoryName(SettingsFile));}AssetDatabase.CreateAsset(settings, SettingsFile);AssetDatabase.SaveAssets();}return settings;}/// <summary>/// 提供一个SerializedObject的获取/// </summary>/// <returns></returns>public static SerializedObject GetSerializedSettings(){return new SerializedObject(GetOrCreateSettings());}
}

2.继承 SettingsProvider

首先我们创建EditorLearnSettingsProvider类并继承SettingsProvider

public class EditorLearnSettingsProvider: SettingsProvider{}

实现SettingsProvider构造函数。

public EditorLearnSettingsProvider(string path, SettingsScope scope) : base(path, scope) { }

重写OnGUI和OnActivate

    /// <summary>/// 当模块被激活时被调用/// </summary>/// <param name="searchContext">用户搜索的内容</param>/// <param name="rootElement">UIElements根节点。如果添加到此,则 SettingsProvider 使用 UIElements 而不是调用 SettingsProvider.OnGUI 来构建 UI。如果不添加到此 VisualElement,则必须使用 IMGUI 来构建 UI。</param>public override void OnActivate(string searchContext, VisualElement rootElement){serializedObject = EditorLearnSettings.GetSerializedSettings();}public override void OnGUI(string searchContext){EditorGUILayout.PropertyField(serializedObject.FindProperty("m_ConfigVersionCode"), new GUIContent("版本码:"));}

3.通过SettingsProvider方法特性注册到SettingsProvider中

    [SettingsProvider]public static SettingsProvider CreateMyCustomSettingsProvider(){var provider = new EditorLearnSettingsProvider(ProjectSettingPtah, SettingsScope.Project);provider.keywords = new[] { "Learn", "KTGame" };return provider;}

4.完整代码

using UnityEditor;
using UnityEngine;
using System.IO;
using UnityEngine.UIElements;[CustomEditor(typeof(EditorLearnSettings))]
public class EditorLearnSettingsView:Editor
{protected override void OnHeaderGUI(){GUILayout.Label("请从Project Settings配置");}public override void OnInspectorGUI() { }
}/// <summary>
/// 用于存储我们的设置配置
/// </summary>
public class EditorLearnSettings : ScriptableObject
{/// <summary>/// 用于我们设置的保存位置/// </summary>private const string SettingsFile= "Assets/Settings/EditorLearnSetting.asset";#region 此处可以存储我们自定义的配置信息/// <summary>/// 模拟我们的配置/// </summary>public int m_ConfigVersionCode = 1;#endregion/// <summary>/// 这里提供一个全局的设置获取方式/// </summary>/// <returns></returns>public static EditorLearnSettings GetOrCreateSettings(){var settings = AssetDatabase.LoadAssetAtPath<EditorLearnSettings>(SettingsFile);if (settings == null){settings = ScriptableObject.CreateInstance<EditorLearnSettings>();settings.m_ConfigVersionCode = 0;if (!Directory.Exists(Path.GetDirectoryName(SettingsFile))){Directory.CreateDirectory(Path.GetDirectoryName(SettingsFile));}AssetDatabase.CreateAsset(settings, SettingsFile);AssetDatabase.SaveAssets();}return settings;}/// <summary>/// 提供一个SerializedObject的获取/// </summary>/// <returns></returns>public static SerializedObject GetSerializedSettings(){return new SerializedObject(GetOrCreateSettings());}
}public class EditorLearnSettingsProvider: SettingsProvider
{private const string ProjectSettingPtah = "Project/编辑器学习";public EditorLearnSettingsProvider(string path, SettingsScope scope) : base(path, scope) { }private SerializedObject serializedObject;/// <summary>/// 当模块被激活时被调用/// </summary>/// <param name="searchContext">用户搜索的内容</param>/// <param name="rootElement">UIElements根节点。如果添加到此,则 SettingsProvider 使用 UIElements 而不是调用 SettingsProvider.OnGUI 来构建 UI。如果不添加到此 VisualElement,则必须使用 IMGUI 来构建 UI。</param>public override void OnActivate(string searchContext, VisualElement rootElement){serializedObject = EditorLearnSettings.GetSerializedSettings();}public override void OnGUI(string searchContext){EditorGUILayout.PropertyField(serializedObject.FindProperty("m_ConfigVersionCode"), new GUIContent("版本码:"));}[SettingsProvider]public static SettingsProvider CreateMyCustomSettingsProvider(){var provider = new EditorLearnSettingsProvider(ProjectSettingPtah, SettingsScope.Project);provider.keywords = new[] { "Learn", "KTGame" };return provider;}
}

总结

  • SettingsScope共有两项,User显示在Preferences 窗口;Project显示在Project Settings窗口。
  • 这里我们使用的是ScriptableObject方式对配置进行存储,我们也可以使用其它的方式存储在非工程里或者存在ProjectSettings文件夹里。
  • 我们存储的配置目标尽可能的保证全局的唯一性。
  • 关于Project Settings配置模块和Preferences 配置我们还是最好进行一个统一的管理。
  • AssetDatabase.CreateAsset创建资源时要保证路径有效。
  • 此主题所有代码都是编辑器代码应该放在Editor下。
  • 如果我们需要提交多个配置模块可以使用SettingsProviderGroup,你的方法应该提供一个SettingsProvider[]

这篇关于自定义ProjectSettings设置项的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/785979

相关文章

C#TextBox设置提示文本方式(SetHintText)

《C#TextBox设置提示文本方式(SetHintText)》:本文主要介绍C#TextBox设置提示文本方式(SetHintText),具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑... 目录C#TextBox设置提示文本效果展示核心代码总结C#TextBox设置提示文本效果展示核心代

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

Feign Client超时时间设置不生效的解决方法

《FeignClient超时时间设置不生效的解决方法》这篇文章主要为大家详细介绍了FeignClient超时时间设置不生效的原因与解决方法,具有一定的的参考价值,希望对大家有一定的帮助... 在使用Feign Client时,可以通过两种方式来设置超时时间:1.针对整个Feign Client设置超时时间

使用Sentinel自定义返回和实现区分来源方式

《使用Sentinel自定义返回和实现区分来源方式》:本文主要介绍使用Sentinel自定义返回和实现区分来源方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Sentinel自定义返回和实现区分来源1. 自定义错误返回2. 实现区分来源总结Sentinel自定

PyCharm如何设置新建文件默认为LF换行符

《PyCharm如何设置新建文件默认为LF换行符》:本文主要介绍PyCharm如何设置新建文件默认为LF换行符问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录PyCharm设置新建文件默认为LF换行符设置换行符修改换行符总结PyCharm设置新建文件默认为LF

如何自定义Nginx JSON日志格式配置

《如何自定义NginxJSON日志格式配置》Nginx作为最流行的Web服务器之一,其灵活的日志配置能力允许我们根据需求定制日志格式,本文将详细介绍如何配置Nginx以JSON格式记录访问日志,这种... 目录前言为什么选择jsON格式日志?配置步骤详解1. 安装Nginx服务2. 自定义JSON日志格式各

Linux上设置Ollama服务配置(常用环境变量)

《Linux上设置Ollama服务配置(常用环境变量)》本文主要介绍了Linux上设置Ollama服务配置(常用环境变量),Ollama提供了多种环境变量供配置,如调试模式、模型目录等,下面就来介绍一... 目录在 linux 上设置环境变量配置 OllamPOgxSRJfa手动安装安装特定版本查看日志在

Android自定义Scrollbar的两种实现方式

《Android自定义Scrollbar的两种实现方式》本文介绍两种实现自定义滚动条的方法,分别通过ItemDecoration方案和独立View方案实现滚动条定制化,文章通过代码示例讲解的非常详细,... 目录方案一:ItemDecoration实现(推荐用于RecyclerView)实现原理完整代码实现

基于Spring实现自定义错误信息返回详解

《基于Spring实现自定义错误信息返回详解》这篇文章主要为大家详细介绍了如何基于Spring实现自定义错误信息返回效果,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录背景目标实现产出背景Spring 提供了 @RestConChina编程trollerAdvice 用来实现 HTT

SpringSecurity 认证、注销、权限控制功能(注销、记住密码、自定义登入页)

《SpringSecurity认证、注销、权限控制功能(注销、记住密码、自定义登入页)》SpringSecurity是一个强大的Java框架,用于保护应用程序的安全性,它提供了一套全面的安全解决方案... 目录简介认识Spring Security“认证”(Authentication)“授权” (Auth