jpskill.com
🛠️ 開発・MCP コミュニティ

unreal-engine-developer

Expert Unreal Engine 5 developer and technical artist for complete game development via agentic coding. Enables AI-driven control of Unreal Editor through MCP, Python scripting, Blueprints, and C++ for level design, asset management, gameplay programming, and visual development.

⚡ おすすめ: コマンド1行でインストール(60秒)

下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。

🍎 Mac / 🐧 Linux
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o unreal-engine-developer.zip https://jpskill.com/download/18273.zip && unzip -o unreal-engine-developer.zip && rm unreal-engine-developer.zip
🪟 Windows (PowerShell)
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/18273.zip -OutFile "$d\unreal-engine-developer.zip"; Expand-Archive "$d\unreal-engine-developer.zip" -DestinationPath $d -Force; ri "$d\unreal-engine-developer.zip"

完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。

💾 手動でダウンロードしたい(コマンドが難しい人向け)
  1. 1. 下の青いボタンを押して unreal-engine-developer.zip をダウンロード
  2. 2. ZIPファイルをダブルクリックで解凍 → unreal-engine-developer フォルダができる
  3. 3. そのフォルダを C:\Users\あなたの名前\.claude\skills\(Win)または ~/.claude/skills/(Mac)へ移動
  4. 4. Claude Code を再起動

⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。

🎯 このSkillでできること

下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。

📦 インストール方法 (3ステップ)

  1. 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
  2. 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
  3. 3. 展開してできたフォルダを、ホームフォルダの .claude/skills/ に置く
    • · macOS / Linux: ~/.claude/skills/
    • · Windows: %USERPROFILE%\.claude\skills\

Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。

詳しい使い方ガイドを見る →
最終更新
2026-05-18
取得日時
2026-05-18
同梱ファイル
1

📖 Skill本文(日本語訳)

※ 原文(英語/中国語)を Gemini で日本語化したものです。Claude 自身は原文を読みます。誤訳がある場合は原文をご確認ください。

Unreal Engine デベロッパー & テクニカルアーティスト

概要

この Skill は、エージェントによるコーディングを通じて、Unreal Engine 5 での完全なゲーム開発を可能にします。以下の専門知識を提供します。

  • MCP Integration - Model Context Protocol を介した Unreal Editor の制御
  • Python Automation - エディタースクリプティングとパイプラインの自動化
  • Blueprint Development - ビジュアルスクリプティングとノードグラフの操作
  • C++ Programming - エンジンの拡張とゲームプレイシステム
  • Technical Art - マテリアル、シェーダー、VFX、およびプロシージャルコンテンツ
  • Level Design - ワールド構築、ライティング、および環境アート

MCP サーバーのセットアップ

オプション 1: runreal/unreal-mcp (推奨 - プラグイン不要)

Unreal の組み込み Python Remote Execution を使用します。完全な Unreal Python API をサポートします。

前提条件:

  • Unreal Engine 5.4 以降
  • Node.js と npx

Unreal Editor のセットアップ:

  1. 編集 → プラグイン → "Python Editor Script Plugin" を有効にする
  2. 編集 → プロジェクト設定 → "Python" を検索 → "Remote Execution" を有効にする
  3. エディターを再起動する

MCP クライアントの設定:

{
  "mcpServers": {
    "unreal": {
      "command": "npx",
      "args": ["-y", "@runreal/unreal-mcp"]
    }
  }
}

利用可能なツール: | Tool | Description | |------|-------------| | editor_run_python | Unreal Editor 内で任意の Python を実行する | | editor_list_assets | すべての Unreal アセットをリスト表示する | | editor_export_asset | アセットをテキストにエクスポートする | | editor_get_asset_info | LOD レベルを含むアセット情報を取得する | | editor_search_assets | 名前/パス/クラスでアセットを検索する | | editor_get_world_outliner | プロパティを持つすべてのアクターを取得する | | editor_create_object | ワールドに新しいアクターを作成する | | editor_update_object | 既存のアクターを更新する | | editor_delete_object | ワールドからアクターを削除する | | editor_console_command | コンソールコマンドを実行する | | editor_take_screenshot | ビューポートのスクリーンショットをキャプチャする | | editor_move_camera | ビューポートカメラを配置する |

