用户工具

站点工具


icore4t_62

差别

这里会显示出您选择的修订版和当前版本之间的差别。

到此差别页面的链接

两侧同时换到之前的修订记录 前一修订版
后一修订版
前一修订版
icore4t_62 [2020/11/09 14:35]
fmj [四、 实验程序]
icore4t_62 [2022/04/01 10:58] (当前版本)
sean
行 2: 行 2:
 |技术支持电话|**0379-69926675-801**||| |技术支持电话|**0379-69926675-801**|||
 |技术支持邮件|Gingko@vip.163.com||| |技术支持邮件|Gingko@vip.163.com|||
-|技术论坛|http://​www.eeschool.org||| 
 ^  版本 ​ ^  日期 ​ ^  作者 ​ ^  修改内容 ​ ^ ^  版本 ​ ^  日期 ​ ^  作者 ​ ^  修改内容 ​ ^
 |  V1.0  |  2020-11-09 ​ |  gingko ​ |  初次建立 ​ |  |  V1.0  |  2020-11-09 ​ |  gingko ​ |  初次建立 ​ | 
行 91: 行 90:
 ==== 三、 实验原理 ==== ==== 三、 实验原理 ====
  
-=== 1. 电阻式触摸屏检测原理 === +=== 电阻式触摸屏检测原理 === 
-  * (一)LTDC关键知识点:  +  * 电阻式触摸屏结构见下图。它主面硬涂层、两ITO、间隔以及玻璃底层构成这些结构层都是透明触摸屏覆盖在液晶面板上透过触摸屏可看到液晶面板。表面涂层起到保护作用,玻璃底层起承载的作用,而两ITO层是触摸屏关键结构它们是涂有铟锡金属氧化物导电层两个ITO层之间使间隔点使两层分开当触摸屏面受到压力时,表面弯曲使得层ITO与下层ITO接触,在触点处连通电路。 
-  * 1)STM32H7LTDC最大支持1024*768分辨率,且支持硬件双实际支持的分辨率可能比1024*768高一点,因为最 ​ 终可以支持的最大分辨率是芯片后期定标的。 +{{ :​icore4t:​icore4t_arm_hal_62_1.png?​direct&​200 |}}
-  * 2)支持32位色,24位色,16位色和8位色。 +
-  * 3)可编程窗口位置和大小,可编程行同步,场同步和数据使能信号的极性。 +
-  * 4)查色表 (CLUT,Color look-up table),每最高可记录256种24位色。 +
-  * 5)支持如下8种颜色格式: +
-  * **ARGB8888**  +
-  * 32位颜色格式,一个像素占用4字节其中低位 3 字节用于颜色分量,高位字节用于 Alpha 混合。红、绿、蓝和 Alpha通道(0x00表示完全透明,0xFF表示完全不透明)都是 8 位表示。 +
-  * 普通列表项目颜色格式:AAAAAAAARRRRRRRRGGGGGGGGBBBBBBBB。 +
-  * **RGB888**  +
-  * 普通列表项目24位颜色格式,一像素点占用3字节分别用于红、绿、蓝。  +
-  * 普通列项目颜色格式:RRRRRRRRGGGGGGGGBBBBBBBB。 +
-  * **RGB565**  +
-  * 16位颜色格式,一个像素点占2字节分别于红、绿、蓝。  +
-  * 颜色格式:RRRRRGGGGGGBBBBB。 +
-  * **ARGB1555**  +
-  * 16位颜色格式像素点占用2字节,Alpha通道使用1个位表示,等于0时候表示完全透明等于1时候表示完全不透明红、绿、蓝都是5个位表示。  +
-  * 颜色格式:ARRRRRGGGGGBBBBB。 +
-  * **ARGB4444** +
-  * 16位颜色格式,一个像素占用2字节,Alpha通道使用2个位表示(0x0表示完全透明0x3示完全不透明)。红、绿、蓝都是用4个位表示。  +
-  * 颜色格式:ARRRRRGGGGGBBBBB。 +
-  * **L8 (8-bit luminance or CLUT)**  +
-  * 8位颜色格式实际上仅仅是8位索引值,范围0–255,​而每个索引值的具体颜色值在查色CLUT里存储。 +
-  * **AL44 (4-bit alpha + 4-bit luminance)**  +
-  * 8位颜色格式,实际是4位Alpha通道(0x0表示完全透明0xF表示完全不透明)和4位的索引值,索引范围0–15,​而每个索引值的具体颜色值查色表CLUT里面存储。 +
-  * **AL88 (8-bit alpha + 8-bit luminance)**  +
-  * 16位颜色格式,实际上是8位Alpha通道(0x00表示完全透明,0xFF表示完全不透明)和8位的索引值,索引范围0–255,​而每个索引值的具体颜色值在查色表CLUT里面存储。+
  
 +  * 两个ITO涂层的两端分别引出X-、X+、Y-、Y+四个电极,见下图,这是电阻屏最常见的四线结构,通过这些电极,外部电路向这两个涂层可以施加匀强电场或检测电压。
 +{{ :​icore4t:​iCore4T_ARM_HAL_62_2.png?​direct&​600 |}}
 +  * 当触摸屏被按下时,两个ITO层相互接触,从触点处把ITO层分为两个电阻,且由于ITO层均匀导电,两个电阻的大小与触点离两电极的距离成比例关系,利用这个特性,可通过以下过程来检测坐标,这也正是电阻触摸屏名称的由来,如下图。
 +{{ :​icore4t:​iCore4T_ARM_HAL_62_3.png?​direct&​600 |}}
 +  - 计算X坐标时,在X+电极施加驱动电压Vref,X-极接地,所以X+与X-处形成了匀强电场,而触点处的电压通过Y+电极采集得到,由于ITO层均匀导电,触点电压与Vref之比等于触点X坐标与屏宽度之比,从而:
 +{{ :​icore4t:​iCore4T_ARM_HAL_62_4.png?​direct&​200 |}}
 +  - 算Y坐标时,在Y+电极施加驱动电压Vref,Y-极接地,所以Y+与Y-处形成了匀强电场,而触点处的电压通过X+电极采集得到,由于ITO层均匀导电,触点电压与Vref之比等于触点Y坐标与屏高度之比,从而:
 +{{ :​icore4t:​iCore4T_ARM_HAL_62_5.png?​direct&​200 |}}
 +  * 为了方便检测触摸的坐标,一些芯片厂商制作了电阻屏专用的控制芯片,控制上述采集过程、采集电压,外部微控制器直接与触摸控制芯片通讯直接获得触点的电压或坐标。
  
