使用X11监听根窗口事件

问题描述 投票:0回答:2

我已经尝试了一段时间来实现这一目标,但我做不到。 XNextEvent 永远不会被调用。 我使用的是 Ubuntu 22.04。 这是我到目前为止的代码。 我想打印点击和鼠标移动。我尝试使用 /dev/input/eventX 但我想获取焦点位于单击的窗口名称,因此我认为必须使用 x11。

#include <stdio.h>
#include <X11/Xlib.h>

char *key_name[] = {
    "first",
    "second (or middle)",
    "third",
    "fourth",  // :D
    "fivth"    // :|
};

int main(int argc, char **argv)
{
    Display *display;
    XEvent xevent;
    Window window;

    if( (display = XOpenDisplay(NULL)) == NULL )
        return -1;

    window = DefaultRootWindow(display);
    XAllowEvents(display, AsyncBoth, CurrentTime);

    XGrabPointer(display, 
                 window,
                 1, 
                 PointerMotionMask | ButtonPressMask | ButtonReleaseMask , 
                 GrabModeAsync,
                 GrabModeAsync, 
                 None,
                 None,
                 CurrentTime);

    while(1) {
        XNextEvent(display, &xevent);

        switch (xevent.type) {
            case MotionNotify:
                printf("Mouse move      : [%d, %d]\n", xevent.xmotion.x_root, xevent.xmotion.y_root);
                break;
            case ButtonPress:
                printf("Button pressed  : %s\n", key_name[xevent.xbutton.button - 1]);
                break;
            case ButtonRelease:
                printf("Button released : %s\n", key_name[xevent.xbutton.button - 1]);
                break;
        }
    }

    return 0;
}
c++ linux events x11
2个回答
0
投票

XSelectInput是你的朋友。

有两种方法可以选择要报告给客户端应用程序的事件。一种方法是在调用 XCreateWindow 和 XChangeWindowAttributes 时设置 XSetWindowAttributes 结构的 event_mask 成员。另一种方法是使用 XSelectInput。

您正在寻找的获取窗口信息的函数是XQueryTreeXQueryPointer。另请参阅完整列表:获取窗口信息


0
投票

调用 XNextEvent 时我们没有收到任何消息,因为 这不是 X11 窗口系统的工作原理。

重点是:

事件的来源是指针所在的可视窗口。

我不创建窗口,因此我的程序不接收键盘事件。即使我创建了窗口,它必须有焦点

X 服务器用来报告这些事件的窗口取决于窗口在窗口层次结构中的位置以及是否有任何介入窗口禁止生成这些事件。

我使用的“hack”正在读取/dev/input/eventX,这是Linux保存鼠标日志的地方,从那里我可以选择我感兴趣的事件并执行逻辑。为了获得更多信息,我确实使用 x11 lib 使用 XQueryPointer 来获取指针所在的窗口,仅当我有兴趣知道例如:用户单击时。

© www.soinside.com 2019 - 2024. All rights reserved.