Skip to main content

An MCP server for creating svg animations.

Project description

MCP SVG Animator

An MCP server for creating animated SVG diagrams. You can create a diagram from text input, photos of sketches and YAML specifications.

You don't normally need to use YAML; just tell Claude code what you want, upload photos of sketches, and then iterate until you've got what you want.

You can see some sample inputs and outputs on the Demo Page

Features

  • Create and iterate on your requirements using natural language and/or rough diagrams
  • Multiple shape types - circle, rectangle, line, text, path, group
  • Path segments - Build curves with move_to, line_to, cubic_bezier, quadratic_bezier, arc
  • SMIL animations - Animate attributes and transforms
  • Reusable definitions - Define once, use many times
  • Library imports - Share definitions across diagrams
  • Relative positioning - Reference other elements' positions
  • Video export - Record animations to .webm video

Installation

# Clone the repository
git clone https://github.com/romilly/mcp-svg-animator.git
cd mcp-svg-animator

# Create and activate virtual environment
python -m venv venv
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install dependencies
pip install -r requirements.txt

# Install Playwright browsers (for video generation)
playwright install chromium

Usage with Claude Code

Register the MCP server globally:

claude mcp add --scope user svg-animator -- /path/to/venv/bin/python -m mcp_svg_animator

Then in any Claude Code session, ask Claude code to create animations:

"Create an animated SVG of a red circle that pulses"

See docs/usage.md for more details.

MCP Tools

You don't need to explicitly invoke these. Ask Claude code to create the animation you describe, and it will invoke the relevant tools.

Tool Description
create_svg_from_yaml Generate SVG from YAML specification
create_animation_video Record SVG animation to .webm video

Development

# Install test dependencies (after following Installation steps above)
pip install -r requirements-test.txt

# Run tests
pytest

# Type checking
pyright src/

Examples

See the examples/ directory for sample YAML files and generated SVGs:

  • demo.yaml - Basic shapes
  • stick_figure.yaml - Static stick figure
  • stick_figure_waving.yaml - Animated waving
  • curves.yaml - Bezier curves and arcs
  • meeting.yaml - Two figures, one walks to meet the other

Acknowledgments

This project uses the following open source packages:

  • MCP - Model Context Protocol SDK (MIT)
  • Pydantic - Data validation (MIT)
  • drawsvg - SVG generation (MIT)
  • PyYAML - YAML parsing (MIT)
  • Playwright - Video recording (Apache 2.0)

License

MIT

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

mcp_svg_animator-0.1.0.tar.gz (13.9 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_svg_animator-0.1.0-py2.py3-none-any.whl (17.6 kB view details)

Uploaded Python 2Python 3

File details

Details for the file mcp_svg_animator-0.1.0.tar.gz.

File metadata

  • Download URL: mcp_svg_animator-0.1.0.tar.gz
  • Upload date:
  • Size: 13.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for mcp_svg_animator-0.1.0.tar.gz
Algorithm Hash digest
SHA256 6900f0e1abd43b8a2987865a95f1a45332e4cc2efe2a6c1c79cc512c30f36727
MD5 05082c1dac6a8e8e102c932698e294db
BLAKE2b-256 e26dbb864de359c8de6ee1bf0d0b5d8cc9144c6af8cb785afac300d09739f4dc

See more details on using hashes here.

File details

Details for the file mcp_svg_animator-0.1.0-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_svg_animator-0.1.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 a86f1df302cf1e4754e98d2deb6ad46ba813f0d31d6e35bc6d897a9b2bd8344a
MD5 09216820ced00f610c9e5b748368f815
BLAKE2b-256 3e60342fccdb2d3c2f266510176d89cfbf8fb17c841d19cca796c07c07034bac

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page