
XPT2046是一款四线制电阻触摸屏控制芯片,由深圳市矽普特科技有限公司研发生产,被广泛的应用于触摸屏驱动,堪称经典之作!他内含12位分辨率125KHz转换速率逐步逼近型A/D转换器,支持从1.5V到5.25V的低电压I/O接口。能通过执行两次A/D转换查出被按的屏幕位置, 除此之外,还可以测量加在触摸屏上的压力。( {' l* t& G: l) d$ h. m) |2 c![]() ![]() 6 n5 |) ?, T/ X8 C |! m! W 连接方法: ![]() | \( ? i: `$ f2 e 说明:1、9、10引脚接VCC,6引脚接GND,2、3、4、5引脚接触摸屏的4条引脚线,16、15、14、12引脚接单片机SPI引脚,11接单片机某个引脚。 工作原理:% M. L0 [2 w1 R3 f9 o 把XPT2046第11引脚接到STM32单片机的引脚设置为中断引脚,触摸屏没有被触摸时,11引脚保持高电平,当有触摸屏被触摸时,11引脚变为低电平。所以用STM32单片机检测11引脚的高低电平,就可以知道有没有触摸屏触摸事件发生。如果发生了触摸屏按下事件,单片机通过SPI口,首先发送读取X坐标的命令0X90,然后读出2个字节的数据,然后再发送读取Y坐标的命令0XD0,然后再读出2个字节的数据。这时候,XY的坐标值就知道了,因为XPT2046是12位精度的ADC,所以读出的2个字节中,只有高12位是有效数据。 关于触摸校准: A8 f! Z7 ~6 c 触摸液晶屏的4个角,采集X和Y坐标的12位值。这时候,就分别得到了X坐标和Y坐标的最小值和最大值,根据液晶屏的分辨率,再通过数学等比公式,就可以通过采集得到的12位ADC值得出现在触摸到屏幕的哪个点了。 c$ T/ E2 r; W; C6 R! x …………………………………………………………………….. 对于一个资深级的电子人,看了我上面的表述,就知道XPT2046怎么用了。但是,对于小白的你,上面的表述对你而言就是雾里看花。不要着急,下面我给你从0补起。3 K7 v4 ]2 ]) M2 ]- \/ y5 w* c: m 首先,你要知道,我上面所讲的内容是:使用XPT2046驱动4线电阻式触摸屏。那么,你见过4线电阻式触摸屏吗?没见过怎么办?好办!请看下图:% @) K. A- l6 `, c 大部分的电阻式触摸屏,都是4线制的,就是引出了4条线的意思。我随便找了一个 ![]() 看它引出的排线,共4条线,所以是4线制的,也就是说,这个触摸屏,就可以用XPT2046驱动。 看到这里,你就赚了,你已经认识了电阻式触摸屏的真面目了,这就是工作单位要的工作经验,想要更多干货,请继续往下看吧。2 @9 H: i K/ n7 i' h7 ? 从前面我们了解到,此芯片的供电电压是常用的3.3V和5V电源都可以。再加上“支持1.5V~5.25V的数字I/O口”特性。就是说,我们常用的5V的和3.3V的单片机,都可以作为他的控制器了,有没有觉得在单片机选型上放宽很多了?% W h- r6 r- `3 \/ l3 @. @ 5 Y/ c' A, P. S8 t XPT2046与MCU连接:2 k. I2 U2 T6 u5 f; C XPT2046与单片机采用SPI连接。分别为引脚16:DCLK(SPI时钟引脚);引脚15:CS(使能引脚或者叫做片选引脚);引脚14:DIN(数据输入引脚);引脚12:DOUT(数据输出引脚)。带SPI模块的单片机,可以配置SPI模块与XPT2046通信。不带SPI模块的单片机,可以随便找4个引脚,模拟SPI时序,与XPT2046通信。 除了SPI通信的4个引脚,还有一个引脚必须接:PENIRQ。当触摸屏有触摸事件发生,这个引脚就会拉低,所以我们把这个引脚接到单片机的某个中断引脚,就可以随时发现触摸屏有被按下(用外部中断)。0 V1 e0 f& ]3 Q, _' Z/ J9 @1 Q' I. k3 l5 | XPT2046的SPI时序' ~3 K6 B8 J \9 i! D- v3 l ![]() & v: N# \$ h+ j* l5 @ BUSY是XPT2046的引脚13,是“忙时信号线”,我们没有用到,不接. y( E( R- M8 u( \ 当我们读出了触摸屏的ADC值后,就可以把它对应到TFT LCD上了$ D, |8 W+ C* s; X2 p$ ? 最后提醒朋友们,使用外部中断别忘了打开AFIO复用时钟。/ t% P1 F0 C# d& A: G 来看看触摸画板的效果吧 ![]() ![]() 画的丑了点,轻喷 ![]() 这是MDK的工程 ![]() |
{2 f( M* E/ o! v& a1 o! p
GPIO_InitTypeDef GPIO_InitStructure;
//下面是SPI相关GPIO初始化5 j& ~' e- q6 T9 a: m7 n# C, c
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_5 | GPIO_Pin_7;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //通用推挽输出6 C* C: J" q9 k, L4 B+ A+ g% _* B
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz;
GPIO_Init(GPIOA,&GPIO_InitStructure); N: S4 J1 P& f% Y, e
//下面是SPI相关GPIO初始化
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; //上拉输入
GPIO_Init(GPIOA,&GPIO_InitStructure);
- r, }# ~- \% `$ i! t
//Configure PC6 pin: TP_CS pin , d3 Z* @6 |. g9 @% ~+ Q8 e
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_6;
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_Out_PP; //推挽输出
GPIO_InitStructure.GPIO_Speed = GPIO_Speed_50MHz; ( C( f* {0 y; O# i$ J- R
GPIO_Init(GPIOC,&GPIO_InitStructure);. Y7 _! c( @$ i* ~) n2 c( S0 o
//Configure PC4 pin: TP_INT pin ) a' z- k0 C2 f& F! }& C
GPIO_InitStructure.GPIO_Pin = GPIO_Pin_4; + {$ L8 O% h8 `4 @* R; ^$ i6 z) n3 m
GPIO_InitStructure.GPIO_Mode = GPIO_Mode_IPU; //上拉输入+ f: M* q% E* X9 B' }
GPIO_Init(GPIOC,&GPIO_InitStructure);
}
模拟+中断的方式
是MDK的,我确定