前面做的那个程序,回车键和退格键用不了。
后来查了下资料发现
injectKeyDown()这个函数传入的是扫描码,而windows消息机制按键出来的是虚拟键码,两个码不一样。
后来无意中看到一个函数。
![](https://i-blog.csdnimg.cn/blog_migrate/cbef093dcc044b2793832001e2365e43.gif)
UINT VirtualKeyToScanCode(WPARAM wParam, LPARAM lParam)
![ExpandedBlockStart.gif](https://i-blog.csdnimg.cn/blog_migrate/2f88ce130b654eb5dc6788e02dbcfc90.gif)
{
if(HIWORD(lParam) & 0x0F00)
![ExpandedSubBlockStart.gif](https://i-blog.csdnimg.cn/blog_migrate/f70a0fde2b51b7dd92a70e712e540cf6.gif)
{
![](https://i-blog.csdnimg.cn/blog_migrate/df37983f39daa189b8c814e01a6a9011.gif)
UINT scancode = MapVirtualKey(wParam, 0);
return scancode | 0x80;
![](https://i-blog.csdnimg.cn/blog_migrate/4a5daaec04350a363f186a4d2c5ed6ce.gif)
}
else ![ExpandedSubBlockStart.gif](https://i-blog.csdnimg.cn/blog_migrate/f70a0fde2b51b7dd92a70e712e540cf6.gif)
{
return HIWORD(lParam) & 0x00FF;
![](https://i-blog.csdnimg.cn/blog_migrate/4a5daaec04350a363f186a4d2c5ed6ce.gif)
}
![](https://i-blog.csdnimg.cn/blog_migrate/0ac3a2d53663ec01c7f7225264eeefae.gif)
}
断点调试了下,主要是红色部分的代码在起作用。
翻越了下MSDN
WM_KEYDOWN:
wParamSpecifies the virtual-key code of the nonsystem key.
lParam
16-23Specifies the scan code. The value depends on the OEM.
大家注意,从16到23位就是扫描码了。
所以那个函数提取高2位然后在 & 0x00FF屏蔽掉前面右移的(以防万一)。
最后得到的就是扫描码了。
在CEGUI windows消息响应机制中添加如下就好。
case WM_CHAR:
![](https://i-blog.csdnimg.cn/blog_migrate/cbef093dcc044b2793832001e2365e43.gif)
CEGUI::System::getSingleton().injectChar((CEGUI::utf32)wParam);
break;
case WM_KEYDOWN:
![](https://i-blog.csdnimg.cn/blog_migrate/cbef093dcc044b2793832001e2365e43.gif)
CEGUI::System::getSingleton().injectKeyDown((CEGUI::utf32)(VirtualKeyToScanCode(wParam, lParam)));
break;
case WM_KEYUP:
![](https://i-blog.csdnimg.cn/blog_migrate/cbef093dcc044b2793832001e2365e43.gif)
CEGUI::System::getSingleton().injectKeyUp((CEGUI::utf32)(VirtualKeyToScanCode(wParam, lParam)));
break;