赞
踩
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<ScriptableObject>();
- // 设置资产的名称
- 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);
-
- // 检查选中的是否为GameObject
- if (assetPath.EndsWith(".prefab") || assetPath.EndsWith(".unity"))
- {
- // 使用AssetDatabase.LoadAssetAtPath加载游戏物体
- GameObject loadedGameObject = AssetDatabase.LoadAssetAtPath<GameObject>(assetPath);
-
-
- }
- }
在这个例子中,当你在Unity编辑器的项目窗口中右键点击一个GameObject或Prefab并选择"Load GameObject"菜单命令时,将会执行加载和显示信息的操作。这种方式更适合在编辑器环境下使用AssetDatabase
进行资源操作。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。