「読み取り専用」に設定されていないテキストボックスがあるので、理論的には書き込みができるはずです。Edit_Enable(hwnd, true)、Edit_SetReadOnly(hwnd, false)、および SetFocus(hwnd) でアクティブ化されます。テキストボックスをクリックしてフォーカスを与えることができ、キャレットが点滅していることもわかりますが、任意のキーを押してもテキストボックスに入力がありません。Edit_SetText() でテキストを設定できますが、手動で何も書き込むことはできません。
次のコードでこのテキストボックスを作成します。
DWORD dwStyle = WS_CHILD | WS_VISIBLE | WS_VSCROLL | ES_AUTOVSCROLL /*| ES_OEMCONVERT*/ | ES_LEFT /*| ES_WANTRETURN */| WS_TABSTOP;
        HWND h = CreateWindowEx(WS_EX_CLIENTEDGE, L"EDIT", (LPCWSTR)NULL, dwStyle, posX, posY, width, height, hParent, NULL, (HINSTANCE)GetModuleHandle(NULL), NULL);
メッセージはこの関数で処理されます。フレームごとに呼び出されます。
bool PumpMessages()
{
    MSG msg;
    ZeroMemory( &msg, sizeof(MSG) );
    bool bQuit = false;
    // Use PeekMessage() so we can use idle time to update the system. 
    while (PeekMessage(&msg, NULL, 0, 0, PM_REMOVE))
    {
        // Translate and dispatch the message
        TranslateMessage(&msg);
        // message bug workaround
        if (msg.message == WM_QUIT)
        {
            bQuit = true;
        }
        DispatchMessage(&msg);
    }
    return bQuit;
}
メッセージの手順は次のようになります。
   LRESULT CALLBACK Window::WndProcThunk(HWND hWnd, UINT msg, WPARAM wParam, LPARAM lParam)
   {
   if (msg == WM_CHAR)
       Log("WM_CHAR");
    ...
   // Finally, if the message isn't consumed by the window or any registered listeners, let Windows do its thing.
    return msgConsumed ? 0 : DefWindowProc(hWnd, msg, wParam, lParam);
   }
2 番目の奇妙なことは、WndProcThunk メッセージ プロシージャで発生します。WM_CHAR メッセージは記録されません。これが、TextBox が何もしない理由だと思います。ユーザーのキーが押されたときに反応するには WM_CHAR メッセージが必要だからです。PumpMessages 関数で TranslateMessage() を使用しているにもかかわらず、WM_CHAR メッセージが送信されない理由を見つける必要があります。何か案は?