Java调win32,枚举窗口EnumWindows,遍历所有底层窗口(JNA)

直接上代码
添加pom依赖:

		<dependency>
            <groupId>net.java.dev.jna</groupId>
            <artifactId>jna</artifactId>
            <version>5.11.0</version>
        </dependency>
        <dependency>
            <groupId>net.java.dev.jna</groupId>
            <artifactId>jna-platform</artifactId>
            <version>5.11.0</version>
        </dependency>
@Test
    public void testEnumWindows(){
        Pointer pointer = Pointer.createConstant(0);
        //此函数通过将句柄依次传递给应用程序定义的回调函数,枚举屏幕上的所有顶级窗口。枚举窗口将继续,直到枚举最后一个顶级窗口或回调函数返回FALSE。
        User32.INSTANCE.EnumWindows((hWnd,p)->{
            //如果窗口有标题栏,此函数将检索指定窗口标题栏文本的长度(以字符为单位)。如果指定的窗口是控件,则函数将检索控件中文本的长度。
            int length = User32.INSTANCE.GetWindowTextLength(hWnd);
            if(length==0){
                //窗口没有文本
            }else {
                //指向将接收文本的缓冲区的长指针
                char[] lpString = new char[length];
                //指定要复制到缓冲区的最大字符数,包括空字符。如果文本超过此限制,它将被截断。
                int nMaxCount = length + 1;
                //此函数用于将指定窗口标题栏的文本(如果有)复制到缓冲区中。如果指定的窗口是控件,则复制该控件的文本。
                User32.INSTANCE.GetWindowText(hWnd, lpString, nMaxCount);
                System.out.println(String.valueOf(lpString));
            }
            //需要返回true,否则无法遍历下一个窗口
            return true;
        },pointer);
    }
  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
以下是使用Win32 API遍历窗口的所有进程的示例代码: ```c++ #include <windows.h> #include <tchar.h> #include <psapi.h> #include <iostream> using namespace std; BOOL CALLBACK EnumProcessModulesProc(HMODULE hModule, DWORD_PTR dwBaseAddress) { TCHAR szModName[MAX_PATH]; if (GetModuleFileNameEx(GetCurrentProcess(), hModule, szModName, sizeof(szModName) / sizeof(TCHAR))) { wcout << L" " << szModName << endl; } return TRUE; } BOOL CALLBACK EnumWindowsProc(HWND hwnd, LPARAM lParam) { DWORD dwProcessId; GetWindowThreadProcessId(hwnd, &dwProcessId); HANDLE hProcess = OpenProcess(PROCESS_QUERY_INFORMATION | PROCESS_VM_READ, FALSE, dwProcessId); if (hProcess) { TCHAR szProcessName[MAX_PATH]; if (GetModuleBaseName(hProcess, NULL, szProcessName, sizeof(szProcessName) / sizeof(TCHAR))) { wcout << L"Process Name: " << szProcessName << endl; } wcout << L"Process ID: " << dwProcessId << endl; HMODULE hMods[1024]; DWORD cbNeeded; if (EnumProcessModules(hProcess, hMods, sizeof(hMods), &cbNeeded)) { for (int i = 0; i < (cbNeeded / sizeof(HMODULE)); i++) { EnumProcessModulesProc(hMods[i], (DWORD_PTR)hProcess); } } } CloseHandle(hProcess); return TRUE; } int main() { EnumWindows(EnumWindowsProc, NULL); return 0; } ``` 该示例使用两个回函数来完成任务。`EnumWindowsProc`函数遍历所有窗口,并使用`GetWindowThreadProcessId`函数获取每个窗口所属的进程ID。然后,它打开进程句柄,并使用`GetModuleBaseName`函数获取进程名称。最后,它使用`EnumProcessModules`函数枚举进程的所有模块,并用`EnumProcessModulesProc`回函数来获取每个模块的名称。 `EnumProcessModulesProc`函数获取模块的名称,并输出到控制台。 请注意,此示例代码需要链接`psapi.lib`库。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

下一页天空

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值