midscene

GitHub
12.7k 946 中等 1 次阅读 今天MIT语言模型图像开发框架Agent
AI 解读 由 AI 自动生成,仅供参考

Midscene 是一款基于人工智能和视觉驱动的 UI 自动化工具,旨在让跨平台的界面操作变得像自然语言对话一样简单。传统自动化测试往往依赖复杂的元素定位代码,一旦界面微调就容易失效,而 Midscene 通过“看”懂屏幕内容来理解用户意图,直接根据自然语言描述规划并执行操作步骤,从而解决了维护成本高、适配难度大等痛点。

这款工具非常适合开发者、测试工程师以及希望提升工作效率的技术研究人员使用。无论是 Web 网页、Android 手机还是 iOS 设备,甚至自定义接口,Midscene 都能通过 JavaScript SDK 或 YAML 脚本轻松掌控。它支持集成 Puppeteer 和 Playwright 等主流框架,也能通过 Bridge 模式控制桌面浏览器。

其核心技术亮点在于融合了先进的视觉模型(如 UI-TARS),无需预先编写繁琐的选择器,只需告诉它“做什么”,它就能自主完成如填写表单、下单购物或点赞互动等复杂任务。此外,Midscene 还具备数据提取能力,并能与机械臂等硬件结合进行车载测试等前沿探索。如果你正在寻找一种更智能、更灵活的自动化方案,Midscene 值得尝试。

使用场景

某电商测试团队需要在每周版本更新后,快速验证官网、iOS 及 Android 三端的核心购物流程(如搜索、加购、结算)是否正常。

没有 midscene 时

  • 脚本维护成本极高:传统自动化依赖固定的 CSS 选择器或 XPath,一旦前端重构或按钮 ID 变更,所有脚本立即报错,需人工逐行修复。
  • 多端适配困难:Web、iOS 和 Android 需要分别编写和维护三套完全不同的测试代码栈,人力投入重复且分散。
  • 非标准元素识别弱:面对动态加载的弹窗、Canvas 绘图或复杂的自定义组件,传统工具往往无法定位,只能被迫插入大量强制等待或跳过测试。
  • 需求响应滞后:产品经理临时调整交互逻辑后,测试脚本的修改周期长达数天,严重拖慢发布节奏。

使用 midscene 后

  • 自然语言驱动执行:测试人员只需用中文描述“点击加入购物车按钮”或“验证订单总价”,midscene 基于视觉理解自动规划操作,不再依赖易变的代码特征。
  • 一套逻辑通吃多端:相同的自然语言指令可直接复用于 Web、iOS 和 Android 环境,midscene 自动适配不同平台的底层驱动,大幅减少重复工作。
  • 视觉感知精准操作:凭借 AI 视觉能力,midscene 能像人眼一样识别屏幕上的任意元素(包括动态弹窗和非标准控件),显著降低误报率。
  • 敏捷应对变更:当界面布局调整时,只需微调自然语言描述甚至无需修改,midscene 能自适应新界面,将脚本维护时间从几天缩短至几分钟。

midscene 通过“所见即所得”的 AI 视觉自动化,将跨端 UI 测试从繁琐的代码维护中解放出来,实现了真正的敏捷质量保障。

运行环境要求

操作系统
  • Windows
  • macOS
  • Linux
GPU
  • 未说明(支持本地部署开源视觉模型如 UI-TARS、Qwen-VL,具体显存需求取决于所选模型
  • 也可调用云端 API 如 Gemini、Doubao)
内存

未说明

依赖
notes该工具核心为 JavaScript/Node.js 环境。Web 端需安装 Puppeteer 或 Playwright;Android 自动化需配置 ADB 环境;iOS 自动化需配置 WebDriverAgent。若选择本地运行视觉大模型(如 UI-TARS),需自行搭建对应的 AI 推理环境(通常涉及 Python、PyTorch 及 GPU 支持)。
python未说明(主要提供 JavaScript/TypeScript SDK,社区有非官方 Python SDK)
@midscene/web
Puppeteer (可选)
Playwright (可选)
adb (Android 自动化必需)
WebDriverAgent (iOS 自动化必需)
scrcpy (可选,用于 Android 控制)
libnut-core (跨平台键鼠控制)
midscene hero image

