AI Assistants Control Unreal Engine with Model Context Protocol (MCP)

This GitHub repository, named "unreal-mcp" by user chongdashu, is an experimental project that enables AI assistant clients like Cursor, Windsurf, and Claude Desktop to control Unreal Engine through natural language using the Model Context Protocol (MCP). The project provides a range of capabilities including actor management, blueprint development, editor control, and more. These capabilities are accessible through natural language commands via AI assistants, allowing for easy automation and control of Unreal Engine workflows.

The project comprises several components: a sample project (MCPGameProject), a plugin (UnrealMCP), and a Python MCP server. The MCPGameProject is based on the Blank Project with the UnrealMCP plugin added. The UnrealMCP plugin is a native TCP server for MCP communication, integrating with Unreal Editor subsystems and implementing actor manipulation tools. The Python MCP server manages TCP socket connections to the C++ plugin, handles command serialization and response parsing, and provides error handling and connection management.

The directory structure includes the example Unreal project, C++ plugin source, plugin source code, plugin definition, Python server and tools, tool modules for actor, editor, and blueprint operations, example scripts and demos, and comprehensive documentation. The quick start guide provides instructions for setting up the project, preparing the project, enabling the plugin, building the plugin, and setting up the Python server.

The project is licensed under the MIT license. For questions, the author can be reached on X/Twitter at @chongdashu.

GitHub - chongdashu/unreal-mcp: Enable AI assistant clients like Cursor, Windsurf and Claude Desktop to control Unreal Engine through natural language using the Model Context Protocol (MCP).

This project enables AI assistant clients like Cursor, Windsurf, and Claude Desktop to control Unreal Engine through natural language using the Model Context Protocol (MCP).

⚠️ Experimental Status

This project is currently in an experimental state. The API, functionality, and implementation details are subject to significant changes. While we encourage testing and feedback, please be aware that:

  • Breaking changes may occur without notice.
  • Features may be incomplete or unstable.
  • Documentation may be outdated or missing.
  • Production use is not recommended at this time.

🌟 Overview

The Unreal MCP integration provides comprehensive tools for controlling Unreal Engine through natural language:

Category Capabilities
Actor Management Create/delete actorsSet actor transformsQuery actor propertiesList all actors in the current level
Blueprint Development Create new Blueprint classes with custom componentsConfigure componentsCompile Blueprints and spawn Blueprint actorsCreate input mappings for player controls
Blueprint Node Graph Add event nodesCreate function call nodes and connect themAdd variables with custom types and default valuesCreate component and self referencesFind and manage nodes in the graph
Editor Control Focus viewport on specific actors or locationsControl viewport camera orientation and distance

All these capabilities are accessible through natural language commands via AI assistants, making it easy to automate and control Unreal Engine workflows.

🧩 Components

Sample Project (MCPGameProject)

  • MCPGameProject: Based off the Blank Project, but with the UnrealMCP plugin added.
  • Plugin (UnrealMCP): MCPGameProject/Plugins/UnrealMCP - Native TCP server for MCP communication Integrates with Unreal Editor subsystemsImplements actor manipulation toolsHandles command execution and response handling
  • Python MCP Server: Python/unreal_mcp_server.py - Manages TCP socket connections to the C++ plugin (port 55557)Handles command serialization and response parsingProvides error handling and connection managementLoads and registers tool modules from the tools directoryUses the FastMCP library to implement the Model Context Protocol

📂 Directory Structure

MCPGameProject/
    - Example Unreal project
    Plugins/UnrealMCP/
        - C++ plugin source
        Source/UnrealMCP/
            - Plugin source code
            UnrealMCP.uplugin - Plugin definition
    Python/
        - Python server and tools
    tools/
        - Tool modules for actor, editor, and blueprint operations
    scripts/
        - Example scripts and demos
    Docs/
        - Comprehensive documentation
    (See Docs/README.md for documentation index)

🚀 Quick Start Guide

Prerequisites:

  • Unreal Engine 5.5+
  • Python 3.12+
  • MCP Client (e.g., Claude Desktop, Cursor, Windsurf)

For getting started quickly, feel free to use the starter project in MCPGameProject. This is a UE 5.5 Blank Starter Project with the UnrealMCP.uplugin already configured.

Prepare the project:

  1. Right-click your .uproject file.
  2. Generate Visual Studio project files.
  3. Build the project (including the plugin).
  4. Open solution (.sln).
  5. Choose Development Editor as your target.
  6. Build Plugin Otherwise, if you want to use the plugin in your existing project:
  7. Copy the plugin to your project.
  8. Copy MCPGameProject/Plugins/UnrealMCP to your project’s Plugins folder.
  9. Enable the plugin - Edit > Plugins Find “UnrealMCP” in Editor category Enable the plugin.
  10. Restart editor when prompted.
  11. Build the plugin.