ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
Primary Data Asset とは
Primary Data Asset (PDA) は UE5 の Asset Manager システムと連携する Data Asset の特殊な形態です。通常の UDataAsset を Blueprint や C++ から直接参照するとHard Reference となりメモリに常駐しますが、PDA は PrimaryAssetId という軽量な ID で参照し、必要時に明示的にロードします。
通常の Data Asset との違い
| 項目 | 通常の Data Asset | Primary Data Asset |
|---|---|---|
| 基底クラス | UDataAsset | UPrimaryDataAsset |
| 参照方法 | Hard Reference (TObjectPtr) / Soft Reference | PrimaryAssetId (FName + Type) |
| ロード | 参照されると自動ロード | 明示的に Load 呼び出し |
| Asset Manager 登録 | 不要 | 必要 |
| 用途 | 少数の固定設定 | 大量のアイテム / キャラ / モンスター定義 |
| メモリ | 参照元が読まれると常駐 | 必要なものだけロード |
C++ で Primary Data Asset を定義
// ItemDataAsset.h
#pragma once
#include "CoreMinimal.h"
#include "Engine/DataAsset.h"
#include "ItemDataAsset.generated.h"
UCLASS(BlueprintType)
class MYGAME_API UItemDataAsset : public UPrimaryDataAsset
{
GENERATED_BODY()
public:
UPROPERTY(EditAnywhere, BlueprintReadOnly, Category = "Item")
FName ItemId;
UPROPERTY(EditAnywhere, BlueprintReadOnly, Category = "Item")
FText DisplayName;
UPROPERTY(EditAnywhere, BlueprintReadOnly, Category = "Item")
TSoftObjectPtr<UTexture2D> Icon;
UPROPERTY(EditAnywhere, BlueprintReadOnly, Category = "Item")
TSoftObjectPtr<UStaticMesh> Mesh;
UPROPERTY(EditAnywhere, BlueprintReadOnly, Category = "Item")
int32 MaxStack = 99;
UPROPERTY(EditAnywhere, BlueprintReadOnly, Category = "Item")
float Weight = 1.0f;
// ★ Asset Manager 用 ID を返す
virtual FPrimaryAssetId GetPrimaryAssetId() const override
{
return FPrimaryAssetId(TEXT("Item"), GetFName());
}
};
Asset Manager にカテゴリを登録
Project Settings → Game → Asset Manager → Primary Asset Types to Scan:
+ Primary Asset Type: Item
Asset Base Class: UItemDataAsset
Has Blueprint Classes: false
Is Editor Only: false
Directories:
- /Game/Items
Specific Assets: (空)
Rules:
Chunk Id: -1
Cook Rule: Always Cook
Apply Recursively: true
これにより /Game/Items 配下の UItemDataAsset 派生アセットが全て自動スキャンされ、FPrimaryAssetId(TEXT("Item"), AssetName) でアクセス可能になります。
実行時に非同期ロード
#include "Engine/AssetManager.h"
void AMyGameMode::LoadItem(FName ItemName)
{
UAssetManager& AM = UAssetManager::Get();
FPrimaryAssetId AssetId(TEXT("Item"), ItemName);
// 非同期ロード開始
FStreamableDelegate Delegate = FStreamableDelegate::CreateLambda([this, AssetId]()
{
UAssetManager& AM = UAssetManager::Get();
UItemDataAsset* Item = Cast<UItemDataAsset>(AM.GetPrimaryAssetObject(AssetId));
if (Item)
{
UE_LOG(LogTemp, Log, TEXT("Loaded: %s"), *Item->DisplayName.ToString());
// 使用処理
}
});
TArray<FName> Bundles; // 必要なら "UI" などのバンドル名
AM.LoadPrimaryAsset(AssetId, Bundles, Delegate);
}
複数の Primary Asset を一括ロード
void AMyGameMode::PreloadAllWeapons()
{
UAssetManager& AM = UAssetManager::Get();
TArray<FPrimaryAssetId> AssetIds;
AM.GetPrimaryAssetIdList(TEXT("Item"), AssetIds);
FStreamableDelegate Delegate = FStreamableDelegate::CreateLambda([]()
{
UE_LOG(LogTemp, Log, TEXT("Bulk load complete"));
});
AM.LoadPrimaryAssets(AssetIds, TArray<FName>(), Delegate);
}
Blueprint からの利用
Blueprint からも Primary Data Asset は扱えます:
- Content Browser で右クリック → Miscellaneous → Data Asset
- 親クラスとして
ItemDataAssetを選択 - 個別のアイテム (Sword.uasset / Potion.uasset 等) を作成
- 各種パラメータを編集
Blueprint ノードで非同期ロード
Async Load Primary Asset (ノード)
Asset: Primary Asset Id (Item.Sword)
Bundles: (empty)
On Loaded → Cast to ItemDataAsset → 使用
サンプル: アイテム図鑑システム
// ItemDatabase.h
UCLASS()
class UItemDatabase : public UGameInstanceSubsystem
{
GENERATED_BODY()
public:
UFUNCTION(BlueprintCallable)
void GetAllItems(TArray<FPrimaryAssetId>& OutIds)
{
UAssetManager::Get().GetPrimaryAssetIdList(TEXT("Item"), OutIds);
}
UFUNCTION(BlueprintCallable)
void LoadItemAsync(FPrimaryAssetId Id, const FOnItemLoaded& Callback)
{
FStreamableDelegate Delegate = FStreamableDelegate::CreateLambda([Id, Callback]()
{
UItemDataAsset* Asset = Cast<UItemDataAsset>(
UAssetManager::Get().GetPrimaryAssetObject(Id));
Callback.ExecuteIfBound(Asset);
});
UAssetManager::Get().LoadPrimaryAsset(Id, TArray<FName>(), Delegate);
}
};
Cook ルール
| Cook Rule | 動作 |
|---|---|
| Always Cook | 常にビルドに含める |
| Development Cook | 開発ビルドのみ |
| Never Cook | ビルドに含めない(デバッグ用) |
| Unknown | 他から参照された場合のみ |
Asset Bundle で部分ロード
UAssetBundleData でテクスチャだけ先読み、メッシュは後でロードのような段階的読み込みが可能:
// AssetBundles メタタグで分類
UPROPERTY(EditAnywhere, AssetBundles="UI")
TSoftObjectPtr<UTexture2D> Icon; // UI バンドル
UPROPERTY(EditAnywhere, AssetBundles="World")
TSoftObjectPtr<UStaticMesh> Mesh; // World バンドル
// ロード時に「UI」バンドルのみ
TArray<FName> Bundles = { TEXT("UI") };
AM.LoadPrimaryAsset(AssetId, Bundles, Delegate);
FAQ
Q: なぜ通常の DataAsset ではなく Primary Data Asset を使う?
A: アイテム数百〜数千の RPG / カードゲームでは、全てを Hard Reference にするとメモリと起動時間が爆発します。PDA で必要なものだけロードしましょう。
Q: Asset Manager で見つからない
A: Project Settings の Asset Manager 設定で Directories が正しいか、Cook Rule が Never Cook になっていないか確認。UAssetManager::Get().ScanPathsSynchronous で手動スキャンも可能。
Q: GetPrimaryAssetId は省略できる?
A: Asset Manager の設定で Asset Base Class が一致すれば自動的に FPrimaryAssetId(ClassName, AssetName) が割り当てられます。明示的にオーバーライドした方が制御しやすい。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- 床の上に乗ったらイベントを発生させる方法
- OverlapAllDynamicとOverlapAllの違い
- タイトル画面を作る方法
- サードパーソンテンプレートでのキャラクター表示の仕組みと非表示にする方法
- ボタンに文字を記載する方法
- Event ActorBeginOverlapとOn Component Begin Overlapの違い
- キャラクターに特定のオブジェクトとの当たり判定を付ける
- 特定のオブジェクトに触れたとき、キャラクターが倒れるようにする
- 動いているオブジェクトに静止しているキャラクターが当たり判定を持たない原因と解決方法
- 「On Component Hit」に「Cast To ~」で複数のクラスを指定する方法
- Blenderファイルをインポートする方法
- 鏡を作成する方法
- レベルブループリントでキャラクターの出現を設定する方法
- サードパーソンテンプレートにおけるキャラクター出現の定義
- アイテムに近づいたらボタンを押してイベントを発火させる方法
- 画面の中央にメッセージを表示する方法
- どこからでも呼び出せるカスタムイベントを作成する方法
- カスタムイベントに引数を追加する方法
- 「Get Overlapping Actors」から特定のクラスの場合のみ処理を実行する方法
- オブジェクトに近づいている間だけメッセージを表示する方法
- PCの画面を操作するUIを作る方法
- コンテンツブラウザに画像を追加する方法
- SetInputMode_UIOnlyを取り消す方法
- 特定の画像の上にマウスカーソルを置いたら手マークにする方法
- オブジェクトがアウトライナーで選択できない原因と解決策
- PlayerStartを作成する方法
- メニュー画面を作成して開く方法
- 「Esc」キーを押してメニュー画面を開く方法
- イベントの「On Clicked」と「On Pressed」の違い
- 「Set Input Mode」の種類と使い方
- 「Set Game Paused」の使い方と詳細解説
- Motion Matchingとは?
- 「GameMode」と「GameModeBase」の違い
- マップに配置したTargetPointを取得する方法
- TargetPointにタグをつけて取得する方法
- Spawnしたインスタンスがイベントを実行する方法
- 特定の時間ごとに処理を実行する方法
- 数値をランダムで出力する方法
- ThirdPersonテンプレートでキャラクターの移動を歩くように変更する方法
- MaxWalkSpeedを変更する方法
- しゃがむ動作を導入する方法
- キャラクターのアニメーションを設定する方法
- 導入済みのプラグインを確認する方法
- Motion Matchingの導入と必要なプラグイン
- プレイヤーを非表示にする方法
- カメラを傾ける角度を制限させる方法
- 配列からランダムに重ならない要素を特定の数取得する方法
- カメラの映す画面に文字やエフェクトを付ける方法
- キャラクターやメッシュを非表示にした際にカメラが移動しなくなる問題の解決方法
- プライマリーデータアセットを活用する方法
- プレイヤーのHPといった変数を定義する最適な場所
- カメラに映った画面をスクリーンショットとして保存する方法
- ゲーム内のカメラ映像を保存して再表示する方法
- HighResShot を使って高解像度の画像を保存する方法(UE5)
- HighResShotで保存した画像のファイル名を取得する方法
- SceneCapture2DとFrameGrabberの画像保存方法の比較
- SceneCapture2Dを使用して画像を保存・取得する方法
- HighResShotとTake High Res Screenshotの違い
- ゲーム終了ボタンを作成する方法
- 「Save Game To Slot」の戻り値がfalseになる問題の解決方法
- 画面上にメッセージを指定された時間表示させる方法
- シェーダコンパイル時間を短縮する方法
- 「Take High Res Screenshot」実行時に「シェーダをコンパイル」に長時間待たされる問題とその解決策
- データベースを活用する方法
- UE5.5がインストールされた環境にUE5.4を追加で導入する方法
- World PartitionとWorld Compositionの違い
- オープンワールドテンプレートとは?
- ポーンをスポーンさせても視点を切り替えない方法
- キャラクター同士がすり抜けてしまう問題の解決方法
- キャラクターの外見を動的に変更
- World Partitionでインスタンスが「アンロード済み」になる問題
- データ アセットとデータ テーブルの違い
- コンポーネントイベントグラフ内で親クラスの変数にアクセスする方
- エディターのソースコードの自動保存の頻度を高める方法
- SpawnActorでSpawn Transform Rotationが反映されない理由
- ミニマップを表示しポーンの位置を反映する方法
- RInterp ToとVInterp Toの違い
- 毎秒実行するイベントの定義方法
- Niagara のエフェクトにコリジョンを持たせる方法
- 「Overlap」と「Hit」の違い
- OverlapはあるがHitがない原因
- Overlapした位置の座標を取得する方法
- ブループリントでレベル間のパラメータを受け渡す方法
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?