オプション 2: chongdashu/unreal-mcp (プラグインベース)

C++ プラグインを介して、より深い Blueprint とノードグラフの制御を提供します。

前提条件:

  • Unreal Engine 5.5 以降
  • Python 3.12 以降
  • uv パッケージマネージャー

インストール:

  1. MCPGameProject/Plugins/UnrealMCP をプロジェクトの Plugins フォルダにコピーする
  2. Visual Studio プロジェクトファイルを生成する
  3. プラグインを使用してプロジェクトをビルドする

MCP クライアントの設定:

{
  "mcpServers": {
    "unrealMCP": {
      "command": "uv",
      "args": [
        "--directory",
        "<path/to/Python>",
        "run",
        "unreal_mcp_server.py"
      ]
    }
  }
}

追加機能:

  • カスタムコンポーネントを持つ Blueprint クラスを作成する
  • コンポーネント (メッシュ、カメラ、ライト) を追加および構成する
  • Blueprint ノードグラフを操作する
  • イベントノード (BeginPlay, Tick) を追加する
  • 関数呼び出しノードを作成し、それらを接続する
  • 型とデフォルトを持つ変数を追加する

Python スクリプティングリファレンス

Unreal で Python を有効にする

  1. 編集 → プラグイン → "Python Editor Script Plugin" を有効にする
  2. 編集 → プラグイン → "Editor Scripting Utilities" を有効にする
  3. エディターを再起動する

Unreal には Python 3.11.8 が埋め込まれています - 個別のインストールは不要です。

コア API パターン

import unreal

# Asset Registry
asset_registry = unreal.AssetRegistryHelpers.get_asset_registry()
assets = asset_registry.get_assets_by_path('/Game/MyFolder', recursive=True)

# Editor Utility
editor_util = unreal.EditorUtilityLibrary()
selected_assets = editor_util.get_selected_assets()

# Actor Operations
world = unreal.EditorLevelLibrary.get_editor_world()
actors = unreal.EditorLevelLibrary.get_all_level_actors()

# Spawn Actor
location = unreal.Vector(0, 0, 100)
rotation = unreal.Rotator(0, 0, 0)
actor = unreal.EditorLevelLibrary.spawn_actor_from_class(
    unreal.StaticMeshActor, location, rotation
)

# Set Properties
actor.set_actor_label('MyActor')
actor.set_actor_location(unreal.Vector(100, 200, 300), False, False)
actor.set_actor_rotation(unreal.Rotator(0, 45, 0), False)

# Static Mesh Component
mesh_component = actor.static_mesh_component
mesh_component.set_static_mesh(
    unreal.load_asset('/Game/Meshes/MyMesh')
)

# Material Assignment
material = unreal.load_asset('/Game/Materials/MyMaterial')
mesh_component.set_material(0, material)

アセット管理

# Create Asset
factory = unreal.MaterialFactoryNew()
asset_tools = unreal.AssetToolsHelpers.get_asset_tools()
new_material = asset_tools.create_asset(
    'M_NewMaterial',
    '/Game/Materials',
    unreal.Material,
    factory
)

# Import Asset
import_task = unreal.AssetImportTask()
import_task.filename = 'C:/path/to/texture.png'
import_task.destination_path = '/Game/Textures'
import_task.automated = True
import_task.save = True
unreal.AssetToolsHelpers.get_asset_tools().import_asset_tasks([import_task])

# Generate LODs for Static Mesh
mesh = unreal.load_asset('/Game/Meshes/MyMesh')
options = unreal.EditorStaticMeshLibrary.generate_lod(mesh, 3)

# Save All
unreal.EditorAssetLibrary.save_loaded_assets([new_material])

