找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 13410|回复: 36
收起左侧

STM32+XPT2046触摸屏带刷卡识别的程序和教程等资料下载

  [复制链接]
ID:194214 发表于 2017-8-18 23:04 | 显示全部楼层 |阅读模式
最近做了一个小项目,里面一个小部分,基于STM32刷卡带触摸屏,功能可能有点简单,但是可以继续往下编。还有刷卡号的识别要更改。

使用触摸屏-SPI程序时如果出现触摸不灵或者误差大,可以按照下面方法进行校正修改,如果使用可以强制校准程序则不需要,只需通过K_UP按键强制校准即可。

如果下载程序后对触摸屏划线,没有出现线条,可以显示触摸值变化,这个是因为没有对触摸屏校正,因此只需要在 touch.c 这个文件内的函数 void TOUCH_Init(void),将这个函数内的语句

if(TouchAdj.posState != TOUCH_ADJ_OK)
{
     TOUCH_Adjust(); //校正   
}  
改成
if(TouchAdj.posState == TOUCH_ADJ_OK)
{
     TOUCH_Adjust(); //校正   
}
编译后将HEX下载到开发板内进行触摸屏校正,校正完成后再修改为!=就可以了。   

0.png
本帖附件中可下载此压缩包

stm32单片机源程序如下(主程序):
  1. /*  程序下载进去后D1指示灯闪烁,表示程序正常运行,按下按键K_UP可以强制触摸校正  */
  2. #include "stm32f10x.h"
  3. #include "led.h"
  4. #include "system.h"
  5. #include "gui.h"
  6. #include "touch.h"
  7. #include "flash.h"
  8. #include "key.h"
  9. #include "systick.h"
  10. #include "tim.h"
  11. #include "RC522.h"
  12. #include "usart.h"

  13. uint16_t penColor;
  14. unsigned char data2[4]  = {0,0,0,0x01};
  15. unsigned char DefaultKey[6] = {0xFF, 0xFF, 0xFF, 0xFF, 0xFF, 0xFF};
  16. unsigned char g_ucTempbuf[20];
  17. void kai_display()  //开机显示
  18. {
  19.         TFT_ClearScreen(BLACK);
  20.     GUI_Show12Char(10,103,"欢迎使用",GREEN,BLACK);
  21.         GUI_Show12Char(10,10,"K_UP:Adjust",GREEN,BLACK);        
  22. }
  23. void lcd_display()           //LCD初始化显示
  24. {
  25.         TFT_ClearScreen(BLACK);
  26.         TFT_ClearScreen(BLACK);
  27.                         GUI_Show12Char(10,50,"关门           ",RED,BLACK);        //关门
  28.                         GUI_Show12Char(10,150,"            ",YELLOW,BLACK);
  29. }
  30. void display_init()  //初始化显示
  31. {
  32.         TFT_ClearScreen(BLACK);
  33.     GUI_Show12Char(0, TFT_YMAX - 16, "X:", RED, BLACK);
  34.     GUI_Show12Char(56, TFT_YMAX - 16, "Y:", RED, BLACK);
  35.     GUI_Show12Char(TFT_XMAX-8*3, 0, "RST", RED, BLACK);
  36.           GUI_Show12Char(56, TFT_YMAX - 106, "一号存储:", RED, BLACK);
  37.     GUI_Show12Char(56, TFT_YMAX - 156, "二号存储:", RED, BLACK);
  38.     GUI_Show12Char(56, TFT_YMAX - 206, "三号存储:", RED, BLACK);
  39. }

  40. int main(void)
  41. {     
  42.                 unsigned char status,i;
  43.         unsigned int temp;
  44.                   uint8_t touchValue[5] = {0, 0, 0, 0, 0};        

  45. //    uint32_t i;
  46.         penColor = BLUE;
  47.                 RC522_Init();
  48.     /* 初始化 */
  49.         PcdReset();
  50.          PcdAntennaOff();
  51.     TFT_Init();
  52.     FLASH_Init();      
  53.     LED_Config();
  54.         KEY_Config();
  55.     SYSTICK_Config();
  56.         delay_ms(10);
  57.          PcdAntennaOn();
  58.         delay_ms(10);
  59.         tim3_init(1000,7199);
  60.         uart_init(9600);
  61.         kai_display();
  62.         SYSTICK_Delay1ms(1500);   
  63.     TOUCH_Init();
  64.     display_init();

  65.         while(1)
  66.         {
  67.         if(KEY_Scan()==KEY_UP)   //按下K_UP按键 强制校准
  68.                 {
  69.                         TOUCH_Adjust(); //校正        
  70.                         display_init();
  71.                 }

  72.                 if(TOUCH_Scan() == 0)
  73.         {   
  74.             /* 显示X轴的物理坐标值 */
  75.             touchValue[0] = (TouchData.x % 10000 /1000) + '0';
  76.                     touchValue[1] = (TouchData.x % 1000 /100) + '0';
  77.                     touchValue[2] = (TouchData.x % 100 /10) + '0';
  78.                     touchValue[3] = (TouchData.x % 10) + '0';
  79.                     GUI_Show12Char(16, TFT_YMAX - 16, touchValue, RED, BLACK);
  80.             /* 显示Y轴的物理坐标值 */
  81.             touchValue[0] = (TouchData.y % 10000 /1000) + '0';
  82.                     touchValue[1] = (TouchData.y % 1000 /100) + '0';
  83.                     touchValue[2] = (TouchData.y % 100 /10) + '0';
  84.                     touchValue[3] = (TouchData.y % 10) + '0';
  85.             
  86.             GUI_Show12Char(72, TFT_YMAX - 16, touchValue, RED, BLACK);
  87.         }
  88.                                  status = PcdRequest(PICC_REQALL, g_ucTempbuf);//寻卡
  89.          if (status != MI_OK)
  90.          {   
  91.                      PcdReset();
  92.                      PcdAntennaOff();
  93.                      PcdAntennaOn();
  94.                           continue;
  95.          }                     
  96.                  printf("卡的类型:");
  97.             for(i=0;i<2;i++)
  98.                 {
  99.                         temp=g_ucTempbuf[i];
  100.                         printf("%X",temp);
  101.                         
  102.                 }        
  103.          status = PcdAnticoll(g_ucTempbuf);//防冲撞
  104.          if(status != MI_OK)
  105.          {    continue;    }
  106.                   
  107.                 ////////以下为超级终端打印出的内容////////////////////////
  108.         
  109.                 printf("卡序列号:");        //超级终端显示,
  110.                 for(i=0;i<4;i++)
  111.                 {
  112.                         temp=g_ucTempbuf[i];
  113.                         printf("%X",temp);
  114.                 }
  115.                 if(g_ucTempbuf[0]==0x37&&g_ucTempbuf[1]==0x25&&g_ucTempbuf[2]==0xAA&&g_ucTempbuf[3]==0x29)
  116.                 {
  117.                         GUI_Show12Char(10,50,"开门           ",GREEN,BLACK);        //开门
  118.                  GUI_Show12Char(10,10,"姓名:一号           ",RED,BLACK);
  119. //                        GPIO_SetBits(GPIOC, (uint16_t)0xff & 0x00FF);
  120.                                         if((TouchData.lcdx>50)&&(TouchData.lcdx<100))
  121.                  {
  122.                         if((TouchData.lcdy>280)&&(TouchData.lcdy<330))
  123.                         {
  124.                         GPIO_ResetBits(GPIOC, (~(uint16_t)0xfe) & 0x00FF);
  125.                         delay_ms(50000);
  126. //      TouchData.lcdx=0;
  127. //      TouchData.lcdy=0;
  128. //                                delay_ms(10);
  129. //                                         GPIO_SetBits(GPIOC, (uint16_t)0xfe& 0x00FF);     
  130.                         }
  131.                         if((TouchData.lcdy>220)&&(TouchData.lcdy<270))
  132.                         {
  133.                                 GPIO_ResetBits(GPIOC, (~(uint16_t)0xfd) & 0x00FF);
  134.         delay_ms(50000);
  135. //        TouchData.lcdx=0;
  136. //        TouchData.lcdy=0;                                
  137. //                                 delay_ms(10);
  138. //                                         GPIO_SetBits(GPIOC, (uint16_t)0xfd & 0x00FF);     
  139.                         }
  140.                         if((TouchData.lcdy>120)&&(TouchData.lcdy<180))
  141.                         {
  142.                                 GPIO_ResetBits(GPIOC, (~(uint16_t)0xfb) & 0x00FF);
  143.                           delay_ms(50000);
  144. //        TouchData.lcdx=0;
  145. //        TouchData.lcdy=0;                                
  146. //                                         delay_ms(10);
  147. //                                         GPIO_SetBits(GPIOC, (uint16_t)0xfb & 0x00FF);     
  148.                         }
  149.                         if ((TouchData.lcdx > TFT_XMAX-8*3) && (TouchData.lcdy < 16))//215 = TFT_XMAX - 24
  150.                         {
  151.                                   GPIO_SetBits(GPIOC, (uint16_t)0xff & 0x00FF);
  152.                         }
  153.                         delay_ms(50000);
  154.                         GPIO_SetBits(GPIOC, (uint16_t)0xff & 0x00FF);
  155.       TouchData.lcdx=0;
  156.       TouchData.lcdy=0;
  157.                  }
  158.                 }
  159.                 else        
  160.                 {        
  161.                   if(g_ucTempbuf[0]==0x1A&&g_ucTempbuf[1]==0x46&&g_ucTempbuf[2]==0x95&&g_ucTempbuf[3]==0x1E)
  162.                   {
  163. //                        led1=0;
  164.                         GUI_Show12Char(10,50,"开门           ",GREEN,BLACK);        //开门
  165.                  GUI_Show12Char(10,10,"姓名:二号          ",RED,BLACK);
  166. //                                GPIO_SetBits(GPIOC, (uint16_t)0xff & 0x00FF);
  167.                                         if((TouchData.lcdx>50)&&(TouchData.lcdx<100))
  168.                                 {
  169.                                         if((TouchData.lcdy>280)&&(TouchData.lcdy<330))
  170.                                         {
  171.                                         GPIO_ResetBits(GPIOC, (~(uint16_t)0xfe) & 0x00FF);
  172.             delay_ms(50000);
  173.             TouchData.lcdx=0;
  174.             TouchData.lcdy=0;                                                
  175. //                                                delay_ms(10);
  176. //                                                         GPIO_SetBits(GPIOC, (uint16_t)0xfe& 0x00FF);     
  177.                                         }
  178.                                         if((TouchData.lcdy>220)&&(TouchData.lcdy<270))
  179.                                         {
  180.                                                 GPIO_ResetBits(GPIOC, (~(uint16_t)0xfd) & 0x00FF);
  181.             delay_ms(50000);
  182.             TouchData.lcdx=0;
  183.             TouchData.lcdy=0;                                                
  184. //                                                 delay_ms(10);
  185. //                                                         GPIO_SetBits(GPIOC, (uint16_t)0xfd & 0x00FF);     
  186.                                         }
  187.                                         if((TouchData.lcdy>120)&&(TouchData.lcdy<180))
  188.                                         {
  189.                                                          GPIO_ResetBits(GPIOC, (~(uint16_t)0xfb) & 0x00FF);
  190.                delay_ms(50000);
  191.                TouchData.lcdx=0;
  192.                TouchData.lcdy=0;                                                
  193. //                                                         delay_ms(10);
  194. //                                                         GPIO_SetBits(GPIOC, (uint16_t)0xfb & 0x00FF);     
  195.                                         }
  196.                                         if ((TouchData.lcdx > TFT_XMAX-8*3) && (TouchData.lcdy < 16))//215 = TFT_XMAX - 24
  197.                            {
  198.                                                                 GPIO_SetBits(GPIOC, (uint16_t)0xff & 0x00FF);
  199.                            }
  200.                                 }
  201.                         if ((TouchData.lcdx > TFT_XMAX-8*3) && (TouchData.lcdy < 16))//215 = TFT_XMAX - 24
  202.                         {
  203.                                                                 GPIO_SetBits(GPIOC, (uint16_t)0xff & 0x00FF);
  204.                         }
  205.                                 
  206.                   }
  207.                         else
  208.                         {
  209. //                        led1=1;        
  210.                         GUI_Show12Char(10,50,"刷卡无法识别         ",RED,BLACK);
  211.                         }}}}
