在MSDN上,对于WM_KEYDOWN定义,它说lparam的位包含:
Bits Meaning
0-15 The repeat count for the current message. The value is the number of times the keystroke is autorepeated as a result of the user holding down the key. If the keystroke is held long enough, multiple messages are sent. However, the repeat count is not cumulative.
16-23 The scan code. The value depends on the OEM.
24 Indicates whether the key is an extended key, such as the right-hand ALT and CTRL keys that appear on an enhanced 101- or 102-key keyboard. The value is 1 if it is an extended key; otherwise, it is 0.
25-28 Reserved; do not use.
29 The context code. The value is always 0 for a WM_KEYDOWN message.
30 The previous key state. The value is 1 if the key is down before the message is sent, or it is zero if the key is up.
31 The transition state. The value is always 0 for a WM_KEYDOWN message.
Run Code Online (Sandbox Code Playgroud)
(http://msdn.microsoft.com/en-us/library/ms646280%28VS.85%29.aspx)
所以我创建了一个带有结构的联合,如下所示:
union KeyState
{
LPARAM lparam;
struct
{
unsigned nRepeatCount : 15;
unsigned nScanCode : 8;
unsigned nExtended : 1;
unsigned nReserved : 4;
unsigned nContext : 1;
unsigned nPrev : 1;
unsigned nTrans : 1;
};
};
Run Code Online (Sandbox Code Playgroud)
然后,当我在编辑框中收到wm_keydown消息时,我将其打印出来:
if (msg == WM_KEYDOWN)
{
std::tstringstream ss;
KeyState ks;
ks.lparam = lparam;
ss << "Key: " << (TCHAR)wparam << ", Val: " << (UINT)wparam << ", nRepeatCount: " << ks.nRepeatCount <<
", nScanCode: " << ks.nScanCode << ", nExtended: " << ks.nExtended << ", nReserved: " << ks.nReserved <<
", nContext: " << ks.nContext << ", nPrev: " << ks.nPrev << ", nTrans: " << ks.nTrans;
SetWindowText(hOut, ss.str().c_str());
}
Run Code Online (Sandbox Code Playgroud)
我在编辑框中输入时返回的值似乎不正确,有时nReserved甚至是1或0,nRepeatCount总是1,无论我按住键记录时间还是按下随机密钥.
我做错了什么吗?如果是这样,从LPARAM获得这些值的理想方法是什么?
| 归档时间: |
|
| 查看次数: |
5696 次 |
| 最近记录: |