我正在构建一个需要根据活动窗口/程序加载不同设置的应用程序(例如,如果您使用Chrome,则会在切换到MS Word时加载与Chrome关联的设置,加载MS Word设置。
现在我正在处理一个每次活动窗口更改时从数据库中获取正确设置的类。这堂课还有一个" LookUp"根据上次提取的设置返回值的方法。
描述我尝试在伪代码中实现的内容:
class RecipeBook{
public:
RecipeBook();
HWINEVENTEVENTHOOK hEvent;
string currentProgram;
static VOID CALLBACK WindowCallback(HWINEVENTHOOK hWinEventHook,
DWORD dwEvent,
HWND hwnd, LONG idObject,
LONG idChild,
DWORD dwEventThread,
DWORD dwmsEventTime); //Actual callback
void messageCheck(void*);
}
RecipeBook::RecipeBook(){
this->hEvent = SetWinEventHook(EVENT_SYSTEM_FOREGROUND,
EVENT_SYSTEM_FOREGROUND,
NULL,&WinEventProcCallback,
0, 0,
WINEVENT_OUTOFCONTEXT | WINEVENT_SKIPOWNPROCESS);
Start messageCheck(void*) in separate thread
}
void messageCheck(void*){
MSG msg;
while (GetMessage(&msg, NULL, 0, 0))
{
TranslateMessage(&msg);
DispatchMessage(&msg);
}
}
VOID CALLBACK WindowCallback(HWINEVENTHOOK hWinEventHook,
DWORD dwEvent,
HWND hwnd, LONG idObject,
LONG idChild,
DWORD dwEventThread,
DWORD dwmsEventTime){
Get the name of the active program from the HWND handle //This is working
Update RecipeBook->CurrentProgram
}
我遇到的问题:
1)无法让消息检查在单独的线程中运行。如果我顺序运行代码,它工作正常。当我尝试在线程中生成messageCheck时(使用
AfxBeginThread(&messageCheck, ¤tProgram, THREAD_PRIORITY_NORMAL, 0, 0,NULL)
)
它似乎并不像是创建了另一个线程。
2)我不知道如何从回调中修改RecipeBook中的值。我已经想过从回调中返回这个名字,但我还没有设法让它发挥作用。如果我可以在回调中编辑字符串,那就太好了。
3)我想只要在调用LookUp方法时询问当前活动程序,但我只能找到获取调用进程ID的方法,而不是活动的Windows进程ID。
这是一个很大的问题,但任何建议都会非常感激!
谢谢!
答案 0 :(得分:0)
GetForgroundWindow()
这就是我想要的!
http://msdn.microsoft.com/en-us/library/windows/desktop/ms633505(v=vs.85).aspx
出于某种原因,我试图使用GetActiveWindow(),每当我看到Forground窗口出于某种原因我都在想背景窗口。哎呀!
除非任何人都能提供一个很好的解释如何进行多任务,CALLBACK的东西,我将只使用此函数并在LookUp完成时查询当前窗口。不应该经常这样,这个过程不会花太长时间。
对于有兴趣了解如何使用窗口句柄从活动窗口/ PID获取进程名称的人,我就是这样做的:
DWORD processID;
LPTSTR processName = new TCHAR[MAX_PATH];
DWORD nameSize = MAX_PATH;
HWND activeWindowH = GetForegroundWindow();
DWORD threadID = GetWindowThreadProcessId(activeWindowH,&processID);
HANDLE processHandle = OpenProcess(PROCESS_QUERY_LIMITED_INFORMATION | PROCESS_QUERY_INFORMATION,FALSE,processID);
BOOL nameSuccess = QueryFullProcessImageName(processHandle,0,processName,&nameSize);
干杯!