久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 4519|回復: 0
打印 上一主題 下一主題
收起左側

Proteus中單片機89C51在LCD12864上畫曲線

[復制鏈接]
跳轉到指定樓層
樓主
Proteus中單片機89C51在LCD12864上畫曲線仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)


單片機源程序如下:
  1. /********************************** LCD12864曲線顯示*******************************************/

  2. #include<avr/io.h>
  3. #include<reg51.h>
  4. #include<drive_functions.h>
  5. #include<math.h>
  6. //#include<get_keys.h>
  7. #define Graphic_Clear 0x01   //檫除點
  8. #define Graphic_Not 0x02     //反相點
  9. #define Graphic_Draw 0x03         //畫點

  10. uchar j=0,i=0;
  11. uchar r=32;
  12. /***********************在LCD上任意坐標畫點********************************/

  13. void DrawPoint(uchar X,uchar Y,uchar Type)
  14. {                                                                         //X,Y化點的坐標Type畫點的類型:反相點,檫除點,畫點
  15.                                                    
  16.    uchar DX = (Y >> 3);               //計算出屬于哪個字節
  17.    uchar BX = Y - (DX << 3);           //計算出屬于字節哪一位
  18.    uchar TempData = 0;
  19.    
  20.    
  21.    if (X > 63)
  22.    {
  23.     chip_select=2;
  24.       X -= 64;
  25.    }
  26.    else
  27.    {
  28.       chip_select=1;
  29.    }

  30.    SetPage(DX);             //設行地址
  31.    SetColumn(X);                         //設列地址
  32.    
  33.    TempData = ReadData();   //讀出所畫點所在字節的內容
  34.    
  35.    switch (Type)            //對該字節進行相應操作
  36.    {
  37.        case Graphic_Clear:
  38.                                                   TempData &= ~(1<<BX);
  39.                                                  break;
  40.       case Graphic_Not:
  41.                                                  TempData ^= (1 << BX);
  42.                                                   break;
  43.       case Graphic_Draw:
  44.                                                   TempData |= (1 << BX);  
  45.                                                         break;
  46.           default:                                break;
  47.    }
  48.    
  49.    SetPage(DX);            //設置行地址
  50.    SetColumn(X);                          //設置列地址
  51.    WriteData(TempData);         //把修改后的字節送回LCD,達到畫點目的
  52. }

  53. /********插值法畫任意兩點之間直線的函數,函數中只用加減法,程序運行效率很高**********/

  54. DrawLine(uchar x1,uchar y1,uchar x2,uchar y2)
  55. {                           //x1,y1起點坐標;x2,y2終點坐標;
  56.     uchar x,y;
  57.     uchar d_x,d_y;            
  58.     char err=0;
  59.     uchar temp=0;

  60.     if(y2<y1){x=x1;y=y1;x1=x2;y1=y2;x2=x;y2=y;}
  61.     d_y=y2-y1;
  62.     if (d_y==0)
  63.         {
  64.         if (x1>x2) {x=x1;x1=x2;x2=x;}
  65.         for ( x=x1;x<=x2;x++ ) DrawPoint(x,y1,Graphic_Draw);
  66.         }
  67.     else
  68.         {
  69.     if(x2>=x1){temp=1;d_x=x2-x1;}else d_x=x1-x2;
  70.     x=x1;y=y1;DrawPoint(x,y,Graphic_Draw);
  71.     if(temp&&(d_y<=d_x))
  72.         while(x!=x2)
  73.             {if(err<0){x=x+1;err=err+(y2-y);}
  74.             else {x=x+1;y=y+1;err=err+(y2-y)-(x2-x);}
  75.             DrawPoint(x,y,Graphic_Draw);
  76.             }
  77.     else if(temp&&(d_y>d_x))
  78.         while(y!=y2)
  79.             {d_x=x2-x;d_y=y2-y;
  80.             if(err<0){x=x+1;y=y+1;err=err+d_y-d_x;}
  81.             else {y=y+1;err=err-d_x;}
  82.             DrawPoint(x,y,Graphic_Draw);
  83.             }
  84.     else if(!temp&&(d_y<=d_x))
  85.         while(x!=x2)
  86.             {d_x=x-x2;d_y=y2-y;
  87.             if(err<0){x=x-1;err=err+d_y;}
  88.             else {x=x-1;y=y+1;err=err+d_y-d_x;}
  89.             DrawPoint(x,y,Graphic_Draw);
  90.             }
  91.     else if(!temp &&(d_y>d_x))
  92.         while(y!=y2)
  93.             {d_x=x-x2;d_y=y2-y;
  94.             if(err<0){x=x-1;y=y+1;err=err+d_y-d_x;}
  95.             else {y=y+1;err=err-d_x;}
  96.             DrawPoint(x,y,Graphic_Draw);
  97.             }
  98.         }   
  99. }                                 


  100. /***********************************************************************/

  101. void DrawLevel(void)
  102. {

  103. for(i=0;i<127;i++){DrawPoint(i,32,Graphic_Draw);}//畫水平直線

  104. }

  105. /************************************************************************************/

  106. void DrawSineWave(void)
  107. {
  108.         uchar xn=0;
  109.         uchar yn=32;
  110.         uchar i;
  111.         uchar xi,yi;
  112. for(i=0;i<127;i++)
  113.         {
  114.                 xi=i;
  115.                 yi=(sin(i*0.1)*32)+32;

  116.                 DrawLine(xn,yn,xi,yi);      //在一系列零散的點上,兩點兩點之間連線,從而得到一條曲線
  117.                
  118.                 xn=i;
  119.                 yn=yi;
  120.                
  121.                 }  
  122.                 }

  123. /*************************************************************************************/

  124. void DrawCircle(uchar x0,uchar y0,uchar r)//x0,y0為圓心坐標,r為圓半徑
  125. {
  126. uchar xn,yn,xi,yi;
  127. unsigned int j;

  128. xn=cos(0)*r+x0;
  129. yn=sin(0)*r+y0;

  130. for(j=0;j<630;j++)
  131.         {
  132.                 xi=(cos(j*0.01)*r)+x0;
  133.                 yi=(sin(j*0.01)*r)+y0;

  134.                 DrawLine(xn,yn,xi,yi);      //在一系列零散的點上,兩點兩點之間連線,從而得到一條曲線
  135.                
  136.                 xn=xi;
  137.                 yn=yi;
  138. }

  139. }

  140. /**************************************************************************************************/

  141. void DrawRetic(uchar x0,uchar y0,uchar x1,uchar y1)//畫正方形,x0,y0為左上角坐標,x1,y1為右下角坐標
  142. {
  143.         uchar i;
  144.         for(i=0;i<=x1-x0;i++){  DrawPoint(x0+i,y0,Graphic_Draw);  DrawPoint(x0+i,y1,Graphic_Draw);  }
  145.         for(i=0;i<=y1-y0;i++){  DrawPoint(x0,y0+i,Graphic_Draw);  DrawPoint(x1,y0+i,Graphic_Draw);  }
  146.         }


  147. /**************************************************************************************************/

  148. void DrawTrigle(uchar x1,uchar y1,uchar x2,uchar y2,uchar x3,uchar y3)//畫三角形,三個坐標為三角形頂點
  149. {
  150.         DrawLine(x1,y1,x2,y2);
  151.         DrawLine(x2,y2,x3,y3);
  152.         DrawLine(x1,y1,x3,y3);
  153.        
  154. }

  155. /******************************** main **********************************************************/

  156. void main(void)
  157. ……………………

  158. …………限于本文篇幅 余下代碼請從51黑下載附件…………
