Skip to main content

MCP server for remote control of napari viewers via Model Context Protocol

Project description

Napari MCP Server

Tests codecov PyPI version Python 3.10+ License: MIT

MCP server for remote control of napari viewers via Model Context Protocol (MCP). Perfect for AI-assisted microscopy analysis with Claude Desktop and other LLM applications.

🚀 Quick Start (3 Steps)

1. Install the Package

pip install napari-mcp

2. Auto-Configure Your AI Application

# For Claude Desktop
napari-mcp-install claude-desktop

# For other applications (Claude Code, Cursor, Cline, etc.)
napari-mcp-install --help  # See all options

3. Restart Your Application & Start Using

Restart your AI app and you're ready! Try asking:

"Can you call session_information() to show my napari session details?"

→ See Full Documentation for detailed guides

🎯 What Can You Do?

Basic Image Analysis

"Load the image from ./data/sample.tif and apply a viridis colormap"
"Create point annotations at coordinates [[100,100], [200,200]]"
"Take a screenshot and save it"

Advanced Workflows

"Execute this code to create a filtered version:
from scipy import ndimage
filtered = ndimage.gaussian_filter(viewer.layers[0].data, sigma=2)
viewer.add_image(filtered, name='filtered')"

"Install scikit-image and segment the cells in this microscopy image"

3D/4D Navigation

"Switch to 3D display mode"
"Navigate to time point 5, Z-slice 10"
"Create a rotating animation of this volume"

Automated Workflows

Want to automate image processing with Python scripts? Use any LLM (OpenAI, Anthropic, etc.) with napari MCP:

→ See Python Integration Examples for batch processing and workflow automation

🤖 Supported AI Applications

Application Command Status
Claude Desktop napari-mcp-install claude-desktop ✅ Full Support
Claude Code napari-mcp-install claude-code ✅ Full Support
Cursor IDE napari-mcp-install cursor ✅ Full Support
Cline (VS Code) napari-mcp-install cline-vscode ✅ Full Support
Cline (Cursor) napari-mcp-install cline-cursor ✅ Full Support
Gemini CLI napari-mcp-install gemini ✅ Full Support
Codex CLI napari-mcp-install codex ✅ Full Support

→ See Integration Guides for application-specific instructions

🛠 Available MCP Tools

The server exposes 20+ tools for complete napari control:

Core Functions

  • Session Management: detect_viewers, init_viewer, close_viewer, session_information
  • Layer Operations: add_image, add_labels, add_points, list_layers, remove_layer
  • Viewer Controls: set_camera, reset_view, set_ndisplay, set_dims_current_step
  • Utilities: screenshot, execute_code, install_packages

→ See API Reference for complete documentation

⚠️ Security Notice

!!! warning "Code Execution Capabilities" This server includes powerful tools that allow arbitrary code execution:

- **`execute_code()`** - Runs Python code in the server environment
- **`install_packages()`** - Installs packages via pip

**Use only with trusted AI assistants on local networks.**
Never expose to public internet without proper sandboxing.

📖 Documentation

🧪 Development Setup

# Clone repository
git clone https://github.com/royerlab/napari-mcp.git
cd napari-mcp

# Install with development dependencies
pip install -e ".[test,dev]"

# Run tests
pytest -m "not realgui"  # Skip GUI tests
pytest --cov=src --cov-report=html  # With coverage

🤝 Contributing

Contributions are welcome! Please:

  1. Fork the repository
  2. Create a feature branch (git checkout -b feature/amazing-feature)
  3. Make your changes with tests
  4. Run pre-commit hooks: pre-commit run --all-files
  5. Commit changes (git commit -m 'Add amazing feature')
  6. Push to branch (git push origin feature/amazing-feature)
  7. Open a Pull Request

📋 Architecture

  • FastMCP Server: Handles MCP protocol communication
  • Napari Integration: Manages viewer lifecycle and operations
  • Qt Event Loop: Asynchronous GUI event processing
  • Tool Layer: Exposes napari functionality as MCP tools
  • External Bridge: Optional connection to existing napari viewers

Key features:

  • Thread-safe: All napari operations are serialized
  • Non-blocking: Qt event loop runs asynchronously
  • Stateful: Maintains viewer state across tool calls
  • Extensible: Easy to add new tools

📚 Resources

📄 License

MIT License - see LICENSE file for details.

🙏 Acknowledgments


Built with ❤️ for the microscopy and AI communities

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

napari_mcp-0.0.4.tar.gz (335.7 kB view details)

Uploaded Source

Built Distribution

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

napari_mcp-0.0.4-py3-none-any.whl (48.0 kB view details)

Uploaded Python 3

File details

Details for the file napari_mcp-0.0.4.tar.gz.

File metadata

  • Download URL: napari_mcp-0.0.4.tar.gz
  • Upload date:
  • Size: 335.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for napari_mcp-0.0.4.tar.gz
Algorithm Hash digest
SHA256 4cf55c9454e018091a66e32471580e8a76065f5b00b16b018607d401b6bb0072
MD5 63692b3c2a5b8c7d6e054ecaf326416b
BLAKE2b-256 cf9d68bb342111e81b47db669ae4f6554b4467c68766986d05b68728e8be2dcf

See more details on using hashes here.

Provenance

The following attestation bundles were made for napari_mcp-0.0.4.tar.gz:

Publisher: release.yml on royerlab/napari-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file napari_mcp-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: napari_mcp-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 48.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for napari_mcp-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 be8cd968b5054f30972c17bd22c5e16a13ccb0fd8edec7403cdc7c6895889ed7
MD5 40cbc9b61503b277a28d1683c8c689d3
BLAKE2b-256 418221755b030e737015bf71268277944cf4949c283fcdd83f65c7181006e70f

See more details on using hashes here.

Provenance

The following attestation bundles were made for napari_mcp-0.0.4-py3-none-any.whl:

Publisher: release.yml on royerlab/napari-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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