复制代码

所有资料51hei提供下载:
触摸屏刷卡.rar (1.95 MB, 下载次数: 579)

评分

参与人数 3黑币 +60 收起 理由
飛饵 + 5 很给力!
dfsdfsddffd + 5 很给力!
admin + 50 共享资料的黑币奖励!

查看全部评分

回复

使用道具 举报

ID:229153 发表于 2017-8-24 17:03 | 显示全部楼层
谢谢 !~
回复

使用道具 举报

ID:226427 发表于 2017-8-31 14:58 | 显示全部楼层
最近在调试一款屏幕,这个触屏的驱动总是有点问题,借鉴楼主的参考看看
回复

使用道具 举报

ID:68875 发表于 2017-9-3 22:11 | 显示全部楼层
不错的东西,收藏了
回复

使用道具 举报

ID:257535 发表于 2017-12-5 09:13 | 显示全部楼层
参考一下
回复

使用道具 举报

ID:277458 发表于 2018-1-18 16:58 | 显示全部楼层
参考一下看看
回复

使用道具 举报

ID:279690 发表于 2018-1-25 16:39 | 显示全部楼层
不错不错
回复

使用道具 举报

ID:285261 发表于 2018-2-24 19:11 | 显示全部楼层
来看看校准怎么写的。原子的看不懂
回复

