gpt4 book ai didi

c - Linux 输入设备读取 ioctl(EVIOCGKEY()) 与 read(input_event)

转载 作者:IT王子 更新时间:2023-10-29 01:22:38 27 4
gpt4 key购买 nike

我所有的代码都基于 linuxjournal.com 上的一篇文章 here is the article I based my code on

我正在编写一个嵌入式应用程序,我正在尝试从键盘读取击键。
这是我正在使用的代码

uint8_t key_b[KEY_MAX/8 + 1];
memset(key_b, 0, sizeof(key_b));
ioctl(fd, EVIOCGKEY(sizeof(key_b)), key_b);

for (yalv = 0; yalv < KEY_MAX; yalv++) {
if (test_bit(yalv, key_b)) {
/* the bit is set in the key state */
printf(" Key 0x%02x ", yalv);
switch ( yalv)
{
case KEY_RESERVED :
printf(" (Reserved)\n");
break;
case KEY_ESC :
printf(" (Escape)\n");
break;
/* other keys / buttons not shown */
case BTN_STYLUS2 :
printf(" (2nd Stylus Button )\n");
break;
case KEY_1:
printf("The key 1 was pressed");
break;
case KEY_2:
printf("The key 2 was pressed");
break;
case KEY_A:
printf("The key A was pressed");
break;
default:
printf(" (Unknown key)\n");
}
}
}

除了我按“a”时,此代码大部分都有效。

根据 input.h,KEY_A 设置为值 30。但是当我在键盘上按“a”时,它返回值 102 而不是 30。我已经测试了键盘上的其他键,并且看起来键 1-6 返回了 KEY_1、KEY_2 等的预期值,但之后返回的值不正确。

我试过直接从/dev/input/eventX 文件中读取事件。并且事件中返回的代码是预期的。

size_t rb;
/* the events (up to 64 at once) */
struct input_event ev[64];
int yalv;
int keybrdToCapture;

if((keybrdToCapture = open(EVENT2, O_RDONLY)) == -1) {
perror("opening device");
exit(EXIT_FAILURE);
printf("L2\n");
}

rb=read(keybrdToCapture,ev,sizeof(struct input_event)*64);

for (yalv = 0; yalv < (int) (rb / sizeof(struct input_event)); yalv++)
{
printf("yalv is %d\n", yalv);
if (EV_KEY == ev[yalv].type)
printf("type %d code %d value %d\n",ev[yalv].type,ev[yalv].code, ev[yalv].value);
}

当我按下“a”键时,上面的代码给出了这个打印。输入 1 代码 30 值 1

此时你可能想知道为什么我不简单地读取输入事件来读取键盘输入。这是因为 read() 是一个阻塞函数。虽然 ioctl() 没有阻塞。

如果有人能帮我弄清楚为什么 EVIOCGKEY() 返回的键值不正确,我将不胜感激。谢谢!

最佳答案

好的,我知道问题出在哪里了。

我的 test_bit() 宏写错了。
基本上,key_b[] 逐位表示键的状态。这意味着如果按下 KEY_A,则第 30 位将设置为 1。在这种情况下,第 30 位将在 key_b[3] 中显示为值 0x40。

以下是每个键如何映射到 key_b[] 的更多示例。

  • KEY_1 = 2 在 key_b 中表示为 --> key_b[0] = 0x04;
  • KEY_2 = 3 在 key_b 中表示为 --> key_b[0] = 0x08;
  • KEY_3 = 4 在 key_b 中表示为 --> key_b[0] = 0x10;
  • KEY_4 = 5 在 key_b 中表示为 --> key_b[0] = 0x20;
  • KEY_5 = 6 在 key_b 中表示为 --> key_b[0] = 0x40;
  • KEY_6 = 7 在 key_b 中表示为 --> key_b[0] = 0x80;
  • KEY_7 = 8 在 key_b 中表示为 --> key_b[1] = 0x01;
  • KEY_8 = 9 在 key_b 中表示为 --> key_b[1] = 0x02;
  • KEY_9 = 10 在 key_b 中表示为 --> key_b[2] = 0x04;
  • KEY_0 = 11 在 key_b 中表示为 --> key_b[3] = 0x08;

关于c - Linux 输入设备读取 ioctl(EVIOCGKEY()) 与 read(input_event),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/23068559/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com