レベル操作

# Load Level
unreal.EditorLevelLibrary.load_level('/Game/Maps/MyLevel')

# Save Current Level
unreal.EditorLevelLibrary.save_current_level()

# Get Level Actors by Class
lights = unreal.EditorFilterLibrary.by_class(
    unreal.EditorLevelLibrary.get_all_level_actors(),
    unreal.PointLight
)

# Duplicate Actors
duplicates = unreal.EditorLevelLibrary.duplicate_actors(
    [actor1, actor2],
    to_level_duplicate=False
)

# Delete Actors
unreal.EditorLevelLibrary.destroy_actors([actor])

Python を介した Blueprint の作成


# Create Blueprint
factory = unreal.BlueprintFactory()
factory.set_editor_property('parent_class', unreal.Actor)

asset_tools = unreal.AssetToolsHelpers.get_asset_tools()
blueprint = asset_tools.create_asset(
    'BP_MyActor',
    '/Game/Blueprints',
    unreal.Blueprint,
    factory
)

# Add Component
unreal.BlueprintEditorLibrary.add_component(
    blueprint,
    unreal.StaticMeshComponent
)

# Compile Blueprint
unreal.BlueprintEditorLibrary.compile_blueprint(blueprint)

# Spawn Blueprint Actor
bp_class = unreal.load_c
📜 原文 SKILL.md(Claudeが読む英語/中国語)を展開

Unreal Engine Developer & Technical Artist

Overview

This skill enables complete game development in Unreal Engine 5 through agentic coding. It provides expertise in:

  • MCP Integration - Control Unreal Editor via Model Context Protocol
  • Python Automation - Editor scripting and pipeline automation
  • Blueprint Development - Visual scripting and node graph manipulation
  • C++ Programming - Engine extension and gameplay systems
  • Technical Art - Materials, shaders, VFX, and procedural content
  • Level Design - World building, lighting, and environment art

MCP Server Setup

Option 1: runreal/unreal-mcp (Recommended - No Plugin Required)

Uses Unreal's built-in Python Remote Execution. Supports full Unreal Python API.

Prerequisites:

  • Unreal Engine 5.4+
  • Node.js with npx

Unreal Editor Setup:

  1. Edit → Plugins → Enable "Python Editor Script Plugin"
  2. Edit → Project Settings → Search "Python" → Enable "Remote Execution"
  3. Restart Editor

MCP Client Config:

{
  "mcpServers": {
    "unreal": {
      "command": "npx",
      "args": ["-y", "@runreal/unreal-mcp"]
    }
  }
}

Available Tools: | Tool | Description | |------|-------------| | editor_run_python | Execute any Python within Unreal Editor | | editor_list_assets | List all Unreal assets | | editor_export_asset | Export asset to text | | editor_get_asset_info | Get asset info including LOD levels | | editor_search_assets | Search assets by name/path/class | | editor_get_world_outliner | Get all actors with properties | | editor_create_object | Create new actor in world | | editor_update_object | Update existing actor | | editor_delete_object | Delete actor from world | | editor_console_command | Run console command | | editor_take_screenshot | Capture viewport screenshot | | editor_move_camera | Position viewport camera |

Option 2: chongdashu/unreal-mcp (Plugin-Based)

Provides deeper Blueprint and node graph control via C++ plugin.

Prerequisites:

  • Unreal Engine 5.5+
  • Python 3.12+
  • uv package manager

Installation:

  1. Copy MCPGameProject/Plugins/UnrealMCP to your project's Plugins folder
  2. Generate Visual Studio project files
  3. Build project with plugin

MCP Client Config:

{
  "mcpServers": {
    "unrealMCP": {
      "command": "uv",
      "args": [
        "--directory",
        "<path/to/Python>",
        "run",
        "unreal_mcp_server.py"
      ]
    }
  }
}

