スクリプタブルオブジェクトで作った文字列を外部アセットにして、ロードできるようにする(ScriptableObjectとAddressable)
データ部分をアプリのコードから分離して、ロードしたりリリースしたりできるようにする基本的なサンプルになります
サンプル
ストーリーが必要とするアプリで、複数の情報を持ちたい場合のサンプルになります
ストーリーのタイトルとそれの説明用の文章をセットにして管理したいとします
また、そのデータの入力はプログラマでなくてもできるようにします
シーン
スクリプタブルオブジェクトを作成し、アウトレット接続しています
data:image/s3,"s3://crabby-images/d211c/d211c415030964c971f19be98c0d88e1518fb059" alt=""
スクリプタブルオブジェクト
データを作るためのコード
タイトルと、そのストーリーをクラスにしたものをリストにしています
using System;
using System.Collections.Generic;
using UnityEngine;
[CreateAssetMenu(menuName = "StoryData")]
public class StoryScriptable : ScriptableObject
{
[Serializable]
public class Storys
{
public string Title;
[TextArea(1, 5)]
public string Story;
}
public List<Storys> storys;
}
データの作成
上記、リスト(タイトルとストーリーのセット)を実際に入力していくためのスクリプタブルオブジェクトを作成します
プロジェクトウィンドウを右クリックしてCreate → StoryDataで作成します
ファイル名は、CaveStoryとしました
data:image/s3,"s3://crabby-images/723d8/723d8445b228e308bf3ab1d8dbd57401317cc282" alt=""
作成したスクリプタブルオブジェクトにデータを入力
プロジェクトウィンドウで作成したCaveStoryを選択し、データを入力していきます
Addressableを使いますので、チェックを入れます
新しく入力するときは、+の記号を押下します
data:image/s3,"s3://crabby-images/c9efa/c9efab8851da010f5ac72086132b5ff944e93f06" alt=""
実行用のコード
Addressablesを読み込むコードを記述します
今回はコンソール画面に結果が表示されるようにしました
using UnityEngine;
using UnityEngine.AddressableAssets;
public class DataSet : MonoBehaviour
{
[SerializeField]
AssetReference storyData;
void Start()
{
Addressables.LoadAssetAsync<StoryScriptable>(storyData).Completed += story =>
{
StoryScriptable selStorys = story.Result;
Debug.Log(selStorys.storys[0].Title);
Debug.Log(selStorys.storys[0].Story);
};
}
}
実行結果
それぞれの文字列が表示されるのを確認します
data:image/s3,"s3://crabby-images/15015/150158a177002c4cf46d3134945b38fc014c46c0" alt=""
ディスカッション
コメント一覧
まだ、コメントがありません