[英]WinAPI Window Closes Instantly
I have been experimenting with the WINAPI trying to learn it but the window I have created closes instantly. 我一直在尝试使用WINAPI尝试学习它,但是我创建的窗口会立即关闭。 As you see when the W key is pressed or the left button is pressed it will close the program but when running it with no buttons being pressed it still closes.
如您所见,当按下W键或按下左键时,它将关闭程序,但是在不按下任何键的情况下运行该程序仍会关闭。
#include <windows.h>
#include <windowsx.h>
// the WindowProc function prototype
LRESULT CALLBACK WindowProc(HWND hWnd,
UINT message,
WPARAM wParam,
LPARAM lParam);
// the entry point for any Windows program
int WINAPI WinMain(HINSTANCE hInstance,
HINSTANCE hPrevInstance,
LPSTR lpCmdLine,
int nCmdShow)
{
// the handle for the window, filled by a function
HWND hWnd;
// this struct holds information for the window class
WNDCLASSEX wc;
// clear out the window class for use
ZeroMemory(&wc, sizeof(WNDCLASSEX));
// fill in the struct with the needed information
wc.cbSize = sizeof(WNDCLASSEX);
wc.style = CS_HREDRAW | CS_VREDRAW;
wc.lpfnWndProc = WindowProc;
wc.hInstance = hInstance;
wc.hCursor = LoadCursor(NULL, IDC_ARROW);
wc.hbrBackground = (HBRUSH)COLOR_WINDOW;
wc.lpszClassName = L"WindowClass1";
// register the window class
RegisterClassEx(&wc);
// create the window and use the result as the handle
hWnd = CreateWindowEx(NULL,
L"WindowClass1", // name of the window class
L"Game", // title of the window
WS_OVERLAPPEDWINDOW, // window style
1, // x-position of the window
1, // y-position of the window
1800, // width of the window
1000, // height of the window
NULL, // we have no parent window, NULL
NULL, // we aren't using menus, NULL
hInstance, // application handle
NULL); // used with multiple windows, NULL
// display the window on the screen
ShowWindow(hWnd, nCmdShow);
// enter the main loop:
// this struct holds Windows event messages
MSG msg;
// wait for the next message in the queue, store the result in 'msg'
while (GetMessage(&msg, NULL, 0, 0))
{
// translate keystroke messages into the right format
TranslateMessage(&msg);
// send the message to the WindowProc function
DispatchMessage(&msg);
}
// return this part of the WM_QUIT message to Windows
return msg.wParam;
}
// this is the main message handler for the program
LRESULT CALLBACK WindowProc(HWND hWnd, UINT message, WPARAM wParam, LPARAM lParam)
{
// sort through and find what code to run for the message given
switch (message)
{
// this message is read when the window is closed
case WM_MOUSEMOVE:
{
// Retrieve mouse screen position
int x = (short)LOWORD(lParam);
int y = (short)HIWORD(lParam);
// Check to see if the left button is held down:
bool leftButtonDown = wParam & MK_LBUTTON;
// Check if right button down:
bool rightButtonDown = wParam & MK_RBUTTON;
if (leftButtonDown == true)
{
//left click
//example lets close the program when press w
PostQuitMessage(0);
return 0;
}
}
case WM_KEYDOWN:
{
switch (wParam)
{
case 'W':
//w pressed
//example lets close the program when press w
PostQuitMessage(0);
return 0;
}
}
case WM_DESTROY:
{
// close the application entirely
PostQuitMessage(0);
return 0;
}
default:
break;
}
// Handle any messages the switch statement didn't
return DefWindowProc(hWnd, message, wParam, lParam);
}
You're missing some break
statements in your switch, so for example, if you get the WM_MOUSEMOVE
message and the leftButtonDown != true
, execution will fall through to WM_KEYDOWN
, etc. 您在交换机中缺少一些
break
语句,因此,例如,如果收到WM_MOUSEMOVE
消息并且leftButtonDown != true
,则执行将落入WM_KEYDOWN
等。
Eventually you get to case WM_DESTROY:
, which will Post
you a lovely QuitMessage
. 最终,您会看到
case WM_DESTROY:
,它将为您Post
一个可爱的QuitMessage
。
As an aside, this would be very easy to spot by stepping through, statement-by-statement, in a debugger. 顺便说一句,通过在调试器中逐条语句逐步执行,很容易发现这一点。
There is no break
in your switch
statement. 您的
switch
语句没有break
。
You end up exetuting 你最终被放逐
PostQuitMessage(0);
You could do something like this: 您可以执行以下操作:
case WM_FOO:
{
if ( bar ) {
return 0;
}
break;
}
Don't detect clicks via the WM_MOUSEMOVE
message, use the WM_MOUSEDOWN
instead. 不要通过
WM_MOUSEMOVE
消息检测到点击,而是使用WM_MOUSEDOWN
。
The problem is that your code is probably launched by you clicking on something, so when your window gets its first WM_MOUSEMOVE
message, the button is still actually pressed. 问题是您的代码可能是通过单击某些东西来启动的,因此,当窗口获得其第一条
WM_MOUSEMOVE
消息时,实际上仍会按下该按钮。 Code runs much faster than fingers.. 代码的运行速度比手指快多了 ..
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.