在Windows Mobile和Wince(Windows Embedded CE)下进行Win32开发,取出窗口句柄的方法

简介:

在上一篇文章讲述了取进程信息的方法,链接如下:

在Windows Mobile和Wince(Windows Embedded CE)下进行Win32开发,取出当前所有运行中进程信息的方法

本文讲述取出进程对应窗口句柄的方法。

 

程序是在上一篇文章的例子上进行修改的。

核心代码如下:

ProcessWndsInfo procInfo;
procInfo.processId = it->th32ProcessID;
if (EnumWindows(EnumWindowsProc, (LPARAM)&procInfo) == FALSE)
{
wprintf(TEXT("EnumWindowsProc Failed. Error: %d\n"),
GetLastError());
continue;
}

通过调用EnumWindows()来取出进程下所有窗口信息。EnumWindows()函数的第一个参数是 回调函数的指针,代码如下:

BOOL CALLBACK EnumWindowsProc(HWND hwnd, LPARAM lParam)
{
ProcessWndsInfo* procInfo = (ProcessWndsInfo*)lParam;
DWORD ProcessId;

GetWindowThreadProcessId ( hwnd, &ProcessId );

if (procInfo != NULL && ProcessId == procInfo->processId)
{
procInfo->windowsHandles.push_back(hwnd);
}

// Keep enumerating
return true;
}

由于EnumWindows()函数轮询所有窗口,每个窗口都会会回调EnumWindowsProc()一次。所以需要判断这个窗口所属进程号。如果属于该进程,就当到list里面。

ProcessWndsInfo的定义如下:

struct ProcessWndsInfo
{
DWORD processId;
std::list<HWND> windowsHandles;
};

包含的进程ID和进程下所有窗口的句柄的list。

 

下面是显示窗口句柄信息的代码。

// Output information for each running process
for( std::list<PROCESSENTRY32>::iterator it=processes.begin();
it!=processes.end(); ++it)
{
wprintf(TEXT("%-*s %8X %13d %9d %9X %10X\n"),
maxProcessNameLength,
it->szExeFile,
it->th32ProcessID,
it->pcPriClassBase,
it->cntThreads,
it->th32MemoryBase,
it->th32AccessKey
);

ProcessWndsInfo procInfo;
procInfo.processId = it->th32ProcessID;
if (EnumWindows(EnumWindowsProc, (LPARAM)&procInfo) == FALSE)
{
wprintf(TEXT("EnumWindowsProc Failed. Error: %d\n"),
GetLastError());
continue;
}

//Output a header to describe the HWnd
wprintf(TEXT("\tHWnd\t\tWindows Title\n"));

WCHAR title[255];
for( std::list<HWND>::iterator itHWnd=procInfo.windowsHandles.begin();
itHWnd!=procInfo.windowsHandles.end(); ++itHWnd)
{
//Get title of the window
GetWindowText(*itHWnd, title, 255);
wprintf(TEXT("\t%10X\t%s\n"), *itHWnd, title);
}
}

为了显示更详细的信息,我把窗口名称一同显示了。效果如下:

Windows-Embedded-CE-HWnd-3

 

源代码:http://files.cnblogs.com/procoder/GetHWnd-without-project-file.rar

由于我在wince下进行开发的,不是通用平台,我把项目文件删掉了,上传源代码,只用于参考。




    本文转自Jake Lin博客园博客,原文链接:http://www.cnblogs.com/procoder/archive/2009/11/19/Windows-Mobile-Native-HWnd.html,如需转载请自行联系原作者


相关文章
|
4月前
|
监控 关系型数据库 MySQL
PowerShell 脚本编写 :自动化Windows 开发工作流程
PowerShell 脚本编写 :自动化Windows 开发工作流程
161 0
|
4月前
|
API Windows
Windows之窗口原理
这篇文章主要介绍了Windows窗口原理和如何使用Windows API创建和管理窗口。
81 0
|
4月前
|
Ubuntu Linux Python
如何利用wsl-Ubuntu里conda用来给Windows的PyCharm开发
如何在WSL(Windows Subsystem for Linux)的Ubuntu环境中使用conda虚拟环境来为Windows上的PyCharm开发设置Python解释器。
378 0
|
5月前
|
存储 安全 程序员
Windows任务管理器开发原理与实现
Windows任务管理器开发原理与实现
|
2月前
|
安全 关系型数据库 MySQL
Windows Server 安装 MySQL 8.0 详细指南
安装 MySQL 需要谨慎,特别注意安全配置和权限管理。根据实际业务需求调整配置,确保数据库的性能和安全。
230 9
|
3月前
|
网络安全 Windows
Windows server 2012R2系统安装远程桌面服务后无法多用户同时登录是什么原因?
【11月更文挑战第15天】本文介绍了在Windows Server 2012 R2中遇到的多用户无法同时登录远程桌面的问题及其解决方法,包括许可模式限制、组策略配置问题、远程桌面服务配置错误以及网络和防火墙问题四个方面的原因分析及对应的解决方案。
216 4
|
3月前
|
监控 安全 网络安全
使用EventLog Analyzer日志分析工具监测 Windows Server 安全威胁
Windows服务器面临多重威胁,包括勒索软件、DoS攻击、内部威胁、恶意软件感染、网络钓鱼、暴力破解、漏洞利用、Web应用攻击及配置错误等。这些威胁严重威胁服务器安全与业务连续性。EventLog Analyzer通过日志管理和威胁分析,有效检测并应对上述威胁,提升服务器安全性,确保服务稳定运行。
|
3月前
|
监控 安全 网络安全
Windows Server管理:配置与管理技巧
Windows Server管理:配置与管理技巧
138 3
|
3月前
|
存储 安全 网络安全
Windows Server 本地安全策略
由于广泛使用及历史上存在的漏洞,Windows服务器成为黑客和恶意行为者的主要攻击目标。这些系统通常存储敏感数据并支持关键服务,因此组织需优先缓解风险,保障业务的完整性和连续性。常见的威胁包括勒索软件、拒绝服务攻击、内部威胁、恶意软件感染等。本地安全策略是Windows操作系统中用于管理计算机本地安全性设置的工具,主要包括用户账户策略、安全选项、安全设置等。实施强大的安全措施,如定期补丁更新、网络分段、入侵检测系统、数据加密等,对于加固Windows服务器至关重要。
133 1