几个星期前,有人在这里帮我写了一个列出所有主窗口的课程。
今天我尝试修改该类,以便枚举特定父窗口的所有子窗口。
这是头文件:
#include "TChar.h"
#include "string.h"
#include "windows.h"
#include "Winuser.h"
#include <string>
#include <vector>
using namespace std;
typedef std::basic_string<TCHAR> tstring; //define basic_string<TCHAR> as a member of the std namespace
//and at the same time use typedef to define the synonym tstring for it
class Handles {
public:
struct child_data
{
tstring caption;
HWND handle;
};
private:
std::vector<child_data> stuff; //define a vector of objecttype "child_data" (the struct defined above) named stuff
BOOL add_window(HWND hwnd)
{
TCHAR String[200] = {0};
if (!hwnd)
return TRUE; // Not a window, return TRUE to Enumwindows in order to get the next handle
if (!::IsWindowVisible(hwnd))
return TRUE; // Not visible, return TRUE to Enumwindows in order to get the next handle
LRESULT result = SendMessageW(hwnd, WM_GETTEXT, sizeof(String), (LPARAM)String); //result stores the number of characters copied from the window
if (!result)
return TRUE; // No window title, return TRUE to Enumwindows in order to get the next handle
child_data data; // define an object of type child_data called data
data.handle = hwnd; //copy the handle to the data.handle member
for(int i = 0; i < result; i++) //copy each character to data.caption by using push_back
data.caption.push_back(String[i]);
stuff.push_back(data); //Put the whole data (with its members data.caption and data.handel) struct in the vector "stuff" using pushback
return TRUE;
}
static BOOL CALLBACK EnumChildWindows(HWND hwnd, LPARAM lParam)
{
Handles* ptr = reinterpret_cast<Handles*>(lParam);
return ptr->add_window(hwnd);
}
public:
Handles& enum_windows()
{
stuff.clear(); //clean up
if(!EnumWindows(EnumChildWindows, reinterpret_cast<LPARAM>(this)))
{
// Error! Call GetLastError();
}
return *this;
}
std::vector<child_data>& get_results()
{
return stuff;
}
};
我通过以下方式调用该函数:
std::vector<Handles::child_data> windows = Handles().enum_windows().get_results(); //Enumerate all visible windows and store handle and caption in "windows"
问题是:
我不太确定如何将父窗口的句柄传递给标头中的回调函数。感觉就像我已经尝试了一切,但我总是遇到类似的错误:变量hwnd没有被声明....
问题是我不懂100%的班级。我弄清楚的事情是评论。
感谢您的帮助!
答案 0 :(得分:2)
您可以调用EnumWindows
来枚举给定父窗口的子窗口,而不是调用枚举屏幕上所有顶级窗口的EnumChildWindows
。为此,您可以向enum_windows
类添加Handles
的重载:
Handles& enum_windows(HWND hParentWnd)
{
stuff.clear(); //clean up
EnumChildWindows(hParentWnd, Handles_WndEnumProc, reinterpret_cast<LPARAM>(this));
return *this;
}
EnumChildWindows
是WNDENUMPROC
的错误名称。我建议将其重命名为更独特的内容,例如Handles_WndEnumProc
。