Desktop Window Screenshot MCP
Enables taking screenshots of the entire desktop or specific windows, with automatic clipboard integration and support for Windows, macOS, and Linux.
README
Desktop Window Screenshot MCP
A Model Context Protocol (MCP) Server that provides cross-platform desktop and window screenshot capabilities with automatic clipboard integration.
Built for Amp but compatible with any MCP client.
Features
- 📸 Full desktop screenshots - Capture entire screen
- 🪟 Window targeting - Target specific windows by ID or title
- 📋 Automatic clipboard - Screenshots automatically copied to clipboard
- 🖥️ Cross-platform - Windows, macOS, and Linux support
- 🔍 Window discovery - List all available windows
- 📊 Multiple formats - PNG and JPEG with quality control
- 🎯 MCP integration - Ready for AI coding assistants
Quick Start
Prerequisites
- Node.js 18.0.0 or higher
- npm or yarn
Installation
- Clone the repository:
git clone https://github.com/Kynlos/desktop-window-screenshot-mcp.git
cd desktop-window-screenshot-mcp
- Install dependencies:
npm install
- Build the project:
npm run build
Usage with Amp
Setup in Amp (Recommended)
- Open Amp (VSCode with Amp extension)
- Access MCP Server settings
- Click "Add MCP Server"
- Configure as follows:
Server Name:
Screenshot
Command or URL:
npx
Arguments (whitespace-separated):
tsx "C:\Users\YourUsername\path\to\desktop-window-screenshot-mcp\src\index.ts"
Replace C:\Users\YourUsername\path\to\desktop-window-screenshot-mcp with your actual project path.
Alternative Setup Methods
Method 1 - Using npm start:
Command: npm
Arguments: --prefix "C:\Users\YourUsername\path\to\desktop-window-screenshot-mcp" start
Method 2 - Using built JavaScript:
Command: node
Arguments: "C:\Users\YourUsername\path\to\desktop-window-screenshot-mcp\dist\index.js"
Example Path Configurations
Windows:
C:\Users\john\Documents\desktop-window-screenshot-mcp\src\index.ts
macOS/Linux:
/Users/john/projects/desktop-window-screenshot-mcp/src/index.ts
Usage with Other MCP Clients
Configuration for generic MCP clients:
{
"mcpServers": {
"screenshot": {
"command": "npx",
"args": ["tsx", "/path/to/desktop-window-screenshot-mcp/src/index.ts"]
}
}
}
Available Tools
📸 take_screenshot
Take a screenshot of the entire desktop or specific window.
Parameters:
windowId(optional): Window ID to screenshot (fromlist_windows)format(optional):'png'or'jpg'(default:'png')quality(optional): 1-100 (default: 90, only for JPEG)copyToClipboard(optional): boolean (default:true)
Example:
// Full desktop screenshot
{ "name": "take_screenshot" }
// Specific window screenshot
{ "name": "take_screenshot", "arguments": { "windowId": 12345 } }
🪟 take_window_screenshot
Take a screenshot by searching for a window title.
Parameters:
windowTitle(required): Part of window title to search for (case-insensitive)format(optional):'png'or'jpg'(default:'png')quality(optional): 1-100 (default: 90)
Example:
// Screenshot Notepad window
{ "name": "take_window_screenshot", "arguments": { "windowTitle": "Notepad" } }
// Screenshot browser with specific quality
{
"name": "take_window_screenshot",
"arguments": {
"windowTitle": "Chrome",
"format": "jpg",
"quality": 85
}
}
🔍 list_windows
List all visible windows with their IDs and titles.
Example:
{ "name": "list_windows" }
Returns:
Found 15 visible windows:
- ID: 12345, Title: "Document.txt - Notepad", Process: notepad.exe (PID: 1234)
- ID: 67890, Title: "Google Chrome", Process: chrome.exe (PID: 5678)
...
Platform Support
| Platform | Status | Notes |
|---|---|---|
| Windows | ✅ Full Support | Native Windows APIs, all features |
| macOS | ✅ Full Support | Native macOS APIs, all features |
| Linux | ✅ Full Support | X11/Wayland support, all features |
Development
Local Development
# Run in development mode
npm run dev
# Build for production
npm run build
# Test the server
npm test
Testing
# Basic functionality test
npm test
# Manual testing
node test-server.js
Troubleshooting
Common Issues
"Module not found" errors:
- Ensure you're using the full absolute path in the Arguments field
- Use forward slashes
/instead of backslashes\on Windows if needed - Verify Node.js and npm are installed correctly
"Window not found" errors:
- Use
list_windowsfirst to see available windows - Window titles are case-sensitive for exact matches
- Try partial title matches (e.g., "Notepad" instead of "Document.txt - Notepad")
Permission errors:
- On macOS/Linux: Grant screen recording permissions if prompted
- On Windows: Run as administrator if needed for certain applications
Debug Mode
Enable debug logging by setting environment variable:
DEBUG=1 npm start
Dependencies
@modelcontextprotocol/sdk- MCP protocol implementationscreenshot-desktop- Cross-platform screenshot captureclipboardy- Cross-platform clipboard accessnode-window-manager- Window enumeration and managementnode-screenshots- Advanced window screenshot capabilitiessharp- Image processing and format conversion
Contributing
- Fork the repository
- Create a feature branch:
git checkout -b feature-name - Commit changes:
git commit -am 'Add feature' - Push to branch:
git push origin feature-name - Submit a Pull Request
License
MIT License - see LICENSE file for details.
Author
Kynlo
Built for Amp - The AI-powered coding assistant.
Repository
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.