通過select較高效的捕獲和處理鼠標鍵盤事件

select監聽這些文件描述符的狀態,若有一個發生變化則返回,否則阻塞。

  1. #include <stdio.h>      
  2. #include <stdlib.h>      
  3. #include <linux/input.h>      
  4. #include <fcntl.h>      
  5. #include <sys/time.h>      
  6. #include <sys/types.h>      
  7. #include <sys/stat.h>      
  8. #include <unistd.h>      
  9.   
  10. int main(int argc,char **argv)      
  11. {      
  12.     int fd, retval;      
  13.     char buf[6];      
  14.     fd_set readfds;      
  15.     struct timeval tv;      
  16.   
  17.     // 打開鼠標設備      
  18.     fd = open( "/dev/input/mice", O_RDONLY );      
  19.     // 判斷是否打開成功      
  20.     if(fd<0) {      
  21.         printf("Failed to open \"/dev/input/mice\".\n");      
  22.         exit(1);      
  23.     } else {      
  24.         printf("open \"/dev/input/mice\" successfuly.\n");      
  25.     }      
  26.       
  27.     int fd_kb;       
  28.     struct input_event event_kb;    
  29.     fd_kb = open("/dev/input/event1", O_RDONLY); //鍵盤輸入    
  30.     if(fd_kb <= 0)    
  31.     {    
  32.             printf("open device error\n");    
  33.             return 0;    
  34.     }  
  35.       
  36.     int fd_mouse;      
  37.     struct input_event event_mouse;         
  38.     fd_mouse = open("/dev/input/event4", O_RDONLY); //鼠標輸入    
  39.     if(fd_mouse <= 0)    
  40.     {    
  41.             printf("open device error\n");    
  42.             return 0;    
  43.     }  
  44.       
  45.       
  46.     while(1) {      
  47.         // 設置最長等待時間      
  48.         tv.tv_sec = 5;      
  49.         tv.tv_usec = 0;      
  50.       
  51.         FD_ZERO( &readfds );      
  52.         FD_SET( fd, &readfds );      
  53.         FD_SET( fd_kb, &readfds );   
  54.         FD_SET( fd_mouse, &readfds );   
  55.       
  56.         int max=fd>fd_kb?(fd>fd_mouse?fd:fd_mouse):(fd_kb>fd_mouse?fd_kb:fd_mouse);  
  57.           
  58.         retval = select( max+1, &readfds, NULL, NULL, &tv );//有文件描述符的狀態發生變化(變爲可讀)或者超時和錯誤就返回,否則就阻塞      
  59.         if(retval==0) {      
  60.             printf( "Time out!\n" );      
  61.         }else if(retval<0){  
  62.             printf( "error!\n" );   
  63.         }else{                      //判斷是哪個文件描述符的狀態發生了變化,進行處理即可  
  64.           
  65.             //鼠標位置  
  66.             if(FD_ISSET(fd,&readfds))   
  67.             {      
  68.                 // 讀取鼠標設備中的數據      
  69.                 if(read(fd, buf, 6) <= 0) {      
  70.                     continue;      
  71.                 }      
  72.                 // 打印出從鼠標設備中讀取到的數據      
  73.                 printf("Button type = %d, X = %d, Y = %d, Z = %d\n", (buf[0] & 0x07), buf[1], buf[2],   buf[3]);      
  74.             }    
  75.               
  76.             //鍵盤點擊  
  77.             if(FD_ISSET(fd_kb,&readfds))   
  78.             {      
  79.                 if(read(fd_kb, &event_kb, sizeof(event_kb)) == sizeof(event_kb))    
  80.                 {    
  81.                     if (event_kb.type == EV_KEY)    
  82.                     {    
  83.                         //if (event_kb.value == 0 || event_kb.value == 1)//1表示按下,0表示釋放,會檢測到兩次    
  84.                         if (event_kb.value == 1)//鍵按下    
  85.                         {    
  86.                                 //printf("key %d %s\n", event_kb.code, (event_kb.value) ? "Pressed" : "Released");    
  87.                                 if(event_kb.code == KEY_ESC)    
  88.                                         break;    
  89.                                 if(event_kb.code == KEY_Q)    
  90.                                     printf("q\n");                                     
  91.                                 if(event_kb.code == KEY_W)    
  92.                                     printf("w\n");      
  93.                                 if(event_kb.code == KEY_E)    
  94.                                     printf("e\n");      
  95.                                 if(event_kb.code == KEY_R)    
  96.                                     printf("r\n");      
  97.                         }    
  98.     
  99.                     }    
  100.                     
  101.                 }       
  102.             }    
  103.               
  104.             //鼠標點擊  
  105.             if(FD_ISSET(fd_mouse,&readfds))   
  106.             {      
  107.                 if(read(fd_mouse, &event_mouse, sizeof(event_mouse)) == sizeof(event_mouse))    
  108.                 {                                       
  109.                     if(event_mouse.type = EV_REL)    
  110.                     {    
  111.                         if(event_mouse.code == REL_WHEEL)           
  112.                             printf("REL_WHEEL %d\n", event_mouse.value);//-1表示下滑,1表示上滑    
  113.                     }       
  114.          
  115.                     if(event_mouse.code == BTN_LEFT && event_mouse.value==1)//左鍵按下,1表示按下,0表示釋放。不然會檢測到兩次    
  116.                         printf("left down: %d\n", event_mouse.code);    
  117.                             
  118.                     if(event_mouse.code == BTN_RIGHT && event_mouse.value==1)    
  119.                         printf("right down: %d\n", event_mouse.code);    
  120.                             
  121.                     if(event_mouse.code == BTN_MIDDLE && event_mouse.value==1)    
  122.                         printf("middle down: %d\n", event_mouse.code);    
  123.   
  124.                 }   
  125.             }     
  126.           
  127.         }         
  128.     
  129.     }      
  130.     close(fd);    
  131.     close(fd_kb);   
  132.     close(fd_mouse);      
  133.     return 0;      
  134. }   
  135.   
  136.   
  137.   
  138.   
  139.     
發佈了15 篇原創文章 · 獲贊 5 · 訪問量 9萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章