AssetDatabase是Unity编辑器环境下的一种API,主要用于在代码中对项目中的资源进行管理和操作。注意:AssetDatabase的这些方法只能在Unity编辑器环境下运行,不能在构建后的游戏中使用。在游戏运行时,你需要使用其他资源加载方法,如Resources.Load、AssetBundle加载或者Addressables等。

以下是一些常用的AssetDatabase方法及其使用示例:

创建新资产

using UnityEngine;using UnityEditor;public class CreateNewAssetExample : Editor{[MenuItem("Assets/Create/New Asset")]static void CreateNewAsset(){// 创建一个新的ScriptableObject类型资产ScriptableObject newAsset = CreateInstance();// 设置资产的名称newAsset.name = "NewAsset";// 选择保存新资产的路径string path = "Assets/MyAssets/NewAsset.asset";// 使用AssetDatabase.CreateAsset方法创建新资产AssetDatabase.CreateAsset(newAsset, path);// 让Unity刷新资源数据库,使新资产在项目窗口中可见AssetDatabase.SaveAssets();AssetDatabase.Refresh();}}

2.创建新文件夹

using UnityEngine;using UnityEditor;public class CreateNewFolderExample : Editor{[MenuItem("Assets/Create/New Folder")]static void CreateNewFolder(){// 指定新文件夹的路径string folderPath = "Assets/MyFolders/NewFolder";// 使用AssetDatabase.CreateFolder方法创建新文件夹AssetDatabase.CreateFolder("Assets/MyFolders", "NewFolder");// 刷新资源数据库AssetDatabase.SaveAssets();AssetDatabase.Refresh();}}

3.删除指定资产或文件夹

using UnityEngine;using UnityEditor;public class DeleteAssetExample : Editor{[MenuItem("Assets/Delete Selected Asset")]static void DeleteSelectedAsset(){// 获取当前选中的资产的路径string assetPath = AssetDatabase.GetAssetPath(Selection.activeObject);// 使用AssetDatabase.DeleteAsset方法删除资产if (!string.IsNullOrEmpty(assetPath) && AssetDatabase.Contains(Selection.activeObject)){AssetDatabase.DeleteAsset(assetPath);AssetDatabase.SaveAssets();AssetDatabase.Refresh();}}}

4.一次性删除多个资产或文件夹

using UnityEngine;using UnityEditor;public class DeleteMultipleAssetsExample : Editor{[MenuItem("Assets/Delete Multiple Assets")]static void DeleteMultipleAssets(){// 获取所有选中的资产的路径string[] assetPaths = Selection.assetGUIDs.Select(AssetDatabase.GUIDToAssetPath).ToArray();// 使用AssetDatabase.DeleteAssets方法删除所有选中的资产AssetDatabase.DeleteAssets(assetPaths);AssetDatabase.SaveAssets();AssetDatabase.Refresh();}}

5.获取资产存储路径的文件夹路径名

using UnityEngine;public class GetAssetPathExample : MonoBehaviour{void Start(){// 获取某个资产的路径string assetPath = AssetDatabase.GetAssetPath(someGameObject);// 获取该资产所在的文件夹路径string folderPath = Path.GetDirectoryName(assetPath);Debug.Log("Asset folder path: " + folderPath);}}

AssetDatabase 如何获取Assets 目录下的一个游戏物体?

在Unity中,你可以使用AssetDatabase.LoadAssetAtPath方法来获取Assets目录下的一个游戏物体(如GameObject)。这个方法需要一个表示资源路径的字符串作为参数,并返回该路径下指定类型的资源。

注意:

在Unity编辑器环境下,我们通常不需要将使用AssetDatabase的代码放在诸如void Start()这样的 MonoBehaviour 生命周期方法中,因为这些方法主要是在运行游戏时调用的。

对于使用AssetDatabase的代码,更常见的做法是将其放在自定义的Editor脚本中的静态方法中,或者在执行特定编辑器操作(如菜单命令、Inspector窗口中的按钮点击等)时调用。这样可以确保这些代码只在Unity编辑器环境下运行,而不会在构建和运行游戏时被执行。

以下是一个修改后的示例,将使用AssetDatabase的代码放在一个自定义的Editor菜单命令中:

以下是一个示例,它加载Assets目录下”Models/FooModel.prefab”的游戏物体:

using UnityEngine;using UnityEditor;public class GetGameObjectFromAssets : Editor{[MenuItem("Assets/Load GameObject")]static void LoadGameObject(){// 获取选中的资源路径string assetPath = AssetDatabase.GetAssetPath(Selection.activeObject);// 检查选中的是否为GameObjectif (assetPath.EndsWith(".prefab") || assetPath.EndsWith(".unity")){// 使用AssetDatabase.LoadAssetAtPath加载游戏物体GameObject loadedGameObject = AssetDatabase.LoadAssetAtPath(assetPath);}}

在这个例子中,当你在Unity编辑器的项目窗口中右键点击一个GameObject或Prefab并选择”Load GameObject”菜单命令时,将会执行加载和显示信息的操作。这种方式更适合在编辑器环境下使用AssetDatabase进行资源操作。