
android adb controller
通过 ADB 命令实现 AI 对 Android 设备的控制。
Repository Info
About This Server
通过 ADB 命令实现 AI 对 Android 设备的控制。
Model Context Protocol (MCP) - This server can be integrated with AI applications to provide additional context and capabilities, enabling enhanced AI interactions and functionality.
Documentation
Android ADB Controller MCP Server
Overview
This MCP server enables AI agents to control Android devices via ADB commands. It provides tools for:
- Listing connected devices
- Executing screen taps
- (Extensible for more ADB commands)
Setup Guide
Prerequisites
- Android device with USB debugging enabled
- ADB installed and working (
adb devicesshould show your device) - Node.js v16+
Installation Steps
- Create MCP Server:
npx @modelcontextprotocol/create-server android-adb-controller
cd android-adb-controller
- Install Dependencies:
npm install adbkit @types/adbkit
- Configure MCP Settings:
Add to
mcp_settings.json:
{
"mcpServers": {
"android-adb": {
"command": "node",
"args": ["android-adb-controller/build/index.js"]
}
}
}
Implementation Details
Key Components
- ADB Client Initialization:
this.adbClient = adb.createClient();
- Command Execution:
private async executeADBCommand(deviceId: string, command: string) {
const device = this.adbClient.getDevice(deviceId);
return await device.shell(command);
}
- Tool Definitions:
list_devices: Lists connected Android devicestap_screen: Executes screen taps at specified coordinates
Troubleshooting Guide
Common Issues & Solutions
- ADB Command Not Found:
- Ensure ADB is installed and in system PATH
- Verify platform-tools are extracted correctly
- Device Not Detected:
- Check USB debugging is enabled
- Verify USB cable connection
- Run
adb devicesto confirm detection
- TypeScript Errors:
Solution: Added proper type definitions in
adbkit.d.ts:
declare module 'adbkit' {
interface Device {
id: string;
type: string;
}
// ... other type definitions
}
- MCP Server Connection Issues:
- Verify server is running (
node build/index.js) - Check MCP settings configuration
Extending Functionality
To add new commands:
- Define new tool in
ListToolsRequestSchema - Implement handler in
CallToolRequestSchema - Add corresponding ADB command execution
Example for text input:
{
name: "input_text",
description: "Input text on device",
inputSchema: {
type: "object",
properties: {
deviceId: { type: "string" },
text: { type: "string" }
}
}
}
Development Workflow
- Make code changes
- Rebuild:
npm run build
- Restart server:
node build/index.js
Architecture
MCP Server (Node.js) ↔ ADB Interface ↔ Android Device
↑
|
AI Control System
Future Improvements
- Add swipe gestures
- Implement screenshot capability
- Add device monitoring
- Support multiple simultaneous devices
Quick Start
Clone the repository
git clone https://github.com/sankhodeep/android-adb-controllerInstall dependencies
cd android-adb-controller
npm installFollow the documentation
Check the repository's README.md file for specific installation and usage instructions.
Repository Details
Recommended MCP Servers
Discord MCP
Enable AI assistants to seamlessly interact with Discord servers, channels, and messages.
Knit MCP
Connect AI agents to 200+ SaaS applications and automate workflows.
Apify MCP Server
Deploy and interact with Apify actors for web scraping and data extraction.
BrowserStack MCP
BrowserStack MCP Server for automated testing across multiple browsers.
Zapier MCP
A Zapier server that provides automation capabilities for various apps.