转载自:http://hi.baidu.com/zyb_debug/item/24a695a8a2396a726cd455b1
UINT VirtualKeyToScanCode(WPARAM wParam, LPARAM lParam)
{
if(HIWORD(lParam) & 0x0F00)
{
UINT scancode = MapVirtualKey(wParam, 0);
return scancode | 0x80;
}
else
{
return HIWORD(lParam) & 0x00FF;
}
}
wParam
Specifies the virtual-key code of the nonsystem key.
lParam
16-23
Specifies the scan code. The value depends on the OEM.
case WM_CHAR:
CEGUI::System::getSingleton().injectChar((CEGUI::utf32)wParam);
break;
case WM_KEYDOWN:
CEGUI::System::getSingleton().injectKeyDown((CEGUI::utf32)(VirtualKeyToScanCode(wParam, lParam)));
break;
case WM_KEYUP:
CEGUI::System::getSingleton().injectKeyUp((CEGUI::utf32)(VirtualKeyToScanCode(wParam, lParam)));
break;
前面做的那个程序,回车键和退格键用不了。
后来查了下资料发现
injectKeyDown()这个函数传入的是扫描码,而windows消息机制按键出来的是虚拟键码,两个码不一样。
后来无意中看到一个函数。












断点调试了下,主要是红色部分的代码在起作用。
翻越了下MSDN
WM_KEYDOWN:
大家注意,从16到23位就是扫描码了。
所以那个函数提取高2位然后在 & 0x00FF屏蔽掉前面右移的(以防万一)。
最后得到的就是扫描码了。
在CEGUI windows消息响应机制中添加如下就好。