Additional Capabilities:

  • Create Blueprint classes with custom components
  • Add and configure components (mesh, camera, light)
  • Manipulate Blueprint node graphs
  • Add event nodes (BeginPlay, Tick)
  • Create function call nodes and connect them
  • Add variables with types and defaults

Python Scripting Reference

Enable Python in Unreal

  1. Edit → Plugins → Enable "Python Editor Script Plugin"
  2. Edit → Plugins → Enable "Editor Scripting Utilities"
  3. Restart Editor

Unreal embeds Python 3.11.8 - no separate installation needed.

Core API Patterns

import unreal

# Asset Registry
asset_registry = unreal.AssetRegistryHelpers.get_asset_registry()
assets = asset_registry.get_assets_by_path('/Game/MyFolder', recursive=True)

# Editor Utility
editor_util = unreal.EditorUtilityLibrary()
selected_assets = editor_util.get_selected_assets()

# Actor Operations
world = unreal.EditorLevelLibrary.get_editor_world()
actors = unreal.EditorLevelLibrary.get_all_level_actors()

# Spawn Actor
location = unreal.Vector(0, 0, 100)
rotation = unreal.Rotator(0, 0, 0)
actor = unreal.EditorLevelLibrary.spawn_actor_from_class(
    unreal.StaticMeshActor, location, rotation
)

# Set Properties
actor.set_actor_label('MyActor')
actor.set_actor_location(unreal.Vector(100, 200, 300), False, False)
actor.set_actor_rotation(unreal.Rotator(0, 45, 0), False)

# Static Mesh Component
mesh_component = actor.static_mesh_component
mesh_component.set_static_mesh(
    unreal.load_asset('/Game/Meshes/MyMesh')
)

# Material Assignment
material = unreal.load_asset('/Game/Materials/MyMaterial')
mesh_component.set_material(0, material)

Asset Management

# Create Asset
factory = unreal.MaterialFactoryNew()
asset_tools = unreal.AssetToolsHelpers.get_asset_tools()
new_material = asset_tools.create_asset(
    'M_NewMaterial',
    '/Game/Materials',
    unreal.Material,
    factory
)

# Import Asset
import_task = unreal.AssetImportTask()
import_task.filename = 'C:/path/to/texture.png'
import_task.destination_path = '/Game/Textures'
import_task.automated = True
import_task.save = True
unreal.AssetToolsHelpers.get_asset_tools().import_asset_tasks([import_task])

# Generate LODs for Static Mesh
mesh = unreal.load_asset('/Game/Meshes/MyMesh')
options = unreal.EditorStaticMeshLibrary.generate_lod(mesh, 3)

# Save All
unreal.EditorAssetLibrary.save_loaded_assets([new_material])

Level Operations

# Load Level
unreal.EditorLevelLibrary.load_level('/Game/Maps/MyLevel')

# Save Current Level
unreal.EditorLevelLibrary.save_current_level()

# Get Level Actors by Class
lights = unreal.EditorFilterLibrary.by_class(
    unreal.EditorLevelLibrary.get_all_level_actors(),
    unreal.PointLight
)

# Duplicate Actors
duplicates = unreal.EditorLevelLibrary.duplicate_actors(
    [actor1, actor2],
    to_level_duplicate=False
)

# Delete Actors
unreal.EditorLevelLibrary.destroy_actors([actor])

Blueprint Creation via Python

# Create Blueprint
factory = unreal.BlueprintFactory()
factory.set_editor_property('parent_class', unreal.Actor)

asset_tools = unreal.AssetToolsHelpers.get_asset_tools()
blueprint = asset_tools.create_asset(
    'BP_MyActor',
    '/Game/Blueprints',
    unreal.Blueprint,
    factory
)

# Add Component
unreal.BlueprintEditorLibrary.add_component(
    blueprint,
    unreal.StaticMeshComponent
)

# Compile Blueprint
unreal.BlueprintEditorLibrary.compile_blueprint(blueprint)

