53.

UE5 スクリーンショット保存 (Scene Capture) 完全ガイド

編集
この記事の要点
  • UE5 で「カメラ映像を画像保存」は SceneCapture2D + RenderTarget + ExportRenderTarget の流れ
  • SceneCapture2D アクタをレベル配置 → UTextureRenderTarget2D アセットを TextureTarget に設定
  • Blueprint Capture Scene ノードで明示キャプチャ、Export Render Target で PNG/EXR 出力
  • HighResShot コンソールコマンドで現在ビューを高解像度キャプチャ(Editor / Game 両対応)
  • 保存先デフォルトは Saved/Screenshots/<Platform>/

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 ノードを使った方法:

  1. Blueprint で Take Screenshot または Take High Res Screenshot ノードを追加
  2. FileName パラメータに保存名を指定 (拡張子なしで OK)
  3. 実行 → 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: アセット準備

  1. Content Browser で右クリック → Texture > Render Target 作成 (名前: RT_Capture)
  2. Render Target を開いて Size X / Y を 1920×1080 等に設定
  3. Render Target Format: RTF_RGBA8 (通常) / RTF_RGBA16f (HDR)

手順2: SceneCapture2D をレベル配置

  1. Place Actors → Scene Capture 2D をドラッグでレベル配置
  2. Inspector で Texture Target に RT_Capture を割当
  3. FOV / Projection / Capture Source を設定
  4. 「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 TypePerspective / Orthographic
Capture SourceFinal Color (LDR) / Scene Color HDR / Depth / Normal など
Capture Every Frame毎フレ撮影(重い)
Capture On Movement動いた時だけ撮影
Show FlagsHUD / Postprocess / Volumetric Fog 等の表示制御
Hidden Actors撮影時だけ非表示にするアクタ
Composite ModeOverwrite / 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: ExportRenderTargetEditorOnly 版もあり。Standalone Game でも動くノードは Export Render Target (BlueprintCallable) を使うこと。

Q: 透過 PNG が欲しい (背景透過)
A: Render Target Format を RGBA、Capture Source を SceneColor (HDR) with Final Color ではなく Alpha 付きに。シーン側で背景を Translucent Mat で抜く必要あり。

編集
Post Share
子ページ

子ページはありません

同階層のページ
  1. 床の上に乗ったらイベントを発生させる方法
  2. OverlapAllDynamicとOverlapAllの違い
  3. タイトル画面を作る方法
  4. サードパーソンテンプレートでのキャラクター表示の仕組みと非表示にする方法
  5. ボタンに文字を記載する方法
  6. Event ActorBeginOverlapとOn Component Begin Overlapの違い
  7. キャラクターに特定のオブジェクトとの当たり判定を付ける
  8. 特定のオブジェクトに触れたとき、キャラクターが倒れるようにする
  9. 動いているオブジェクトに静止しているキャラクターが当たり判定を持たない原因と解決方法
  10. 「On Component Hit」に「Cast To ~」で複数のクラスを指定する方法
  11. Blenderファイルをインポートする方法
  12. 鏡を作成する方法
  13. レベルブループリントでキャラクターの出現を設定する方法
  14. サードパーソンテンプレートにおけるキャラクター出現の定義
  15. アイテムに近づいたらボタンを押してイベントを発火させる方法
  16. 画面の中央にメッセージを表示する方法
  17. どこからでも呼び出せるカスタムイベントを作成する方法
  18. カスタムイベントに引数を追加する方法
  19. 「Get Overlapping Actors」から特定のクラスの場合のみ処理を実行する方法
  20. オブジェクトに近づいている間だけメッセージを表示する方法
  21. PCの画面を操作するUIを作る方法
  22. コンテンツブラウザに画像を追加する方法
  23. SetInputMode_UIOnlyを取り消す方法
  24. 特定の画像の上にマウスカーソルを置いたら手マークにする方法
  25. オブジェクトがアウトライナーで選択できない原因と解決策
  26. PlayerStartを作成する方法
  27. メニュー画面を作成して開く方法
  28. 「Esc」キーを押してメニュー画面を開く方法
  29. イベントの「On Clicked」と「On Pressed」の違い
  30. 「Set Input Mode」の種類と使い方
  31. 「Set Game Paused」の使い方と詳細解説
  32. Motion Matchingとは?
  33. 「GameMode」と「GameModeBase」の違い
  34. マップに配置したTargetPointを取得する方法
  35. TargetPointにタグをつけて取得する方法
  36. Spawnしたインスタンスがイベントを実行する方法
  37. 特定の時間ごとに処理を実行する方法
  38. 数値をランダムで出力する方法
  39. ThirdPersonテンプレートでキャラクターの移動を歩くように変更する方法
  40. MaxWalkSpeedを変更する方法
  41. しゃがむ動作を導入する方法
  42. キャラクターのアニメーションを設定する方法
  43. 導入済みのプラグインを確認する方法
  44. Motion Matchingの導入と必要なプラグイン
  45. プレイヤーを非表示にする方法
  46. カメラを傾ける角度を制限させる方法
  47. 配列からランダムに重ならない要素を特定の数取得する方法
  48. カメラの映す画面に文字やエフェクトを付ける方法
  49. キャラクターやメッシュを非表示にした際にカメラが移動しなくなる問題の解決方法
  50. プライマリーデータアセットを活用する方法
  51. プレイヤーのHPといった変数を定義する最適な場所
  52. カメラに映った画面をスクリーンショットとして保存する方法
  53. ゲーム内のカメラ映像を保存して再表示する方法
  54. HighResShot を使って高解像度の画像を保存する方法(UE5)
  55. HighResShotで保存した画像のファイル名を取得する方法
  56. SceneCapture2DとFrameGrabberの画像保存方法の比較
  57. SceneCapture2Dを使用して画像を保存・取得する方法
  58. HighResShotとTake High Res Screenshotの違い
  59. ゲーム終了ボタンを作成する方法
  60. 「Save Game To Slot」の戻り値がfalseになる問題の解決方法
  61. 画面上にメッセージを指定された時間表示させる方法
  62. シェーダコンパイル時間を短縮する方法
  63. 「Take High Res Screenshot」実行時に「シェーダをコンパイル」に長時間待たされる問題とその解決策
  64. データベースを活用する方法
  65. UE5.5がインストールされた環境にUE5.4を追加で導入する方法
  66. World PartitionとWorld Compositionの違い
  67. オープンワールドテンプレートとは?
  68. ポーンをスポーンさせても視点を切り替えない方法
  69. キャラクター同士がすり抜けてしまう問題の解決方法
  70. キャラクターの外見を動的に変更
  71. World Partitionでインスタンスが「アンロード済み」になる問題
  72. データ アセットとデータ テーブルの違い
  73. コンポーネントイベントグラフ内で親クラスの変数にアクセスする方
  74. エディターのソースコードの自動保存の頻度を高める方法
  75. SpawnActorでSpawn Transform Rotationが反映されない理由
  76. ミニマップを表示しポーンの位置を反映する方法
  77. RInterp ToとVInterp Toの違い
  78. 毎秒実行するイベントの定義方法
  79. Niagara のエフェクトにコリジョンを持たせる方法
  80. 「Overlap」と「Hit」の違い
  81. OverlapはあるがHitがない原因
  82. Overlapした位置の座標を取得する方法
  83. ブループリントでレベル間のパラメータを受け渡す方法

最近更新/作成されたページ