CorelDRAW Signage MCP
This MCP server exposes CorelDRAW as a tool server, enabling AI agents to create documents, replace text, manipulate shapes, run preflight checks, and batch-export production files from natural language instructions via COM API.
README
CorelDRAW Signage MCP
Let AI drive CorelDRAW directly via the Model Context Protocol — automated design file generation at scale
Overview
This project exposes CorelDRAW as an MCP (Model Context Protocol) tool server. An AI Agent connects via COM API to create documents, replace text, manipulate shapes, run preflight checks, and batch-export production files — all from natural language instructions.
Key capabilities
- Natural language → CorelDRAW operations, no manual repetition
- Template filling and batch export to PDF / DXF / PNG
- Streamlit Chat UI for local debugging, or connect any MCP-compatible client (Claude Desktop, OpenCode, etc.)
Architecture
┌─────────────────────────────────────────────────┐
│ Designer's machine (Windows) │
│ │
│ ┌──────────────┐ ┌────────────────────┐ │
│ │ AI Agent │─MCP─▶│ MCP Server │ │
│ │ (runner.py) │◀─────│ (FastMCP / HTTP) │ │
│ │ │ │ │ │
│ │ Streamlit │ │ CorelDRAW COM API │ │
│ │ Chat UI │ │ (pywin32) │ │
│ └──────────────┘ └────────┬───────────┘ │
│ │ │
│ ┌───────▼──────┐ │
│ │ CorelDRAW │ │
│ │ (local proc) │ │
│ └──────────────┘ │
└─────────────────────────────────────────────────┘
│ LLM API calls
▼
Company LiteLLM Proxy (planned)
or Anthropic / DeepSeek / Qwen direct
Three-layer structure
| Layer | Component | Description |
|---|---|---|
| Agent | server/agent/runner.py |
LLM tool-call loop; supports Claude / DeepSeek / Qwen |
| MCP tools | server/server.py + server/tools/ |
30+ CorelDRAW tools, HTTP or stdio transport |
| CorelDRAW | server/core/connection.py |
Drives local CorelDRAW via pywin32 COM API |
Tool modules
| Module | Tools | Functionality |
|---|---|---|
document |
7 | Open template, create, save, close, page management |
shapes |
11 | Rectangle / ellipse / line drawing, SVG / image import, boolean ops |
text |
5 | Text replacement, style, overflow detection, convert to curves |
colors |
8 | CMYK / RGB / Pantone fill & stroke, RGB compliance check |
layers |
5 | Create, query, assign, show/hide, lock layers |
export |
7 | PDF / DXF / AI / SVG / PNG export, visual preview, batch export |
preflight |
4 | Size check, text overflow, missing fonts, color report |
data_merge |
3 | Excel data read, barcode / QR code generation |
Requirements
- OS: Windows 10 / 11 (CorelDRAW COM API is Windows-only)
- Python: 3.11+, 64-bit (must match CorelDRAW's bitness)
- CorelDRAW: X6 or later (must be installed and activated; X6 verified compatible)
- LLM API Key: one of Anthropic Claude, DeepSeek, or Alibaba Qwen
Installation
# 1. Clone the repo
git clone <repo-url>
cd coreldraw-signage-mcp
# 2. Create virtual environment
python -m venv .venv
.venv\Scripts\activate
# 3. Install dependencies
pip install -r requirements.txt
# 4. Configure environment variables
copy .env.example .env
# then fill in a real LLM API key
Minimal .env:
# Pick one LLM provider
ANTHROPIC_API_KEY=sk-ant-xxxxx
# MCP Server transport (stdio or streamable-http)
MCP_TRANSPORT=streamable-http
MCP_HOST=127.0.0.1
MCP_PORT=8765
Usage
Option 1 — Streamlit Chat UI (recommended for quick start)
# Make sure CorelDRAW is running first, then:
streamlit run server/app.py
Open http://localhost:8501, enter your API key in the sidebar, and control CorelDRAW with natural language.
Note: The Streamlit UI connects to CorelDRAW directly via COM. Do not run
server.pyat the same time — two simultaneous COM connections can cause conflicts.
Option 2 — Claude Desktop / OpenCode via MCP HTTP
The repo ships a .mcp.json that Claude Desktop and OpenCode auto-discover:
# Start MCP Server in HTTP mode
cd server
MCP_TRANSPORT=streamable-http python server.py
Option 3 — stdio mode (for MCP client integration)
cd server
MCP_TRANSPORT=stdio python server.py
Example prompts
Batch room-number signs
- Place a CDR template (with text placeholders) in
server/templates/ - Prepare an Excel sheet (one sign per row)
- Type:
Batch generate room signs, template: room_template.cdr, data: rooms.xlsx - The agent reads the data, fills the template row by row, runs preflight, and exports PDF + DXF
Single sign, quick output
Create a 300×150 mm room sign, room number 301, department "R&D Center",
background CMYK(0,0,0,80), export print-ready PDF and laser-cut DXF
Directory structure
coreldraw-signage-mcp/
├── server/
│ ├── server.py # MCP Server entry point
│ ├── app.py # Streamlit Web UI
│ ├── agent/
│ │ ├── runner.py # Agent main loop (LLM + tool calls)
│ │ └── prompts.py # System prompt
│ ├── tools/ # MCP tool implementations (30+ tools)
│ ├── core/ # CorelDRAW COM connection & shared models
│ ├── config/ # Settings & template registry
│ └── templates/ # CDR template files
├── docs/ # Architecture docs & diagrams
├── CONTRIBUTING.md
├── LICENSE
├── NOTICE
├── requirements.txt
└── pyproject.toml
Development
# Install dev dependencies
pip install -e ".[dev]"
# Lint
ruff check server/
# End-to-end test (requires CorelDRAW running locally)
cd server
python test_e2e.py
Roadmap
| Phase | Status | Scope |
|---|---|---|
| Phase 1 MVP | ✅ Done | MCP Server + 30+ tools + Agent loop + HTTP transport |
| Phase 2 | In progress | LiteLLM Proxy for unified LLM management; migrate agent orchestration to LangGraph |
| Planned | Architecture drafted | Company dispatch mode: task queue, multi-workstation workers, concurrency lock |
Contributing
See CONTRIBUTING.md. Note: the COM API is Windows-only, so end-to-end testing requires a Windows machine with CorelDRAW installed.
License
Apache 2.0 © 2026 深圳市玄熵智能科技有限责任公司 (Xuanshang Intelligent Technology Co., Ltd., Shenzhen)
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.