久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 1025|回復: 0
打印 上一主題 下一主題
收起左側

簡易單片機計算器,最基礎的

[復制鏈接]
跳轉到指定樓層
樓主
剛學到,求助多功能計算器的設計


代碼:

#include         "reg51.h"
#include         "math.h"
#define         ON                10                                       
#define         ADD                 11
#define         SUB                 12
#define         MUL                 13
#define         DIV         14
#define         EQU        15
#define        BLANK        10                                       
#define        ERROR        11                                       
#define        MINUS        12                                       
sbit         SPEAKER = P3^7;                        
long Result,VarTmp;                        
unsigned char code LED[]={0xC0,0xF9,0xA4,0xB0,0x99,0x92,0x82,0xF8,0x80,0x90,0xff,0x86,0xbf};
                              
unsigned char code KeyTable[]={ON,0,EQU,ADD,1,2,3,SUB,4,5,6,MUL,7,8,9,DIV};
unsigned char DisplayNo ,Operate,MS,DisplayBuffer[8];   
bit Over,NoError=1,FirstInput=1;                        
unsigned int BeepTime,DelayTime;                     
void delayms(unsigned int ms)
{        DelayTime=ms;
        while(DelayTime);
}
unsigned char Key()                                      
{        unsigned char Row,Col,k;
                P1=0x0f;
                k=P1&0x0f;
                if(k==0x0f)        return -1;
        delayms(20);                                                
                k=P1&0x0f;
                if(k==0x0f)        return -1;
                BeepTime=300;                                               
                for(Row=0;Row<4;Row++)                                
                {        P1=0x7f>>Row;
                        k=P1&0x0f;
                        if(k!=0x0f)
                        {        Col=0;
                                while(k&(1<<Col))        Col++;        
                                break;
                }        }        
                while((P1&0x0f)!=0x0f);                                
                k= Row+Col*4;                                               
                return KeyTable[k];                                       
}
void ClrDisplayBuffer()                                
{        unsigned char i;
                for(i=0;i<7;i++)
                        DisplayBuffer[ i]=BLANK;
                DisplayBuffer[7]=0;
}
void ModifyDisplayBuffer(long num)               
{        unsigned char i;
                if(num>9999999||num<-9999999)                        
                {        ClrDisplayBuffer();
                        DisplayBuffer[0]=ERROR;                     
                        NoError=0;
                        return;
                }
                ClrDisplayBuffer();
                if(num<0)                                                      
                {        num=labs(num);                                       
                            DisplayBuffer[0]=MINUS;              
                }
                i=7;
        do
        {        DisplayBuffer[ i]=num%10;
                        num/=10;
                        i--;
                }while(num!=0);                                               
}
void Calculate()                                               
{        switch(Operate)
                {        case ADD:
                                        Result=Result+VarTmp;
                                 ModifyDisplayBuffer(Result);
                                        break;
                         case SUB:
                                        Result=Result-VarTmp;
                                 ModifyDisplayBuffer(Result);
                                        break;
                         case MUL:
                                        Result=Result*VarTmp;
                                        ModifyDisplayBuffer(Result);
                                        break;
                         case DIV:
                                        if(VarTmp!=0)
                                        {        Result=Result/VarTmp;
                                         ModifyDisplayBuffer(Result);
                                        }
                                        else                                               
                                        {        ClrDisplayBuffer();
                                                DisplayBuffer[0]=ERROR;
                                                NoError=0;
                                        }
                                        break;
}        }
void KeyProcess(unsigned char k)      
{        if(k==ON)                       
                {         Result=0,        VarTmp=0,Operate=0,Over=0,NoError=1,FirstInput=1;
                        ClrDisplayBuffer();
                }
                if(!NoError)         return;                                
                if(k<10)                                                        
                {        if(Over)         Over=0,VarTmp=0,Result=0,Operate=0,FirstInput=1;
                        VarTmp=VarTmp*10+k;
                        if(VarTmp>9999999)                VarTmp=VarTmp/10;
                        if(Operate)                FirstInput=0;
                        ModifyDisplayBuffer(VarTmp);
                }
                if(k>10&&k<15)                                                
                {        if(Over)                                               
                        {        Over=0,VarTmp=0,FirstInput=1, Operate=k;
                                return;
                        }
                        if(Operate&&FirstInput==0)                        
                        {        Calculate();
                                VarTmp=0,FirstInput=1;
                        }
                        if(Operate==0)                                       
                        {        Result=VarTmp;                        
                                VarTmp=0;                                       
                        }
                        Operate=k;
                }
                if(k==EQU)                                                
                {        if(Operate&&FirstInput==0)
                        {        Calculate();
                                Over=1;                                       
}                }        }
void main()                                                      
{        unsigned char k;
                TMOD=1;
                TR0=1;
                ET0=1;
                EA=1;
                ClrDisplayBuffer();
                while(1)
                {        k=Key();
                        if(k!=-1)                                               
                                KeyProcess(k);
}                }

void Display() interrupt 1                              
{        TL0=64536%256;                                       
                TH0=64536/256;
        if(DelayTime)DelayTime--;
                if(BeepTime)
                {        BeepTime--;                                       
                        SPEAKER=~SPEAKER;                     
                }
                P2=0;                                                      
        P0=LED[DisplayBuffer[DisplayNo]];               
                P2=1<<DisplayNo;                                       
                if(++DisplayNo==8)                                      
                        DisplayNo=0;
}

1705480153567.jpg (210.4 KB, 下載次數: 90)

Proteus圖

Proteus圖
分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 精品区| 91av小视频| 色综合视频| 欧美一级在线观看 | 成人妇女免费播放久久久 | 美女一级a毛片免费观看97 | 国产精品不卡一区 | 亚洲高清一区二区三区 | 手机看黄av免费网址 | 一区二区久久 | 精品国产乱码久久久久久a丨 | 国产成人福利在线观看 | 99久久婷婷国产综合精品电影 | 夜久久| 国产成人免费一区二区60岁 | 91在线精品秘密一区二区 | 黄色在线观看 | 91精品国产色综合久久 | 精品国产91久久久久久 | 日本免费网 | 日韩成人中文字幕 | 成人影院网站ww555久久精品 | 午夜视频一区二区 | 久久宗合色 | 国产在线观看网站 | 国产乱码精品1区2区3区 | 国产美女特级嫩嫩嫩bbb片 | 在线一级片 | 久久久高清 | 久久精品视频网站 | 一区二区免费看 | 毛片入口 | www.久草.com | 欧美日韩成人影院 | 精品免费国产一区二区三区四区 | 国产999精品久久久久久 | 国产免费看 | www.99热.com | av片免费 | 亚洲福利av | 亚洲欧美在线视频 |