Когда используешь GetWindowRect
таким же образом в примере MSDN я получаю следующую ошибку,
«невозможно преобразовать ‘RECT’ в ‘tagRECT *’ для аргумента ‘2’ в ‘BOOL GetWindowRect (HWND__, 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;
}
Вам нужно передать адрес вашего RECT
чтобы GetWindowRect
может изменить это. Функция принимает указатель на RECT
(RECT *
), но вы передаете RECT
,
Исправьте это так:
RECT blah;
GetWindowRect(hwnd, &blah);
^
Если функция взяла RECT
любые изменения, сделанные в нем, будут отброшены, потому что он будет передан по значению (то есть копия вашего объекта будет передана в). Что происходит с &blah
является то, что указатель, а не объект, передается по значению, но это значение остается тем же адресом объекта, поэтому изменение того, что находится по этому адресу, сохраняется. Таким образом, это одно понятие передачи объекта по ссылке, а другое — с фактической ссылкой. Поскольку Windows API был создан в основном на C, он использует более метод C-ish для получения указателя, а не ссылки, что обычно более предпочтительно в C ++.
Других решений пока нет …