ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
Unreal Engine 5(UE5)で、ゲーム画面上のボタンなどをマウスカーソルでクリック操作できるUIを作るには、「プレイヤーコントローラーでマウスカーソルを表示」し、「入力モードをゲーム+UI(またはUIのみ)に切り替え」たうえで、ウィジェットをビューポートに追加する、という3つの手順が基本になります。この記事では、ゲーム内のコンピューター端末(PC画面)のようなUIを例に、マウスで操作できるインターフェースを作る流れと、つまずきやすいポイントを解説します。
| この記事の要点 |
|---|
|
前提:ゲーム中はマウスカーソルが「見えない・効かない」のが既定
一般的なゲーム向けのプロジェクトでは、プレイ中はマウスカーソルが非表示で、マウスの動きはカメラやキャラクターの操作などゲーム側の入力として消費されるのが既定の状態です。この状態のままウィジェットを画面に表示しても、カーソルが見えず、ボタンをクリックしてもゲーム側に入力が吸われてUIが反応しない、ということが起こります。
そのため、マウスでUIを操作させたいときは、「カーソルを表示する」設定と、「入力をUIに届ける」設定の2つを意識的に行う必要があります。順番に見ていきましょう。
手順1:マウスカーソルを表示する(Show Mouse Cursor)
マウスカーソルの表示・非表示は、プレイヤーコントローラー(Player Controller)が持つ「Show Mouse Cursor」というブール値で制御します。これをtrueにするとカーソルが表示され、falseにすると非表示になります。
ブループリントでは、「Get Player Controller」でプレイヤーコントローラーを取得し、そこから「Set Show Mouse Cursor」ノードを呼び出して、チェック(true)を入れます。Player Controllerのブループリント内で行う場合は、対象をSelfにすればそのまま設定できます。
// 例:BeginPlayなどでカーソルを表示する(疑似コード) PlayerController = GetPlayerController(0) PlayerController.bShowMouseCursor = true |
カーソルを表示しただけでは、カーソルが見えるようになるだけで、UIへの入力が保証されるわけではありません。次の入力モードの設定と合わせて使うのが基本です。
手順2:入力モードをUIに向ける(Set Input Mode)
「入力モード」は、マウスやキー入力をゲーム側に渡すか、UI(ウィジェット)側に渡すかを決める設定です。プレイヤーコントローラーに対して、主に次のノードで切り替えます。
| ノード | おおまかな挙動 | 主な用途 |
| Set Input Mode Game And UI | 入力をUIとゲームの両方が受け取れる状態にする | ゲーム操作を残しつつUIも触らせたいとき |
| Set Input Mode UI Only | 入力をUIのみに向け、ゲーム操作は基本的に止める | メニューや端末操作に専念させたいとき |
| Set Input Mode Game Only | 入力をゲームのみに向ける | UIを閉じて通常プレイに戻すとき |
「Set Input Mode Game And UI」は、UIのオブジェクトとゲームワールドの両方でマウス入力を受け付けられる状態にするためのノードです。これらのノードには、フォーカスを当てたいウィジェットを指定する入力(In Widget to Focus など)や、カーソルをビューポート内にロックするか・カーソルを表示し続けるかといったオプションが用意されている場合があります。挙動の細部やオプション名はエンジンのバージョンによって異なることがあるため、実際の画面で確認してください。
典型的には、UIを開くタイミングで「Show Mouse Cursor=true」+「Set Input Mode Game And UI(または UI Only)」をセットで実行し、UIを閉じるタイミングで「Show Mouse Cursor=false」+「Set Input Mode Game Only」に戻す、という形にします。
手順3:UIウィジェットを作ってビューポートに表示する
操作対象となるUIは、Widget Blueprint(UMG)で作成します。今回はゲーム内のコンピューター端末のような画面を例にしますが、メニューやインベントリなど、マウスで操作するUI全般に同じ考え方が使えます。
ウィジェットの作成
コンテンツブラウザで新規に「Widget Blueprint」を作成し、分かりやすい名前を付けます(例:「WBP_PCScreen」)。ウィジェットエディタを開き、背景となるImageや、操作用のButton、情報表示用のTextなどを配置して、画面のレイアウトを組み立てます。端末風のUIなら、壁紙にあたる背景画像、アプリを表すパネル、起動ボタン、テキスト表示といった要素を組み合わせるとイメージしやすいでしょう。
画面への表示(Add to Viewport)
作成したウィジェットを画面に出すには、ブループリントで「Create Widget」ノードでウィジェットのインスタンスを生成し、その戻り値(Return Value)を「Add to Viewport」ノードにつなぎます。プレイヤーコントローラーのブループリントや、端末を起動するイベントの中などで実行します。
// UIを開く処理(疑似コード) ScreenWidget = CreateWidget(OwningController, WBP_PCScreen) ScreenWidget.AddToViewport() PlayerController.bShowMouseCursor = true SetInputModeGameAndUI(InWidgetToFocus = ScreenWidget) |
同じウィジェットを何度も生成しないよう、生成したインスタンスは変数に保持しておき、再表示時には使い回す、あるいは閉じるときに「Remove from Parent」でビューポートから取り除く、といった管理をしておくと扱いやすくなります。
手順4:ボタンのクリックを受け取る(On Clicked)
配置したButtonをマウスでクリックしたときの処理は、ボタンの「On Clicked」イベントで受け取ります。ウィジェットエディタでButtonを選択し、詳細パネルのイベント欄から「On Clicked」を追加すると、グラフにイベントノードが生成されます。ここに、ウィンドウの表示切り替えやアプリ起動などの処理をつないでいきます。
端末UIで複数の「ウィンドウ(アプリ画面)」を切り替えたい場合は、各ウィンドウをパネルとして用意し、ボタンの「On Clicked」から「Set Visibility」ノードで表示・非表示を切り替える、といった作りが分かりやすいです。クリックのほかにも、ポインタを乗せたときの「On Hovered」、外したときの「On Unhovered」などのイベントがあり、ボタンの見た目を変化させる演出に使えます。
ゲーム操作とUI操作を切り替える
多くのケースでは、普段はゲームを操作し、特定のキーを押したときだけUIを開いてマウス操作に切り替える、という流れになります。たとえば「端末に近づいて決定キーを押したら端末UIを開く」「閉じるボタンや特定キーでUIを閉じてゲームに戻る」といった具合です。
このとき、UIを開くきっかけのイベントで「カーソル表示+入力モードをGame And UI / UI Only」を実行し、UIを閉じるイベントで「カーソル非表示+入力モードをGame Only」に戻します。入力モードを戻し忘れると、UIを閉じたあともゲーム操作が効かない、という不具合につながりやすいので注意します。
つまずきやすいポイント
| よくある原因と確認ポイント |
|---|
|
よくある質問(FAQ)
Q. ウィジェットを画面に出したのに、ボタンがまったく反応しません。
多くは「入力モード」と「Visibility」のどちらか(または両方)が原因です。まず入力モードが「Game And UI」か「UI Only」になっているかを確認し、次にボタンや、その親パネルのVisibilityが入力を受け付ける設定(Visible など)になっているかを確認してください。さらに、ボタンの上に透明な要素が重なっていないか、ボタンがIs Enabled=falseになっていないかも切り分けポイントになります。
Q. UIを閉じたあと、キャラクターが動かせなくなりました。
UIを開くときに入力モードをUI寄り(UI Only など)にしたまま、閉じるときに「Set Input Mode Game Only」へ戻していない可能性が高いです。UIを閉じる処理に、入力モードをゲームに戻す処理と、必要に応じてカーソルを非表示にする処理をセットで入れてください。
Q. マウスカーソルは出るのに、UIの上以外をクリックするとカーソルが消える・操作が乱れます。
入力モードのオプション(カーソルをビューポート内にロックするか、カーソルを表示し続けるか、マウスをキャプチャするか)の組み合わせによって挙動が変わります。UI操作中はカーソルを表示し続ける・マウスをキャプチャしないといった設定にすると安定しやすくなります。オプション名や既定値はエンジンのバージョンで異なる場合があるため、実際のノードの入力ピンを確認しながら調整してください。
まとめ
UE5でマウス操作のUIを作る要点は、「カーソルを表示する(Show Mouse Cursor)」「入力をUIに向ける(Set Input Mode Game And UI / UI Only)」「ウィジェットをビューポートに追加する」という3点に集約されます。あとはボタンの「On Clicked」などのイベントで処理をつなぎ、ゲーム操作とUI操作を入力モードの切り替えで行き来させれば、ゲーム内の端末画面のようなマウス操作UIも無理なく実装できます。うまく反応しないときは、入力モード・Visibility・重なり順・Is Enabled・Is Focusableを順に確認していくと原因を切り分けやすくなります。各ノードのオプションや既定の挙動はバージョンによって差があるため、不確実な部分は公式ドキュメントやエディタ上の表示で確認することをおすすめします。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
コメントを削除してもよろしいでしょうか?