Unity (编辑器)数据持久化 之 ScriptableObject初识与创建

1.什么是ScriptableObject

ScriptableObject - Unity 手册

如题,一个可以在Unity编辑器中方便编辑数据的工具

一个脚本继承该类,并且序列化或者有公共变量,即可在Inspector窗口看到它们

其特点:

Q:是否可以将 ScriptableObject的数据保存到本地?

A:可以,可以通过Json的序列化与反序列化保存 ScriptableObject的数据

2.创建一个ScriptableObject文件

2.1 使用CreateAssetMenu(建议)

先继承ScriptableObject!!!!!!!!!!!!!!!!!!!!!!!!

使用CreateAssetMenu创建一个ScriptableObjec配置文件

cs 复制代码
[CreateAssetMenu(fileName ="文件名" ,menuName ="菜单名",order =0)]

示例:

当我的脚本中写了如下变量之后:

cs 复制代码
  public int a;
  public string b;
  [SerializeField]
  private GameObject c;

该文件就会出现对应的变量

总览:

cs 复制代码
[CreateAssetMenu(fileName ="文件名" ,menuName ="菜单名",order =0)]
public class LearnScripttableObject : ScriptableObject
{
    public int a;
    public string b;
    [SerializeField]
    private GameObject c;
}

2.2 使用MenuItem

示例:

cs 复制代码
public class TextMenuItem : MonoBehaviour
{
    //使用该特性在unity编辑器菜单栏中显示一个手势
    [MenuItem("菜单栏/手势")]
    public static void NewFunc()
    { 
    
    
    
    }
}

之后使用ScriptableObject的静态方法进行创建数据并保存到本地

cs 复制代码
public class TextMenuItem : MonoBehaviour
{
    //使用该特性在unity编辑器菜单栏中显示一个手势
    [MenuItem("菜单栏/手势")]
    public static void NewFunc()
    {
        //创建实例
        LearnScripttableObject  learnScripttable = ScriptableObject.CreateInstance<LearnScripttableObject>();
        //创建数据源文件       
        AssetDatabase.CreateAsset(learnScripttable,"Assets/Resources/sob数据文件.asset");
        //保存文件
        AssetDatabase.SaveAssets();
        //刷新
        AssetDatabase.Refresh();
    }
}

点击手势就会执行特性下的函数(NewFunc)


拆解:

第一行行代码,是abc数据的来源

cs 复制代码
 LearnScripttableObject  learnScripttable = ScriptableObject.CreateInstance<LearnScripttableObject>();

第二三行代码是在指定路径下保存该文件为指定名字

cs 复制代码
 //创建数据源文件       
 AssetDatabase.CreateAsset(learnScripttable,"Assets/Resources/sob数据文件.asset");
 //保存文件
 AssetDatabase.SaveAssets();
相关推荐
Hody9119 小时前
【XR开发系列】Unity第一印象:编辑器界面功能布局介绍(六大功能区域介绍)
unity·编辑器·xr
Lucky小小吴21 小时前
各大编码编辑器的缓存目录迁移到D盘【未完待续】
缓存·编辑器
言6661 天前
vscode 设置中文-语言
ide·vscode·编辑器
天天向上10242 天前
markdown及vscode中可以的emoji
ide·vscode·编辑器
IT利刃出鞘2 天前
WordPress插件--Markdown编辑器
编辑器
Joyce_JTR2 天前
【vscode】vscode上plantuml安装和使用
ide·vscode·编辑器
Hy行者勇哥2 天前
VSCode 插件开发实战:从零打造「文件模板快建」工具,吃透扩展生态核心技术
ide·vscode·编辑器
月起星九3 天前
vscode中claude code插件代理地址设置
ide·vscode·编辑器
myourdream23 天前
获取VSCE_TOKEN用于发布Visual Studio Code扩展
ide·vscode·编辑器
Justin_JGT3 天前
vscode配置Claude Code(使用智谱API)
ide·vscode·编辑器