找回密码
 立即注册

QQ登录

只需一步,快速开始

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

基于51单片机的简易计算器

[复制链接]
跳转到指定楼层
楼主
ID:442545 发表于 2018-12-11 13:58 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
/******************************************************************
                                                        按键说明
                        s6-s8为数字123,s10-s12为数字456,s14-s16为789,s19为数字0,
                        s9为加,s13为减,s17为乘,s18为清零,s20为除,s21为等于。
程序功能:        本程序为简易计算器。可以算整数且正数类型的运算。
                        但是暂时没有实现其连算功能,故在每次运算之后,请按下清零键。
******************************************************************/
#include<reg51.h>

#define uchar unsigned char

uchar a0=16,b0=16,c0=16,d0=16,e0=16,f0=16,wei,temp,key,i,j,k;
uchar jia,jian,cheng,chu,dengyu,jia0,jian0,cheng0,chu0,qingling;
uchar s0,s1,s2,s3,s4,s5; //参加运算的各个位
unsigned long qian,hou;//定义参于运算的第一个数和第二个数。
sbit dula=P2^6;
sbit wela=P2^7;
sbit beep=P2^3;

unsigned char code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,
                        0x07,0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71,0x00};
/*******************************************************************
函数名:delay
功能:延时
形式参数:i
返回值:无
**********************************************************************/
void delay(uchar i)
{
        for(j=i;j>0;j--)
        for(k=125;k>0;k--);
}

/******************************************************************
函数名:display
功能:显示[ ][ ][ ][ ][ ][ ][ ][ ]
           效果[a][b][c][d][e][f][ ][ ]
形式参数:a b c d e f
           若参数是0-9,a-f正常显示;
           若参数是16,不显示。
返回值:无
*****************************************************************/
void display(uchar a,uchar b,uchar c,uchar d,uchar e,uchar f)
{

   dula=0;
   P0=table[a];
   dula=1;
   dula=0;

   wela=0;
   P0=0xfe;
   wela=1;
   wela=0;
   delay(5);

   P0=table[b];
   dula=1;
   dula=0;

   P0=0xfd;
   wela=1;
   wela=0;
   delay(5);

   P0=table[c];
   dula=1;
   dula=0;

   P0=0xfb;
   wela=1;
   wela=0;
   delay(5);

   P0=table[d];
   dula=1;
   dula=0;

   P0=0xf7;
   wela=1;
   wela=0;
   delay(5);

   P0=table[e];
   dula=1;
   dula=0;

   P0=0xef;
   wela=1;
   wela=0;
   delay(5);

   P0=table[f];
   dula=1;
   dula=0;

   P0=0xdf;
   wela=1;
   wela=0;
   delay(5);
}

void keyscan()
{
  {       
    P3=0xfe;
    temp=P3;
    temp=temp&0xf0;
    if(temp!=0xf0)
    {
      delay(10);
      if(temp!=0xf0)
      {       
        temp=P3;
        switch(temp)
        {
          case 0xee:
               key=1;
                           wei++;
               break;

          case 0xde:
               key=2;
                           wei++;
               break;

          case 0xbe:
               key=3;
                           wei++;
               break;

          case 0x7e:
               jia=1;
               break;
         }
         while(temp!=0xf0)
        {
           temp=P3;
           temp=temp&0xf0;
           beep=0;
         }
         beep=1;
      }
    }
    P3=0xfd;
    temp=P3;
    temp=temp&0xf0;
    if(temp!=0xf0)
    {
      delay(10);
      if(temp!=0xf0)
      {
        temp=P3;
        switch(temp)
        {
          case 0xed:
               key=4;
                           wei++;
               break;

          case 0xdd:
               key=5;
                           wei++;
               break;

          case 0xbd:
               key=6;
                           wei++;
               break;

          case 0x7d:
               jian=1;
               break;
         }
         while(temp!=0xf0)
         {
           temp=P3;
           temp=temp&0xf0;
           beep=0;
         }
         beep=1;
      }
      }
    P3=0xfb;
    temp=P3;
    temp=temp&0xf0;
    if(temp!=0xf0)
    {
      delay(10);
      if(temp!=0xf0)
      {
        temp=P3;
        switch(temp)
        {
          case 0xeb:
               key=7;
                           wei++;
               break;

          case 0xdb:
               key=8;
                           wei++;
               break;
                          
          case 0xbb:
                           key=9;
                           //key=10;
                           wei++;
               break;

          case 0x7b:
                        cheng=1;
                           //key=11;
                           //wei++;
               break;
         }
        while(temp!=0xf0)
         {
           temp=P3;
           temp=temp&0xf0;
           beep=0;
         }
         beep=1;
      }
      }
              P3=0xf7;
    temp=P3;
    temp=temp&0xf0;
    if(temp!=0xf0)
    {
      delay(10);
      if(temp!=0xf0)
      {
        temp=P3;
        switch(temp)
        {
          case 0xe7:
                            qingling=1;
               //key=12;
                          // wei++;
               break;

          case 0xd7:
               key=0;
                           wei++;
               break;

          case 0xb7:
               chu=1;
               break;

          case 0x77:
              dengyu=1;
               break;
         }
         while(temp!=0xf0)
         {
           temp=P3;
           temp=temp&0xf0;
           beep=0;
         }
         beep=1;
      }
    }
  }
}                               

