c - PostMessage 似乎不起作用?

标签 c windows winapi

我正在尝试学习如何使用和接收原始输入消息,因此我设计了以下程序来测试我到目前为止的理解...

当我收到输入消息时,我尝试更改显示的字符串并在队列中放置一个新的 WM_PAINT 消息。但是这条消息似乎没有被调用。只有当我调整窗口大小时,文本才会显示不同。

为什么 WM_PAINT 消息根本没有得到处理,直到我调整窗口大小?

#define _WIN32_WINNT 0x501
#include <Windows.h>
#include <assert.h>
#include <cstring>
#include <cstdio>

LRESULT CALLBACK WinProcedure(HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam);

int WinMain(HINSTANCE hInst,HINSTANCE,LPSTR,int nCmdShow)
{
    WNDCLASS wc;
    HWND hwnd;

    wc.hInstance = hInst;
    wc.lpfnWndProc = WinProcedure;
    wc.style = CS_HREDRAW | CS_VREDRAW;
    wc.cbClsExtra = 0;
    wc.cbWndExtra = 0;
    wc.hIcon = LoadIcon(NULL, IDI_WINLOGO);
    wc.hCursor = LoadCursor(NULL, IDC_ARROW);
    wc.hbrBackground = (HBRUSH)COLOR_WINDOWFRAME;
    wc.lpszMenuName = NULL;
    wc.lpszClassName = "Untitled";

    if (!RegisterClass(&wc)) {
        // Error registering class
        return -1;
    }

    if (!(hwnd = CreateWindow(wc.lpszClassName, wc.lpszClassName, WS_OVERLAPPEDWINDOW, 
                    CW_USEDEFAULT,CW_USEDEFAULT,500,300,NULL,NULL,hInst,NULL))) {
        // Error creating window
        return -1;
    }

    ShowWindow(hwnd,nCmdShow); 
    UpdateWindow(hwnd);

    RAWINPUTDEVICE Rid[1];

    Rid[0].usUsagePage = 0x01; 
    Rid[0].usUsage = 0x06; 
    Rid[0].dwFlags = 0;   // adds HID keyboard and also ignores legacy keyboard messages
    Rid[0].hwndTarget = 0;

    if (RegisterRawInputDevices(Rid, 1, sizeof(Rid[0])) == FALSE) {
        return -5;
    }

    MSG msg;
    while (GetMessage(&msg,NULL,0,0) > 0) 
    { 
        TranslateMessage(&msg); 
        DispatchMessage(&msg); 
    }
    return 0;
}

LRESULT CALLBACK WinProcedure(HWND hwnd, UINT msg, WPARAM wparam, LPARAM lparam)
{
    static char buffer[5000] = "hi";

    if (msg == WM_PAINT) {
        PAINTSTRUCT ps; 
        HDC dc; 
        RECT r; 
        GetClientRect(hwnd,&r); 
        dc=BeginPaint(hwnd,&ps); 
        DrawText(dc,buffer,-1,&r,DT_SINGLELINE|DT_CENTER|DT_VCENTER); 
        EndPaint(hwnd,&ps);
        return 0;
    }

    if (msg == WM_INPUT) {
        strcpy(buffer, "Recieved input.");
        //assert(false);
        PostMessage(hwnd, WM_PAINT, wparam, lparam);
        return 0;
    }

    if (msg == WM_DESTROY) {
        PostQuitMessage(0);
        return 0;
    }

    return DefWindowProc(hwnd, msg, wparam, lparam);
}

最佳答案

如果你看一下the documentation for the WM_PAINT message , 它说得很清楚:

The WM_PAINT message is generated by the system and should not be sent by an application.

如果某些东西没有按您预期的方式工作,请先查阅文档。它们的存在是有原因的。充分利用它们。

之所以只发布 WM_PAINT 不起作用,是因为除了发送 WM_PAINT 消息之外,还有更多方法可以绘画。例如,系统设置适当的结构以允许应用程序在窗口上绘画等。将WM_PAINT 发送到窗口只是整个绘画过程的一小部分。

您可能想要的是 InvalidateRect() function ,它告诉操作系统您要重新绘制窗口的某个区域。操作系统然后执行正确的绘画程序。

关于c - PostMessage 似乎不起作用?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8920302/

相关文章:

c - 初学者关于C程序函数调用栈、序列点(sequencing)的疑问

Windows 服务无法启动,出现一般错误

java - 如何处理java.lang.Exception : Socket bind failed: [730013] exception

c++ - 如何从 C++ 发送双击键盘焦点对象?

c++ - 将 wchar_t 转换为 char

c - 我需要能够从标准输入读取字符串

捕获信号 SIGINT 仍然会杀死程序

windows - BSOD错误代码解释

C#:将 DllImport 与继承相结合?

c++ - 使用宏访问 C 中的结构成员名称