找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 4225|回复: 2
打印 上一主题 下一主题
收起左侧

51单片机用LCD12864做的示波器程序和Proteus仿真

  [复制链接]
跳转到指定楼层
楼主
用51单片机做的简易示波器,利用proteus里的波形生成器在通过ADC转换,就可以显示在LCD12864上。正弦波,三角波,方波等都能显示
仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


单片机源程序如下:
  1. #include "reg51.h"
  2. #include "LCD12864.h"
  3. #include "font.h"

  4. #define ADC_VALUE P0
  5. sbit START = P3^4;
  6. sbit OE    = P3^6;
  7. sbit EOC   = P3^5;

  8. #define COLLECT_NUM 64
  9. uint8_t adc_collect[COLLECT_NUM];


  10. uint8_t GatAdcValue()
  11. {
  12.     uint8_t temp;
  13.    
  14.     START = 1;
  15.     START = 0;   //  下降沿触发转换
  16.     OE = 1;
  17.     while(EOC == 0);   //等待转换完成
  18.     temp = ADC_VALUE;
  19.     OE = 0;
  20.     return temp;
  21.    
  22.    
  23. }


  24. void main()
  25. {
  26.     uint8_t i,j,k,row,col,page,Data;
  27.     uint8_t old_Data,old_page,temp_Data,temp_Data2,temp_page;
  28.     LCD12864_Init();
  29.    
  30.    
  31.     while(1)
  32.     {
  33.         for(i = 0;i<COLLECT_NUM;i++)
  34.             adc_collect[i] = GatAdcValue();
  35.         for(j = 0;j<COLLECT_NUM;j++)
  36.         {
  37.             col = j;          // 列
  38.             row = adc_collect[j]/4;   // 计算在第几行
  39.             page = row/8;
  40.             Data = 0x01 <<(row-page*8);
  41.             refresh_one_list(col);
  42.           
  43.             if(j!=0)
  44.             {
  45.                 temp_Data2 = Data;
  46.                 temp_page = page;
  47.                 if(page == old_page)   //  同一页内
  48.                 {
  49.                     if(Data > old_Data)     //波形下降  向上补充
  50.                     {
  51.                         temp_Data = Data;
  52.                         temp_Data = temp_Data>>1;
  53.                         while(temp_Data!=old_Data)
  54.                         {
  55.                             temp_Data = temp_Data>>1;
  56.                             Data = Data|(Data>>1);     //向上补充

  57.                         }
  58.                     }
  59.                     else if(Data < old_Data)    // 波形上升  向下补充
  60.                     {
  61.                         temp_Data = Data;
  62.                         temp_Data =temp_Data<<1;
  63.                         while(temp_Data!=old_Data)
  64.                         {
  65.                             temp_Data =temp_Data<<1;                           
  66.                             Data = Data|(Data<<1);     //向下补充
  67.                         }
  68.                     }
  69.                 } //end   if(page == old_page)   //  同一页内
  70.                 else if(page > old_page)   // 跨页下降   应该向上补充
  71.                 {
  72.                     temp_Data = Data;
  73.                     for(k = 0;k<(row-page*8);k++)    //向上补充到本页顶部
  74.                         temp_Data |= (temp_Data>>1);     //向上补充
  75.                     write_one_list(page,col,temp_Data);  //填充本页
  76.                     page--;      //往上一页
  77.                     while(page != old_page)   //填充两点之间的中间的页
  78.                     {
  79.                         write_one_list(page,col,0xFF);
  80.                         page --;
  81.                     }
  82.                     if(page == old_page)   // 来到了同一页
  83.                     {
  84.                         temp_Data = 0x80;
  85.                         Data = 0x80;
  86.                         if(Data>old_Data)
  87.                         {
  88.                             temp_Data = temp_Data>>1;          // 上移一格
  89.                             while(temp_Data != old_Data)
  90.                             {
  91.                                 temp_Data = temp_Data>>1;          // 上移一格                                       
  92.                                 Data = Data|(Data>>1);     // 向上补充
  93.                   
  94.                             }
  95.                         }
  96.                     }
  97.                 }//end  else if(page > old_page)   // 跨页下降   应该向上补充
  98.                 else if(page < old_page)    // 跨页上升    应该向下补充
  99.                 {
  100.                     temp_Data = Data;
  101.                     for(k = 0;k<(7-(row-page*8));k++)
  102.                     {    temp_Data|=(temp_Data<<1);}
  103.                     write_one_list(page,col,temp_Data);
  104.                     page++;     //向下一页
  105.                     while(page != old_page)
  106.                     {
  107.                         write_one_list(page,col,0xFF);
  108.                         page++   ;  // 下降一页
  109.                     }
  110.                     if(page == old_page)
  111.                     {
  112.                         Data = 0x01;
  113.                         temp_Data = 0x01;
  114.                         if(Data < old_Data)
  115.                         {
  116.                             temp_Data = temp_Data<<1;   //向下移动一格
  117.                             while(temp_Data != old_Data)
  118.                             {
  119.                                 temp_Data = temp_Data<<1;   //向下移动一格
  120.                                 Data |= (Data<<1);    //向下补充

  121.                             }
  122.                         }
  123. ……………………

  124. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
示波器.rar (124.61 KB, 下载次数: 161)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏6 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:510905 发表于 2021-4-28 11:09 | 只看该作者
仿真图在哪里啊,找不到
回复

使用道具 举报

板凳
ID:918467 发表于 2021-10-24 21:06 | 只看该作者
请问有原理图吗,实物图上12864怎么接,CS1,CS2改怎么接
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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