找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3884|回复: 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 单片机教程网

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