是否有一个好的库可用于从鼠标/键盘/操纵杆收集Linux中的用户输入,而不会强迫您创建可见的窗口呢?SDL可让您以合理的方式获取用户输入,但似乎会迫使您创建一个窗口,如果您已抽象了控件,那么这将很麻烦,因此控制计算机不必与渲染计算机相同。但是,如果控制机器和渲染机器相同,则会在显示器顶部出现一个很小的SDL窗口。
编辑说明 : 渲染器有一个输出窗口,在正常情况下,该窗口是全屏的,除非它们都在同一台计算机上运行,所以可以使控制器聚焦。实际上,可以有多个渲染器在全部由同一控制器控制的不同计算机上显示相同数据的不同视图,因此输入与输出完全脱钩(充分利用内置的X11客户端/服务器内容来减少显示次数)另外,一个渲染器也可以有多个控制器应用程序。控制器和渲染器之间的通信是通过套接字进行的。
好的,如果您使用的是X11,并且想要获取kbd,则需要进行抓取。如果您不是,那么我唯一的好答案是来自终端的ncurses。
这是您从键盘上抓取所有东西并再次释放的方法:
/* Demo code, needs more error checking, compile * with "gcc nameofthisfile.c -lX11". /* weird formatting for markdown follows. argh! */
#include <X11/Xlib.h>
int main(int argc, char **argv) { Display *dpy; XEvent ev; char *s; unsigned int kc; int quit = 0; if (NULL==(dpy=XOpenDisplay(NULL))) { perror(argv[0]); exit(1); } /* * You might want to warp the pointer to somewhere that you know * is not associated with anything that will drain events. * (void)XWarpPointer(dpy, None, DefaultRootWindow(dpy), 0, 0, 0, 0, x, y); */ XGrabKeyboard(dpy, DefaultRootWindow(dpy), True, GrabModeAsync, GrabModeAsync, CurrentTime); printf("KEYBOARD GRABBED! Hit 'q' to quit!\n" "If this job is killed or you get stuck, use Ctrl-Alt-F1\n" "to switch to a console (if possible) and run something that\n" "ungrabs the keyboard.\n"); /* A very simple event loop: start at "man XEvent" for more info. */ /* Also see "apropos XGrab" for various ways to lock down access to * certain types of info. coming out of or going into the server */ for (;!quit;) { XNextEvent(dpy, &ev); switch (ev.type) { case KeyPress: kc = ((XKeyPressedEvent*)&ev)->keycode; s = XKeysymToString(XKeycodeToKeysym(dpy, kc, 0)); /* s is NULL or a static no-touchy return string. */ if (s) printf("KEY:%s\n", s); if (!strcmp(s, "q")) quit=~0; break; case Expose: /* Often, it's a good idea to drain residual exposes to * avoid visiting Blinky's Fun Club. */ while (XCheckTypedEvent(dpy, Expose, &ev)) /* empty body */ ; break; case ButtonPress: case ButtonRelease: case KeyRelease: case MotionNotify: case ConfigureNotify: default: break; } } XUngrabKeyboard(dpy, CurrentTime); if (XCloseDisplay(dpy)) { perror(argv[0]); exit(1); } return 0; }
从终端运行此命令,所有kbd事件都应命中它。我正在Xorg下对其进行测试,但它使用了古老而稳定的Xlib机制。
希望这可以帮助。
请谨慎对待X之下的争夺。当您不熟悉X时,有时最好启动一个延时过程,该过程将在测试代码时使服务器脱钩,并让它每两分钟坐下来运行并脱钩。它节省了必须杀死服务器或从服务器切换到外部重置状态的麻烦。
在这里,我将留给您决定如何多路复用渲染。阅读XGrabKeyboard文档和XEvent文档以开始使用。如果您在屏幕角落暴露了小窗口,则可以将指针卡在一个角落中以选择控制器。XWarpPointer也可以从代码中将指针推到其中之一。
还有一点:您也可以获取指针和其他资源。如果您坐在前面的盒子上运行着一个控制器,则可以使用键盘和鼠标输入在具有不同渲染器的开放式插座之间切换。通过这种方法,您不再需要将输出窗口的大小调整为小于全屏大小。通过做更多的工作,您实际上可以使用SHAPE和COMPOSITE扩展名将Alpha混合的叠加放置在顶部,以响应用户输入获得不错的叠加功能(这可能算作百合的烫金)。