ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
3 つの方式比較
| 方式 | 用途 | 解像度 | 難易度 |
|---|---|---|---|
| HighResShot コマンド | 編集中のスクショ・ゲーム実行中 | 任意倍率 | ★ |
| Take Screenshot (BP / C++) | ゲーム内ボタン → 撮影 | 画面解像度 | ★★ |
| SceneCapture2D + RenderTarget | 任意カメラ視点・ミニマップ・サムネ生成 | RT サイズ任意 | ★★★ |
方式 1: HighResShot コンソールコマンド
最も簡単。Editor の Viewport またはゲーム実行中のコンソール (~ キー) でコマンド入力:
// 倍率指定 (現在解像度 × 倍率)
HighResShot 4 // 4 倍解像度
// 解像度直接指定
HighResShot 3840x2160 // 4K
// 全画面 (HUD 無し)
HighResShot 1920x1080 hud:0
// 保存場所
// プロジェクト/Saved/Screenshots/Windows/HighresScreenshot00000.png
// HUD 無し・ビネット無し
HighResShot 3840x2160 ShowFlag.OnScreenDebug=0
Blueprint からコマンド実行
// Blueprint: Execute Console Command ノード
// Command 引数に "HighResShot 4" を渡す
// または C++ から
UKismetSystemLibrary::ExecuteConsoleCommand(
GetWorld(),
TEXT("HighResShot 3840x2160"),
nullptr
);
方式 2: ゲーム内スクリーンショット (Blueprint)
UE5 標準の Blueprint ノードを使った方法:
- Blueprint で Take Screenshot または Take High Res Screenshot ノードを追加
- FileName パラメータに保存名を指定 (拡張子なしで OK)
- 実行 →
Saved/Screenshots/に PNG 保存
// C++ 版
#include "Engine/GameViewportClient.h"
#include "UnrealClient.h"
void UMyGameInstance::TakeScreenshot(const FString& Filename)
{
FScreenshotRequest::RequestScreenshot(Filename, false, false);
}
// Blueprint Callable で呼べる関数
UFUNCTION(BlueprintCallable, Category = "Screenshot")
void RequestScreenshot();
方式 3: SceneCapture2D + RenderTarget
「メインカメラとは別の視点」を撮りたい場合の本命。ミニマップ・キャラサムネ・セキュリティカメラ表現で多用します。
手順1: アセット準備
- Content Browser で右クリック → Texture > Render Target 作成 (名前: RT_Capture)
- Render Target を開いて Size X / Y を 1920×1080 等に設定
- Render Target Format:
RTF_RGBA8(通常) /RTF_RGBA16f(HDR)
手順2: SceneCapture2D をレベル配置
- Place Actors → Scene Capture 2D をドラッグでレベル配置
- Inspector で Texture Target に RT_Capture を割当
- FOV / Projection / Capture Source を設定
- 「Capture Every Frame」のチェックを必要に応じて操作 (常時撮影 vs 1 回だけ)
手順3: Blueprint で 1 回だけキャプチャして PNG 保存
// CaptureAndSave_BP の擬似コード
// 1. SceneCapture2D の Capture Every Frame を false にしておく
// 2. 撮影タイミングで以下:
// Node: Capture Scene (Target: SceneCapture2D 参照)
// → RenderTarget に 1 フレーム分書き込まれる
// Node: Export Render Target
// Render Target: RT_Capture
// File Path: "C:/Captures/" (絶対パス or プロジェクト相対)
// File Name: "shot_001.png"
// → PNG として保存される
C++ で同等処理
#include "Kismet/KismetRenderingLibrary.h"
#include "Components/SceneCaptureComponent2D.h"
#include "Engine/TextureRenderTarget2D.h"
void AMyCaptureActor::CaptureAndSave()
{
if (!SceneCaptureComp || !RenderTarget) return;
// 1 フレームだけ撮影
SceneCaptureComp->TextureTarget = RenderTarget;
SceneCaptureComp->CaptureScene();
// PNG 出力
FString FilePath = FPaths::ProjectSavedDir() / TEXT("Captures");
FString FileName = TEXT("shot_001.png");
UKismetRenderingLibrary::ExportRenderTarget(
this,
RenderTarget,
FilePath,
FileName
);
}
動的に RenderTarget サイズを変更
// 解像度を変えて再キャプチャ
RenderTarget->ResizeTarget(3840, 2160);
SceneCaptureComp->TextureTarget = RenderTarget;
SceneCaptureComp->CaptureScene();
SceneCapture2D の主要パラメータ
| パラメータ | 説明 |
|---|---|
| FOV Angle | 視野角 (デフォ 90°) |
| Projection Type | Perspective / Orthographic |
| Capture Source | Final Color (LDR) / Scene Color HDR / Depth / Normal など |
| Capture Every Frame | 毎フレ撮影(重い) |
| Capture On Movement | 動いた時だけ撮影 |
| Show Flags | HUD / Postprocess / Volumetric Fog 等の表示制御 |
| Hidden Actors | 撮影時だけ非表示にするアクタ |
| Composite Mode | Overwrite / Additive / Composite |
PNG 以外のフォーマット保存
// EXR (HDR 保存)
UKismetRenderingLibrary::ExportRenderTarget(
this, RT_HDR, SavePath, TEXT("hdr_capture.exr")
);
// バイナリで取得して任意保存
TArray<uint8> Buffer;
UKismetRenderingLibrary::ConvertRenderTargetToTexture2DEditorOnly(
this, RenderTarget, OutTexture
);
// JPG 保存(IImageWrapper 経由)
IImageWrapperModule& ImageWrapperModule = FModuleManager::LoadModuleChecked<IImageWrapperModule>(
FName("ImageWrapper"));
TSharedPtr<IImageWrapper> ImageWrapper = ImageWrapperModule.CreateImageWrapper(EImageFormat::JPEG);
// SetRaw → GetCompressed → SaveArrayToFile
FFileHelper::SaveArrayToFile(JpgData, *FilePath);
サムネイル生成への応用
キャラ選択画面のサムネ、車選択画面の車絵、レベルセレクトのプレビュー画像など、SceneCapture2D + RenderTarget の組み合わせで動的に画像を生成し、Material で UMG (UI) に貼ることで使えます:
// Material: TextureSample に RT_Capture を割当
// UMG Image Widget の Brush の Resource Object に
// その Material インスタンスをセット
// Blueprint で動的に撮影 → UMG に反映
CaptureScene(SceneCapture);
Image->SetBrushFromMaterial(MyMaterialInstance);
保存先パス
| 方法 | デフォルト保存先 |
|---|---|
| HighResShot | <Project>/Saved/Screenshots/Windows/ |
| Take Screenshot | <Project>/Saved/Screenshots/<Platform>/ |
| Export Render Target | 引数で指定したパス(絶対 or プロジェクト相対) |
| FFileHelper::SaveArrayToFile | 任意指定(書き込み権限注意) |
パフォーマンス注意
- SceneCapture2D はシーンを再描画するので非常に重い → 毎フレ撮影は通常 NG
- 解像度 1080p → 4K で負荷 4 倍
- 必要な瞬間だけ
CaptureScene()を呼ぶ - Hidden Actors で関係ないアクタを除外
- Capture Source は Final Color が一番軽い
FAQ
Q: スクショ撮ったら UI も入ってしまう
A: HighResShot 1920x1080 hud:0 で HUD オフ。または Show Flags で UI を切る。SceneCapture2D は元から UMG を含まない。
Q: PIE (Play In Editor) でしか動かない
A: ExportRenderTarget は EditorOnly 版もあり。Standalone Game でも動くノードは Export Render Target (BlueprintCallable) を使うこと。
Q: 透過 PNG が欲しい (背景透過)
A: Render Target Format を RGBA、Capture Source を SceneColor (HDR) with Final Color ではなく Alpha 付きに。シーン側で背景を Translucent Mat で抜く必要あり。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子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
コメントを削除してもよろしいでしょうか?