
FlaUI 是一个基于微软 UIAutomation 技术的 .NET 库,主要用于对 Windows 应用程序(如 Win32、WinForms、WPF 等)进行自动化 UI 测试。它提供了强大的元素查找和交互功能,支持多种框架,并且易于使用和定制。内部采用异步调用以提高效率,社区也非常活跃。
安装
- 确保已安装 .NET 环境:FlaUI 需要 .NET 支持。
- 添加 NuGet 包:在 Visual Studio 中右击解决方案,选择“管理 NuGet 包”,搜索并安装
FlaUI.Core、FlaUI.UIA2和FlaUI.UIA3。
获取窗体
-
获取主窗体
var app = Application.Launch("notepad.exe"); using (var automation = new UIA3Automation()) { var mainWindow = app.GetMainWindow(automation); } -
获取子窗体
var processes = System.Diagnostics.Process.GetProcessesByName("notepad"); var id = processes.First().Id; var app = FlaUI.Core.Application.Attach(id); var mainWindow = app.GetMainWindow(automation); var childWindow = FindWindowByAllChildren(mainWindow, "子窗体标题"); -
获取所有顶级窗体
var processes = System.Diagnostics.Process.GetProcessesByName("notepad"); var id = processes.First().Id; var app = FlaUI.Core.Application.Attach(id); var windows = app.GetAllTopLevelWindows(automation).ToList(); var mainWindow = FindWindowByAllTopLevelWindows(windows, "主窗体标题"); 获取桌面上的所有窗体 获取元素推荐使用 XPath 获取元素,类似于网页中的 XPath,可以方便地定位界面中的任意元素。例如,
//Document[@Name="文本编辑器"]可以定位到记事本中的文本编辑区域。
元素操作
注意:请在linux环境下测试或生产使用 青鸟内测是一个移动应用分发系统,支持安卓苹果应用上传与下载,并且还能快捷封装网址为应用。应用内测分发:一键上传APP应用包,自动生成下载链接和二维码,方便用户内测下载。应用封装:一键即可生成app,无需写代码,可视化编辑、 直接拖拽组件制作页面的高效平台。工具箱:安卓证书生成、提取UDID、Plist文件在线制作、IOS封装、APP图标在线制作APP分发:
-
点击操作
var button = mainWindow.FindFirstDescendant(cf => cf.ByText("按钮文本")).AsButton(); button.Click(); -
输入文本
var textBox = mainWindow.FindFirstDescendant(cf => cf.ByAutomationId("文本框AutomationId")).AsTextBox(); textBox.Enter("输入的文本"); -
调用方法
var menu = mainWindow.FindFirstDescendant(cf => cf.ByText("菜单文本")).AsMenu(); menu.Invoke(); -
键盘操作
Keyboard.Type("Hello FlaUI"); // 输入字符串 Keyboard.Press(VirtualKeyShort.BACK); // 按下 Backspace 键 Keyboard.Pressing(VirtualKeyShort.CONTROL); // 按下 Ctrl 键 Keyboard.Press(VirtualKeyShort.Key_A); // 按下 A 键 Keyboard.Release(VirtualKeyShort.CONTROL); // 释放 Ctrl 键 Keyboard.TypeSimultaneously(VirtualKeyShort.CONTROL, VirtualKeyShort.KEY_A); // 同时按下 Ctrl 和 A 键 -
鼠标操作
Mouse.Click(button); // 点击按钮 Mouse.HorizontalScroll(40); // 水平滚动 40 个单位 Mouse.VerticalScroll(30); // 垂直滚动 30 个单位
示例 打开记事本并输入文本
// See https://aka.ms/new-console-template for more information
using FlaUI.Core;
using FlaUI.Core.AutomationElements;
using FlaUI.UIA3;
Console.WriteLine("Hello, World!");
var app = Application.Launch("notepad.exe");
using (var automation = new UIA3Automation())
{
var window = app.GetMainWindow(automation);
var textBox = window.FindFirstDescendant(cf => cf.ByAutomationId("15")).AsTextBox();
textBox.Enter("Hello FlaUI");
}
app.Close();