使用道具 举报

ID:290556 发表于 2018-3-11 22:17 | 显示全部楼层
原子的也看了,不太懂,找这个来看看。
回复

使用道具 举报

ID:373 发表于 2018-4-8 11:46 | 显示全部楼层
学习下,不知道是不是很容易理解
回复

使用道具 举报

ID:304662 发表于 2018-4-10 16:48 | 显示全部楼层
好棒,感觉好厉害呀。
回复

使用道具 举报

ID:232751 发表于 2018-7-11 09:19 | 显示全部楼层
谢谢,学习下
回复

使用道具 举报

ID:149505 发表于 2018-7-17 09:00 | 显示全部楼层
谢谢分享!
回复

使用道具 举报

ID:384308 发表于 2018-8-8 17:55 | 显示全部楼层
多谢分享
回复

使用道具 举报

ID:89443 发表于 2018-9-7 09:19 | 显示全部楼层
学习了,谢谢分享
回复

使用道具 举报

ID:101507 发表于 2018-9-11 23:28 | 显示全部楼层
不错,好东西,谢谢分享
回复

使用道具 举报

ID:429839 发表于 2019-1-7 12:34 | 显示全部楼层
学习了 谢谢分享
回复

使用道具 举报

ID:506197 发表于 2019-4-7 13:05 | 显示全部楼层
谢谢 !学习一下
回复

