MCP Hub
Back to servers

claude-in-mobile

An MCP server for mobile device automation that allows Claude to control Android devices via ADB and iOS Simulators via simctl using a unified API. It supports UI interactions, screenshots, app management, and system log retrieval through natural language.

Stars
23
Forks
2
Tools
20
Updated
Jan 5, 2026
Validated
Jan 9, 2026

Claude Mobile

MCP server for mobile device automation — Android (via ADB) and iOS Simulator (via simctl). Like Claude in Chrome but for mobile devices.

Control your Android phone, emulator, or iOS Simulator with natural language through Claude.

Features

  • Unified API — Same commands work for both Android and iOS
  • Smart screenshots — Auto-compressed for optimal LLM processing (no more oversized images!)
  • Device logs — Read logcat/system logs with filters for debugging
  • UI interactions — Tap, long press, swipe by coordinates or element text
  • Text input — Type into focused fields
  • App control — Launch, stop, and install apps
  • Platform selection — Explicitly target Android or iOS, or auto-detect

Installation

Claude Code CLI (recommended)

claude mcp add --transport stdio mobile -- npx -y claude-in-mobile

To add globally (available in all projects):

claude mcp add --scope user --transport stdio mobile -- npx -y claude-in-android

From npm

npx claude-in-mobile

From source

git clone https://github.com/AlexGladkov/claude-in-mobile.git
cd claude-in-mobile
npm install
npm run build

Manual configuration

Add to your Claude Code settings (~/.claude.json or project settings):

{
  "mcpServers": {
    "mobile": {
      "command": "npx",
      "args": ["-y", "claude-in-mobile"]
    }
  }
}

Windows

claude mcp add --transport stdio mobile -- cmd /c npx -y claude-in-android

Requirements

Android

  • ADB installed and in PATH
  • Connected Android device (USB debugging enabled) or emulator

iOS

  • macOS with Xcode installed
  • iOS Simulator (no physical device support yet)

Available Tools

ToolAndroidiOSDescription
list_devicesList all connected devices
set_deviceSelect active device
screenshotTake screenshot
tapTap at coordinates or by text
long_pressLong press gesture
swipeSwipe in direction or coordinates
input_textType text
press_keyPress hardware buttons
launch_appLaunch app
stop_appStop app
install_appInstall APK/.app
get_ui⚠️Get UI hierarchy (limited on iOS)
find_elementFind elements by text/id
get_current_activityGet foreground activity
open_urlOpen URL in browser
shellRun shell command
waitWait for duration
get_logsGet device logs (logcat/system log)
clear_logs⚠️Clear log buffer
get_system_infoBattery, memory info

Usage Examples

Just talk to Claude naturally:

"Show me all connected devices"
"Take a screenshot of the Android emulator"
"Take a screenshot on iOS"
"Tap on Settings"
"Swipe down to scroll"
"Type 'hello world' in the search field"
"Press the back button on Android"
"Open Safari on iOS"
"Switch to iOS simulator"
"Run the app on both platforms"

Platform Selection

You can explicitly specify the platform:

"Screenshot on android"     → Uses Android device
"Screenshot on ios"         → Uses iOS simulator
"Screenshot"                → Uses last active device

Or set the active device:

"Use the iPhone 15 simulator"
"Switch to the Android emulator"

How It Works

┌─────────────┐     ┌──────────────────┐     ┌─────────────────┐
│   Claude    │────▶│  Claude Mobile   │────▶│  Android (ADB)  │
│             │     │   MCP Server     │     └─────────────────┘
│             │     │                  │     ┌─────────────────┐
│             │     │                  │────▶│  iOS (simctl)   │
└─────────────┘     └──────────────────┘     └─────────────────┘
  1. Claude sends commands through MCP protocol
  2. Server routes to appropriate platform (ADB or simctl)
  3. Commands execute on your device
  4. Results (screenshots, UI data) return to Claude

License

MIT

Reviews

No reviews yet

Sign in to write a review