Wince Linux 屏幕校准

来源:互联网 发布:淘宝实物不符怎么处理 编辑:程序博客网 时间:2024/04/30 01:04

  FL2440下触摸屏校准问题 收藏
没想到飞凌的开发板,默认出货的时候是没有校屏的。包括WINCE和LINUX。这里分享下校屏的经验。

一:WINCE之校屏

WINCE的校屏参数是保存在注册表中的。打开BSP包中的platform.reg,找到如下代码:

view plaincopy to clipboardprint?
IF BSP_NOTOUCH !  
[HKEY_LOCAL_MACHINE/HARDWARE/DEVICEMAP/TOUCH]  
 "MaxCalError"=dword:7  
 "CalibrationData"="626,464 1054,823 192,813 190,108 1070,104" 
   "Order"=dword:1  
ENDIF BSP_NOTOUCH ! 
IF BSP_NOTOUCH !
[HKEY_LOCAL_MACHINE/HARDWARE/DEVICEMAP/TOUCH]
 "MaxCalError"=dword:7
 "CalibrationData"="626,464 1054,823 192,813 190,108 1070,104"
   "Order"=dword:1
ENDIF BSP_NOTOUCH !

这里的CalibrationData即是校屏数据。由于WINCE开机后触摸偏移太大,根本没法点击进入校屏程序,有两种方法:

方法一:如果您手上有USB鼠标,将USB鼠标插入USB的HOST接口,这时就可以通过鼠标进入校屏界面了。点开始,控制
面板,笔针。

方法二:这种方法不适合初学者,适合程序开发人员。首先同步开发板,将校屏应用程序拷到开发板某目录,再通过
VS2005,任意打开一个应用程序,将程序入口指向拷备的应用程序,再F5,即运行了该校屏程序。详细步骤这里就不
一一列举了。

校完屏后,如果校正的注册表丢失,再重烧系统后,又会出现偏移。批量生产时就更不用说了。那怎么办呢?其实,当
您校完屏后,保存的校正数据已经保存起来了。通过remote register editer查看注册表信息,进入如下路径:
HKEY_LOCAL_MACHINE/HARDWARE/DEVICEMAP/TOUCH
记录CalibrationData的数据,将platform.reg里的错误数据用该数据替换。注意,files目录下的和release目录下的
platform.reg都要修改!更改后再make一下,生成的NK,就是正确的数据了。

二:LINUX之校屏

由于飞凌开发板默认没有校屏,但是引导linux系统后,已经进入shell界面了[QT界面],没有校准的过程。怎么办?通过
DNW或者超级终端,进入linux的consloe,查看/etc下有个文件pointercal,删除该文件,reboot,系统将重启,自动进入校准界面。这时就可以校屏了。
如果这时校屏仍然无法成功,即反复的点击那个十字架不停,这是触摸屏驱动的问题,“修改以下代码:
/drivers/char/s3c2410ts.c中将static inline void s3c2410_get_XY(void)函数中的x,y值调换顺序。” 具体地:

view plaincopy to clipboardprint?
static inline void s3c2410_get_XY(void)  
{  
if (adc_state == 0) {   
  adc_state = 1;  
  disable_ts_adc();  
  x = __raw_readl(S3C2410_ADCDAT1) & 0x3ff;//x:f04 y:f0e  by pht.  
  mode_y_axis();  
  start_adc_y();  
} else if (adc_state == 1) {   
  adc_state = 0;  
  disable_ts_adc();  
  y = __raw_readl(S3C2410_ADCDAT0) & 0x3ff;//y:f04 x:f0e  by pht.  
  DPRINTK("PEN DOWN: x: %08d, y: %08d/n", x, y);  
  wait_up_int();  
  tsdev.penStatus = PEN_DOWN;  
  tsEvent();  
}  

static inline void s3c2410_get_XY(void)
{
if (adc_state == 0) {
  adc_state = 1;
  disable_ts_adc();
  x = __raw_readl(S3C2410_ADCDAT1) & 0x3ff;//x:f04 y:f0e  by pht.
  mode_y_axis();
  start_adc_y();
} else if (adc_state == 1) {
  adc_state = 0;
  disable_ts_adc();
  y = __raw_readl(S3C2410_ADCDAT0) & 0x3ff;//y:f04 x:f0e  by pht.
  DPRINTK("PEN DOWN: x: %08d, y: %08d/n", x, y);
  wait_up_int();
  tsdev.penStatus = PEN_DOWN;
  tsEvent();
}
}

将上面的代码改为

view plaincopy to clipboardprint?
static inline void s3c2410_get_XY(void)  
{  
if (adc_state == 0) {   
  adc_state = 1;  
  disable_ts_adc();  
  y = __raw_readl(S3C2410_ADCDAT1) & 0x3ff;//x:f04 y:f0e  by pht.  
  mode_y_axis();  
  start_adc_y();  
} else if (adc_state == 1) {   
  adc_state = 0;  
  disable_ts_adc();  
  x = __raw_readl(S3C2410_ADCDAT0) & 0x3ff;//y:f04 x:f0e  by pht.  
  DPRINTK("PEN DOWN: x: %08d, y: %08d/n", x, y);  
  wait_up_int();  
  tsdev.penStatus = PEN_DOWN;  
  tsEvent();  
}  

static inline void s3c2410_get_XY(void)
{
if (adc_state == 0) {
  adc_state = 1;
  disable_ts_adc();
  y = __raw_readl(S3C2410_ADCDAT1) & 0x3ff;//x:f04 y:f0e  by pht.
  mode_y_axis();
  start_adc_y();
} else if (adc_state == 1) {
  adc_state = 0;
  disable_ts_adc();
  x = __raw_readl(S3C2410_ADCDAT0) & 0x3ff;//y:f04 x:f0e  by pht.
  DPRINTK("PEN DOWN: x: %08d, y: %08d/n", x, y);
  wait_up_int();
  tsdev.penStatus = PEN_DOWN;
  tsEvent();
}
}
编完驱动后更新kernel,重烧kernel,问题解决。


本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/armeasy/archive/2010/04/05/5451266.aspx

原创粉丝点击