使用道具 举报

ID:255779 发表于 2019-5-2 21:40 | 显示全部楼层
不错哦,可以仔细看看
回复

使用道具 举报

ID:486936 发表于 2019-5-14 08:49 | 显示全部楼层
请问有基于STC89C52的吗??
回复

使用道具 举报

ID:495731 发表于 2019-6-23 15:31 | 显示全部楼层
感謝分享!正在找這方面的資料!!
回复

使用道具 举报

ID:282095 发表于 2019-6-23 16:44 | 显示全部楼层
楼上所示里面应该包含RFID的相关技术吧
回复

使用道具 举报

ID:103831 发表于 2019-6-30 00:37 | 显示全部楼层

不错的东西,收藏了
回复

使用道具 举报

ID:613895 发表于 2019-9-20 08:56 | 显示全部楼层
不错不错,收藏了
回复

使用道具 举报

ID:229407 发表于 2019-10-25 15:22 | 显示全部楼层
项目正好要用到,谢谢分享!
回复

使用道具 举报

ID:669869 发表于 2020-1-8 22:32 | 显示全部楼层
不错,收藏了,感謝分享!
回复

使用道具 举报

ID:658039 发表于 2020-1-10 19:29 | 显示全部楼层
请问刷什么卡的?
回复

使用道具 举报

ID:695190 发表于 2020-2-19 16:07 | 显示全部楼层
参考一下,真心不错
回复

使用道具 举报

ID:260263 发表于 2020-2-19 17:15 | 显示全部楼层
非常好的视频,谢谢楼主分享
回复

使用道具 举报

ID:403336 发表于 2020-2-25 13:56 | 显示全部楼层
谢谢,下载学习
回复

使用道具 举报

ID:561907 发表于 2020-3-5 11:27 | 显示全部楼层
正好需要的资料,谢谢分享。
回复

使用道具 举报

ID:714544 发表于 2020-3-24 09:47 | 显示全部楼层
正好需要的资料,谢谢分享
回复

使用道具 举报

ID:194214 发表于 2020-3-31 16:40 | 显示全部楼层
shu_007 发表于 2020-1-10 19:29
请问刷什么卡的?

射频IC卡
回复

使用道具 举报

ID:888567 发表于 2021-3-5 09:49 | 显示全部楼层
***x:2065 y:3345 **
***x:2321 y:3345 **
***x:2577 y:3345 **
***x:3089 y:3345 **
***x:3345 y:3345 **
***x:3345 y:3089 **
***x:1121 y:1169 **
这是原始数据。。。 需要转换
回复

使用道具 举报

ID:576911 发表于 2021-9-3 15:17 | 显示全部楼层
谢谢。非常感谢楼主的分享。
回复

使用道具 举报

ID:6633 发表于 2021-9-21 22:58 | 显示全部楼层
感谢分享   调试一下看看
回复

使用道具 举报

ID:1041608 发表于 2022-8-13 12:39 | 显示全部楼层
这个LCD 是怎么接线的
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表