Skip to content

枚举窗口 - EnumWindow

函数简介

根据指定条件,枚举系统中符合条件的窗口。

接口名称

EnumWindow

DLL调用

long EnumWindow(long ola, long parent, string title, string class_name, int filter);

参数说明

参数名类型说明
ola长整数型OLAPlug对象的指针,由 CreateCOLAPlugInterFace 接口生成。
parent长整数型父窗口句柄,为 0 时获取桌面的子窗口。
title字符串窗口标题,支持模糊匹配。为空字符串则不匹配标题。
class_name字符串窗口类名,支持模糊匹配。为空字符串则不匹配类名。
filter整数型过滤条件,可组合使用(值相加)。

filter 过滤条件

说明
1匹配窗口标题(参数title有效)。
2匹配窗口类名(参数class_name有效)。
4只匹配第一个进程的窗口。
8匹配顶级窗口(所有者窗口为0)。
16匹配可见窗口。

示例

SDK 调用

cpp
#include "OLAPlugServer.h"

OLAPlugServer ola;
std::string result = ola.EnumWindow(0, "记事本", "value", 1 + 8 + 16);
// 返回格式为 "hwnd1,hwnd2,hwnd3"
csharp
using OLAPlug;

var ola = new OLAPlugServer();
string result = ola.EnumWindow(0, "记事本", "value", 1 + 8 + 16);
// 返回格式为 "hwnd1,hwnd2,hwnd3"
python
from OLAPlugServer import OLAPlugServer

ola = OLAPlugServer()
result = ola.EnumWindow(0, "记事本", "value", 1 + 8 + 16)
# 返回格式为 "hwnd1,hwnd2,hwnd3"
java
import com.olaplug.OLAPlugServer;

OLAPlugServer ola = new OLAPlugServer();
String result = ola.EnumWindow(0, "记事本", "value", 1 + 8 + 16);
// 返回格式为 "hwnd1,hwnd2,hwnd3"
cpp
var ola = com("OlaPlug.OlaSoft")
var result = ola.EnumWindow(0, "记事本", "value", 1 + 8 + 16)
// 返回格式为 "hwnd1,hwnd2,hwnd3"
vbscript
Set ola = CreateObject("OlaPlug.OlaSoft")
result = ola.EnumWindow(0, "记事本", "value", 1 + 8 + 16)
' 返回格式为 "hwnd1,hwnd2,hwnd3"
text
.局部变量 ola, OLAPlug
ola.创建 ()
result = ola.EnumWindow(0, “记事本”, “value”, 1 + 8 + 16)
' 返回格式为 "hwnd1,hwnd2,hwnd3"
aardio
import OLAPlugServer;
var ola = OLAPlugServer();
var result = ola.EnumWindow(0, "记事本", "value", 1 + 8 + 16);
// 返回格式为 "hwnd1,hwnd2,hwnd3"
text
变量 ola <类型 = OLAPlugServer>
ola = 新建 OLAPlugServer
文本型 result = ola.EnumWindow(0, "记事本", "value", 1 + 8 + 16)
// 返回格式为 "hwnd1,hwnd2,hwnd3"
cpp
#include "OLAPlugServer.h"

OLAPlugServer ola;
std::string result = ola.EnumWindow(0, "记事本", "value", 1 + 8 + 16);
// 返回格式为 "hwnd1,hwnd2,hwnd3"

原生 DLL 调用

cpp
long instance = CreateCOLAPlugInterFace();
long ptr = EnumWindow(instance, 0, "记事本", "", 1 + 8 + 16);
if (ptr != 0) {
    char buffer[512] = {0};
    GetStringFromPtr(ptr, buffer, sizeof(buffer));
    FreeStringPtr(ptr);
    // 返回格式为 "hwnd1,hwnd2,hwnd3"
}
csharp
using System.Runtime.InteropServices;
using System.Text;

[DllImport("OLAPlug_x64.dll", CallingConvention = CallingConvention.StdCall)]
static extern long CreateCOLAPlugInterFace();
[DllImport("OLAPlug_x64.dll", CallingConvention = CallingConvention.StdCall)]
static extern int GetStringFromPtr(long ptr, StringBuilder lpString, int size);
[DllImport("OLAPlug_x64.dll", CallingConvention = CallingConvention.StdCall)]
static extern int FreeStringPtr(long ptr);
[DllImport("OLAPlug_x64.dll", CallingConvention = CallingConvention.StdCall)]
static extern int GetStringSize(long ptr);
[DllImport("OLAPlug_x64.dll", CallingConvention = CallingConvention.StdCall)]
static extern long EnumWindow(long ola, long parent, string title, string class_name, int filter);

long instance = CreateCOLAPlugInterFace();
long ptr = EnumWindow(instance, 0, "记事本", "", 1 + 8 + 16);
if (ptr != 0) {
    StringBuilder sb = new StringBuilder(GetStringSize(ptr) + 1);
    GetStringFromPtr(ptr, sb, sb.Capacity);
    FreeStringPtr(ptr);
    string result = sb.ToString();
}
python
from ctypes import CDLL, c_int, c_int64, create_string_buffer

ola = CDLL("OLAPlug_x64.dll")
ola.CreateCOLAPlugInterFace.restype = c_int64
instance = ola.CreateCOLAPlugInterFace()
ptr = ola.EnumWindow(instance, 0, "记事本", "", 1 + 8 + 16)
if ptr:
    buf = create_string_buffer(512)
    ola.GetStringFromPtr(ptr, buf, 512)
    ola.FreeStringPtr(ptr)
    result = buf.value.decode("utf-8")

返回值

返回值说明
(返回值)字符串指针地址,包含所有匹配的窗口句柄,格式为 "hwnd1,hwnd2,hwnd3"。未找到返回空字符串。

注意事项

项目说明
释放内存DLL调用返回字符串指针地址,需要调用 FreeStringPtr 接口释放内存。
过滤条件可以组合使用过滤条件可以组合使用,例如 1+8+16 表示匹配标题、顶级窗口和可见窗口。