-  * (二)LTDC 硬件框图: ​ 
-{{ :​icore4t:​iCore4T_ARM_HAL_63_1.png?​direct |}} 
-  * ltdc_aclk :为LTDC寄存器提供时钟,时钟来自AXI时钟域。 ​ 
-  * ltdc_pclk :LTDC寄存器接口时钟。  ​ 
-  * ltdc_ker_ck :用于生成LCD_CLK(像素时钟输出)的LTDC内核时钟。 ​ 
-  * ltdc_li_it :LTDC行中断,用于触发MDMA。 
-  * ltdc_it :LTDC全局中断请求。 ​ 
-  * ltdc_err_it :LTDC全局错误中断请求。 ​ 
-  * 下面是LCD接口引脚,用于外接显示屏: ​ 
-  * LCD_CLK :像素时钟输出。 ​ 
-  * LCD_HSYNC :水平同步信号。 ​ 
-  * LCD_VSYN :垂直同步信号。 ​ 
-  * LCD_DE :数据使能信号。 ​ 
-  * LCD_R[7:0] :8位红色数据。 ​ 
-  * LCD_G[7:0] :8 位绿色数据。 ​ 
-  * LCD_B[7:0] :8位蓝色数据。 
  
-=== 2.电阻触摸触摸相关知识=== +=== 在本实验中,选用电阻触摸芯片NS2009来实现触摸功能。以下为NS2009基础知识。 === 
-  * 有了TFT裸屏后还要配套电阻触摸板或者电容触摸板才可以获取触摸信息。触摸板贴到TFT屏上面的,然后再通过阻触摸芯片就可以获取阻触摸板的信息通过容触摸芯片采集容触摸板的信息目前市面上常用电阻触摸IC是STMPE811电容触摸IC是GT811、GT911和FT5X06。,电阻触摸电容触摸两者区别如下: +  * 1.电阻触摸芯片NS2009基本原理 
-  * 电阻触摸芯片STMPE811其实就是ADC返回的是ADC数值,而容触摸芯片GT811、GT911和FT5X06返回的是显屏实际的坐标值。 +    * NS2009一种典型逐次逼近型ADC(SAR ADC)包含采样/​保持,模数转换,I2C数据输出功能。单源供电,电压范围为2.0V~5.5V通过控制寄存器模拟输入(XY,Z)进入ADC,作为触摸屏应用,应将配置为差分模式以有效消除驱动器开关的寄生电阻和测量误差引起外部干扰,并改善转换精度。 
-  使用电阻触摸芯片STMPE811需要做触摸校准而使用电容触摸芯片GT811、GT911和FT5X06是自动校准,无需手动校准。 +  * 2.模拟输入特性 
- +    * MUX,ADC的模拟输入以及I2C接口路如下图所示。 
-=== 3.电容触摸芯片GT911介绍=== +{{ :​icore4t:​iCore4T_ARM_HAL_62_6.png?​direct&​800 |}} 
-  * 在本实验中,选用电容触摸芯片GT911来实现电容触摸功能。 +    ​控制字节顺序位C3,C2C1,C0以及NS2009之间配置关系如下表所示: 
-  * 电容触摸相比电阻触摸简单电容触摸不需要做触摸校准而且用是触摸板触摸芯片一体的也不需要做寄存器初始化配置上电后直接读取参数即。 +{{ :​icore4t:​iCore4T_ARM_HAL_62_7.png?​direct&​800 |}} 
-  * GT911、GT928、GT9147都属GT9系列非单层多点触控芯片,他们支持触控数不同(GT928支持10个点、GT911支持5个点)、驱动和感应通道也可能不同。可他们的寄存器和IIC通讯时序相同,也就说驱动序是兼容的。 +  * 3.差分模式 
-  * GT911是专为7”~8”设计的新一代5点电容触控方案拥有26个驱动通道和14个感应通道,以满足更高的touch精度要求。GT911可同时识别5个触摸点位的实时准确位置,移动轨迹及触摸面积。并可根据主控需要,读取应点数的触摸信息。 +    当命令控制位C3为高平时NS2009处于X,Y,Z的测量模式,内部ADC参考电压源差分模式如下图所示。差分模式优势:+REF-REF直接输入YPYN,可以消除由开关导通电阻引起测量误差。缺点是:无论充裕转换过程,驱动器都需要开启,相对于单端模式功耗增加了。 
-  * 与主机的接口共有6PIN分别为:VDD、GND、SCL、SDA、INT、RESET。 +{{ :​icore4t:​iCore4T_ARM_HAL_62_8.png?​direct&​400 |}} 
-    * INT、RESET不需要接上下拉电阻,可与主机直连。 +  * 4.压力测量 
-    SCL、SDA需要接上拉电阻4.7K,毕竟400KHz的通信频率,没有上拉可能导致SCL、SDA边沿不够陡峭。 +    * NS2009可测量触摸的压力,即Z方向的测量常,此类测量性能求不高因此可以使用8位分辨率模式但是,下面的计算是采用12位分辨率模式的即可。有几种不同的方法可以实现压力测量。 
-    * RST是复位引脚,拉低100us,即可复位工作时应该保持拉高。 +    * 第种方法需要知道X面板的电X的量位置,触摸屏面板在两个附加面板之间测量值(Z1Z2)使用列公式计算触摸: 
-    * INT是GT9xx触摸信号输出引脚,在正常工作时,主机端设置为悬浮输入即不上下拉GT9xx的驱动能力有限如果外部上拉,GT9xx可能驱动不了)。触摸发生时,INT引脚会输出上升沿或下降沿(内部寄存器可以配置),主机端可以一直读取INT脚的电平信号也可以用端口外部中断检。 +{{ :icore4t:iCore4T_ARM_HAL_62_9.png?direct&​400 ​|}} 
- +    第二种方法需要检测X和Y面板面板电阻XY位置以及Z1位置可以使用列公式计算触摸: 
-=== 4.电容触摸芯片GT911I2C通讯=== +{{ :icore4t:iCore4T_ARM_HAL_62_10.png?direct&​600 ​|}} 
- +{{ :icore4t:iCore4T_ARM_HAL_62_11.png?direct&​600 ​|}} 
-  * GT911提供标准的I2C通讯接口,由SCLSDA与主CPU进行通讯在系统中GT911始终作为从设备,所有通讯都是由主CPU发起,建议通讯速度为400Kbps或以下。其支持的I2C硬件路支持时序如下: +  * 5.字接口 
-{{ :icore4t:iCore4T_ARM_HAL_63_2.png?direct |}} +    NS2009的数据接口是I2C串行接口满足I2C接口协议可以实现标准模式(100K)快速模式(400K)或高速模式(3.4M)控制NS2009写入读取两种命令格式 ​write命令用于输入地址和命令字节以便在指定的NS2009配置和模式下工作NS2009 read命令用于输出ADC转换的数据以获得与测量的信。 
-  GT911I2C从设备地址有两组分别为0xBA/​0xBB0x28/0x29主控在上电初始化时控制Reset和INT口状态进行设定,设定方法及时序图如: +    * 1)Write Command ​命令时序图如下 
-  * 上时序图: +{{ :icore4t:iCore4T_ARM_HAL_62_12.png?direct&​800 ​|}} 
-{{ :icore4t:iCore4T_ARM_HAL_63_3.png?direct |}} +    * 地址字节个字节: 
-{{ :icore4t:iCore4T_ARM_HAL_63_4.png?direct |}} +{{ :icore4t:iCore4T_ARM_HAL_62_13.png?direct&​800 ​|}} 
- +    最低R / W(bit0),0表示写入命令1表示读取命令。 
-  * **1)据传输(以设备地址为0xBA/​0xBB为例)** +    * A0(Bit1)用于硬件地址的控制位该位必须与8引脚电平才能选中相的NS2009。 
- +    该软件最高5位地址必须输入一个固定的代码“10010” 
-  ​通讯总是由主 CPU 发起,有效起始信号为:在 SCL 保持为“1”时,SDA 上发生由“1”到“0”的跳变。地址信息或数据流均在起始信号之后传输。 +    * 第二个字节全部被接收后,NS2009在第9个时钟周期出响应信号ACK(0级)指示数据已经收到。 
-  * 所有连I2C总线上的从设备都要检测总线上起始信号之后所发送的8位地址信息 +    * 命令字节的第二个字节: 
-  * 并做出正确反应。在收到与自己相匹配的地址信息时GT911在第9个时钟周期将SDA改输出口并置“0”作为应答信号。若收到不与自己匹配的地址信息即非0XBA或0XBBGT911将保持闲置状态。 +{{ :​icore4t:​iCore4T_ARM_HAL_62_14.png?​direct&​800 |}} 
-  * SDA口上的数据按9个时钟周期串行发送9位数据:8位效数据+1位接收方发送应答号ACK或非应答信号NACK。数据传输在SCL为“1”时有效。 +    C3,C2,C1,C0决定输入信号的NS2009配置以及相应的测量功能。PD1,PD0用于控制内部基准电压源和笔中断信号,如下图所示: 
-  当通讯完成时,由主CPU发送停止信号。停止信号是当SCL为“1”时,SDA状态由“0”到“1”的跳变。 + {{ :icore4t:iCore4T_ARM_HAL_62_15.png?direct&​800 ​|}}  
- +    M----模式选择位ADC分辨率。MODE = 0ADC12位模式; MODE = 1,ADC为8位模式。 
-  * **2)对GT911操作(以设备地址为0xBA/​0xBB为例)** +    X位(bit3和bit0)为预留位,一设置为0。 
-{{ :icore4t:iCore4T_ARM_HAL_63_5.png?direct |}} +    * 在第二个字节全部被接收后NS2009将在第18个时钟周期发出响应信号ACK(0-电平)指示数据已收到。 
-  上图为主CPU对GT911进行的写操作流程图。首先主CPU产生一个起始信号,然后发送地址信息及读写位信息“0”表示写操作:​0XBA。在收到应答后,主CPU发送寄存器16位地址,随后是8位要写入到寄存器的数据内容GT911寄存器的地址指针会在写操作后自动加1,所以当主CPU需要对连续地址的寄存器进行写操作时,可以在次写操作中连续写入。写操作完成,主CPU发送停止信号结束当前写操作。 +    2)Read Command 读命令时序图如下 
- +{{ :icore4t:iCore4T_ARM_HAL_62_16.png?direct&​800 ​|}} 
-  * **3)对GT911读操作(以设备地址为0xBA/​0xBB为例)** +    读取命令包含3个字节,第一个字节是地址,类似于bit0为高的写命令;接下来的2个字节是NS2009的12位(如果是8位模,则仅为1字节数据),冗余4位为零。 
-{{ :icore4t:iCore4T_ARM_HAL_63_6.png?direct |}} +    NS2009收到地址数据的第一个字节后在第9时钟周期发出响应信号ACK(0电平),然后开始输出数据的第一个字节,主机收到数据第一个字节后应出响应主机ACK(0级)NS2009接收到掩码(masker ACK)后ACK开始送第二个字节的数据主机接收到第二个字节的数据后,不应答,此时,SDA将被拉高,也就是上图所示的掩码(masker ACK)信号
-  上图为主CPU对GT911进行读操作流程图。首先主CPU产生一个起始信号然后发送设备地址信息及读写位信息“0表示写操作:0XBA。在收到应答后主CPU发送首寄存器的16位地址信息,设置要读取的寄存器地址。在收到应答后主CPU重新发送次起始信号发送读操作:0XBB。收到答后,主CPU开始读取数据。 +
-  GT911同样支持连续读操作默认为连续读取数据。主CPU在每收到一个Byte数据后需发送一个应答信号表示成功接收。在接收到所需的最后一个Byte数据后,主CPU送“非信号NACK”然后再发送停止信号结束通讯。 +
- +
-===5.电容触摸芯片GT911功能描述=== +
-  (一)工作模式 +
-{{ :icore4t:iCore4T_ARM_HAL_63_7.png?direct |}} +
-  **a)Normal Mode** +
-  * GT911在Normal Mode时最快的坐标刷新周期为7ms-10ms间(依赖信息设定配置信息可控周期步进长度1ms)。 +
-  Normal mode状态下,一段时间无触摸事件发生,GT911将自动转入Green mode,以降低功耗。GT911无触摸自动进入Green mode的时间可通过配置信息设置,范围为0~15s,步进为1s。 +
-  * **b)Green Mode**  +
-  ​* 在Green mode下GT911扫描周期约为40ms若检测有触摸动作发生,自动进入Normal mode。 +
-  **c)Sleep Mode**  +
-  * 主CPU通过I2C命令,使GT911进入Sleep mode(需要先将INT脚输出低电平)。当需要GT911退出Sleep mode,主机输出一个高电平到INT脚(主机打高INT脚2~5ms),唤醒后GT911将进入Normal mode。 +
-{{ :icore4t:iCore4T_ARM_HAL_63_8.png?direct |}} +
- +
-  ​(二)断触发方式 +
-  当有触摸时GT911 每扫描周期均会通过 INT 脚发出脉冲信号,通知主 CPU 读取坐标信息。主CPU可以通过相关寄存器位“INT”来设置触方式。设为“0”表示上升沿触发即在有用户操作时GT911会在INT口输出上升沿跳变,通知 CPU;设为“1”表示下降沿触发,即在有户操作时,GT911会在INT口输出下降沿跳变+
  
 +  * 6.高速模式
 +    * 当主机发送的数据“00001XXX” 被NS2009接收到后,主机不需要等待响应,NS2009将进入高速模式(串行速率可以为3.4Mhz),直到主机发出停止信号。高速模式下,读/​写命令格式与标准模式和速度模式相同,但无法发出STOP信号,否则高速模式将终止。
 +  * 7.数据格式
 +    * NS2009输出的数据格式是标准的二进制格式。下图给出了不同电压对应的理想编码。
 +{{ :​icore4t:​iCore4T_ARM_HAL_62_17.png?​direct&​600 |}}
 +  * 8.PENIRQ中断输出功能
 +    * PENIRQ可以通过PD0设置,PEN中断输出功能如下图所示。
 +    * 当PD0=0时,YN驱动打开,Y触摸屏面板连接到GND。PENIRQ 输出通过两个开关连接到XP。在待机模式下,当有触摸屏操作时,XP输入通过触摸屏下拉至GND,PENIRQ输出为低电平。当没有运动的触摸屏断开至GND时,PENIRQ为高输出。在X,Y和Z的测量过程中,PENIRQ输出为低电平;
 +    * PD0 = 1,禁止了PEN中断功能,无法监视触摸屏上的触摸运动。如果要重新启用中断功能PEN,需要控制PD0 = 0写入NS2009,如果最后一个控制字包含PD0 = 0,则该命令完成后将使能PEN中断输出。
 +    * 为避免误触发,​建议处理器向NS2009发送命令时,​屏蔽掉PENIRQ的中断。
 +{{ :​icore4t:​iCore4T_ARM_HAL_62_18.png?​direct&​600 |}}
  
 ==== 四、 实验程序 ==== ==== 四、 实验程序 ====
icore4t_62.1604903705.txt.gz · 最后更改: 2020/11/09 14:35 由 fmj