C++ 调用GetWindowRect时出现编译器错误
在MSDN示例中以相同的方式使用C++ 调用GetWindowRect时出现编译器错误,c++,winapi,compiler-errors,dev-c++,C++,Winapi,Compiler Errors,Dev C++,在MSDN示例中以相同的方式使用GetWindowRect时,我得到以下错误:, “无法将参数“2”的“RECT”转换为“tagRECT*”,而将参数“2”转换为“BOOL GetWindowRect(HWND_uu;,tagRECT)”,下面是复制错误的代码: #include <windows.h> LRESULT CALLBACK WindowProcedure (HWND, UINT, WPARAM, LPARAM); char szClassName[ ] = "Windo
GetWindowRect
时,我得到以下错误:,
“无法将参数“2”的“RECT”转换为“tagRECT*”,而将参数“2”转换为“BOOL GetWindowRect(HWND_uu;,tagRECT)”,下面是复制错误的代码:
#include <windows.h>
LRESULT CALLBACK WindowProcedure (HWND, UINT, WPARAM, LPARAM);
char szClassName[ ] = "WindowsApp";
int WINAPI WinMain (HINSTANCE hThisInstance, HINSTANCE hPrevInstance,
LPSTR lpszArgument, int nFunsterStil)
{
HWND hwnd;
MSG messages;
WNDCLASSEX wincl;
wincl.hInstance = hThisInstance;
wincl.lpszClassName = szClassName;
wincl.lpfnWndProc = WindowProcedure;
wincl.style = CS_DBLCLKS;
wincl.cbSize = sizeof (WNDCLASSEX);
wincl.hIcon = LoadIcon (NULL, IDI_APPLICATION);
wincl.hIconSm = LoadIcon (NULL, IDI_APPLICATION);
wincl.hCursor = LoadCursor (NULL, IDC_ARROW);
wincl.lpszMenuName = NULL;
wincl.cbClsExtra = 0;
wincl.cbWndExtra = 0;
wincl.hbrBackground = (HBRUSH) COLOR_BACKGROUND;
if (!RegisterClassEx (&wincl))
return 0;
hwnd = CreateWindowEx (0, szClassName, "Windows App", WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT, CW_USEDEFAULT, 544, 375, HWND_DESKTOP, NULL,
hThisInstance, NULL);
RECT blah;
GetWindowRect (hwnd, blah);
ShowWindow (hwnd, nFunsterStil);
while (GetMessage (&messages, NULL, 0, 0))
{
TranslateMessage(&messages);
DispatchMessage(&messages);
}
return messages.wParam;
}
LRESULT CALLBACK WindowProcedure (HWND hwnd, UINT message, WPARAM wParam,
LPARAM, lParam)
{
switch (message)
{
case WM_DESTROY:
PostQuitMessage (0);
break;
default:
return DefWindowProc (hwnd, message, wParam, lParam);
}
return 0;
}
#包括
LRESULT回调窗口过程(HWND、UINT、WPARAM、LPARAM);
char szClassName[]=“WindowsApp”;
int WINAPI WinMain(HINSTANCE hThisInstance、HINSTANCE HPPreInstance、,
LPSTR lpsz参数,int nFunsterStil)
{
HWND-HWND;
消息;
WNDCLASSEX wincl;
wincl.hInstance=hthis实例;
wincl.lpszClassName=szClassName;
wincl.lpfnWndProc=窗口程序;
wincl.style=CS_DBLCLKS;
wincl.cbSize=sizeof(WNDCLASSEX);
wincl.hIcon=加载图标(空,IDI_应用程序);
wincl.hIconSm=加载图标(空,IDI_应用程序);
wincl.hCursor=LoadCursor(空,IDC_箭头);
wincl.lpszMenuName=NULL;
wincl.cbClsExtra=0;
wincl.cbWndExtra=0;
wincl.hbrBackground=(HBRUSH)颜色背景;
if(!RegisterClass(&wincl))
返回0;
hwnd=CreateWindowEx(0,szClassName,“Windows应用程序”,WS_OVERLAPPEDWINDOW,
CW_USEDEFAULT,CW_USEDEFAULT,544375,HWND_桌面,空,
hthis实例,空);
直截了当的废话;
GetWindowRect(hwnd,blah);
显示窗口(hwnd、nFunsterStil);
while(GetMessage(&messages,NULL,0,0))
{
翻译消息(和消息);
DispatchMessage(&messages);
}
返回messages.wParam;
}
LRESULT回调窗口过程(HWND HWND,UINT消息,WPARAM WPARAM,
LPARAM,LPARAM)
{
开关(信息)
{
案例WM_销毁:
PostQuitMessage(0);
打破
违约:
返回DefWindowProc(hwnd、message、wParam、lParam);
}
返回0;
}
您需要传递RECT
的地址,以便GetWindowRect
可以更改它。该函数获取指向RECT
(RECT*
)的指针,但您正在传递RECT
像这样修复它:
RECT blah;
GetWindowRect(hwnd, &blah);
^
如果函数采用
RECT
,对它所做的任何更改都将被丢弃,因为它将按值传递(也就是说,将传入对象的副本)。&blah
的结果是指针(而不是对象)按值传递,但该值仍然是对象的同一地址,因此更改该地址处的内容仍然存在。因此,一个概念是通过引用传递对象,另一个概念是通过实际引用传递对象。由于Windows API主要是在C中实现的,但是它使用的是更多的C-ISH方法,而不是引用,而C++通常更适合。p> 您需要传递RECT
的地址,以便GetWindowRect
可以更改它。该函数获取指向RECT
(RECT*
)的指针,但您正在传递RECT
像这样修复它:
RECT blah;
GetWindowRect(hwnd, &blah);
^
如果函数采用
RECT
,对它所做的任何更改都将被丢弃,因为它将按值传递(也就是说,将传入对象的副本)。&blah
的结果是指针(而不是对象)按值传递,但该值仍然是对象的同一地址,因此更改该地址处的内容仍然存在。因此,一个概念是通过引用传递对象,另一个概念是通过实际引用传递对象。由于Windows API主要是在C中实现的,但是它使用的是更多的C-ISH方法,而不是引用,而C++通常更适合。p> 错误消息告诉您出了什么问题。我可以想象看到RECT
到tagRECT*
,而它真正的意思是RECT
到RECT*
,是多么令人困惑。这真的让错误失去了一些用处。错误消息告诉你出了什么问题。我可以想象看到RECT
到tagRECT*
,而它真正的意思是RECT
到RECT*
,是多么令人困惑。这确实让错误失去了一些用处。