「読み取り専用」に設定されていないテキストボックスがあるので、理論的には書き込みができるはずです。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 メッセージが送信されない理由を見つける必要があります。何か案は?