objectToAdd | 既存のアセットに追加するオブジェクト |
path | アセットのファイルシステム上のパス |
path
に存在するアセットに objectToAdd
を追加
すべてのパスは、例えば "Assets/MyTextures/hello.png" のような Project フォルダーに対する相対パスです。
注意:
GameObject を加えることはできません。代わりに、 PrefabUtility を使用してください。
using UnityEngine; using UnityEditor;
public class CreateMaterialExample : MonoBehaviour { [MenuItem("GameObject/Create Material")] static void CreateMaterial( ) { // Create a simple material asset
Material material = new Material( Shader.Find( "Specular" ) ); AssetDatabase.CreateAsset( material, "Assets/MyMaterial.mat" );
// Add an animation clip to it AnimationClip animationClip = new AnimationClip( ); animationClip.name = "My Clip"; AssetDatabase.AddObjectToAsset( animationClip, material );
// Reimport the asset after adding an object. // Otherwise the change only shows up when saving the project AssetDatabase.ImportAsset( AssetDatabase.GetAssetPath( animationClip ) );
// Print the path of the created asset Debug.Log( AssetDatabase.GetAssetPath( material ) ); } }
assetObject
によって指定される既存のアセットに objectToAdd
を追加
注意:
GameObject を加えることはできません。代わりに、 PrefabUtility を使用してください。
using UnityEngine; using UnityEditor;
public class CreateMaterialExample : MonoBehaviour { [MenuItem("GameObject/Create Material")] static void CreateMaterial( ) { // Create a simple material asset
Material material = new Material( Shader.Find( "Specular" ) ); AssetDatabase.CreateAsset( material, "Assets/MyMaterial.mat" );
// Add an animation clip to it AnimationClip animationClip = new AnimationClip( ); animationClip.name = "My Clip"; AssetDatabase.AddObjectToAsset( animationClip, material );
// Reimport the asset after adding an object. // Otherwise the change only shows up when saving the project AssetDatabase.ImportAsset( AssetDatabase.GetAssetPath( animationClip ) );
// Print the path of the created asset Debug.Log( AssetDatabase.GetAssetPath( material ) ); } }