Control Blender from Claude and other LLMs through the Model Context Protocol
Project description
blendmcp
Control Blender from Claude and other LLMs through the Model Context Protocol (MCP). blendmcp lets an AI assistant inspect and edit your Blender scene: create and transform objects, apply materials, run Python, capture viewport screenshots, and pull in assets from PolyHaven, Sketchfab, Hyper3D, and Hunyuan3D.
Naming: install it as
blendmcp(uvx blendmcporpip install blendmcp). The GitHub repo and the Python import module aremcpblender, and the Blender add-on appears as BlendMCP. The distribution name differs from the import name because PyPI reserves names too close to the originalblender-mcp(this is normal, likepip install pillowthenimport PIL).
This is a telemetry-free fork of blender-mcp by Siddharth Ahuja. Original tutorial video (the setup differs slightly; follow the instructions below).
Quick start
- Install uv.
- Add the server to your MCP client (Claude Desktop, Cursor, or VS Code). Minimal config:
{ "mcpServers": { "blendmcp": { "command": "uvx", "args": ["blendmcp"] } } }
- Install the Blender add-on, then connect:
uv tool install blendmcp blendmcp install-addon
In Blender's 3D View sidebar (pressN), open the BlendMCP tab and click Connect to Claude.
Full details and other clients are in Installation below.
Release notes
blendmcp 1.4.0 (first release of this fork)
- Structured editing tools:
add_primitive,modify_object,set_material,duplicate_object, anddelete_object. These are more reliable than generating raw Python and they return the affected object's bounding box and dimensions so the result is confirmed in one step. batch_editapplies many editing operations in a single round trip, with per-operation results, for bulk changes.get_blender_statusreports the connection state and which integrations are enabled. Call it first if a tool reports a connection problem.execute_blender_codeacceptsreturn_screenshot=Trueto return a viewport image alongside the result, and surfaces the full Python traceback when the code fails so it can be corrected.- The connection reconnects and retries once after a dropped socket, so restarting Blender mid-session no longer breaks the next call.
- The addon ships inside the package, so
blendmcp install-addonkeeps it on the same version as the server (a version handshake warns when it drifts). - Removed the telemetry/data-collection code entirely; this fork sends no usage data.
- See
docs/claude-integration-improvements.mdfor the rationale and the full list of changes.
Inherited from the original blender-mcp
- View screenshots of the Blender viewport to better understand the scene
- Generate 3D models with Hunyuan3D and Hyper3D Rodin
- Search and download Sketchfab models
- Poly Haven asset support (models, textures, HDRIs)
- Run the MCP server on a remote host
Installing a new version (existing users)
- For newcomers, you can go straight to Installation. For existing users, see the points below
- The addon now ships inside the
blendmcppackage, so the server and addon update together. If you installed the server as a uv tool, update both with:uv tool upgrade blendmcp blendmcp install-addon
Then restart Blender.blendmcp install-addon --listshows detected Blender versions;--allinstalls into every one, and--blender-version 4.2targets one. - Prefer manual? Download the latest
src/mcpblender/addon.pyand replace the older one in Blender. - If your MCP client caches the server, remove and re-add it (or restart the client) so it picks up the new version.
get_blender_statusreports the server and addon versions and warns when the addon is out of date.
Features
- Two-way communication: Connect Claude AI to Blender through a socket-based server
- Structured editing tools: Add primitives, transform objects, set materials, duplicate, and delete through dedicated tools that return the affected object's bounding box and dimensions for confirmation
- Object manipulation: Create, modify, and delete 3D objects in Blender
- Material control: Apply and modify materials and colors
- Scene inspection: Get detailed information about the current Blender scene
- Visual feedback: Capture viewport screenshots, including alongside
execute_blender_coderesults - Code execution: Run arbitrary Python code in Blender from Claude
Components
The system consists of two main components:
- Blender Addon (
src/mcpblender/addon.py): A Blender addon that creates a socket server within Blender to receive and execute commands - MCP Server (
src/mcpblender/server.py): A Python server that implements the Model Context Protocol and connects to the Blender addon
Installation
Prerequisites
- Blender 3.0 or newer
- Python 3.10 or newer
- uv package manager:
If you're on Mac, please install uv as
brew install uv
On Windows
powershell -c "irm https://astral.sh/uv/install.ps1 | iex"
and then add uv to the user path in Windows (you may need to restart Claude Desktop after):
$localBin = "$env:USERPROFILE\.local\bin"
$userPath = [Environment]::GetEnvironmentVariable("Path", "User")
[Environment]::SetEnvironmentVariable("Path", "$userPath;$localBin", "User")
Otherwise installation instructions are on their website: Install uv
⚠️ Do not proceed before installing UV
Environment Variables
The following environment variables can be used to configure the Blender connection:
BLENDER_HOST: Host address for Blender socket server (default: "localhost")BLENDER_PORT: Port number for Blender socket server (default: 9876)
Example:
export BLENDER_HOST='host.docker.internal'
export BLENDER_PORT=9876
Claude for Desktop Integration
Watch the setup instruction video (Assuming you have already installed uv)
Go to Claude > Settings > Developer > Edit Config > claude_desktop_config.json to include the following:
{
"mcpServers": {
"blendmcp": {
"command": "uvx",
"args": [
"blendmcp"
]
}
}
}
Cursor integration
For Mac users, go to Settings > MCP and paste the following
- To use as a global server, use "add new global MCP server" button and paste
- To use as a project specific server, create
.cursor/mcp.jsonin the root of the project and paste
{
"mcpServers": {
"blendmcp": {
"command": "uvx",
"args": [
"blendmcp"
]
}
}
}
For Windows users, go to Settings > MCP > Add Server, add a new server with the following settings:
{
"mcpServers": {
"blendmcp": {
"command": "cmd",
"args": [
"/c",
"uvx",
"blendmcp"
]
}
}
}
⚠️ Only run one instance of the MCP server (either on Cursor or Claude Desktop), not both
Visual Studio Code Integration
Prerequisites: Make sure you have Visual Studio Code installed before proceeding.
Installing the Blender Addon
The addon ships inside the blendmcp package, so you can install it with one
command instead of downloading a file. After installing the server as a uv tool:
uv tool install blendmcp # if you have not already
blendmcp install-addon
This copies the addon into your Blender add-ons folder (use --list to see
detected Blender versions, --all for every version, or --blender-version 4.2
for a specific one). Then open Blender, go to Edit > Preferences > Add-ons, and
enable "Interface: BlendMCP". This keeps the addon on the same version as the
server, which matters because newer tools require the matching addon.
Manual install (alternative):
- Download
src/mcpblender/addon.pyfrom this repo - Open Blender
- Go to Edit > Preferences > Add-ons
- Click "Install..." and select the
addon.pyfile - Enable the addon by checking the box next to "Interface: BlendMCP"
Usage
Starting the Connection
- In Blender, go to the 3D View sidebar (press N if not visible)
- Find the "BlendMCP" tab
- Turn on the Poly Haven checkbox if you want assets from their API (optional)
- Click "Connect to Claude"
- Make sure the MCP server is running in your terminal
Using with Claude
Once the config file has been set on Claude, and the addon is running on Blender, you will see a hammer icon with tools for the Blender MCP.
Capabilities
- Get scene and object information
- Add primitives and create, delete, duplicate and modify shapes through dedicated tools that confirm the result
- Apply or create materials for objects
- Execute any Python code in Blender (optionally returning a viewport screenshot)
- Download the right models, assets and HDRIs through Poly Haven
- AI generated 3D models through Hyper3D Rodin
Example Commands
Here are some examples of what you can ask Claude to do:
- "Create a low poly scene in a dungeon, with a dragon guarding a pot of gold" Demo
- "Create a beach vibe using HDRIs, textures, and models like rocks and vegetation from Poly Haven" Demo
- Give a reference image, and create a Blender scene out of it Demo
- "Generate a 3D model of a garden gnome through Hyper3D"
- "Get information about the current scene, and make a threejs sketch from it" Demo
- "Make this car red and metallic"
- "Create a sphere and place it above the cube"
- "Make the lighting like a studio"
- "Point the camera at the scene, and make it isometric"
Hyper3D integration
Hyper3D's free trial key allows you to generate a limited number of models per day. If the daily limit is reached, you can wait for the next day's reset or obtain your own key from hyper3d.ai and fal.ai.
Troubleshooting
- Start here: ask Claude to run
get_blender_status. It reports whether the server can reach Blender, which integrations are enabled, and whether the addon is out of date (with a fix). - Connection issues: Make sure the Blender addon server is running (you clicked "Connect to Claude" in the BlendMCP sidebar) and the MCP server is configured on Claude. Do not run the
uvxcommand yourself in a terminal; the MCP client launches it. Sometimes the first command won't go through but it starts working after that. - Addon out of date: After upgrading the server, run
blendmcp install-addonand restart Blender. Newer tools require the matching addon version. - Timeout errors: Try simplifying your requests or breaking them into smaller steps.
- Poly Haven integration: Claude is sometimes erratic with its behaviour.
- Still stuck?: Restart both Claude and the Blender server.
Technical Details
Communication Protocol
The system uses a simple JSON-based protocol over TCP sockets:
- Commands are sent as JSON objects with a
typeand optionalparams - Responses are JSON objects with a
statusandresultormessage
Limitations & Security Considerations
- The
execute_blender_codetool allows running arbitrary Python code in Blender, which can be powerful but potentially dangerous. Use with caution in production environments. ALWAYS save your work before using it. - Poly Haven requires downloading models, textures, and HDRI images. If you do not want to use it, please turn it off in the checkbox in Blender.
- Complex operations might need to be broken down into smaller steps
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Development
Tests live in tests/ and run outside Blender. Because addon.py imports bpy
(only available inside Blender), tests/conftest.py installs lightweight
stand-ins for bpy, mathutils, and requests so the addon's pure helper
functions can be imported and tested directly.
Install the dev dependencies and run the suite with uv:
uv sync --group dev
uv run pytest
The tests cover the Sketchfab size-normalization geometry helpers in the addon;
the server helpers and tools (color normalization, environment config, the
editing tools, get_blender_status); the connection logic (reconnect-once-and-retry,
code-execution tracebacks, batch edits); and the addon installer (Blender-directory
resolution, install/uninstall, and a guard that the addon version matches the
package).
Credits and disclaimer
This is a third-party integration and not made by Blender. BlendMCP is a fork of blender-mcp by Siddharth Ahuja, maintained by Owen Kent. It keeps the original MIT license and copyright. Unlike upstream, this fork collects no telemetry.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file blendmcp-1.4.1.tar.gz.
File metadata
- Download URL: blendmcp-1.4.1.tar.gz
- Upload date:
- Size: 54.5 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e5e740179e0cc0e3eb77d33cd69dd8d205f9af7a0b90712954868c5d384c99b3
|
|
| MD5 |
6e3d0badae679db0f07e9a873d42461e
|
|
| BLAKE2b-256 |
6d9e9941d83d70596b07e01a2a0f19731438915a318b6d74c6a9b827aaf2f4ef
|
Provenance
The following attestation bundles were made for blendmcp-1.4.1.tar.gz:
Publisher:
publish.yml on owenpkent/mcpblender
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
blendmcp-1.4.1.tar.gz -
Subject digest:
e5e740179e0cc0e3eb77d33cd69dd8d205f9af7a0b90712954868c5d384c99b3 - Sigstore transparency entry: 1828087866
- Sigstore integration time:
-
Permalink:
owenpkent/mcpblender@abd00bca9e24ee4cb35dfcd772fd13f17abf847a -
Branch / Tag:
refs/tags/v1.4.1 - Owner: https://github.com/owenpkent
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@abd00bca9e24ee4cb35dfcd772fd13f17abf847a -
Trigger Event:
release
-
Statement type:
File details
Details for the file blendmcp-1.4.1-py3-none-any.whl.
File metadata
- Download URL: blendmcp-1.4.1-py3-none-any.whl
- Upload date:
- Size: 49.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
dab6699fbd07efc5f3efa952732d291a1d6964c23b3528bdc3feff8939c12de6
|
|
| MD5 |
afa75b3d0b7c0c0976c081028d7b8fc3
|
|
| BLAKE2b-256 |
04bf53bc319915dc53c5c1d7f423d5b28586c88874f4ac81c8763c5064ecd854
|
Provenance
The following attestation bundles were made for blendmcp-1.4.1-py3-none-any.whl:
Publisher:
publish.yml on owenpkent/mcpblender
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
blendmcp-1.4.1-py3-none-any.whl -
Subject digest:
dab6699fbd07efc5f3efa952732d291a1d6964c23b3528bdc3feff8939c12de6 - Sigstore transparency entry: 1828087949
- Sigstore integration time:
-
Permalink:
owenpkent/mcpblender@abd00bca9e24ee4cb35dfcd772fd13f17abf847a -
Branch / Tag:
refs/tags/v1.4.1 - Owner: https://github.com/owenpkent
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@abd00bca9e24ee4cb35dfcd772fd13f17abf847a -
Trigger Event:
release
-
Statement type: