色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

如何在Linux中讀取低級鼠標單擊位置。

瀏覽:121日期:2023-07-12 09:57:26
如何解決如何在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的指導。

標簽: Linux系統
相關文章:
主站蜘蛛池模板: 国产在线高清视频 | 免费观看日本高清a毛片 | 免费黄色成人 | 亚洲精品男人天堂 | 日本视频在线观看不卡高清免费 | 精品色综合 | 99精品福利视频 | 黄色片免费网址 | 欧美成人精品久久精品 | 亚洲精品一区国产二区 | 一级特级欧美a毛片免费 | 成人午夜看片在线观看 | 亚洲国产精品国产自在在线 | 在线免费观看一级片 | 欧美做a欧美 | 最新精品亚洲成a人在线观看 | 亚洲最新在线视频 | 美国三级网站 | 91在线精品亚洲一区二区 | aaa欧美| 免费精品久久 | 欧美大片欧美毛片大片 | 日本精品久久久久久久久免费 | 怡红院在线观看在线视频 | 在线看欧美成人中文字幕视频 | 黑人一级大毛片 | 香蕉自拍视频 | 欧美色欧| 成人国产精品毛片 | 国产区最新| 亚洲国产成人精品一区91 | 国产高清视频免费最新在线 | 九九精品国产兔费观看久久 | 免费一级毛片在线播放欧美 | 91高端极品外围在线观看 | 日本久久久久一级毛片 | 狠狠色丁香婷婷久久综合不卡 | 美女视频一区二区三区 | 日本一区二区三区不卡在线视频 | 国产成人精品高清不卡在线 | 欧美特级午夜一区二区三区 |