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();
相关推荐
后天han10 小时前
vscode中launch.json中定义的编译文件名于生成的不一致修改
ide·vscode·编辑器
Thomas_YXQ14 小时前
Unity3D编辑器扩展-物体批量替换设置材质
游戏·unity·编辑器·游戏引擎·材质
在嵌入式里摸爬滚打15 小时前
VScode远程连接Ubuntu报错问题分析
ide·vscode·编辑器
EnigmaCoder1 天前
【Linux】Vim编辑器:从入门到高效使用
linux·运维·编辑器·vim
无你想你3 天前
利用vscode时进行调试,即使设置justMyCode为False仍然失败,如何解决?
ide·vscode·编辑器·justmycode
xcs194053 天前
AI 自动化编程 trae 体验 页面添加富编辑器
运维·自动化·编辑器
雷工笔记4 天前
【软件安装】VScode介绍安装步骤及中文界面设置方法
ide·vscode·编辑器
gaog2zh4 天前
100202Title和Input组件_编辑器-react-仿低代码平台项目
react.js·低代码·编辑器
一瞬祈望5 天前
Visual Studio Code 基础设置指南
vscode·编辑器
hfut02885 天前
【vscode使用说明】
vscode·编辑器·vim