API 获取窗口属性详解
窗口属性获取原理
操作系统为每个窗口分配唯一标识(句柄),通过系统 API 可查询窗口的各类属性,不同操作系统(Windows/macOS/Linux)的 API 设计差异较大,本文以 Windows 平台为例说明。

核心步骤说明
获取窗口句柄
// 通过窗口标题获取句柄
[DllImport("user32.dll", SetLastError = true)]
static extern IntPtr FindWindow(string lpClassName, string lpWindowName); 查询窗口信息
// 获取窗口尺寸和位置
[DllImport("user32.dll", SetLastError = true)]
static extern bool GetWindowRect(IntPtr hWnd, out RECT lpRect);
// 获取窗口标题文本
[DllImport("user32.dll", SetLastError = true)]
static extern int GetWindowText(IntPtr hWnd, StringBuilder lpString, int nMaxCount); 解析返回数据
struct RECT { public int Left; public int Top; public int Right; public int Bottom; }
// 示例:获取记事本窗口属性
IntPtr notepadHandle = FindWindow("Notepad", null);
if (notepadHandle != IntPtr.Zero) {
RECT rect; GetWindowRect(notepadHandle, out rect);
StringBuilder title = new StringBuilder(256);
GetWindowText(notepadHandle, title, title.Capacity);
Console.WriteLine($"标题:{title}, 尺寸:{rect.Right-rect.Left}x{rect.Bottom-rect.Top}");
} 常用窗口属性对照表
| 属性类别 | API 函数 | 返回值类型 | 适用场景 |
|---|---|---|---|
| 基础标识 | IsWindowVisible() | 布尔值 | 判断窗口是否可见 |
| IsWindowEnabled() | 布尔值 | 判断窗口是否可操作 | |
| 几何属性 | GetWindowRect() | RECT 结构体 | 获取窗口坐标和尺寸 |
| GetClientRect() | RECT 结构体 | 获取客户区尺寸 | |
| 样式属性 | GetWindowLong() + GWL_STYLE | 整型数值 | 查询窗口样式标志 |
| 文本属性 | GetWindowText() | 字符串 | 获取窗口标题文本 |
| 状态属性 | IsWindowMinimized() | 布尔值 | 判断是否最小化 |
| 父子关系 | GetParent() | 句柄 | 获取父窗口句柄 |
权限与兼容性说明
- 权限要求:查询本进程窗口属性无需特殊权限,跨进程查询需启用
EnablePrivilege - 系统限制:UAC开启时部分系统窗口属性受保护
- 跨平台方案:
- Windows: 使用 User32.dll API
- macOS: 调用
NSWindow接口方法 - Linux(X11): 通过 X11/extensions/Xrender 库
相关问题与解答
Q1:如何判断窗口是否处于最小化状态?
A:可通过检测窗口显示状态:
[DllImport("user32.dll")]
static extern bool IsIconic(IntPtr hWnd);
bool isMinimized = IsIconic(hWnd); Q2:如何批量获取所有顶级窗口的标题?
A:使用枚举窗口配合回调函数:

[DllImport("user32.dll")]
static extern bool EnumWindows(Func<IntPtr, IntPtr, bool> lpEnumFunc, IntPtr lParam);
EnumWindows((hWnd, lParam) => {
StringBuilder title = new StringBuilder(256);
GetWindowText(hWnd, title, title.Capacity);
Console.WriteLine(title);
return true; // 继续枚举
}, Int 以上内容就是解答有关“api 获取窗口属性”的详细内容了,我相信这篇文章可以为您解决一些疑惑,有任何问题欢迎留言反馈,谢谢阅读。
【版权声明】:本站所有内容均来自网络,若无意侵犯到您的权利,请及时与我们联系将尽快删除相关内容!
发表回复