如何拦截消息:“WM_QUIT || WM_DESTROY || WM_CLOSE”WinAPI

时间:2013-09-16 12:06:25

标签: c++ winapi

我将此代码用于主循环(我的函数):

    while (running)
{
    if(is_close)
    {
        Log().push_log("close", "message close!", logInfo);
        running = active = false;

        break;
    }

    while (PeekMessage(&msg, g_hWnd, 0, 0, PM_REMOVE))
    {
        std::cout << "Wnd: " << msg.message << std::endl;

        if (msg.message == WM_QUIT || msg.message == WM_DESTROY || msg.message == WM_CLOSE)
        {
            MessageBox(0, "Hello, World", "Hello", MB_OK);
            running = false;
        }
        // TranslateMessage(&msg);
        DispatchMessage(&msg);
    }

    if (running && active)
        render.DrawObject(g_hDC);
}

那么我使用WndProc:

LRESULT CALLBACK GLWindowProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
    std::cout << "Wnd Proc: " << msg << std::endl;

    return DefWindowProc(hWnd, msg, wParam, lParam);
}

当我尝试在我的函数中收到消息WM_QUITWM_DESTROYWM_CLOSE时,它不起作用。我的功能没有看到消息。

我该如何收到此消息?

1 个答案:

答案 0 :(得分:9)

PeekMessage或GetMessage将仅返回使用PostMessage()发布到消息队列的消息。这永远不会是WM_CLOSE或WM_DESTROY,这些消息与SendMessage()一起发送,直接传递给窗口过程而不进入消息队列。除非你的代码中有一个PostQuitMessage()调用,否则你不会得到WM_QUIT。

你真的必须为你的主窗口编写一个窗口过程。简单地处理WM_DESTROY并调用PostQuitMessage(0)就足够了。

LRESULT CALLBACK GLWindowProc(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
{
    if (msg == WM_DESTROY) PostQuitMessage(0);
    return DefWindowProc(hWnd, msg, wParam, lParam);
}

现在你将在游戏循环中获得WM_QUIT。