📄 ipaq.c
字号:
/*** $Id: ipaq.c,v 1.17 2003/09/04 03:38:25 weiym Exp $**** ipaq.c: Low Level Input Engine for iPAQ H3600/H3800** ** Copyright (C) 2003, Feynman Software.**** The device driver of iPAQ H3600 touch screen is compliant to** the Specification for Generic Touch Screen Driver.** Please see the file: spec_general_ts_drv.html in this directory.**** So this IAL engine can be a good template of your new IAL engines,** which compliant to the specification.**** Created by Wei Yongming, 2001/08/20*//*** This program is free software; you can redistribute it and/or modify** it under the terms of the GNU General Public License as published by** the Free Software Foundation; either version 2 of the License, or** (at your option) any later version.**** This program is distributed in the hope that it will be useful,** but WITHOUT ANY WARRANTY; without even the implied warranty of** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the** GNU General Public License for more details.**** You should have received a copy of the GNU General Public License** along with this program; if not, write to the Free Software** Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA*/#include <stdio.h>#include <stdlib.h>#include <string.h>#include <unistd.h>#include <sys/ioctl.h>#include <sys/poll.h>#include <linux/kd.h>#include <sys/types.h>#include <sys/stat.h>#include <fcntl.h>#include "common.h"#ifdef _IPAQ_IAL#include <linux/h3600_ts.h>#include "misc.h"#include "ial.h"#include "ipaq.h"/* for data reading from /dev/hs3600_ts */typedef struct { unsigned short b; unsigned short x; unsigned short y; unsigned short pad;} POS;static unsigned char state [NR_KEYS];static int ts = -1;static int btn_fd = -1;static unsigned char btn_state=0;static int mousex = 0;static int mousey = 0;static POS pos;#undef _DEBUG/************************ Low Level Input Operations **********************//* * Mouse operations -- Event */static int mouse_update(void){ return 1;}static void mouse_getxy(int *x, int* y){#ifdef _DEBUG printf ("mousex = %d, mousey = %d\n", mousex, mousey);#endif if (mousex < 0) mousex = 0; if (mousey < 0) mousey = 0; if (mousex > 319) mousex = 319; if (mousey > 239) mousey = 239;#ifdef _COOR_TRANS#if _ROT_DIR_CCW *x = mousey; *y = 319 - mousex;#else *x = 239 - mousey; *y = mousex;#endif#else *x = mousex; *y = mousey;#endif}static int mouse_getbutton(void){ return pos.b;}static int keyboard_update(void){ char *statinfo; int status; int key; //Attention! statinfo = (btn_state & KEY_RELEASED)? "UP":"DOWN"; status = (btn_state & KEY_RELEASED)? 0 : 1; key = btn_state & KEY_NUM;#ifdef _DEBUG fprintf(stderr, "key %d is %s", key, statinfo);#endif switch (key) { case 1: //state[H3600_SCANCODE_RECORD] = status; state[SCANCODE_LEFTSHIFT] = status; break; case 2: state[H3600_SCANCODE_CALENDAR] = status; break; case 3: state[H3600_SCANCODE_CONTACTS] = status; break; case 4: state[H3600_SCANCODE_Q] = status; break; case 5: state[H3600_SCANCODE_START] = status; break; case 6: state[H3600_SCANCODE_UP] = status; break; case 7: state[H3600_SCANCODE_RIGHT] = status; break; case 8: state[H3600_SCANCODE_LEFT] = status; break; case 9: state[H3600_SCANCODE_DOWN] = status; break; case 10: state[H3600_SCANCODE_ACTION] = status; break; case 11: state[H3600_SCANCODE_SUSPEND] = status; break; } return NR_KEYS;}static const char* keyboard_getstate(void){ return (char *)state;}#ifdef _LITE_VERSION static int wait_event (int which, int maxfd, fd_set *in, fd_set *out, fd_set *except, struct timeval *timeout)#elsestatic int wait_event (int which, fd_set *in, fd_set *out, fd_set *except, struct timeval *timeout)#endif{ fd_set rfds; int retvalue = 0; int e; if (!in) { in = &rfds; FD_ZERO (in); } if ((which & IAL_MOUSEEVENT) && ts >= 0) { FD_SET (ts, in);#ifdef _LITE_VERSION if (ts > maxfd) maxfd = ts;#endif } if ((which & IAL_KEYEVENT) && btn_fd >= 0){ FD_SET (btn_fd, in);#ifdef _LITE_VERSION if(btn_fd > maxfd) maxfd = btn_fd;#endif }#ifdef _LITE_VERSION e = select (maxfd + 1, in, out, except, timeout) ;#else e = select (FD_SETSIZE, in, out, except, timeout) ;#endif if (e > 0) { if (ts >= 0 && FD_ISSET (ts, in)) { FD_CLR (ts, in); pos.x=0; pos.y=0; // FIXME: maybe failed due to the struct alignment. read (ts, &pos, sizeof (POS)); //if (pos.x != -1 && pos.y != -1) { if (pos.b > 0) { mousex = pos.x; mousey = pos.y; } //}#ifdef _DEBUG if (pos.b > 0) { printf ("mouse down: pos.x = %d, pos.y = %d\n", pos.x, pos.y); }#endif pos.b = ( pos.b > 0 ? 4:0); retvalue |= IAL_MOUSEEVENT; } if (btn_fd >= 0 && FD_ISSET(btn_fd, in)) { unsigned char key; FD_CLR(btn_fd, in); read(btn_fd, &key, sizeof(key)); btn_state = key; retvalue |= IAL_KEYEVENT; } } else if (e < 0) { return -1; } return retvalue;}BOOL InitIPAQInput (INPUT* input, const char* mdev, const char* mtype){ ts = open ("/dev/h3600_ts", O_RDONLY); if (ts < 0) { fprintf (stderr, "IPAQ: Can not open touch screen!\n"); return FALSE; } btn_fd = open ("/dev/h3600_key", O_RDONLY); if (btn_fd < 0 ) { fprintf (stderr, "IPAQ: Can not open button key!\n"); return FALSE; } input->update_mouse = mouse_update; input->get_mouse_xy = mouse_getxy; input->set_mouse_xy = NULL; input->get_mouse_button = mouse_getbutton; input->set_mouse_range = NULL; input->update_keyboard = keyboard_update; input->get_keyboard_state = keyboard_getstate; input->set_leds = NULL; input->wait_event = wait_event; mousex = 0; mousey = 0; pos.x = pos.y = pos.b = 0; return TRUE;}void TermIPAQInput (void){ if (ts >= 0) close(ts); if (btn_fd >= 0) close(btn_fd);}#endif /* _IPAQ_IAL */
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -