本实验的源码工程在开发板光盘资料的:i.MX6UL终结者光盘资料\04_裸机例程源码\17_touchscreen 目录下。我们在Ubuntu系统下使用命令“mkdir 17_touchscreen”建立“17_touchscreen”文件夹,如图 1所示:

图 1

然后使用“cd 17_touchscreen”命令进入到17_touchscreen文件夹,如图 2所示:

图 2

然后使用命令“cp -r …/16_i2c/* ./”将上一章试验中的所有内容拷贝到刚刚新建的“17_touchscreen”里面,如图 3所示:

图 3

然后在drivers目录下建立touchscreen文件夹,用来保存触摸的驱动文件,然后在“drivers/touchscreen”目录中新建ft5xx6.c.h和ft5xx6.c.c两个文件,然后在ft5xx6.c.h文件输入下面的代码:

 1 #ifndef _FT5XX6_H2 #define _FT5XX6_H3 4 #include "imx6ul.h"5 #include "gpio.h"6 7 /* 宏定义 */8 #define FT5426_ADDR                    0X38    /* FT5426设备地址 */9 10 #define FT5426_DEVICE_MODE              0X00    /* 模式寄存器   */11 #define FT5426_IDGLIB_VERSION   0XA1             /* 固件版本寄存器     */12 #define FT5426_IDG_MODE                 0XA4    /* 中断模式           */13 #define FT5426_TD_STATUS                0X02     /* 触摸状态寄存器     */14 #define FT5426_TOUCH1_XH                0X03    /* 触摸点坐标寄存器,15                                                 * 一个触摸点用4个寄存器存
储坐标数据*/16 17 #define FT5426_XYCOORDREG_NUM   30          /* 触摸点坐标寄存器数量 */18 #define FT5426_INIT_FINISHED    1               /* 触摸屏初始化完成     */19 #define FT5426_INIT_NOTFINISHED 0               /* 触摸屏初始化未完成   */20 21 #define FT5426_TOUCH_EVENT_DOWN                 0x00   /* 按下         */22 #define FT5426_TOUCH_EVENT_UP                   0x01    /* 释放         */23 #define FT5426_TOUCH_EVENT_ON                   0x02    /* 接触         */24 #define FT5426_TOUCH_EVENT_RESERVED             0x03    /* 没有事件 */25 26 /* 触摸屏结构体 */27 struct ft5426_dev_struc28 {29         unsigned char initfalg;         /* 触摸屏初始化状态    */30         unsigned char intflag;          /* 标记中断有没有发生 */31         unsigned char point_num;       /* 触摸点      */32         unsigned short x[5];            /* X轴坐标      */33         unsigned short y[5];            /* Y轴坐标      */34 35 };36 37 extern struct ft5426_dev_struc ft5426_dev;38 39 /* 函数声明 */40 void ft5426_init(void);41 ^Mvoid gpio1_io9_irqhandler(void);42 unsigned char ft5426_write_byte(unsigned char addr,43                                 unsigned char reg,44                                 unsigned char data);45 unsigned char ft5426_read_byte(unsigned char addr,46                                 unsigned char reg);47 void ft5426_read_len(unsigned char addr,48                         unsigned char reg,49                         unsigned char len,50                         unsigned char *buf);51 void ft5426_read_tpnum(void);52 void ft5426_read_tpcoord(void);53 54 #endif

该文件主要定义了一些宏用来表示FT5426的I2C地址,寄存器,以及一些操作状态,然后在27行定义了一个保存触摸信息的结构体,最后声明了一些FT5426操作的函数。
接下来我们打开ft5xx6.c

  1 #include "ft5xx6.h"2 #include "i2c.h"3 #include "int.h"4 #include "delay.h"5 #include "stdio.h"6 7 struct ft5426_dev_struc ft5426_dev;8 9 /*10  * @description : 初始化触摸屏,其实就是初始化FT542611  * @param               : 无12  * @return              : 无13  */14 void ft5426_init(void)15 {16         unsigned char reg_value[2];17 18         ft5426_dev.initfalg = FT5426_INIT_NOTFINISHED;19 20         /* 1、初始化IIC2 IO21      * I2C2_SCL -> UART5_TXD22      * I2C2_SDA -> UART5_RXD23      */24         IOMUXC_SetPinMux(IOMUXC_UART5_TX_DATA_I2C2_SCL,1);25         IOMUXC_SetPinMux(IOMUXC_UART5_RX_DATA_I2C2_SDA,1);26 27         /* 配置I2C2 IO属性      28          *bit 16:0 HYS关闭29          *bit [15:14]: 1 默认47K上拉30          *bit [13]: 1 pull功能31          *bit [12]: 1 pull/keeper使能 32          *bit [11]: 0 关闭开路输出33          *bit [7:6]: 10 速度100Mhz34          *bit [5:3]: 110 驱动能力为R0/635          *bit [0]: 1 高转换率36          */37         IOMUXC_SetPinConfig(IOMUXC_UART5_TX_DATA_I2C2_SCL,0x70B0);38         IOMUXC_SetPinConfig(IOMUXC_UART5_RX_DATA_I2C2_SDA,0X70B0);39 40         /* 2、初始化触摸屏中断IO和复位IO */41         gpio_pin_config_t ctintpin_config;42 43         IOMUXC_SetPinMux(IOMUXC_GPIO1_IO09_GPIO1_IO09,0);       /* 复用为GPIO1_IO9 */44         IOMUXC_SetPinMux(IOMUXC_SNVS_SNVS_TAMPER9_GPIO5_IO09,0);/* 复用为GPIO5_IO9 */45 46         IOMUXC_SetPinConfig(IOMUXC_GPIO1_IO09_GPIO1_IO09,0xF080);47         IOMUXC_SetPinConfig(IOMUXC_SNVS_SNVS_TAMPER9_GPIO5_IO09,0X10B0);48 49         /* 中断IO初始化 */50         ctintpin_config.direction = kGPIO_DigitalInput;51         ctintpin_config.interruptMode = kGPIO_IntRisingOrFallingEdge;52         gpio_init(GPIO1, 9, &ctintpin_config);53 54         GIC_EnableIRQ(GPIO1_Combined_0_15_IRQn);        /* 使能GIC中对应的中断 */55         system_register_irqhandler(GPIO1_Combined_0_15_IRQn,56                                         (system_irq_handler_t)gpio1_io9_irqhandler,57                                         NULL);  /* 注册中断服务函数 */58         gpio_enableint(GPIO1, 9);               /* 使能GPIO1_IO18的中断功能 */59 60         /* 复位IO初始化 */61     ctintpin_config.direction=kGPIO_DigitalOutput;62     ctintpin_config.interruptMode=kGPIO_NoIntmode;63     ctintpin_config.outputLogic=1;64     gpio_init(GPIO5, 9, &ctintpin_config);65 66         /* 3、初始化I2C */67         i2c_init(I2C2);68 69         /* 4、初始化FT5426 */70         gpio_pinwrite(GPIO5, 9, 0);     /* 复位FT5426 */71         delayms(20);72         gpio_pinwrite(GPIO5, 9, 1); /* 停止复位FT5426 */73         delayms(20);74 75         ft5426_write_byte(FT5426_ADDR, FT5426_DEVICE_MODE, 0); /*正常模式 */76         ft5426_write_byte(FT5426_ADDR, FT5426_IDG_MODE, 1);   /* 中断模式 */77 78 79         ft5426_read_len(FT5426_ADDR,80                         FT5426_IDGLIB_VERSION,81                         2, reg_value);82         printf("Touch Frimware Version:%#X\r\n",83                         ((unsigned short)reg_value[0] << 8) + reg_value[1]);84 85         ft5426_dev.initfalg = FT5426_INIT_FINISHED;/* 标记FT5426初始化完成 */86         ft5426_dev.intflag = 0;87 }88 89 /*90  * @description         : GPIO1_IO9最终的中断处理函数91  * @param               : 无92  * @return              : 无93  */94 void gpio1_io9_irqhandler(void)95 {96         if(ft5426_dev.initfalg == FT5426_INIT_FINISHED)97         {98                 //ft5426_dev.intflag = 1;99                 ft5426_read_tpcoord();
100         }
101         gpio_clearintflags(GPIO1, 9); /* 清除中断标志位 */
102 }
103
104
105 /*
106  * @description : 向FT5429写入数据
107  * @param - addr: 设备地址
108  * @param - reg : 要写入的寄存器
109  * @param - data: 要写入的数据
110  * @return              : 操作结果
111  */
112 unsigned char ft5426_write_byte(unsigned char addr,
113                                 unsigned char reg,
114                                 unsigned char data)
115 {116     unsigned char status=0;
117     unsigned char writedata=data;
118     struct i2c_transfer masterXfer;
119
120     /* 配置I2C xfer结构体 */
121     masterXfer.slaveAddress = addr;     /* 设备地址 */
122     masterXfer.direction = kI2C_Write;  /* 写入数据 */
123     masterXfer.subaddress = reg;        /* 要写入的寄存器地址 */
124     masterXfer.subaddressSize = 1;      /* 地址长度一个字节 */
125     masterXfer.data = &writedata;       /* 要写入的数据 */
126     masterXfer.dataSize = 1;            /* 写入数据长度1个字节*/
127
128     if(i2c_master_transfer(I2C2, &masterXfer))
129         status=1;
130
131     return status;
132 }
133
134 /*
135  * @description : 从FT5426读取一个字节的数据
136  * @param - addr: 设备地址
137  * @param - reg : 要读取的寄存器
138  * @return      : 读取到的数据。
139  */
140 unsigned char ft5426_read_byte(unsigned char addr,
141                                 unsigned char reg)
142 {143         unsigned char val=0;
144
145         struct i2c_transfer masterXfer;
146         masterXfer.slaveAddress = addr; /* 设备地址 */
147         masterXfer.direction = kI2C_Read;       /* 读取数据 */
148         masterXfer.subaddress = reg;    /* 要读取的寄存器地址   */
149         masterXfer.subaddressSize = 1;  /* 地址长度一个字节     */
150         masterXfer.data = &val;         /* 接收数据缓冲区       */
151         masterXfer.dataSize = 1;        /* 读取数据长度1个字节  */
152         i2c_master_transfer(I2C2, &masterXfer);
153
154         return val;
155 }
156
157 /*
158  * @description : 从FT5429读取多个字节的数据
159  * @param - addr: 设备地址
160  * @param - reg : 要读取的开始寄存器地址
161  * @param - len : 要读取的数据长度.
162  * @param - buf : 读取到的数据缓冲区
163  * @return              : 无
164  */
165 void ft5426_read_len(unsigned char addr,
166                         unsigned char reg,
167                         unsigned char len,
168                         unsigned char *buf)
169 {170         struct i2c_transfer masterXfer;
171
172         masterXfer.slaveAddress = addr; /* 设备地址 */
173         masterXfer.direction = kI2C_Read;       /* 读取数据 */
174         masterXfer.subaddress = reg;    /* 要读取的寄存器地址 */
175         masterXfer.subaddressSize = 1;  /* 地址长度一个字节 */
176         masterXfer.data = buf;          /* 接收数据缓冲区 */
177         masterXfer.dataSize = len;              /* 读取数据长度1个字节*/
178         i2c_master_transfer(I2C2, &masterXfer);
179 }
180
181 /*
182  * @description : 读取当前触摸点个数
183  * @param               : 无
184  * @return              : 无
185  */
186 void ft5426_read_tpnum(void)
187 {188         ft5426_dev.point_num = ft5426_read_byte(FT5426_ADDR,
189                                                 FT5426_TD_STATUS);
190 }
191
192 /*
193  * @description : 读取当前所有触摸点的坐标
194  * @param               : 无
195  * @return              : 无
196  */
197 void ft5426_read_tpcoord(void)
198 {199         unsigned char i = 0;
200         unsigned char type = 0;
201         //unsigned char id = 0;
202         unsigned char pointbuf[FT5426_XYCOORDREG_NUM];
203
204         ft5426_dev.point_num = ft5426_read_byte(FT5426_ADDR,
205                                                 FT5426_TD_STATUS);
206
207         /*
208          *从寄存FT5426_TOUCH1_XH开始连续读取30个寄存器的值这30个寄存器
209          * 保存着5个点的触摸值,每个点占用6个寄存器。
210          */
211         ft5426_read_len(FT5426_ADDR,
212                         FT5426_TOUCH1_XH,
213                         FT5426_XYCOORDREG_NUM, pointbuf);
214
215         for(i = 0; i < ft5426_dev.point_num ; i++)
216         {217                 unsigned char *buf = &pointbuf[i * 6];
218                 /*以第一个触摸点为例寄存TOUCH1_XH(地址0X03),各位描述如下:
219                  * bit7:6  Event flag  0:按下 1:释放 2:接触 3:没有事件
220                  * bit5:4  保留
221                  * bit3:0  X轴触摸点的11~8位。
222                  */
223                 ft5426_dev.x[i] = ((buf[2] << 8) | buf[3]) & 0x0fff;
224                 ft5426_dev.y[i] = ((buf[0] << 8) | buf[1]) & 0x0fff;
225
226                 type = buf[0] >> 6;/* 获取触摸类型 */^M
227
228                 /*以第一个触摸点为例寄存TOUCH1_YH(地址0X05),各位描述如下:
229                  * bit7:4  Touch ID  触摸ID,表示是哪个触摸点
230                  * bit3:0  Y轴触摸点的11~8位。
231                  */
232                 //id = (buf[2] >> 4) & 0x0f;
233
234                 if(type == FT5426_TOUCH_EVENT_DOWN
235                         || type == FT5426_TOUCH_EVENT_ON )/* 按下 */
236                 {237
238                 } else  {       /* 释放 */
239
240                 }
241         }
242 }

ft5426_init函数完成触摸的初始化功能,此函数先初始化FT5426使用的I2C2的IO引脚,复位引脚和中断引脚,然后使能了中断,注册了中断处理函数,最后完成了I2C2和FT5426的初始化。

gpio1_io9_irqhandler函数是中断处理函数,在该函数中会调用ft5426_read_tpcoord函数读取触摸点的坐标信息。
ft5426_write_byte函数用于向FT5426写入一个字节数据。
ft5426_read_byte函数用于从FT5426读取一个字节的数据。
ft5426_read_len函数用于从FT5426读取一串数据。
ft5426_read_tpnum函数用于读取当前触摸点个数。
ft5426_read_tpcoord函数用于读取当前所有触摸点的坐标数据。

然后打开main.c文件,在里面输入下面的内容:

1 #include "clk.h"2 #include "delay.h"3 #include "led.h"4 #include "beep.h"5 #include "key.h"6 #include "int.h"7 #include "uart.h"8 #include "lcd.h"9 #include "lcdapi.h"10 #include "rtc.h"11 #include "ft5xx6.h"12 #include "gt9147.h"13 #include "stdio.h"14 15 /*16  * @description : 使能I.MX6U的硬件NEON和FPU17  * @param               : 无18  * @return              : 无19  */20  void imx6ul_hardfpu_enable(void)21 {22         uint32_t cpacr;23         uint32_t fpexc;24 25         /* 使能NEON和FPU */26         cpacr = __get_CPACR();27         cpacr = (cpacr & ~(CPACR_ASEDIS_Msk | CPACR_D32DIS_Msk))28                    |  (3UL << CPACR_cp10_Pos) | (3UL << CPACR_cp11_Pos);29         __set_CPACR(cpacr);30         fpexc = __get_FPEXC();31         fpexc |= 0x40000000UL;32         __set_FPEXC(fpexc);33 }34 35 /*36  * @description : main函数37  * @param               : 无38  * @return              : 无39  */40 int main(void)41 {42         unsigned char i = 0;43         unsigned char state = OFF;44 45         imx6ul_hardfpu_enable();/* 使能I.MX6U的硬件浮点         */46         int_init();             /* 初始化中断(一定要最先调用!) */47         imx6u_clkinit();        /* 初始化系统时钟               */48         delay_init();           /* 初始化延时                   */49         clk_enable();           /* 使能所有的时钟               */50         led_init();             /* 初始化led                    */51         beep_init();            /* 初始化beep                   */52         uart_init();            /* 初始化串口,波特率115200     */53         lcd_init();             /* 初始化LCD                    */54 55         /* 初始化触摸屏                                 */56         ft5426_init();57         //gt9147_init();58 59         tftlcd_dev.forecolor = LCD_RED;60         lcd_show_string(50, 10, 400, 24, 24, (char*)"i.MX6ULL TOUCH SCREEN TEST");61 62         lcd_show_string(50, 110, 400, 16, 16,   (char*)"TP Num  :");63         lcd_show_string(50, 130, 200, 16, 16,   (char*)"Point0 X:");64         lcd_show_string(50, 150, 200, 16, 16,   (char*)"Point0 Y:");65         lcd_show_string(50, 170, 200, 16, 16,   (char*)"Point1 X:");66         lcd_show_string(50, 190, 200, 16, 16,   (char*)"Point1 Y:");67         lcd_show_string(50, 210, 200, 16, 16,   (char*)"Point2 X:");68         lcd_show_string(50, 230, 200, 16, 16,   (char*)"Point2 Y:");69         lcd_show_string(50, 250, 200, 16, 16,   (char*)"Point3 X:");70         lcd_show_string(50, 270, 200, 16, 16,   (char*)"Point3 Y:");71         lcd_show_string(50, 290, 200, 16, 16,   (char*)"Point4 X:");72         lcd_show_string(50, 310, 200, 16, 16,   (char*)"Point4 Y:");73         tftlcd_dev.forecolor = LCD_BLUE;74 75         while(1)76         {77                 lcd_shownum(50 + 72, 110, ft5426_dev.point_num , 1, 16);78                 lcd_shownum(50 + 72, 130, ft5426_dev.x[0], 5, 16);79                 lcd_shownum(50 + 72, 150, ft5426_dev.y[0], 5, 16);80                 lcd_shownum(50 + 72, 170, ft5426_dev.x[1], 5, 16);81                 lcd_shownum(50 + 72, 190, ft5426_dev.y[1], 5, 16);82                 lcd_shownum(50 + 72, 210, ft5426_dev.x[2], 5, 16);83                 lcd_shownum(50 + 72, 230, ft5426_dev.y[2], 5, 16);84                 lcd_shownum(50 + 72, 250, ft5426_dev.x[3], 5, 16);85                 lcd_shownum(50 + 72, 270, ft5426_dev.y[3], 5, 16);86                 lcd_shownum(50 + 72, 290, ft5426_dev.x[4], 5, 16);87                 lcd_shownum(50 + 72, 310, ft5426_dev.y[4], 5, 16);88 89                 delayms(10);90                 i++;91 92                 if(i == 50)93                 {94                         i = 0;95                         state = !state;96                         led_switch(LED0,state);97                 }98         }99         return 0;
100 }