復制代碼

所有資料51hei提供下載:
Proteus中單片機89C51在LCD12864上畫曲線.rar (62.69 KB, 下載次數: 44)


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

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 日本久久福利 | 在线观看午夜视频 | 国产美女在线观看 | 亚洲成人三级 | 国产精品久久a | 99久久婷婷国产综合精品电影 | 一区在线视频 | 精品一区二区三区四区五区 | 欧美性大战久久久久久久蜜臀 | 亚洲精品黄色 | 国产精品中文字幕在线 | 精品国产乱码一区二区三区 | 91精品一区二区三区久久久久久 | 精品久久一 | 网站黄色在线免费观看 | 韩国av一区二区 | 欧美极品在线观看 | 91亚洲精品国偷拍自产在线观看 | 色婷婷av99xx | 日韩精品一区二区三区在线播放 | 国产精品久久久久久久久免费桃花 | av黄色片| 午夜国产在线 | 亚洲一区二区网站 | 亚洲精彩免费视频 | 久草影视在线 | 日干夜操 | 啪啪综合网 | 日韩av一区二区在线观看 | 天堂在线免费视频 | 国产精品第2页 | 四虎影视免费观看 | 亚洲天天干| 国产日韩精品久久 | 久久久久久久久久久久久久av | 国产999精品久久久久久绿帽 | 精品一区二区三区四区 | 欧美日韩在线一区二区 | 国产中文字幕在线观看 | 欧美激情国产精品 | 成人片免费看 |