找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3048|回復(fù): 1
打印 上一主題 下一主題
收起左側(cè)

ALIENTEK MINISTM32觸摸屏實驗源碼

[復(fù)制鏈接]
跳轉(zhuǎn)到指定樓層
樓主
ID:265406 發(fā)表于 2017-12-24 13:38 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
單片機源程序如下:
  1. #include "led.h"
  2. #include "delay.h"
  3. #include "sys.h"
  4. #include "usart.h"
  5. #include "lcd.h"
  6. #include "key.h"  
  7. #include "24cxx.h"
  8. #include "myiic.h"
  9. #include "touch.h"
  10. //ALIENTEK Mini STM32開發(fā)板范例代碼21
  11. //觸摸屏實驗  

  12. void Load_Drow_Dialog(void)
  13. {
  14.         LCD_Clear(WHITE);//清屏   
  15.         POINT_COLOR=BLUE;//設(shè)置字體為藍色
  16.         LCD_ShowString(lcddev.width-24,0,200,16,16,"RST");//顯示清屏區(qū)域
  17.           POINT_COLOR=RED;//設(shè)置畫筆藍色
  18. }
  19. ////////////////////////////////////////////////////////////////////////////////
  20. //電容觸摸屏專有部分
  21. //畫水平線
  22. //x0,y0:坐標
  23. //len:線長度
  24. //color:顏色
  25. void gui_draw_hline(u16 x0,u16 y0,u16 len,u16 color)
  26. {
  27.         if(len==0)return;
  28.         LCD_Fill(x0,y0,x0+len-1,y0,color);       
  29. }
  30. //畫實心圓
  31. //x0,y0:坐標
  32. //r:半徑
  33. //color:顏色
  34. void gui_fill_circle(u16 x0,u16 y0,u16 r,u16 color)
  35. {                                                                                          
  36.         u32 i;
  37.         u32 imax = ((u32)r*707)/1000+1;
  38.         u32 sqmax = (u32)r*(u32)r+(u32)r/2;
  39.         u32 x=r;
  40.         gui_draw_hline(x0-r,y0,2*r,color);
  41.         for (i=1;i<=imax;i++)
  42.         {
  43.                 if ((i*i+x*x)>sqmax)// draw lines from outside  
  44.                 {
  45.                         if (x>imax)
  46.                         {
  47.                                 gui_draw_hline (x0-i+1,y0+x,2*(i-1),color);
  48.                                 gui_draw_hline (x0-i+1,y0-x,2*(i-1),color);
  49.                         }
  50.                         x--;
  51.                 }
  52.                 // draw lines from inside (center)  
  53.                 gui_draw_hline(x0-x,y0+i,2*x,color);
  54.                 gui_draw_hline(x0-x,y0-i,2*x,color);
  55.         }
  56. }  
  57. //兩個數(shù)之差的絕對值
  58. //x1,x2:需取差值的兩個數(shù)
  59. //返回值:|x1-x2|
  60. u16 my_abs(u16 x1,u16 x2)
  61. {                         
  62.         if(x1>x2)return x1-x2;
  63.         else return x2-x1;
  64. }  
  65. //畫一條粗線
  66. //(x1,y1),(x2,y2):線條的起始坐標
  67. //size:線條的粗細程度
  68. //color:線條的顏色
  69. void lcd_draw_bline(u16 x1, u16 y1, u16 x2, u16 y2,u8 size,u16 color)
  70. {
  71.         u16 t;
  72.         int xerr=0,yerr=0,delta_x,delta_y,distance;
  73.         int incx,incy,uRow,uCol;
  74.         if(x1<size|| x2<size||y1<size|| y2<size)return;
  75.         delta_x=x2-x1; //計算坐標增量
  76.         delta_y=y2-y1;
  77.         uRow=x1;
  78.         uCol=y1;
  79.         if(delta_x>0)incx=1; //設(shè)置單步方向
  80.         else if(delta_x==0)incx=0;//垂直線
  81.         else {incx=-1;delta_x=-delta_x;}
  82.         if(delta_y>0)incy=1;
  83.         else if(delta_y==0)incy=0;//水平線
  84.         else{incy=-1;delta_y=-delta_y;}
  85.         if( delta_x>delta_y)distance=delta_x; //選取基本增量坐標軸
  86.         else distance=delta_y;
  87.         for(t=0;t<=distance+1;t++ )//畫線輸出
  88.         {  
  89.                 gui_fill_circle(uRow,uCol,size,color);//畫點
  90.                 xerr+=delta_x ;
  91.                 yerr+=delta_y ;
  92.                 if(xerr>distance)
  93.                 {
  94.                         xerr-=distance;
  95.                         uRow+=incx;
  96.                 }
  97.                 if(yerr>distance)
  98.                 {
  99.                         yerr-=distance;
  100.                         uCol+=incy;
  101.                 }
  102.         }  
  103. }   
  104. ////////////////////////////////////////////////////////////////////////////////
  105. //5個觸控點的顏色                                                                                                 
  106. //電阻觸摸屏測試函數(shù)
  107. void rtp_test(void)
  108. {
  109.         u8 key;
  110.         u8 i=0;          
  111.         while(1)
  112.         {
  113.                  key=KEY_Scan(0);
  114.                 tp_dev.scan(0);                  
  115.                 if(tp_dev.sta&TP_PRES_DOWN)                        //觸摸屏被按下
  116.                 {       
  117.                          if(tp_dev.x[0]<lcddev.width&&tp_dev.y[0]<lcddev.height)
  118.                         {       
  119.                                 if(tp_dev.x[0]>(lcddev.width-24)&&tp_dev.y[0]<16)Load_Drow_Dialog();//清除
  120.                                 else TP_Draw_Big_Point(tp_dev.x[0],tp_dev.y[0],RED);                //畫圖                                    
  121.                         }
  122.                 }else delay_ms(10);        //沒有按鍵按下的時候             
  123.                 if(key==KEY0_PRES)        //KEY0按下,則執(zhí)行校準程序
  124.                 {
  125.                         LCD_Clear(WHITE);//清屏
  126.                     TP_Adjust();  //屏幕校準
  127.                         TP_Save_Adjdata();         
  128.                         Load_Drow_Dialog();
  129.                 }
  130.                 i++;
  131.                 if(i%20==0)LED0=!LED0;
  132.         }
  133. }
  134. const u16 POINT_COLOR_TBL[CT_MAX_TOUCH]={RED,GREEN,BLUE,BROWN,GRED};  
  135. //電容觸摸屏測試函數(shù)
  136. void ctp_test(void)
  137. {
  138.         u8 t=0;
  139.         u8 i=0;                      
  140.         u16 lastpos[5][2];                //最后一次的數(shù)據(jù)
  141.         while(1)
  142.         {
  143.                 tp_dev.scan(0);
  144.                 for(t=0;t<CT_MAX_TOUCH;t++)//最多5點觸摸
  145.                 {
  146.                         if((tp_dev.sta)&(1<<t))//判斷是否有點觸摸?
  147.                         {
  148.                                 if(tp_dev.x[t]<lcddev.width&&tp_dev.y[t]<lcddev.height)//在LCD范圍內(nèi)
  149.                                 {
  150.                                         if(lastpos[t][0]==0XFFFF)
  151.                                         {
  152.                                                 lastpos[t][0] = tp_dev.x[t];
  153.                                                 lastpos[t][1] = tp_dev.y[t];
  154.                                         }
  155.                                         lcd_draw_bline(lastpos[t][0],lastpos[t][1],tp_dev.x[t],tp_dev.y[t],2,POINT_COLOR_TBL[t]);//畫線
  156.                                         lastpos[t][0]=tp_dev.x[t];
  157.                                         lastpos[t][1]=tp_dev.y[t];
  158.                                         if(tp_dev.x[t]>(lcddev.width-24)&&tp_dev.y[t]<16)
  159.                                         {
  160.                                                 Load_Drow_Dialog();//清除
  161.                                         }
  162.                                 }
  163.                         }else lastpos[t][0]=0XFFFF;
  164.                 }
  165.                
  166.                 delay_ms(5);i++;
  167.                 if(i%20==0)LED0=!LED0;
  168.         }       
  169. }
  170. ……………………

  171. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復(fù)制代碼

所有資料51hei提供下載:
ALIENTEK MINISTM32 觸摸屏實驗.rar (364.73 KB, 下載次數(shù): 55)


分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏2 分享淘帖 頂 踩
回復(fù)

使用道具 舉報

沙發(fā)
ID:435521 發(fā)表于 2018-12-4 08:49 | 只看該作者
大神這個案例是否是實現(xiàn)觸摸屏多功能畫筆工具?
回復(fù)

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規(guī)則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機教程網(wǎng)

快速回復(fù) 返回頂部 返回列表