Enables interaction with Android devices through ADB and Accessibility API, allowing for app navigation, UI interactions (click, swipe, type), and automated QA testing without requiring computer-vision pipelines.
Android-MCP is a lightweight, open-source tool that bridge between AI agents and Android devices. Running as an MCP server, it lets LLM agents perform real-world tasks such as app navigation, UI interaction and automated QA testing without relying on traditional computer-vision pipelines or preprogramed scripts.
https://github.com/user-attachments/assets/cf9a5e4e-b69f-46d4-8487-0f61a7a86d67
✨ Features
Native Android Integration
Interact with UI elements via ADB and the Android Accessibility API: launch apps, tap, swipe, input text, and read view hierarchies.Bring Your Own LLM/VLM
Works with any language model, no fine-tuned CV model or OCR pipeline required.Rich Toolset for Mobile Automation
Pre-built tools for gestures, keystrokes, capture, device state, shell commands execution.Real-Time Interaction
Typical latency between actions (e.g., two taps) ranges 2-4s depending on device specs and load.
Supported Operating Systems
Android 10+
Related MCP server: ADB MCP Server
Installation
📦 Prerequisites
Python 3.10+
UIautomator2
Android 10+ (Emulator/ Android Device)
A computer to run MCP server
🏁 Getting Started
Clone the repository
Install dependencies
Connect to the MCP server
Locate your Claude Desktop configuration file:
Windows:
%APPDATA%\Claude\claude_desktop_config.jsonmacOS:
~/Library/Application Support/Claude/claude_desktop_config.json
Add the following JSON to your Claude Desktop config:
Replace:
path/to/uvwith the actual path to your uv executablepath/to/Android-MCPwith the absolute path to where you have cloned this repo
NOTE: --emulator this is used to run in emulator, remove it to use actual device
Restart the Claude Desktop
Restart your Claude Desktop. You should see "android-mcp" listed as an available integration. That's it, now you're ready to start controlling your Android device with natural language.
For troubleshooting tips (log locations, common ADB issues), see the MCP docs.
🛠️ Available Tools
Claude can access the following tools to interact with Windows:
State-Tool: To understand the state of the device.Click-Tool: Click on the screen at the given coordinates.Long-Click-Tool: Perform long click on the screen at the given coordinates.Type-Tool: Type text on the specified coordinates (optionally clears existing text).Swipe-Tool: Perform swipe from one location to other.Drag-Tool: Drag from one point to another.Press-Tool: To press the keys on the mobile device (Back, Volume Up, ...etc).Wait-Tool: Pause for a defined duration.State-Tool: Combined snapshot of active apps and interactive UI elements.Notification-Tool: To access the notifications seen on the device.Shell-Tool: To execute shell commands on the android device.
⚠️ Caution
Android-MCP can execute arbitrary UI actions on your mobile device. Use it in controlled environments (emulators, test devices) when running untrusted prompts or agents.
🪪 License
This project is licensed under the MIT License. See LICENSE for details.
🤝 Contributing
Contributions are welcome! Please read CONTRIBUTING for dev setup and PR guidelines.
Made with ❤️ by CursorTouch,
developers: Jeomon George, Muhammad Yaseen