幸运时时彩平台

单片机+LCD12864数字示波器程序+Proteus仿真

2020-01-31来源: 51hei关键字:单片机  LCD12864  数字示波器  Proteus仿真

基于51单片机和Proteus仿真的数字示波器
 
#include
#include
//12864控制引脚定义
sbit DI = P2 ^ 2; //数据指令选择引脚
sbit RW = P2 ^ 1; //读写选择引脚
sbit E= P2 ^ 0;   //读写使能引脚
sbit CS1 = P2 ^ 4;    //片选1引脚
sbit CS2 = P2 ^ 3;    //片选2引脚
sbit BUSY= P1 ^ 7;    //忙标志位
//按键控制定义
sbit Y1 = P3 ^ 0;
sbit Y2 = P3 ^ 1;
sbit X1 = P3 ^ 3;
sbit X2 = P3 ^ 7;
//ADC0832控制引脚
sbit START=P3^4;
sbit OE=P3^6;
sbit EOC=P3^5;

unsigned int ADdata;    //AD采集值
unsigned int Ldata;
unsigned char ye,lei,shu;
unsigned char ADViewdata[91]; //AD显示数据存储区

char code FrameData[]={                     //提示字符存储区                                                                                                                                         
0x00,0x00,0x3F,0xF8,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0xFF,0xFE,0x01,0x00,
0x01,0x00,0x11,0x10,0x11,0x08,0x21,0x04,0x41,0x02,0x81,0x02,0x05,0x00,0x02,0x00,    //示
0x00,0x20,0x20,0x20,0x10,0x20,0x13,0xFE,0x82,0x22,0x42,0x24,0x4A,0x20,0x0B,0xFC,
0x12,0x84,0x12,0x88,0xE2,0x48,0x22,0x50,0x22,0x20,0x24,0x50,0x24,0x88,0x09,0x06,                //波                
0x00,0x00,0x3E,0x7C,0x22,0x44,0x22,0x44,0x3E,0x7C,0x01,0x20,0x01,0x10,0xFF,0xFE,
0x02,0x80,0x0C,0x60,0x30,0x18,0xC0,0x06,0x3E,0x7C,0x22,0x44,0x22,0x44,0x3E,0x7C,    //器 
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,
0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,0x00,    //" "
};
//AD转换软件
void ADCChage()
{
  START=1;
  START=0;
  while(EOC==0)  //等待转换完成
{
   OE=1;
}
  ADdata = P0;   //读取AD数据
        OE=0;
}
//检查12864液晶状态                               
void CheckState()
{
  DI=0;
        RW=1;
        do
        {
          E=1; 
          E=0;
   //仅当第7位为0时才可操作(判别busy信号)
        }while(BUSY==1);
}
//向12864写入一个字节的命令
void WriteCommand(unsigned char cmd)         
{
        CheckState();         //检查当前的12864状态
        DI = 0;
        RW = 0;
        P1 = cmd;             //送出相应的命令
        E = 1;
        E = 0;
}  
//向12864写入一个字节的数据
void WriteData(unsigned char dat)                
{
   CheckState();   //检查当前的12864状态
   DI = 1; 
   RW = 0;
   P1 = dat;       //送出相应的数据
   E = 1; 
   E = 0; 
}
//12864液晶的选择控制引脚
void LCMCSControl(unsigned int csl)
{
  if(csl==1)    //根据参数不同判断当前的12864控制引脚状态
  { 
    CS1=0,
    CS2=1;
  }
  if(csl==2)
  {
    CS1=1,
    CS2=0;
  }
  if(csl==3)
  {
    CS1=0,
    CS2=0;
  }
}
//12864显示函数
void LCMView()
{
  LCMCSControl(Ldata);     //先发送控制命令
  WriteCommand(ye);
  WriteCommand(lei);
  WriteData(shu);         //然后发送数据
}
//12864的清屏函数
void CleanScreen()                                                
{
        unsigned char page,i;
        LCMCSControl(3);
        for(page=0xb8;page<=0xbf;page++)
        {   
                WriteCommand(page);
                WriteCommand(0x40);
                for(i=0;i<64;i++)
    {
                  WriteData(0x00);
    }
        }
        LCMCSControl(1);
  lei=0x40;
        for(ye=0xb8;ye<0xbf;ye++)
        {
         shu=0xff;
         LCMView();
        }
        ye=0xb8;
        for(lei=0x40;lei<=0x7f;lei++)
        {
          shu=0x80;
          LCMView();
        }
        ye=0xbf;
        for(lei=0x40;lei<=0x7f;lei++)
        {
          shu=0x01;
          LCMView();
        }
  LCMCSControl(2);
  ye=0xb8;
        for(lei=0x40;lei<=0x5b;lei++)
  {
          shu=0x80;
          LCMView();
        }
        ye=0xbf;
        for(lei=0x40;lei<=0x5b;lei++)
        {
          shu=0x01;
          LCMView();
        }
        lei=0x5b;
        for(ye=0xb9;ye<=0xbe;ye++)
        {
         shu=0xff;
         LCMView();
        } 
}
//12864的初始化函数
void InitLCM(void)   
{        
  WriteCommand(0xc0);
        WriteCommand(0x3f);
}
//50us的延时函数
void Delay50us(unsigned int t)
{
unsigned char j;  
for(;t>0;t--)   
  for(j=19;j>0;j--);
}
//刷新12864液晶
void RefreshLCM()
{
  unsigned char i;
  for(i=0xb9;i<=0xbe;i++)
  {
    ye=i;
          shu=0x00;
          LCMView();
        }
}
//主函数
void main()
{
    unsigned int r,j,q,k;
    unsigned int Xaxis =0;
    unsigned int Yaxis = 1;
    unsigned char l;
    unsigned char d1,d2,d3,d4,d5;
    CleanScreen();
    InitLCM();
          LCMCSControl(2);
          l=0xb8;
          for(k=0;k<4;k++,l=l+0x02)         //首先显示右侧的提示
          {
            ye=l;
            lei=0x70;
            for(r=0;r<16;r++)
      {
        shu=FrameData[2*r+1+32*k];
              LCMView();
              lei++;
            }
            ye=l+0x01;
            lei=0x70;
            for(r=0;r<16;r++)
      { 
        shu=FrameData[2*r+32*k];
              LCMView();
              lei++;
            }
        }
  while(1)
  {
    while(X2==0)      //调节X轴
    {
      while(X2==0);
      Xaxis = Xaxis + 1;
    }
    while(X1==0)
    {
      while(X1==0);
      if(Xaxis!=0) 
      {
        Xaxis = Xaxis - 1;
      }
    }
    while(Y1==0)     //调节Y轴
    {
      while(Y1==0);
      Yaxis = Yaxis + 1;
    }
    while(Y2==0)
    {
      while(Y2==0);
      if(Yaxis!=1) 
      {
        Yaxis=Yaxis-1;
      }
    }
    for(j=0;j<90;j++) //AD采样最大值
    {
      ADCChage();
      ADViewdata[j]=ADdata;
      if(ADViewdata[j]>ADViewdata[91])
      {
        ADViewdata[91]=ADViewdata[j];
      }
      Delay50us(Xaxis);
    }
    while(ADdata!=ADViewdata[91])    //如果采集值不相等,则继续
    {
      ADCChage();
    }
    for(j=0;j<90;j++)      //连续采样90次
    {
       ADCChage();
       ADViewdata[j]=ADdata; 
       Delay50us(Xaxis);
    }
    lei=0x41;
    for(r=0,j=0;r<90;r++,j++)
          {
             if(j<63)
      { 
        Ldata=1;
      }
            if(j==63)
      { 
        lei=0x40;
      }
            if(j>=63)
      {
        Ldata=2;
      }
            RefreshLCM();     //刷新当前显示
            if(ADViewdata[j>=127])//正电压
            {                             
        ADdata=(ADViewdata[j]-127)*0.196/Yaxis;  //计算电压值
        if(ADdata<=7)       
        {
          ye=0xbb;
          shu=(0x80>>ADdata);
        }
              else if(ADdata<=15) 
        {
          ye=0xba;
          shu=(0x80>>(ADdata-8));
        }
        else if(ADdata<=23)
        {
          ye=0xb9;
          shu=(0x80>>(ADdata-16));
         }
        else if(ADdata<=31) 
        {
          ye=0xb9;
          shu=(0x80>>(ADdata-24));
        }
            }
            if(ADViewdata[j]<127)     //负电压
            {
                ADdata=(127-ADViewdata[j])*0.196/Yaxis;    //计算电压值
          if(ADdata<=7)
          {
              ye=0xbc;
              shu=(0x01<<(ADdata));
          }
          else if(ADdata<=15)
          {
              ye=0xbd;
              shu=(0x01<<(ADdata-8));
          }
          else if(ADdata<=23) 
          {
              ye=0xbe;
              shu=(0x01<<(ADdata-16));
          }
                else if(ADdata<=31)
          {
              ye=0xbe;
              shu=(0x01<<(ADdata-24));
          }
            }
      if(r==0)//判断正负
            {
              d1=shu;
              d2=ye;
             }
             if(r!=0)
            {
              d3=shu;
              d4=ye;
              if(ye==d2)  //如果相等,则判断是否显示完成
              {
                if(shu>d1)
                {
                  d5=shu;
                  d5=d5>>1;
                  while(d5!=d1)
                  {
              d5=d5>>1;
                    shu=shu|(shu>>1);
            }
                }
                if(shu                {
                  d5=shu;
                  d5=d5<<1;
                  while(d5!=d1)
                 {
              d5=d5<<1;
              shu=shu|(shu<<1);
           } 
                }
              }
        if(ye              {  
                for(q=0;q<7;q++) 
                {
                        shu=shu|(shu<<1);
                      } 
                    LCMView();
                     ye++;
                    while(ye        {
          shu=0xff;
          LCMView();
          ye++;
        }
                    if(ye==d2)
        {
                        shu=0x01;
                                          if(shu                  {
                    d5=shu;
                    d5=d5<<1;
                    while(d5!=d1)
                    {
                d5=d5<<1;
                shu=shu|(shu<<1);
               } 
                   }
                                          }
        }
              if(ye>d2)
              {
                for(q=0;q<7;q++) 
                {
                        shu=shu|(shu>>1);
                      }
                    LCMView();
                     ye--;
                    while(ye>d2) {shu=0xff,LCMView(),ye--;}
                    if(ye==d2)
        {
                        shu=0x80;
                                          if(shu>d1)
                  {
                    d5=shu;
                    d5=d5>>1;
                    while(d5!=d1)
                    {
                d5=d5>>1;
                shu=shu|(shu>>1);
               } 
                   }
                                } 
      }
          }
          if(r!=0)
          {
            d1=d3;
            d2=d4;
          }
    LCMView();
    if(lei!=0x7f)
    {
      lei++;
    }
   }
        }
}

关键字:单片机  LCD12864  数字示波器  Proteus仿真 编辑:什么鱼 引用地址:http://news.sonata9.com/mcu/ic486812.html 本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:单片机驱动TEA5767 FM立体声收音机C51通用源码
下一篇:单片机PWM+红外对管控制直流电机设计

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

AT90S8515单片机幸运时时彩平台SPI驱动74LS595源程序
AT90S8515使用SPI驱动74LS595。我这里使用了SS口线PB.4,作为74LS595的锁存信号,关键是把PB.4设置为输出。74LS595驱动发光管显示加1计数,我用SPI最高速度,所以显示16位计数高八位,低八位太快,看不清楚。单片机源程序如下://ICC-AVR application builder : 2020/3/30 22:23:31// Target : 8515// Crystal: 8.0000Mhz#include <io8515v.h>#include <macros.h>#define SS_ON PORTB |= BIT(4);     
发表于 2020-09-16
AT90S8515<font color='red'>单片机</font>SPI驱动74LS595源程序
avr单片机秒表Proteus仿真程序 tm1637数码管显示
单片机源程序如下:/***版权所有(c)2018,艁ukasz Marcin Podkalicki*2009年12月13日            *简单定时器(启动/复位/停止),使用基于TM1637的一个按钮和7段显示模块。              *            *注意,这个ATtiny13项目使用的内部时钟并不精确            
发表于 2020-09-16
avr<font color='red'>单片机</font>秒表Proteus仿真程序 tm1637数码管显示
基于MSP430F149的阻抗测量系统设计
  引 言  医学阻抗测量是利用生物组织与器官的电特性及其变化,提取与生物体生理、病理状况相关的生物医学信息的一种检测技术。它通常借助于驱动电极向检测对象送入一微小的交变电流(或电压)信号,同时测量两极的电压(或电流)信号,从而计算出相应阻抗,然后应用于不同目的。  本设计利用MSP430F149自带的串口通过RS485进行远距离实时传输,上位机可将实时数据进行曲线绘制、数据保存等处理。  1 系统结构  系统采用TI公司的MSP430F149单片机。该单片机有60 KB Flash、2 KB RAM,具有强大的数据处理能力。单片机通过向AD9852发送频率字、幅度字从而控制正弦波的频率、幅度。正弦波经过电流转电压、功率放大等电路
发表于 2020-09-16
基于MSP430F149的阻抗测量系统设计
单片机、ARM、MCU、DSP、FPGA、嵌入式的定义、特征及关系详解
首先,“嵌入式”这是个概念,准确的定义没有,各个书上都有各自的定义。但是主要思想是一样的,就是相比较PC机这种通用系统来说,嵌入式系统是个专用系统,结构精简,在硬件和软件上都只保留需要的部分,而将不需要的部分裁去。所以嵌入式系统一般都具有便携、低功耗、性能单一等特性。然后,MCU、DSP、FPGA这些都属于嵌入式系统的范畴,是为了实现某一目的而使用的工具。MCU 俗称”单片机“经过这么多年的发展,早已不单单只有普林斯顿结构的51了,性能也已得到了很大的提升。因为MCU必须顺序执行程序,所以适于做控制,较多地应用于工业。而ARM本是一家专门设计MCU的公司,由于技术先进加上策略得当,这两年单片机市场份额占有率巨大。ARM
发表于 2020-09-16
51单片机控制+MAX7219+DS1302 电子钟
/***************************************************程序名称:  MAX7219 C语言控制程序                          *程序功能: 3线串行控制8位共阴数码管                       &n
发表于 2020-09-16
基于单片机内部定时器中断计数器设计
电源电路就是单片机的供电电路,一般是3.3V或者5V,具体多少要参考各种型号的单片机的工作电压,通常情况下是5V,这里是指通常情况下。整体设计思路:单片机中断初始化程序应完成du如下工作:1、对TMOD赋值,以确定T0和T1的工作方式。2、计算初值,并将其写入TH0、TL0或TH1、TL1。3、中断方式时,则对IE赋值,开放中断。4、使TR0或TR1置位,启动定时/计数器定时或计数。整体设计思路单片机的中断为向量中断,即一响应中断就转入固定入口地址执行中断服务程序。各中断源服务程序的入口地址两个中断入口间只相隔8字节,难以安放一个完整的中断服务程序。因此,通常在中断入口地址处放置一条无条件转移指令,使程序执行转向中断服务程序入口
发表于 2020-09-16
基于<font color='red'>单片机</font>内部定时器中断计数器设计
小广播
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
电子工程世界版权所有 京ICP证060456号 京ICP备10001474号 电信业务审批[2006]字第258号函 京公海网安备110108001534 Copyright © 2005-2020 sonata9.com, Inc. All rights reserved
北京pk10 小米彩票开奖记录数据分析 幸运时时彩平台 小米彩票开奖 幸运时时彩 幸运时时彩 五分时时彩 北京pk10 幸运时时彩官网 湖南快乐十分官网