안녕하세요 경호입니다.
핸들만을 가지고 윈도우의 실행파일을 알아내는 방법은 없는것으로 알고 있습니다.
하지만 Snapshot을 이용하는 방법이 있지요 ^^
API중 ::GetWindowThreadProcessId();라는 놈이 있습니다.
이놈에 현재 활성화 되어 있는 윈도우의 핸들을 넘겨주면 해당 윈도우의
ProcessId를 얻을수 있지요. 이놈을 가지구 Snapshot을 이용해서 검색한
놈들의 ProcessId와 비교하면 이름을 얻을수는 있답니다.
대충 코드로 만들어 보았습니다.
DWORD dwProcID;
HWND hSnapshot;
PROCESSENTRY32 Process32;
::GetWindowThreadProcessId(GetForegroundWindow(),&dwProcID);
hSnapshot = ::CreateToolhelp32Snapshot(TH32CS_SNAPPROCESS, 0 );
if ( ::Process32First(hSnapshot, &Process32 ) )
{
do
{
if ( dwProcID == Process32.th32ProcessID )
ShowMessage(AnsiString(Process32.szExeFile));
}while(::Process32Next(hSnapshot,&Process32));
}
음 경호의 잔머리였습니다.
그럼 즐프하세요 ^^
|
hSnapshot를 CloseHandle해주셔야 합니다.
안그러면 함수 호출할때마다 process의 Handle의 수가 계속 늘어날것입니다.