第56行调用ft5426_init初始化触摸屏,最后在while主循环里面每隔10毫秒就会更新获取到的触摸信息,以及对应的坐标信息,我们在本例程中使用的是中断获取触摸信息的方式,所以在main.c中并没有调用ft5426的获取触摸信息的函数。

i.MX6ULL终结者电容触摸实验程序设计相关推荐

  1. 基于stm32f10x(原子)的电容触摸实验的个人解读 (16)

    首先,我先介绍电容触摸按键的原理. 一个电容充满电的时候是需要一定时间,当两个电容并联的时候,此时,总电容大小就变成两个电容之和.导致充电的时间变成.电容触摸实验就是基于此,来根据时间的长短变换来确定 ...

  2. 迅为i.MX6ULL终结者Linux中断实验运行测试

    文章目录 1 编译驱动程序 2 编译应用测试程序 3 运行测试 1 编译驱动程序 和前面章节中驱动测试程序一样需要一个Makefile文件,只是将obj-m的值改为key_irq.o,Makefile ...

  3. 北京迅为i.mx6ull终结者开发板使用手册+嵌入式Linux开发指南+裸机手册下载地址

    i.MX6ULL终结者三大手册,加速学习和开发速度,一秒化无形! <嵌入式Linux开发指南>+<开发板使用手册>+<裸机使用手册> 详细手册点击链接下载:http ...

  4. 最简单DIY基于STM32的远程控制电脑系统①(电容触摸+按键控制)

    STM32库函数开发系列文章目录 第一篇:STM32F103ZET6单片机双串口互发程序设计与实现 第二篇:最简单DIY基于STM32单片机的蓝牙智能小车设计方案 第三篇:最简单DIY基于STM32F ...

  5. 判断按键值_「正点原子NANO STM32开发板资料连载」第十六章电容触摸按键实验...

    1)实验平台:ALIENTEK NANO STM32F411 V1开发板2)摘自<正点原子STM32F4 开发指南(HAL 库版>关注官方微信号公众号,获取更多资料:正点原子 第十六章电容 ...

  6. STM32精英版(正点原子STM32F103ZET6开发板)学习篇12——电容触摸按键实验

    电容触摸按键原理 RC充放电电路原理:   RC充放电原理,其实就是电(R)和电容(C)组成的串联电路.   按键开关未按下时,电路两端电压都是0V,无法形成电势差,也就无法形成电流.但当按键开关按下 ...

  7. STM32学习心得十九:电容触摸按键实验及相关代码解读

    记录一下,方便以后翻阅~ 主要内容 1) 电容触摸按键原理: 2)部分实验代码解读. 实验内容 手触摸按键后,LED1灯翻转. 硬件原理图 上图,TPAD与STM_ADC用跳线帽相连,即TPAD与PA ...

  8. STM32笔记20--电容触摸实验/IIC协议

    1.电容触摸按键实验 参考资料:<STM32开发指南-库函数版本>第16章 电容触摸按键实验 1.1.电容触摸按键实验原理 首先是模电的相关知识,如下图所示,当开关断开时,没有电流经过,电 ...

  9. ESP32 开发笔记(三)源码示例 6_TouchPad_Interrupt 电容触摸中断实现触摸按钮

    开发板购买链接 https://item.taobao.com/item.htm?spm=a2oq0.12575281.0.0.50111deb2Ij1As&ft=t&id=62636 ...