void display0()
{
        if(key!=20)
        {
        switch(wei)
                {
                        case 1: a0=key;
                                        b0=16;
                                        c0=16;
                                        d0=16;
                                        e0=16;
                                        f0=16;
                                        break;
                        case 2: b0=key;
                                        c0=16;
                                        d0=16;
                                        e0=16;
                                        f0=16;
                                        break;
                        case 3: c0=key;
                                        d0=16;
                                        e0=16;
                                        f0=16;
                                        break;
                        case 4: d0=key;
                                        e0=16;
                                        f0=16;
                                        break;
                        case 5: e0=key;
                                        f0=16;
                                        break;
                        case 6: f0=key;
                                        //wei=0;
                                        break;
        }
        key=20;
        }
        display(a0,b0,c0,d0,e0,f0);
        if(a0!=16) s5=a0;
        if(b0!=16) s4=b0;
        if(c0!=16) s3=c0;
        if(d0!=16) s2=d0;
        if(e0!=16) s1=e0;
        if(f0!=16) s0=f0;
}


void main()
{        uchar gongneng,yunsuan;           //功能变量、运算变量
          while(1)
        {
                  keyscan();
                gongneng=jia|jian|cheng|chu|dengyu|qingling;
                if(gongneng==0)
                {
                        display0();       
                }
                else
                {         
                    yunsuan=jia|jian|cheng|chu;
                        if(yunsuan)
                        {       
       
                                a0=16;
                                b0=16;
                                c0=16;
                                d0=16;
                                e0=16;
                                f0=16;
                                //wei=0;
                                if(jia)
                                {jia=0;        jia0=1;jian0=0;cheng0=0;chu0=0;}
                                if(jian)
                                {jian=0;jia0=0;jian0=1;cheng0=0;chu0=0;}
                                if(cheng)
                                {cheng=0;jia0=0;jian0=0;cheng0=1;chu0=0;}
                                if(chu)
                                {chu=0;        jia0=0;jian0=0;cheng0=0;chu0=1;}
                                switch(wei)
                                {
                                        case 6:
                                        qian=s5*100000+s4*10000+s3*1000+s2*100+s1*10+s0;break;
                                        case 5:
                                        qian=s5*10000+s4*1000+s3*100+s2*10+s1;break;
                                        case 4:
                                        qian=s5*1000+s4*100+s3*10+s2;break;
                                        case 3:
                                        qian=s5*100+s4*10+s3;break;
                                        case 2:
                                        qian=s5*10+s4;break;
                                        case 1:
                                        qian=s5;break;
                                }
                                wei=0;
                                s0=0;s1=0;s2=0;s3=0;s4=0;s5=0;
                                display(a0,b0,c0,d0,e0,f0);
                                //P1=0x55;
                        }
                        if(dengyu)
                        {
                                 dengyu=0;
                                 //display(16,16,16,16,16,16);
                                 switch(wei)
                                {
                                        case 6:
                                        hou=s5*100000+s4*10000+s3*1000+s2*100+s1*10+s0;break;
                                        case 5:
                                        hou=s5*10000+s4*1000+s3*100+s2*10+s1;break;
                                        case 4:
                                        hou=s5*1000+s4*100+s3*10+s2;break;
                                        case 3:
                                        hou=s5*100+s4*10+s3;break;
                                        case 2:
                                        hou=s5*10+s4;break;
                                        case 1:
                                        hou=s5;break;
                                }
                                wei=0;
                                s0=0;s1=0;s2=0;s3=0;s4=0;s5=0;
                                 if(jia0)
                                 {jia0=0;        hou=qian+hou;}
                                 if(jian0)
                                 {jian0=0;        hou=qian-hou;}
                                 if(cheng0)
                                 {cheng0=0;        hou=qian*hou;}
                                 if(chu0)
                                 {chu0=0;        hou=qian/hou;}
                                 if(hou<10)
                                 {
                                         a0=hou;b0=16;c0=16;d0=16;e0=16;f0=16;
                                 }
                                 else
                                 {
                                         if(hou<100)
                                        {a0=hou/10;b0=hou%10;c0=16;d0=16;e0=16;f0=16;}
                                        else
                                        {
                                                if(hou<1000)
                                                {a0=hou/100;b0=hou%100/10;c0=hou%10;d0=16;e0=16;f0=16;}
                                                else
                                                {
                                                        if(hou<10000)
                                                        {a0=hou/1000;b0=hou%1000/100;c0=hou%100/10;d0=hou%10;e0=16;f0=16;}
                                                        else
                                                        {
                                                                if(hou<100000)
                                                                {a0=hou/10000;b0=hou%10000/1000;c0=hou%1000/100;d0=hou%100/10;e0=hou%10;f0=16;}
                                                                else
                                                                {
                                                                        if(hou<1000000)
                                                                        {a0=hou/100000;b0=hou%100000/10000;c0=hou%10000/1000;d0=hou%1000/100;e0=hou%100/10;f0=hou%10;}
                                                                }
                                                        }
                                                }
                                        }
                                 }
                                 display(a0,b0,c0,d0,e0,f0);
                                 P1=hou;
       
                        }
                        if(qingling)
                        {
                                a0=16;b0=16;c0=16;d0=16;e0=16;f0=16;
                                s0=0;s1=0;s2=0;s3=0;s4=0;s5=0;
                                jia=0;jian=0;cheng=0;chu=0;
                                jia0=0;jian0=0;cheng0=0;chu0=0;
                                qingling=0;dengyu=0;
                                qian=0;hou=0;
                                display(a0,b0,c0,d0,e0,f0);
                        }
                       
                }

        }
}

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

使用道具 举报

沙发
ID:1 发表于 2018-12-11 20:47 | 只看该作者
补全原理图或者详细说明一下电路连接即可获得100+黑币
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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