4]L|+foWGN2pVq0 摘要:给出S3C2410上触摸屏的实现原理、硬件结构和软件程序;对软件进行优化,改进软件滤波的实现方法。其算法使用C语言实现,可移植到任何操作系统的触摸屏驱动程序中。
关键词:触摸屏 S3C2410 滤波
;c)SQ#Hh.pr0引言木铎校园 BBS 社区"Dw+D-{El\
随着个人数字助理(PDA)、瘦容户机等的普及,触摸屏作为终端与用户交互的媒介,在我们的生活中使用得越来普遍。触摸屏分为电阻式、电容式、声表面波式和红外线扫描式等类型,使用得最多的是4线电阻式触摸屏。
G0`9zwH:k1p~0本文以三星公司ARM9内核芯片S3C2410触摸屏接口为基础,通过外接4线电阻式触摸屏构成硬件基础。在此基础上,开发了触摸屏面图板程序。木铎校园 BBS 社区6U8Rr7i2Jx2{
1 触摸屏原理木铎校园 BBS 社区^*?2P[@zS#W
S3C2410接4线电阻式触摸屏的电路原理如图1所示。整个触摸屏由模向电阻比和纵向电阻线组成,由nYPON、YMON、nXPON、XMON四个控制信号控制4个MOS管(S1、S2、S3、S4)的通断。S3C2410有8个模拟输入通道。其中,通道7作为触摸屏接口的X坐标输入(图1的AIN[7]),通道5作为触摸屏接口的Y坐标输入(图1的AIN[5])。电路如图2所示。在接入S3C2410触摸屏接口前,它们都通过一个阻容式低通滤器滤除坐标信号噪声。这里的滤波十分重要,如果传递给S3C2410模拟输入接口的信号中干扰过大,不利于后续的软件处理。在采样过程中,软件只用给特殊寄存器置位,S3C2410的触摸屏控制器就会自动控制触摸屏接口打开或关闭各MOS管,按顺序完成X坐标点采集和Y坐标点采集。
R"|8X|5s0
4Mx*z'@5Y$g%|bK'}0 木铎校园 BBS 社区J6mw-lcSj
2 S3C2410触摸屏控制器
D9^se,c$^0S3C2410触摸屏控制器有2种处理模式:
jdJ_:o0①X/Y位置分别转换模式。触摸屏控制器包括两个控制阶段,X坐标转换阶段和Y坐标转换阶段。
g
FC$IpNJ0②X/Y位置自动转换模式。触摸屏控制器将自动转换X和Y坐标。
$YvLAh zj0本文使用X/Y位置自动转换模式。木铎校园 BBS 社区l'nOhXDh
3 S3C2410触摸屏编程木铎校园 BBS 社区
tZx:`M&BD`
由于触摸屏程序中参数的选取优化需要多次试验,而加入操作系统试验参数,每次编译下载耗费时间过多,不易于试验的进行,因而我们直接编写裸机触摸屏程序。三星公司开放了S3C2410测试程序2410test(可在三星网站下载),提供了触摸屏接口自动转换模式的程序范例ts_auto.c,见本刊网站www.dpj.com.cn。本文在此范例的基础上编写了触摸屏画图板程序——在显示屏上画出触摸笔的流走痕迹。
)o#@n3D4Y+q1pq9x5a0针对坐标点采样时产生的噪声,本文采用噪声滤波算法,编写了相应的噪声滤波程序,滤除干扰采样点。整个触摸屏画图板程序的处理流程如图3所示。
:z)mu/B |+b}]h8b03.1 程序初始化木铎校园 BBS 社区w!N/~!_d-Y
初始化触摸屏控制器为自动转换模式。其中寄存器ADCDLY的值需要根据具体的试验选取,可运行本文提供的程序看画线的效果来选取具体的参数。触摸屏中断处理程序Adc_or_TsAuto是判断触摸屏是否被按下了。触摸屏被按下,给全局变量Flag_Touch赋值为Touch_Down,否则赋值为Touch_Up。木铎校园 BBS 社区0Ps^z$MtFI+? [

$~3r(`%K j0
e$a'sLG I^,G#R3H0初始化脉宽调制计时器(PWM TIMER),选择计时器4为时钟,定义10ms中断1次,提供触摸屏采样时间基准,即10ms触摸屏采样1次。计数器中断处理程序Timer4Intr中判断Flag_Touch被赋值为Touch_Down,则给全局变量gTouchStartSample置位,以控制触摸屏采样。
/]Y+uC%L)DD)k:f;v0之后清除触摸屏中断和计时器中断屏蔽位,接受中断响应,同时计时器开始计时。
ATv1ohM iL9^03.2 触摸屏采样程序木铎校园 BBS 社区:hQJ0|{J]~~
如果gTouchStartSample为TRUE,触摸屏接口开始对坐标X和Y的模拟量进行采样,根据试验选取适合的的采集次数。本文中使用9次采集,分别记入到ptx[TouchSample]和pty[TouchSample]数组中,TouchSample为采集次数。木铎校园 BBS 社区Y:`d i A P9g
为了减少运算量,将ptx[]和pty[]分别分三组取平均值,存储在px[3]和py[3]中。这里以处理X坐标为例:
XT(t A5lG!]}0px[0]=(ptx[0]+ptx[1]+ptx[2])/3;木铎校园 BBS 社区N+tF$Mi
px[1]=(ptx[3]+ptx[4]+ptx[5])/3;
Ktdcp^:kS0px[2]=(ptx[6]+ptx[7]+ptx[8])/3;木铎校园 BBS 社区!QEbV4mX
F5O
计算以上三组数据的差值:
4x(TtV!Q0dlXDiff0=px[0]-px[1];
/|jQ fuG'ft+@"k0dlXDiff1=px[1]-px[2];
'Q2U|7M!Y.ht"Q8R0dlXDiff2=px[2]-px[0];
4q
Gc
F4w0然后对上述差值取绝对值,所得结果简称绝对差值:木铎校园 BBS 社区&wg+vZA7?
dlXDiff0=dlXDiff0>0?dlXDiff0:-dlXDiff0;木铎校园 BBS 社区3y`:G4E)M
l5J
dlXDiff1=dlXDiff1>0?dlXDiff1:-dlXDiff1;木铎校园 BBS 社区_
n5]#VtX6P
dlXDiff2=dlXDiff2>0?dlXDiff2:-dlXDiff2;木铎校园 BBS 社区$@&l.Gb-[O0l
判断上述计算的色对差值是否都超过差值门限,如果这3个绝对差值都超过门限值,判定这次采样点为野点,抛弃采样点,程序返回等待下次采样。其中的差值门限需要根据试验测试得到,本文取值为2。
(Ii'@"K6AF"`$yi!P,|0找出其中绝对差值最小的2组数据,再将它们作平均,同时赋值给tmx:木铎校园 BBS 社区1I] i%HF%Lq$y
if(dlXDiff0<dlXDiff1){
(Jg.A9i o%f0if(dlXDiff2<dlXDiff0){
/}8z\gy3o0tmx=((px[0]+px[2]>>1);木铎校园 BBS 社区U"fyq6_F9Te
}
{"z?W8ASW|R0else{
.C3S(D%N"F_,r
US;_K0tmx=((px[0]+px[1])>>1);
\1U-r(Fv"T'Z4z0}
k4O8T
_6J8@;SJ f$V0}木铎校园 BBS 社区{7`C,N$[e
else if(dlXDiff2<dlXDiff1){木铎校园 BBS 社区lD3OC(H|-Mg
tmx=((px[0]+px[2])>>1);木铎校园 BBS 社区P!k5ySRJ
t
}
-Z\]"vW0else{
h!{VEzv0tmx=((px[1]+px[2])>>1);
Y8Q
f]$v,f7\D0}
f2J5d^
CsB0
,e-Hi(a
Ra{0
8E9Z.K~jamRc0
:gO#i&Cg^({R0 函数Touch_Coordinate Conversion完成触摸屏采样值转换成显示坐标,根据不同的硬件有不同的转换方法。本触摸屏采样坐标及显示坐标如图4、图5所示。其中TOUCH_MAX_X和TOUCH_MIN_X是触摸屏X坐标采样值的最大和最小值;Y坐标同理。可以运行本文程序,同时使用触摸笔在触摸屏的4个角取得最大最小采样值。这里使用的是320×240的TFT屏,所以TOUCH_X值为320。下面是X坐标的转换程序:
~HE2e*P|8|0Touch_CoordinateConversio(int*px){
&ic
XV7aU0TmpX=(tmx>=TOUCH_MAX_X)?(TOUCH_MAX_X):*px;木铎校园 BBS 社区"F&m.GG/pj)VD4FB
TmpX-=TOUCH_MIN_X;木铎校园 BBS 社区7X7Q'mc7G
TmpX=(TmpX)?TmpX:0;
Y(I6t)e P*y0*px=(TmpX*TOUCH_X)/(TOUCH_MAX_X-TOUCH_MIN_X);木铎校园 BBS 社区1X1B$r J5]
}木铎校园 BBS 社区&Q"hvH"d
3.3 坐标滤波程序
K;XU&mrH!v"x0坐标滤波程序Touch_Pen_filtering,考虑人机界面中对触摸屏的操作有3种:木铎校园 BBS 社区0pr1jCi9uu8T-[
*触摸笔在触摸屏上的位置不变;
Q8as1eZ0*触摸笔在触摸屏上连续滑过;
@(_;g$d9}No0*触摸笔在触摸屏上有大幅度的跳跃。木铎校园 BBS 社区9{P!~7dI&a
i'@
假设三次连续采样时刻为T1、T2、T3(T3>T2>T1),采样间隔为10ms。由于采样间隔远小于人的反应时间,所以在前两种操作模式下,如果采样点有效,将T1和T3时刻的采样值作平均。其平均值和T2时刻的采样值比较一般不会大于某个门限,否则判定此次采样点为野点。而对于第三种模式下,采样点数据会有很大的跳变。跳变过程中的数据是不稳定的,虽然记入了数据,但被判定成无效的采样点,所以需要在程序中定义一个静态数组x[2]记录相邻的两次采样数据。只有当前后数据持续稳定一段时间,才认为这时的采样点有效。程序中使用的间隔门限FILTER_LIMIT是需要经过试验来选取的。这里只给出X坐标的滤波过程。
o:R&l2k|n%n0//*px为T3时刻的采样值,count是记录连续有效采样点次数的静态变量,标志当前数据持续稳定时间,一旦发现大于//FILTER_LIMIT,count的值又要从0开始计数。木铎校园 BBS 社区c[h.D(U}ZV
Int Touch_Pen_filtering(int *px){木铎校园 BBS 社区|e*D4r tWr*?%a2u
BOOL retVal;木铎校园 BBS 社区PysxsyeJ:J w
Static int count=0;
&E!Yw_0p{jq"z0count++;木铎校园 BBS 社区.} M,["L?t `
//如果连续有效采样点次数大于2次,开始进行滤波算法木铎校园 BBS 社区8|"f/Fq_[
Y
if(count>2){木铎校园 BBS 社区1I!bgxl
count=2;木铎校园 BBS 社区cQ/X3r+^
//将T3时刻采样值和T1时刻采样值作平均
W"V{+bI0TmpX=(x[0]+*px)/2;木铎校园 BBS 社区1T
DW1P;^-f
//计算平均值和T2时刻采样值的差值
2m/s2}0skC cJ3r0dx=(x[1]>TmpX)?(x[1]-TmpX):(TmpX-x[1]);
&g7P7K5NEc+@.r|d_0木铎校园 BBS 社区8y({'Y*|'^#_
木铎校园 BBS 社区5hDB3b L gA5vs
//如果差值大于门限值,说明T3的采样值无效,判为野点返回值为FALSE。为了避免过大的跳跃,认为触摸笔坐标沿变,使用T2时刻采样值来代替本次采样点,同时静态变量x[]中的数据不变,count重新开始记录连续有效采样点次数木铎校园 BBS 社区S,Z Fqp
if((dx>FIL TER_LIMIT)){
fC0Y^igx0*px=x[1];
B3sl2|3g X0B0retVal=FLASE;
@(F
\zmf-w1O~0count=0;木铎校园 BBS 社区H
b*a8H8]C{$O
}木铎校园 BBS 社区eK"_{"Xu
//否则采样点有效返回值为TRUE,将T3的采样点记入到x[1]中,T2的采样点移到x[0]中木铎校园 BBS 社区`/xN0?_)M&\5P"V6s*p
else{木铎校园 BBS 社区&l5@rP] Cw
x[0]=x[1];木铎校园 BBS 社区U"M1oA,@8ZV,b+HiR
x[1]=*px;
tP+vQwd8RJ
uC0retVal=TRUE;
+my4q&ro
V$d1H0}
^}/I#vbr4eN5J0}木铎校园 BBS 社区E*qUa8Xf
else{
%C#f+k,a;xg%X0//连续有效采样次数小于2,将T3的采样值记入到x[1],T2的采样值移动到x[0],并不进行滤波处理木铎校园 BBS 社区3U|/Q{%Fn&mR)fN8X/B
x[0]=x[1];木铎校园 BBS 社区 C6n
EM$y
k:T0b
x[1]=*px;木铎校园 BBS 社区},oM.]0pd1Z5^ O q
retVal=FLASE;
\L.n5hI ]F0}
.m'M&b;Yd `d6M0return retVal;
:o!`"uOk0}木铎校园 BBS 社区8{K~FG(U0oM
3.4 后续处理木铎校园 BBS 社区)RR5Xx{$d
经过上述的筛选和滤波,如果被判定采样值有效,则将其滤波值送给操作系统进行后续处理,否则程序返回,等待下一次采样。在2410 test程序中,可以结合LCD的画点函数,将有效的采样点在LCD上画出,以此检验参数设置是否合理。木铎校园 BBS 社区war.O8V
结语
+DO/P l8j1j-F`&O0本文以三星公司ARM9内核芯片S3C2410和4线电阻式触摸屏为硬件基础。基于此硬件结构,开发了触摸屏画图板程序。通过软件滤波,提高了系统性能,得到了很好的处理效果,有很强的实用性。用此算法实现的Windows CE触摸屏驱动,在汉王手写输入软件的测试下得到了很高的识别率。软件使用C语言实现,可以方便地移植到任何操作系统上。木铎校园 BBS 社区0@.O;Qvj5ZO