在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.
(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;
};
};
然后,当我在编辑框中收到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());
}
当我在我的编辑框中输入时我得到的值似乎不正确,有时nReserved甚至是1或0,并且nRepeatCount总是1,无论我是否按住键一起登录时间或者只需按下随机键。
我做错了什么吗?如果是这样,那么从LPARAM中获取这些值的理想方法是什么?
答案 0 :(得分:12)
嗯,一方面0-15是16位,而不是15位。
答案 1 :(得分:0)
是的,容易出错(参见500的回答)。我只想使用位图和位移。
EG。 NRepeat = lparam&amp; 0xFFFF的;