快速开始

Midscene.js

Midscene.js

英语 | 简体中文

官方网站: https://midscenejs.com/

web-infra-dev%2Fmidscene | Trendshift

基于人工智能与视觉驱动的跨平台UI自动化工具。

npm版本 Hugging Face模型 下载量 许可证 Discord Twitter Ask DeepWiki.com

📣 Midscene Skills来了!

使用Midscene Skills,结合OpenClaw即可控制任意平台。

展示案例

💡 核心功能

使用自然语言编写自动化脚本

  • 描述你的目标和步骤,Midscene将为你规划并操作用户界面。
  • 支持通过JavaScript SDK或YAML编写自动化脚本。

适用于Web、移动端及任何界面

面向开发者

  • 三种API
    • 交互API:用于与用户界面交互。
    • 数据提取API:从用户界面和DOM中提取数据。
    • 工具API:提供aiAssert()aiLocate()aiWaitFor()等实用函数。
  • MCP:Midscene提供MCP服务,将原子级的Midscene Agent动作封装为MCP工具,使上层智能体能够以自然语言检查和操作UI。文档
  • 高效缓存机制:利用缓存重放脚本,大幅提升执行速度。
  • 调试体验:Midscene.js提供可视化回放报告文件、内置游乐场以及Chrome扩展程序,简化调试流程。这些都是开发者真正需要的工具。

👉 无需代码的快速体验

✨ 由视觉语言模型驱动

Midscene.js完全采用纯视觉路线进行UI操作:元素定位和交互仅基于截图。它支持诸如Qwen3-VLDoubao-1.6-visiongemini-3-proUI-TARS等视觉语言模型。在数据提取和页面理解方面,您仍可根据需要选择是否包含DOM。

  • UI操作完全基于纯视觉定位;已移除DOM提取模式。
  • 可跨Web、移动、桌面甚至<canvas>表面运行。
  • 由于操作时不再使用DOM,大幅减少Token消耗,从而降低成本并加快运行速度。
  • 在需要进行数据提取和页面理解时,仍可选择包含DOM。
  • 提供强大的开源选项,方便自行部署。

更多关于模型策略的信息请参阅。

📄 资源

🤝 社区

🌟 令人惊叹的 Midscene

扩展 Midscene.js 功能的社区项目:

  • midscene-ios - 为 Midscene 提供 iOS 镜像自动化支持
  • midscene-pc - 适用于 Windows、macOS 和 Linux 的 PC 操作设备
  • midscene-pc-docker - 预装 Midscene-PC 服务器的 Docker 镜像
  • Midscene-Python - 用于 Midscene 自动化的 Python SDK
  • midscene-java 由 @Master-Frank 开发 - 用于 Midscene 自动化的 Java SDK
  • midscene-java 由 @alstafeev 开发 - 用于 Midscene 自动化的 Java SDK

📝 致谢

我们衷心感谢以下项目:

  • RsbuildRslib,为我们提供了构建工具。
  • UI-TARS,开源代理模型 UI-TARS。
  • Qwen-VL,开源 VL 模型 Qwen-VL。
  • scrcpyyume-chan,使我们能够通过浏览器控制 Android 设备。
  • appium-adb,提供 adb 的 JavaScript 桥接。
  • appium-webdriveragent,用于通过 JavaScript 操作 XCTest。
  • YADB,一款提升文本输入性能的 yadb 工具。
  • libnut-core,提供跨平台的原生键盘和鼠标控制。
  • Puppeteer,用于浏览器自动化与控制。
  • Playwright,用于浏览器自动化、控制及测试。

📖 引用

如果您在研究或项目中使用了 Midscene.js,请引用如下:

@software{Midscene.js,
  author = {Xiao Zhou, Tao Yu, YiBing Lin},
  title = {Midscene.js:您的 Web、Android、iOS 自动化与测试 AI 操作员。},
  year = {2025},
  publisher = {GitHub},
  url = {https://github.com/web-infra-dev/midscene}
}

✨ 星标历史

星标历史图表

📝 许可证

Midscene.js 采用 MIT 许可证


如果本项目对您有所帮助或启发,请为我们点亮一颗星吧!

版本历史

v1.7.5-beta-20260420075536.02026/04/20
v1.7.5-beta-20260420061332.02026/04/20
v1.7.5-beta-20260420032657.02026/04/20
v1.7.5-beta-20260420031652.02026/04/20
v1.5.62026/03/17
v1.7.42026/04/16
v1.7.32026/04/09
v1.7.22026/04/09
v1.7.12026/04/08
v1.7.02026/04/08
v1.6.42026/04/07
v1.6.32026/04/07
v1.6.22026/04/02
v1.6.12026/04/01
v1.6.02026/03/26
v1.5.82026/03/25
v1.5.72026/03/23
v1.5.52026/03/16
v1.5.42026/03/11
v1.5.32026/03/09

常见问题

相似工具推荐

openclaw

OpenClaw 是一款专为个人打造的本地化 AI 助手,旨在让你在自己的设备上拥有完全可控的智能伙伴。它打破了传统 AI 助手局限于特定网页或应用的束缚,能够直接接入你日常使用的各类通讯渠道,包括微信、WhatsApp、Telegram、Discord、iMessage 等数十种平台。无论你在哪个聊天软件中发送消息,OpenClaw 都能即时响应,甚至支持在 macOS、iOS 和 Android 设备上进行语音交互,并提供实时的画布渲染功能供你操控。 这款工具主要解决了用户对数据隐私、响应速度以及“始终在线”体验的需求。通过将 AI 部署在本地,用户无需依赖云端服务即可享受快速、私密的智能辅助,真正实现了“你的数据,你做主”。其独特的技术亮点在于强大的网关架构,将控制平面与核心助手分离,确保跨平台通信的流畅性与扩展性。 OpenClaw 非常适合希望构建个性化工作流的技术爱好者、开发者,以及注重隐私保护且不愿被单一生态绑定的普通用户。只要具备基础的终端操作能力(支持 macOS、Linux 及 Windows WSL2),即可通过简单的命令行引导完成部署。如果你渴望拥有一个懂你

349.3k|★★★☆☆|2周前
Agent开发框架图像

n8n

n8n 是一款面向技术团队的公平代码(fair-code)工作流自动化平台,旨在让用户在享受低代码快速构建便利的同时,保留编写自定义代码的灵活性。它主要解决了传统自动化工具要么过于封闭难以扩展、要么完全依赖手写代码效率低下的痛点,帮助用户轻松连接 400 多种应用与服务,实现复杂业务流程的自动化。 n8n 特别适合开发者、工程师以及具备一定技术背景的业务人员使用。其核心亮点在于“按需编码”:既可以通过直观的可视化界面拖拽节点搭建流程,也能随时插入 JavaScript 或 Python 代码、调用 npm 包来处理复杂逻辑。此外,n8n 原生集成了基于 LangChain 的 AI 能力,支持用户利用自有数据和模型构建智能体工作流。在部署方面,n8n 提供极高的自由度,支持完全自托管以保障数据隐私和控制权,也提供云端服务选项。凭借活跃的社区生态和数百个现成模板,n8n 让构建强大且可控的自动化系统变得简单高效。

184.7k|★★☆☆☆|今天
数据工具开发框架Agent

AutoGPT

AutoGPT 是一个旨在让每个人都能轻松使用和构建 AI 的强大平台,核心功能是帮助用户创建、部署和管理能够自动执行复杂任务的连续型 AI 智能体。它解决了传统 AI 应用中需要频繁人工干预、难以自动化长流程工作的痛点,让用户只需设定目标,AI 即可自主规划步骤、调用工具并持续运行直至完成任务。 无论是开发者、研究人员,还是希望提升工作效率的普通用户,都能从 AutoGPT 中受益。开发者可利用其低代码界面快速定制专属智能体;研究人员能基于开源架构探索多智能体协作机制;而非技术背景用户也可直接选用预置的智能体模板,立即投入实际工作场景。 AutoGPT 的技术亮点在于其模块化“积木式”工作流设计——用户通过连接功能块即可构建复杂逻辑,每个块负责单一动作,灵活且易于调试。同时,平台支持本地自托管与云端部署两种模式,兼顾数据隐私与使用便捷性。配合完善的文档和一键安装脚本,即使是初次接触的用户也能在几分钟内启动自己的第一个 AI 智能体。AutoGPT 正致力于降低 AI 应用门槛,让人人都能成为 AI 的创造者与受益者。

183.6k|★★★☆☆|今天
Agent语言模型插件

stable-diffusion-webui

stable-diffusion-webui 是一个基于 Gradio 构建的网页版操作界面,旨在让用户能够轻松地在本地运行和使用强大的 Stable Diffusion 图像生成模型。它解决了原始模型依赖命令行、操作门槛高且功能分散的痛点,将复杂的 AI 绘图流程整合进一个直观易用的图形化平台。 无论是希望快速上手的普通创作者、需要精细控制画面细节的设计师,还是想要深入探索模型潜力的开发者与研究人员,都能从中获益。其核心亮点在于极高的功能丰富度:不仅支持文生图、图生图、局部重绘(Inpainting)和外绘(Outpainting)等基础模式,还独创了注意力机制调整、提示词矩阵、负向提示词以及“高清修复”等高级功能。此外,它内置了 GFPGAN 和 CodeFormer 等人脸修复工具,支持多种神经网络放大算法,并允许用户通过插件系统无限扩展能力。即使是显存有限的设备,stable-diffusion-webui 也提供了相应的优化选项,让高质量的 AI 艺术创作变得触手可及。

162.1k|★★★☆☆|2周前
开发框架图像Agent

everything-claude-code

everything-claude-code 是一套专为 AI 编程助手(如 Claude Code、Codex、Cursor 等)打造的高性能优化系统。它不仅仅是一组配置文件,而是一个经过长期实战打磨的完整框架,旨在解决 AI 代理在实际开发中面临的效率低下、记忆丢失、安全隐患及缺乏持续学习能力等核心痛点。 通过引入技能模块化、直觉增强、记忆持久化机制以及内置的安全扫描功能,everything-claude-code 能显著提升 AI 在复杂任务中的表现,帮助开发者构建更稳定、更智能的生产级 AI 代理。其独特的“研究优先”开发理念和针对 Token 消耗的优化策略,使得模型响应更快、成本更低,同时有效防御潜在的攻击向量。 这套工具特别适合软件开发者、AI 研究人员以及希望深度定制 AI 工作流的技术团队使用。无论您是在构建大型代码库,还是需要 AI 协助进行安全审计与自动化测试,everything-claude-code 都能提供强大的底层支持。作为一个曾荣获 Anthropic 黑客大奖的开源项目,它融合了多语言支持与丰富的实战钩子(hooks),让 AI 真正成长为懂上

161.1k|★★☆☆☆|今天
开发框架Agent语言模型

opencode

OpenCode 是一款开源的 AI 编程助手(Coding Agent),旨在像一位智能搭档一样融入您的开发流程。它不仅仅是一个代码补全插件,而是一个能够理解项目上下文、自主规划任务并执行复杂编码操作的智能体。无论是生成全新功能、重构现有代码,还是排查难以定位的 Bug,OpenCode 都能通过自然语言交互高效完成,显著减少开发者在重复性劳动和上下文切换上的时间消耗。 这款工具专为软件开发者、工程师及技术研究人员设计,特别适合希望利用大模型能力来提升编码效率、加速原型开发或处理遗留代码维护的专业人群。其核心亮点在于完全开源的架构,这意味着用户可以审查代码逻辑、自定义行为策略,甚至私有化部署以保障数据安全,彻底打破了传统闭源 AI 助手的“黑盒”限制。 在技术体验上,OpenCode 提供了灵活的终端界面(Terminal UI)和正在测试中的桌面应用程序,支持 macOS、Windows 及 Linux 全平台。它兼容多种包管理工具,安装便捷,并能无缝集成到现有的开发环境中。无论您是追求极致控制权的资深极客,还是渴望提升产出的独立开发者,OpenCode 都提供了一个透明、可信

144.3k|★☆☆☆☆|4天前
Agent插件