ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
全体フロー
UE5 でゲーム中に Esc キーを押すと「PAUSE」「Resume」「Settings」「Quit」のメニューが表示される、よくあるポーズメニュー機能の作り方です。
処理の流れ
1. ゲーム実行中、ユーザーが Esc を押下
2. Enhanced Input Action (IA_OpenMenu) が Trigger 発火
3. Player Controller / Pawn の Blueprint で Bind
4. Pause Menu Widget を生成(Create Widget)
5. Add to Viewport で画面に表示
6. Set Game Paused = true でゲーム停止
7. Set Input Mode = UI Only でゲーム操作を止める
8. Set Show Mouse Cursor = true でマウス表示
[再開]
1. メニュー内 Resume ボタン押下
2. Remove from Parent で Widget 撤去
3. Set Game Paused = false
4. Set Input Mode = Game Only
5. Set Show Mouse Cursor = false
手順1: Enhanced Input の Input Action 作成
UE5.1 以降、Input 周りは Enhanced Input に移行しています(旧 Input は非推奨)。
- Content Browser で右クリック → Input → Input Action を作成、名前を
IA_OpenMenu - 開いて Value Type を
Digital (bool)に設定 - 続けて Input → Input Mapping Context を作成、名前を
IMC_Default IMC_Defaultを開き、+ Mappings でIA_OpenMenuを追加- キーに Escape を指定
- 必要に応じてゲームパッドの Start / Special Right も追加
手順2: Pawn / Player Controller でバインド
BP_PlayerController の Event Graph
[ Event BeginPlay ]
↓
[ Get Player Controller (0) ]
↓
[ Cast To Enhanced Input Local Player Subsystem ]
↓
[ Add Mapping Context (IMC_Default, Priority=0) ]
↓
(バインドは Pawn 側、または Player Controller 側で)
[ Enhanced Input Action IA_OpenMenu (Triggered) ]
↓
[ Open Pause Menu (custom event) ]
C++ で書く場合のスニペット:
// MyPlayerController.h
UCLASS()
class MYGAME_API AMyPlayerController : public APlayerController
{
GENERATED_BODY()
public:
UPROPERTY(EditDefaultsOnly, Category="Input")
TObjectPtr<class UInputMappingContext> DefaultMappingContext;
UPROPERTY(EditDefaultsOnly, Category="Input")
TObjectPtr<class UInputAction> OpenMenuAction;
UPROPERTY(EditDefaultsOnly, Category="UI")
TSubclassOf<class UUserWidget> PauseMenuClass;
protected:
virtual void BeginPlay() override;
virtual void SetupInputComponent() override;
void HandleOpenMenu();
};
// MyPlayerController.cpp
void AMyPlayerController::BeginPlay()
{
Super::BeginPlay();
if (auto* Subsystem = ULocalPlayer::GetSubsystem<UEnhancedInputLocalPlayerSubsystem>(GetLocalPlayer()))
{
Subsystem->AddMappingContext(DefaultMappingContext, 0);
}
}
void AMyPlayerController::SetupInputComponent()
{
Super::SetupInputComponent();
if (auto* EIC = Cast<UEnhancedInputComponent>(InputComponent))
{
EIC->BindAction(OpenMenuAction, ETriggerEvent::Triggered, this, &AMyPlayerController::HandleOpenMenu);
}
}
void AMyPlayerController::HandleOpenMenu()
{
if (PauseMenuClass)
{
UUserWidget* Menu = CreateWidget<UUserWidget>(this, PauseMenuClass);
if (Menu) Menu->AddToViewport();
SetPause(true);
bShowMouseCursor = true;
FInputModeUIOnly Mode;
Mode.SetWidgetToFocus(Menu->TakeWidget());
SetInputMode(Mode);
}
}
手順3: Pause Menu Widget の作成
- Content Browser で右クリック → User Interface → Widget Blueprint、名前
WBP_PauseMenu - Designer タブで Canvas Panel に Vertical Box を配置
- Vertical Box の中に Button を 3 つ追加: Resume / Settings / Quit
- 各 Button の OnClicked イベントを Graph に追加
WBP_PauseMenu のイベント Graph
[ On Clicked (Resume Button) ]
↓
[ Set Game Paused (false) ]
↓
[ Remove from Parent (self) ]
↓
[ Get Player Controller (0) ]
↓
[ Set Show Mouse Cursor (false) ]
↓
[ Set Input Mode Game Only ]
[ On Clicked (Settings Button) ]
↓
[ Create Widget (WBP_Settings) ]
↓
[ Add to Viewport ]
[ On Clicked (Quit Button) ]
↓
[ Quit Game (Player Controller=0, Quit Preference=Quit) ]
手順4: Input Mode と Mouse Cursor
| Input Mode | 動作 |
|---|---|
| Game Only | ゲーム操作のみ、UI フォーカスなし |
| UI Only | UI 操作のみ、ゲーム入力を完全に止める ★ メニュー時 |
| Game and UI | 両方受け付け、HUD のホバー等に |
[ Open Menu ]
- Create Widget WBP_PauseMenu
- Add to Viewport
- Set Game Paused = true
- Set Show Mouse Cursor = true
- Set Input Mode UI Only Ex
In Widget to Focus = WBP_PauseMenu
[ Close Menu ]
- Remove from Parent
- Set Game Paused = false
- Set Show Mouse Cursor = false
- Set Input Mode Game Only
Pause の挙動とフラグ
Set Game Paused は内部的に UGameplayStatics::SetGamePaused を呼びます。これにより:
- すべての Tick が止まる(Pause 中も動かしたい Actor は
bTickEvenWhenPaused = true) - Timer / Animation も停止
- SetTimerByEvent 等もカウント停止
- マルチプレイヤーではクライアント側のみ Pauseされる(サーバは止まらない)
ポーズ中も UI / BGM を動かす
WBP_PauseMenu の Class Defaults
- Is Focusable: true
AudioComponent / UMG Widget で
- Receive Tick While Paused: true
- bTickEvenWhenPaused: true
ButtonHover アニメーション、ループ BGM は通常設定で動くが、
World 内の SoundComponent は止まる。
マルチプレイヤーの場合の制約
| 状況 | 挙動 | 対処 |
|---|---|---|
| クライアントが Pause | 自分のクライアントだけ止まる | 正常動作 |
| サーバが Pause | 全員止まる | シングルプレイ感覚で使うと事故 |
| オンライン対戦中 | Pause せず、UI だけ出すのが慣例 | Set Game Paused 呼ばない |
| 協力プレイ | 全員一致で Pause したい | RPC で全クライアントに Pause 指示 |
FocusWidget でゲームパッド対応
[ Set Input Mode UI Only Ex ]
In Widget to Focus = Resume Button ← 個別 Widget を渡せる
[ Set Keyboard Focus ] on Resume Button
→ ゲームパッドの方向キーでメニュー間移動できる
[ Set Show Mouse Cursor ] = true / false
[ Set Cinematic Mode ] = true でカメラ等を固定する応用
よくあるトラブル
| 症状 | 原因 | 対処 |
|---|---|---|
| Esc キーで PIE が終了する | Editor Preference の Stop on Escape が ON | Project Settings → Level Editor → Play で OFF |
| Esc 押しても何も起きない | Mapping Context 未 Add | BeginPlay で Add Mapping Context |
| メニューは出るが操作できない | Input Mode が Game Only | Set Input Mode UI Only に変更 |
| マウスが見えない | Set Show Mouse Cursor 忘れ | Player Controller の同プロパティを true |
| Resume してもキャラが動かない | Set Game Paused = false 忘れ | Resume 時に明示的に false |
| Widget が二重に出る | Esc を連打で複数生成 | 変数 IsMenuOpen でガード |
ガード処理(多重表示防止)
Player Controller 変数: IsMenuOpen (Boolean)
[ Enhanced Input IA_OpenMenu (Triggered) ]
↓
[ Branch ] ← IsMenuOpen
│ False
↓
[ Open Menu ]
↓
[ Set IsMenuOpen = true ]
メニュー Close 時
↓
[ Set IsMenuOpen = false ]
FAQ
Q: Esc 以外に「P」や Start ボタンでも開きたい
A: IMC_Default の IA_OpenMenu に複数キーを追加できます。Mappings の + ボタンで Escape / P / Generic Gamepad Special Right などを並べるだけ。
Q: メニュー中に BGM だけは続けたい
A: BGM 用の AudioComponent で Receive Tick While Paused を ON、Sound Cue 側で bIgnoreForPause を ON。
Q: 旧 Input (Project Settings → Input) からの移行は?
A: Input Action / Input Mapping Context を新規作成し、Player Controller の SetupInputComponent で Bind します。旧 ActionMapping は非推奨のため新規プロジェクトは Enhanced Input 一択。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 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
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- 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
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 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
コメントを削除してもよろしいでしょうか?