# Spawn Blueprint Actor
bp_class = unreal.load_class(None, '/Game/Blueprints/BP_MyActor.BP_MyActor_C')
actor = unreal.EditorLevelLibrary.spawn_actor_from_class(
    bp_class, unreal.Vector(0,0,0), unreal.Rotator(0,0,0)
)

Editor Utility Widgets

Create custom Editor tools with Python + Blueprints:

# Execute Python from Editor Utility Widget
# Use "Execute Python Command" node in Blueprint

# Example: Batch rename selected assets
import unreal

assets = unreal.EditorUtilityLibrary.get_selected_assets()
for asset in assets:
    old_name = asset.get_name()
    new_name = 'SM_' + old_name  # Add prefix
    unreal.EditorAssetLibrary.rename_asset(
        asset.get_path_name(),
        asset.get_path_name().replace(old_name, new_name)
    )

Coordinate System & Units

Axis Direction Notes
X Forward (Red) Positive = Forward
Y Right (Green) Positive = Right
Z Up (Blue) Positive = Up

Units: 1 Unreal Unit = 1 centimeter

Rotation: Pitch (Y), Yaw (Z), Roll (X) in degrees


Common Workflows

1. Procedural Level Generation

import unreal
import random

def spawn_grid(mesh_path, rows, cols, spacing):
    mesh = unreal.load_asset(mesh_path)
    for x in range(rows):
        for y in range(cols):
            loc = unreal.Vector(x * spacing, y * spacing, 0)
            actor = unreal.EditorLevelLibrary.spawn_actor_from_class(
                unreal.StaticMeshActor, loc, unreal.Rotator(0,0,0)
            )
            actor.static_mesh_component.set_static_mesh(mesh)
            # Random rotation
            actor.set_actor_rotation(
                unreal.Rotator(0, random.uniform(0, 360), 0), False
            )

2. Batch Material Assignment

import unreal

def assign_material_to_selection(material_path):
    material = unreal.load_asset(material_path)
    actors = unreal.EditorLevelLibrary.get_selected_level_actors()

    for actor in actors:
        components = actor.get_components_by_class(unreal.StaticMeshComponent)
        for comp in components:
            for i in range(comp.get_num_materials()):
                comp.set_material(i, material)

3. Export Level Data

import unreal
import json

def export_level_to_json(output_path):
    actors = unreal.EditorLevelLibrary.get_all_level_actors()
    data = []

    for actor in actors:
        actor_data = {
            'name': actor.get_actor_label(),
            'class': actor.get_class().get_name(),
            'location': [
                actor.get_actor_location().x,
                actor.get_actor_location().y,
                actor.get_actor_location().z
            ],
            'rotation': [
                actor.get_actor_rotation().pitch,
                actor.get_actor_rotation().yaw,
                actor.get_actor_rotation().roll
            ]
        }
        data.append(actor_data)

    with open(output_path, 'w') as f:
        json.dump(data, f, indent=2)

Verification Checklist

Before completing any task:

  • [ ] Python scripts execute without errors in Unreal Console
  • [ ] Assets are saved after creation/modification
  • [ ] Blueprint compiles successfully if modified
  • [ ] Level saves after actor changes
  • [ ] MCP connection verified if using remote execution
  • [ ] Screenshots captured for visual verification when relevant

Troubleshooting

MCP Connection Issues

  1. Verify Python Editor Script Plugin is enabled
  2. Verify Remote Execution is enabled in Project Settings
  3. Try bind address 0.0.0.0 instead of 127.0.0.1
  4. Restart Unreal Editor completely
  5. Kill any zombie Node.js processes

Python Script Errors

  1. Check Output Log for Python exceptions
  2. Verify asset paths use /Game/ prefix
  3. Ensure assets are loaded before access
  4. Use unreal.load_asset() or unreal.load_class() as needed

Blueprint Compilation Failures

  1. Check Message Log for BP errors
  2. Verify parent class compatibility
  3. Ensure all required pins are connected
  4. Save and recompile after node changes

Resources