最新文章

  1. Canvas之translate,scale,rotate,skew
  2. 洛谷——P3811 【模板】乘法逆元
  3. Matlab 实现对 Excel sheet 重命名 合并单元格
  4. k1658停运_最新通知!福州这些列车停运!
  5. spyder python调试查看类信息_使用Spyder进行Python调试
  6. 01_Flume基本架构及原理
  7. js-Date()对象,get/setFullYear(),getDay()编程练习
  8. Linux命令行下WEP密码破解(通用,也可非BT平台)
  9. 荐书|图解深度学习与神经网络:从张量到TensorFlow实现
  10. 原理图和PCB设计流程概述
  11. 毕业季怎么做答辩PPT?
  12. 微信小程序 内容评论-回复评论-回复回复的实现
  13. MAC怎样显示隐藏文件
  14. sdk 今日头条_今日头条商业SDK(激励视频)的坑
  15. 第四百九十五日:念念不忘,必有回响
  16. itunes显示app store无法连接服务器,无法连接到iTunes Store的解决方案
  17. WCF,WPF,WWF 的新读音?WinCom, WinPrez, WinFlow
  18. 解决运行web项目问题:localhost: 8080 is already in use
  19. 小程序RSA加密 - 公钥加密
  20. CMake问题:The CXX compiler identification is unknown

热门文章

  1. 永远的友谊_友谊的传递属性-温馨介绍的重要性
  2. java中定义数组的3种方式
  3. vscode replace with a newline
  4. Linux服务器开发,开源框架log4cpp和日志模块实现
  5. 拼多多是如何做用户增长的?
  6. 3)数据科学的数学之序列与极限--阶乘/指数增长比较
  7. 我的2016——程序员年到三十,工作第四年
  8. 换计算机硬盘分区,笔记本提速,换硬盘,分区,系统迁移,装机!
  9. 什么是IDE,ATA,SATA,SCSI和SAS硬盘
  10. 软件质量模型(ISO/IEC 9126和Mc Call)