如何在Linux中讀取低級鼠標單擊位置。
您可以從X11獲取初始位置,并使用相對坐標來跟蹤指針:
#include <stdio.h>#include <stdlib.h>#include <unistd.h>#include <linux/input.h>#include <fcntl.h>#include <X11/Xlib.h>#define MOUSEFILE '/dev/input/event6'int main(){ int fd; struct input_event ie; display *dpy; Window root, child; int rootX, rootY, winX, winY; unsigned int mask; dpy = XOpendisplay(NULL); XQueryPointer(dpy,DefaultRootwindow(dpy),&root,&child, &rootX,&rootY,&winX,&winY,&mask); if((fd = open(MOUSEFILE, O_RDONLY)) == -1) { perror('opening device'); exit(EXIT_FAILURE); } while(read(fd, &ie, sizeof(struct input_event))) { if (ie.type == 2) { if (ie.code == 0) { rootX += ie.value; } else if (ie.code == 1) { rootY += ie.value; } printf('time%ld.%06ldtx %dty %dn', ie.time.tv_sec, ie.time.tv_usec, rootX, rootY); } else if (ie.type == 1) { if (ie.code == 272 ) { printf('Mouse button ');if (ie.value == 0) printf('released!!n');if (ie.value == 1) printf('pressed!!n'); } else {printf('time %ld.%06ldttype %dtcode %dtvalue %dn', ie.time.tv_sec, ie.time.tv_usec, ie.type, ie.code, ie.value); } } return 0;}解決方法
我正在使用此代碼從linux中的dev / input / event *讀取鼠標事件。
#include <stdio.h>#include <stdlib.h>#include <unistd.h>#include <linux/input.h>#include <fcntl.h>#define MOUSEFILE '/dev/input/event4'int main(){ int fd; struct input_event ie; if((fd = open(MOUSEFILE,O_RDONLY)) == -1) {perror('opening device');exit(EXIT_FAILURE); } while(read(fd,&ie,sizeof(struct input_event))) {printf('time %ld.%06ldttype %dtcode %dtvalue %dn',ie.time.tv_sec,ie.time.tv_usec,ie.type,ie.code,ie.value);} return 0;}
它給我的結果格式:
時間1342517261.840285類型2代碼0值-1
“時間”是時間戳,它返回事件發生的時間。
“代碼”是事件代碼,例如REL_X或KEY_BACKSPACE,完整列表位于include / linux / input.h中。
“價值”是事件帶來的價值。EV_REL的相對更改,EV_ABS(操縱桿…)的絕對新值,或EV_KEY的釋放為0,按鍵為1以及自動重復為2。
當我單擊時,我得到了事件,但沒有在屏幕上獲得鼠標的位置,如何在屏幕上獲得鼠標的位置。
編輯1:所以事實證明我必須使用相對坐標來獲取鼠標坐標。我相信這是一個普遍的要求,因此可能會有庫/預先存在的代碼可用于獲取坐標。關于該主題的任何信息將非常有用。
Edit2:解決方案
#include <stdio.h>#include <stdlib.h>#include <unistd.h>#include <linux/input.h>#include <fcntl.h>#include <X11/Xlib.h>#define MOUSEFILE '/dev/input/event4'int main(){ int fd; struct input_event ie; Display *dpy; Window root,child; int rootX,rootY,winX,winY; unsigned int mask; dpy = XOpenDisplay(NULL); XQueryPointer(dpy,DefaultRootWindow(dpy),&root,&child,&rootX,&rootY,&winX,&winY,&mask); if((fd = open(MOUSEFILE,O_RDONLY)) == -1) { perror('opening device'); exit(EXIT_FAILURE); } while(read(fd,sizeof(struct input_event))) { if (ie.type == 2) { if (ie.code == 0) { XQueryPointer(dpy,&mask); //rootX += ie.value; } else if (ie.code == 1) { XQueryPointer(dpy,&mask); // rootY += ie.value; } printf('time%ld.%06ldtx %dty %dn',rootX,rootY); } else printf('time %ld.%06ldttype %dtcode %dtvalue %dn',ie.value); } return 0;}
XQueryPointer似乎是更方便的解決方案。謝謝@perreal的指導。
相關文章:
1. YunDetectService.exe是什么進程?YunDetectService.exe禁止使用的方法2. Freebsd 雙硬盤無法啟動的解決辦法3. rsync結合 inotfiy 實現實時備份的問題4. 支持深色 / 淺色模式,微軟 Win11 Build 25281 為“產品密鑰”窗口啟用新界面5. Fedora系統外觀怎么設置? Fedora Linux外觀主題設置技巧6. Win11Beta預覽版22621.1180和22623.1180發布 附KB5022363內容匯總7. 去掉系統快捷方式箭頭的途徑——修改注冊表8. Mac版steam錯誤代碼118怎么解決?Mac版steam錯誤代碼118解決教程9. mac程序沒反應怎么辦 mac強制關閉程序的方法10. 世界上最流行的操作系統不是Linux或者Windows,而是MINIX
