找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 10401|回复: 14
收起左侧

51单片机在LCD12864上画曲线的Proteus仿真及程序

  [复制链接]
ID:137190 发表于 2016-9-4 20:49 | 显示全部楼层 |阅读模式
0.png

51单片机在LCD12864上画曲线的源码如下:
  1. /********************************** LCD12864曲线显示*******************************************/
  2. /*********作者:王胜文。 email:nunk@163.com 希望与大家交流2017。08。03**********/

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

  11. uchar j=0,i=0;
  12. uchar r=32;
  13. /***********************在LCD上任意坐标画点********************************/

  14. void DrawPoint(uchar X,uchar Y,uchar Type)
  15. {                                                                         //X,Y化点的坐标Type画点的类型:反相点,檫除点,画点
  16.                                                    
  17.    uchar DX = (Y >> 3);               //计算出属于哪个字节
  18.    uchar BX = Y - (DX << 3);           //计算出属于字节哪一位
  19.    uchar TempData = 0;
  20.    
  21.    
  22.    if (X > 63)
  23.    {
  24.     chip_select=2;
  25.       X -= 64;
  26.    }
  27.    else
  28.    {
  29.       chip_select=1;
  30.    }

  31.    SetPage(DX);             //设行地址
  32.    SetColumn(X);                         //设列地址
  33.    
  34.    TempData = ReadData();   //读出所画点所在字节的内容
  35.    
  36.    switch (Type)            //对该字节进行相应操作
  37.    {
  38.        case Graphic_Clear:
  39.                                                   TempData &= ~(1<<BX);
  40.                                                  break;
  41.       case Graphic_Not:
  42.                                                  TempData ^= (1 << BX);
  43.                                                   break;
  44.       case Graphic_Draw:
  45.                                                   TempData |= (1 << BX);  
  46.                                                         break;
  47.           default:                                break;
  48.    }
  49.    
  50.    SetPage(DX);            //设置行地址
  51.    SetColumn(X);                          //设置列地址
  52.    WriteData(TempData);         //把修改后的字节送回LCD,达到画点目的
  53. }

  54. /********插值法画任意两点之间直线的函数,函数中只用加减法,程序运行效率很高**********/

  55. DrawLine(uchar x1,uchar y1,uchar x2,uchar y2)
  56. {                           //x1,y1起点坐标;x2,y2终点坐标;
  57.     uchar x,y;
  58.     uchar d_x,d_y;            
  59.     char err=0;
  60.     uchar temp=0;

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


  101. /***********************************************************************/

  102. void DrawLevel(void)
  103. {

  104. for(i=0;i<127;i++){DrawPoint(i,32,Graphic_Draw);}//画水平直线

  105. }

  106. /************************************************************************************/

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

  117.                 DrawLine(xn,yn,xi,yi);      //在一系列零散的点上,两点两点之间连线,从而得到一条曲线
  118.                
  119.                 xn=i;
  120.                 yn=yi;
  121.                
  122.                 }  
  123.                 }

  124. /*************************************************************************************/

  125. void DrawCircle(uchar x0,uchar y0,uchar r)//x0,y0为圆心坐标,r为圆半径
  126. {
  127. uchar xn,yn,xi,yi;
  128. unsigned int j;

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

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

  135.                 DrawLine(xn,yn,xi,yi);      //在一系列零散的点上,两点两点之间连线,从而得到一条曲线
  136.                
  137.                 xn=xi;
  138.                 yn=yi;
  139. }

  140. }

  141. /**************************************************************************************************/

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


  148. /**************************************************************************************************/

  149. void DrawTrigle(uchar x1,uchar y1,uchar x2,uchar y2,uchar x3,uchar y3)//画三角形,三个坐标为三角形顶点
  150. {
  151.         DrawLine(x1,y1,x2,y2);
  152.         DrawLine(x2,y2,x3,y3);
  153.         DrawLine(x1,y1,x3,y3);
  154.         
  155. }

  156. /******************************** main **********************************************************/

  157. void main(void)
  158. {

  159. ClearLCD();

  160. while(1)
  161. {

  162. ClearLCD();
  163. //DrawLevel();
  164. //DrawLine(0,63,127,0);
  165. DrawSineWave();

  166. //DrawCircle(63,32,r);
  167. //r-=4;
  168. //}

  169. //DrawRetic(10,10,30,30);
  170. //DrawTrigle(12,23,80,60,120,6);
  171. DrawRetic(5,5,120,60);
  172. }

  173. }
复制代码
0.png

仿真文件下载: Proteus中单片机89C51在LCD12864上画曲线.rar (62.69 KB, 下载次数: 192)
回复

使用道具 举报

ID:138707 发表于 2016-9-7 12:47 | 显示全部楼层
O(∩_∩)O谢谢   楼主分享
回复

使用道具 举报

ID:146583 发表于 2016-11-7 12:01 | 显示全部楼层
不错,学习学习
回复

使用道具 举报

ID:166657 发表于 2017-2-25 22:30 | 显示全部楼层
感谢分享,很详细
回复

使用道具 举报

ID:169968 发表于 2017-3-16 21:54 | 显示全部楼层
好东西,谢谢分享,给楼主点赞
回复

使用道具 举报

ID:192737 发表于 2017-4-23 16:46 | 显示全部楼层
学习,学习
回复

使用道具 举报

ID:192737 发表于 2017-4-23 17:13 | 显示全部楼层
这个带字库的和不带字库的引脚的定义有什么不同啊?
回复

使用道具 举报

ID:192737 发表于 2017-4-23 17:13 | 显示全部楼层
引脚CS1和CS2不怎么会接,我买的12864怎么没有这两个引脚的定义?
回复

使用道具 举报

ID:107680 发表于 2017-11-11 15:34 | 显示全部楼层
谢谢分享谢谢分享
回复

使用道具 举报

ID:265974 发表于 2017-12-24 11:39 | 显示全部楼层
感谢楼主分享
回复

使用道具 举报

ID:184706 发表于 2018-6-25 10:37 | 显示全部楼层
真棒  我就是要找这个 谢谢
回复

使用道具 举报

ID:499790 发表于 2019-4-18 01:14 | 显示全部楼层
不错下载下来研究一下
回复

使用道具 举报

ID:160450 发表于 2020-5-22 12:08 | 显示全部楼层
可以借鉴
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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