Jak odczytać pozycję niskiego poziomu kliknięcia myszą w Linuksie.

Używam tego kodu do odczytu zdarzeń myszy z dev / input / event * w linuxie.

#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.%06ld\ttype %d\tcode %d\tvalue %d\n",
               ie.time.tv_sec, ie.time.tv_usec, ie.type, ie.code, ie.value);

}
    return 0;
}

Daje mi wyniki w formacie:

czas 1342517261.840285 typ 2 kod 0 wartość -1

„time” to znacznik czasu, zwraca czas zdarzenia.

„kod” to kod zdarzenia, na przykład REL_X lub KEY_BACKSPACE, pełna lista znajduje się w include / linux / input.h.

„wartość” to wartość, jaką niesie wydarzenie. Albo względna zmiana dla EV_REL, absolutna nowa wartość dla EV_ABS (joysticki ...), albo 0 dla EV_KEY dla zwolnienia, 1 dla naciśnięcia klawisza i 2 dla automatycznego powtórzenia.

kiedy klikam, dostaję zdarzenie, ale nie dostaję pozycji myszy na ekranie, jaki jest sposób uzyskania pozycji myszy na ekranie.

Edytuj 1: Tak więc, jak się okazuje, muszę użyć względnych współrzędnych, aby uzyskać współrzędne myszy. Sądzę, że jest to powszechne wymaganie, więc mogą istnieć biblioteki / wcześniejszy kod, którego można użyć, aby uzyskać współrzędne. Wszelkie informacje na ten temat będą bardzo przydatne.

Edit2: ROZWIĄZANIE

#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, &ie, sizeof(struct input_event))) {
    if (ie.type == 2) {
      if (ie.code == 0) {
          XQueryPointer(dpy,DefaultRootWindow(dpy),&root,&child,
                        &rootX,&rootY,&winX,&winY,&mask);
          //rootX += ie.value;
          }
      else if (ie.code == 1) {
          XQueryPointer(dpy,DefaultRootWindow(dpy),&root,&child,
                        &rootX,&rootY,&winX,&winY,&mask);
         // rootY += ie.value;
          }
      printf("time%ld.%06ld\tx %d\ty %d\n",
         ie.time.tv_sec, ie.time.tv_usec, rootX, rootY);
    } else
      printf("time %ld.%06ld\ttype %d\tcode %d\tvalue %d\n",
          ie.time.tv_sec, ie.time.tv_usec, ie.type, ie.code, ie.value);
  }
  return 0;
}

XQueryPointer wydaje się wygodniejszym rozwiązaniem. Dzięki, @perreal za wskazówki.

questionAnswers(2)

yourAnswerToTheQuestion