我制作了一个程序,允许我在键盘上阅读所有独立的功能键(我认为至少要测试)。我设计它,以便我可以将任何单个键输入作为单个值引用。它处理返回, F1 - F12 ,删除,退格,箭头等< / p>
我只想测试输入的修改。我已确定轮班有效,但现在我决定测试 Ctrl 和 Alt 。
问题1 为什么 Alt 不能修改任何输入密钥代码?
问题2 为什么我不能捕获某些 Ctrl +组合? 例如。 Ctrl + s ; Ctrl + 1 - 9 ;
Ctrl + 2 有效,但我认为可能是因为我的键盘设置为英国。
这是我正在使用的代码。
请注意,我不一定要问如何捕获这些组合键(除非是一个简单的修改或两个)。我只想知道为什么我无法做到。
#include <iostream>
#include <conio.h>
#include <cwchar>
union wide_char
{
short Result;
char C[2];
};
int main()
{
wchar_t R;
int N;
wide_char user_input;
//Loops forever, this is only a proof of concept program proving this is possible to incorporate into a larger program
while(true)
{
user_input.C[0] = 0;
user_input.C[1] = 0;
//Loop twice, or until code causes the loop to exit
//Two times are neccessary for function keys unfortunately
for(int i = 0; i < 2; ++i)
{
//While there isn't a key pressed, loop doing nothing
while(!kbhit()){}
//Grab the next key from the buffer
//Since the loop is done, there must be at least one
user_input.C[i] = getch();
switch(user_input.C[i])
{
case 0:
case -32:
//The key pressed is a Function key because it matches one of these two cases
//This means getch() must be called twice
//Break switch, run the for loop again ++i
break;
default:
//The character obtained from getch() is from a regular key
//Or this is the second char from getch() because the for loop is on run #2
//Either way we need a wide char (16 bits / 2 Bytes)
if(user_input.C[1] != 0)
//Function keys {Arrows, F1-12, Esc}
//We now combine the bits of both chars obtained
//They must be combined Second+First else the F1-12 will be duplicate
//This is because on F1-12 getch() returns 0 thus won't affect the combination
R = user_input.Result;
else
//Regular key press
R = user_input.C[0];
//Display our unique results from each key press
N = R;
std::cout << R << " R = N " << N << std::endl;
if( R == 'a' )
std::cout << "a = " << N << std::endl;
//Manually break for loop
i = 3;
break;
}
}
//We need to reset the array in this situation
//Else regular key presses will be affected by the last function key press
}
}
答案 0 :(得分:1)
这非常适合您的环境。您正在使用特定于DOS / Windows的conio
。
大多数 Ctrl + alpha键值都绑定到字符1 - 26,而某些其他值绑定到31以下的其他值,以映射到ASCII控制字符。但有些像 Ctrl + S 有特殊含义( Ctrl + S 是ASCII中的XOFF),所以可能会被你的环境“吃掉”。
从根本上说,您面临的问题是getch
近似旧式串行终端界面。它们只在“最小公分母”级别显示键盘事件,而不是允许您区分修饰键等的较低级别,并为您提供更好的方法来处理特殊键,如功能键。
(正如您所注意到的,功能键具有特殊的多字节序列。再次,这是由于模拟老式串行终端,键盘可能位于远程链接的另一端。)
要获得更低级别(因此更直接和更灵活的界面),您需要使用更具特定于平台的库或更丰富的库(如SDL)。要么会给你一个较低级别的键盘输入视图。