YetAnotherUnityMcp
Allows AI agents to inspect and control a running Unity scene, including executing C# code, querying scene hierarchy and object properties, capturing screenshots, modifying GameObjects, and retrieving editor logs.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@YetAnotherUnityMcplist all GameObjects in the scene"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
YetAnotherUnityMcp
A Unity Master Control Protocol (MCP) implementation that allows AI agents to control and interact with Unity.
Overview
YetAnotherUnityMcp is a system that bridges the Unity game engine with AI-driven tools using the Model Context Protocol (MCP). It consists of a Unity .NET/C# plugin acting as the MCP client, and a Python MCP server (built with FastMCP) that handles requests from AI agents. Communication between Unity and the server is done via WebSockets, enabling real-time, bidirectional exchange of JSON messages and image data.
This architecture cleanly separates the game engine concerns from the AI logic, improving scalability and maintainability. The goal is to allow AI agents (e.g. an LLM-based assistant) to inspect and control a running Unity scene in a structured, safe manner.
Key components include:
Unity MCP Plugin (Client) – A C# plugin integrated into the Unity Editor that connects to the MCP server via WebSockets
FastMCP Python Server – A Python application that implements the MCP interface for Unity
MCP Client (AI or External) – The external entity (such as an AI assistant or testing script) that sends MCP requests
What is MCP?
The Model Context Protocol (MCP) is a standardized way for AI models to interact with applications. It separates the concerns of providing context from the LLM interaction itself, allowing for:
Resources: Providing data to LLMs (like Unity scene hierarchies)
Tools: Allowing LLMs to take actions (like executing code in Unity)
Prompts: Defining interaction templates (like how to create GameObjects)
Features
Execute C# code in Unity from AI agents
Query Unity Editor state through MCP resources
Capture screenshots with AI-driven parameters
Get logs and debug information from Unity
Modify GameObject properties with AI assistance
List and navigate GameObject hierarchies
Provide contextual templates through MCP prompts
Real-time communication via WebSockets
Fallback to local command execution when server is unavailable
Getting Started
Server Setup
# Clone the repository
git clone https://github.com/yourusername/YetAnotherUnityMcp.git
cd YetAnotherUnityMcp
# Create and activate a virtual environment using uv
uv venv -p 3.11
source .venv/bin/activate # On Windows: .venv\Scripts\activate
# Install the server with development dependencies
uv pip install -e ".[dev]"
# Run the MCP server for AI integration
python -m server.mcp_server
# Alternatively, run the WebSocket-based server
python -m server.websocket_mcp_serverMCP Integration
# Install FastMCP and tools
uv pip install fastmcp
# Run the server with MCP inspector for debugging
fastmcp dev server/mcp_server.py
# Install in Claude Desktop
fastmcp install server/mcp_server.py --name "Unity Controller"Unity Plugin Setup
Open your Unity project (2020.3 or later)
Import the YetAnotherUnityMcp plugin using one of these methods:
Copy the
plugin/Scriptsfolder to your Unity project's Assets directoryCreate a Unity package and import it
Create a symbolic link for development (Windows PowerShell example):
New-Item -ItemType SymbolicLink -Target "D:\Dev\YetAnotherUnityMcp\plugin" -Path "C:\Users\azrea\My project\Assets\Plugins\YetAnotherUnityMcp"
Add the MCPClient to your scene
Create an empty GameObject
Add the MCPClient component
Configure the server URL (WebSocket URL, e.g., ws://localhost:8000/ws)
Use the MCP Editor Window
Open: Window > MCP Client (standard HTTP-based client)
Or: Window > WebSocket MCP Client (WebSocket-based client)
Connect to the server
Test the various MCP features
Project Structure
YetAnotherUnityMcp/
├── server/ # Python MCP server
│ ├── api/ # API endpoints
│ ├── models/ # Data models
│ ├── main.py # Traditional API server
│ ├── mcp_server.py # MCP server implementation
│ ├── websocket_mcp_server.py # WebSocket-based MCP server
│ └── fastmcp_example.py # Simple FastMCP example
├── plugin/ # Unity C# plugin
│ ├── Scripts/ # Plugin source code
│ │ ├── Editor/ # Editor extensions
│ │ │ ├── Commands/ # Editor command implementations
│ │ │ ├── Models/ # Data models for Editor
│ │ │ └── WebSocket/ # WebSocket implementation
│ │ └── YetAnotherUnityMcp.asmdef # Assembly definition
│ └── README.md # Plugin documentation
└── tests/ # Test suiteMCP Resources and Tools
Resources
unity://info- Basic information about the Unity environmentunity://logs- Editor logs for debuggingunity://scene/{scene_name}- Information about a specific sceneunity://object/{object_id}- Details about a specific GameObject
Tools
execute_code- Run C# code in the Unity Editorscreen_shot_editor- Take screenshots of the Unity Editormodify_object- Change properties of Unity GameObjects
Prompts
create_object- Template for creating new GameObjectsdebug_error- Template for diagnosing Unity errors
Communication Protocol
All communication between the Unity plugin and the Python server uses a WebSocket connection, which allows persistent, low-latency bidirectional messaging. The connection is initiated by the Unity client to the server's WebSocket endpoint (e.g. ws://localhost:8000/ws).
Every message is a JSON object containing at least a message type, a unique ID (to pair requests with responses), and a payload. For more details on the communication protocol, see the Technical Details document.
Development
# Server development
python -m pytest # Run tests
python -m black . # Format code
python -m flake8 # Lint code
python -m mypy . # Type check
python -m pytest tests/test_mcp_server.py # Test MCP integration
# MCP Development
fastmcp dev server/mcp_server.py # Run with MCP Inspector UI
fastmcp dev server/websocket_mcp_server.py # Run WebSocket server with Inspector
# Plugin development
# The Unity plugin can be developed in Unity Editor
# Use the editor window for testingLicense
This project is licensed under the MIT License - see the LICENSE file for details.
For more details on architecture, implementation, and extensibility, see the Technical Details document.
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/unitycoder/YetAnotherUnityMcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server