请教创建进程后,得到这个进程的窗口hwnd

你妹的特盗不 2010-04-26 06:07:18

typedef struct tagWNDINFO
{
DWORD dwProcessId;
HWND hWnd;
} WNDINFO, *LPWNDINFO;

BOOL CALLBACK EnumWndProc(HWND hwnd,LPARAM lParam);
void xxxx::run_proc(void)
{
CString szFilePath;
szFilePath.Format(_T("C:\\windows\\notepad.exe"));

STARTUPINFO strinfo;
memset(&strinfo,0,sizeof(STARTUPINFO));//这句不可少
strinfo.cb=sizeof(STARTUPINFO);
::GetStartupInfo(&strinfo);
strinfo.wShowWindow=SW_SHOWNORMAL;
strinfo.dwFlags=STARTF_USESHOWWINDOW | STARTF_USESTDHANDLES;

PROCESS_INFORMATION Process_Info;
CreateProcessW(szFilePath,NULL,NULL,NULL,true,NULL,NULL,NULL,&strinfo,&Process_Info);

WNDINFO wndf;
wndf.dwProcessId=Process_Info.dwProcessId;
wndf.hWnd=NULL;
EnumWindows(EnumWndProc,(LPARAM)&wndf);

TRACE("handle ==>%x id ==>%x ==>%x\r\n",Process_Info.hProcess,Process_Info.dwProcessId,wndf.hWnd);
}

BOOL CALLBACK EnumWndProc(HWND hwnd,LPARAM lParam)
{
DWORD dwProcessId;
GetWindowThreadProcessId(hwnd, &dwProcessId);
TRACE("Process id==>%x \r\n",dwProcessId);
LPWNDINFO pInfo = (LPWNDINFO)lParam;
if(pInfo->dwProcessId==dwProcessId)
{
TRACE("<===========================>");
pInfo->hWnd=hwnd;
return false;
}
else
return true;

}


为什么这样,不能正确得到窗口的HWND,网上说了 GetWindowThreadProcessId这个得到的是线程ID,那怎么得到进程ID呢?
...全文
287 6 打赏 收藏 转发到动态 举报
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
你妹的特盗不 2010-04-26
  • 打赏
  • 举报
回复

自己实现了
不知道这个代码有什么错误,暂时没过多的测试
void CdemoDlg::run_proc(void)
{
CString szFilePath;
szFilePath.Format(_T("C:\\windows\\notepad.exe"));

STARTUPINFO strinfo;
memset(&strinfo,0,sizeof(STARTUPINFO));//这句不可少
strinfo.cb=sizeof(STARTUPINFO);
::GetStartupInfo(&strinfo);
strinfo.wShowWindow=SW_SHOWNORMAL;
strinfo.dwFlags=STARTF_USESHOWWINDOW | STARTF_USESTDHANDLES;

PROCESS_INFORMATION Process_Info;
CreateProcessW(szFilePath,NULL,NULL,NULL,false,NULL,NULL,NULL,&strinfo,&Process_Info);

WNDINFO wndf;
wndf.dwProcessId=Process_Info.dwProcessId;
wndf.hWnd=NULL;
int x=0;
while(!wndf.hWnd&&x<1000)
{
EnumWindows(EnumWndProc,(LPARAM)&wndf);
Sleep(10);
x++;
}
TRACE("x=> %d",x);
//WaitForInputIdle(Process_Info.hProcess, INFINITE);

WINDOWPLACEMENT wpment;
wpment.length=sizeof(wpment);
::GetWindowPlacement(wndf.hWnd,&wpment);
wpment.showCmd=SW_SHOWMAXIMIZED;
::SetWindowPlacement(wndf.hWnd,&wpment);
TRACE("handle ==>%x id ==>%x ==>%x\r\n",Process_Info.hProcess,Process_Info.dwProcessId,wndf.hWnd);
}

BOOL CALLBACK EnumWndProc(HWND hwnd,LPARAM lParam)
{
if(!::IsWindow(hwnd))
return true; //不是窗口,直接返回,查找下一个
if(!::IsWindowVisible(hwnd))
return true;//不是可见窗口,直接返回,查找下一个

DWORD dwProcessId;
GetWindowThreadProcessId(hwnd, &dwProcessId);

LPWNDINFO pInfo = (LPWNDINFO)lParam;
if(pInfo->dwProcessId==dwProcessId)
{
HWND pHwnd=::GetParent(hwnd);
HWND oldhwnd=hwnd;
while(pHwnd)
{
oldhwnd=pHwnd;
pHwnd=::GetParent(oldhwnd);
}
pInfo->hWnd=oldhwnd;
return false;
}
else
return true;

}
wocow3 2010-04-26
  • 打赏
  • 举报
回复
CreateProcess后调用WaitForInputIdle(Process_Info.hProcess, INFINITE);等待进程窗口初始化完成
尹成 2010-04-26
  • 打赏
  • 举报
回复
//获取对应进程名的ID
DWORD GetSpecifiedProcessId(const char *pszProcessName)
{
DWORD id;
//获得系统快照句柄 (通俗的讲, 就是得到当前的所有进程)
HANDLE hSnapShot = CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS,0) ;
PROCESSENTRY32 pInfo; //用于保存进程信息的一个数据结构
pInfo.dwSize = sizeof(pInfo);
//从快照中获取进程列表
Process32First(hSnapShot, &pInfo) ; //从第一个进程开始循环
do
{
//这里的 pszProcessName 为你的进程名称
if(strcmp(strlwr(_strdup(pInfo.szExeFile)), pszProcessName) == 0)
{
id = pInfo.th32ProcessID ;
break ;
}
}while(Process32Next(hSnapShot, &pInfo) != FALSE);
return id; //id 就是你要的进程PID 了..
}
你妹的特盗不 2010-04-26
  • 打赏
  • 举报
回复
[Quote=引用 2 楼 visualeleven 的回复:]
GetProcessId()得到进程的ID
[/Quote]
肯定要通过HWND 去得到啊,记事本可以得到了,得Sleep();然后别的复杂的UI界面的得到的是错误的
郁闷的


if(pInfo->dwProcessId==dwProcessId)
{
HWND pHwnd=::GetParent(hwnd);
HWND oldhwnd=hwnd;
while(pHwnd)
{
oldhwnd=pHwnd;
pHwnd=::GetParent(oldhwnd);
}
pInfo->hWnd=oldhwnd;
return false;
}

Eleven 2010-04-26
  • 打赏
  • 举报
回复
GetProcessId()得到进程的ID
你妹的特盗不 2010-04-26
  • 打赏
  • 举报
回复
又看了这个帖子 http://w370063119.blog.163.com/blog/static/114100174201032604711489/
那我的是正确的吧

郁闷中啊

16,472

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Web++
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