六位數的數碼管的計算器,能簡單的實現加減乘除的功能,能顯示負數
仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)
計算器.PNG (56.69 KB, 下載次數: 99)
下載附件
proteus仿真
2019-7-24 16:17 上傳
C程序代碼如下:
#include<reg52.h>
#include<math.h>
#define uchar unsigned char
#define uint unsigned int
#define ulong unsigned long
sbit wela=P2^7;
sbit dula=P2^6;
long in1,in2,out,x;
int cnt,i,flag;
uchar code num[]={
0x3f,0x06,0x5b,0x4f,
0x66,0x6d,0x7d,0x07,
0x7f,0x6f,0x77,0x7c,
0x39,0x5e,0x79,0x71};
void delay(uint xms) //延時函數
{
uint j;
for(i=xms;i>0;i--)
for(j=114;j>0;j--);
}
void display() //數碼管顯示函數
{
uchar w1,w2,w3,w4,w5,w6,f=0; //f是負號標志位
long y;
if(x>=0) //判斷數字正負
{
if(x>=1e6) //數是否超出6位數,若超出,數碼管顯示 CUO
{
P0=0xff;
wela=1;
P0=0xf7; //位碼值
wela=0;
dula=1;
P0=num[12]; //段碼值 顯示C
dula=0;
delay(2);
P0=0xff;
wela=1;
P0=0xef;
wela=0;
dula=1;
P0=0x3e; //段碼值顯示U
dula=0;
delay(2);
P0=0xff;
wela=1;
P0=0xdf;
wela=0;
dula=1;
P0=num[0]; //段碼值顯示0
dula=0;
delay(2);
return;
}
w1=x%10;w2=x/10%10;w3=x/100%10;w4=x/1000%10;w5=x/10000%10;w6=x/100000%10;//沒有超出6位數
if(f==1||w6) //顯示十萬位
{
f=1;
P0=0xff;
wela=1;
P0=0xfe;
wela=0;
dula=1;
P0=num[w6];
dula=0;
delay(2);
}
if(f==1||w5) //顯示萬位
{
f=1;
P0=0xff;
wela=1;
P0=0xfd;
wela=0;
dula=1;
P0=num[w5];
dula=0;
delay(2);
}
if(f==1||w4) //顯示千位
{
f=1;
P0=0xff;
wela=1;
P0=0xfb;
wela=0;
dula=1;
P0=num[w4];
dula=0;
delay(2);
}
if(f==1||w3) //顯示百位
{
f=1;
P0=0xff;
wela=1;
P0=0xf7;
wela=0;
dula=1;
P0=num[w3];
dula=0;
delay(2);
}
if(f==1||w2) //顯示十位
{
f=1;
P0=0xff;
wela=1;
P0=0xef;
wela=0;
dula=1;
P0=num[w2];
dula=0;
delay(2);
}
P0=0xff; //顯示個位
wela=1;
P0=0xdf;
wela=0;
dula=1;
P0=num[w1];
dula=0;
delay(2);
}
else //數為負數時
{
y=labs(x); //取絕對值
if(y>=1e5) //因為負號占一位,所以不能超過五位數,如果超出,顯示CUO
{
P0=0xff;
wela=1;
P0=0xf7;
wela=0;
dula=1;
P0=num[12];
dula=0;
delay(2);
P0=0xff;
wela=1;
P0=0xef;
wela=0;
dula=1;
P0=0x3e;
dula=0;
delay(2);
P0=0xff;
wela=1;
P0=0xdf;
wela=0;
dula=1;
P0=num[0];
dula=0;
delay(2);
return;
}
w1=y%10;w2=y/10%10;w3=y/100%10;w4=y/1000%10;w5=y/10000%10;
if(f==1||w5)
{
if(f==0)
{
P0=0xff;
wela=1;
P0=0xfe;
wela=0;
dula=1;
P0=0x40;
dula=0;
delay(2);
}
f=1;
P0=0xff;
wela=1;
P0=0xfd;
wela=0;
dula=1;
P0=num[w5];
dula=0;
delay(2);
}
if(f==1||w4)
{
if(f==0)
{
P0=0xff;
wela=1;
P0=0xfd;
wela=0;
dula=1;
P0=0x40;
dula=0;
delay(2);
}
f=1;
P0=0xff;
wela=1;
P0=0xfb;
wela=0;
dula=1;
P0=num[w4];
dula=0;
delay(2);
}
if(f==1||w3)
{
if(f==0)
{
P0=0xff;
wela=1;
P0=0xfb;
wela=0;
dula=1;
P0=0x40;
dula=0;
delay(2);
}
f=1;
P0=0xff;
wela=1;
P0=0xf7;
wela=0;
dula=1;
P0=num[w3];
dula=0;
delay(2);
}
if(f==1||w2)
{
if(f==0)
{
P0=0xff;
wela=1;
P0=0xf7;
wela=0;
dula=1;
P0=0x40;
dula=0;
delay(2);
}
f=1; //顯示第二位
P0=0xff;
wela=1;
P0=0xef;
wela=0;
dula=1;
P0=num[w2];
dula=0;
delay(2);
}
if(f==0)
{
P0=0xff;
wela=1;
P0=0xef;
wela=0;
dula=1;
P0=0x40;
dula=0;
delay(2);
}
P0=0xff;
wela=1;
P0=0xdf;
wela=0;
dula=1;
P0=num[w1];
dula=0;
delay(2);
}
}
void keyscan() //矩陣鍵盤掃描函數
{
uchar temp;
P1=0xfe;
temp=P1;
temp=temp&0xf0;
if(temp!=0xf0)
{
delay(8);
temp=P1;
temp=temp&0xf0;
if(temp!=0xf0)
{
temp=P1;
switch(temp)
{
case 0xee:
if(cnt<6)
{
cnt++;
if(flag==0)
{
in1=in1*10+7;
x=in1;
}
else
{
in2=in2*10+7;
x=in2;
}
}
break;
case 0xde:
if(cnt<6)
{
cnt++;
if(flag==0)
{
in1=in1*10+8;
x=in1;
}
else
{
in2=in2*10+8;
x=in2;
}
}
break;
case 0xbe:
if(cnt<6)
{
cnt++;
if(flag==0)
{
in1=in1*10+9;
x=in1;
}
else
{
in2=in2*10+9;
x=in2;
}
}
break;
case 0x7e:
if(cnt!=0&&flag==0)
{
cnt=0;
flag=4;
}
break;
}
while(temp!=0xf0)
{
temp=P1;
temp=temp&0xf0;
}
}
}
P1=0xfd;
temp=P1;
temp=temp&0xf0;
if(temp!=0xf0)
{
delay(8);
temp=P1;
temp=temp&0xf0;
if(temp!=0xf0)
{
temp=P1;
switch(temp)
{
case 0xed:
if(cnt<6)
{
cnt++;
if(flag==0)
{
in1=in1*10+4;
x=in1;
}
else
{
in2=in2*10+4;
x=in2;
}
}
break;
case 0xdd:
if(cnt<6)
{
cnt++;
if(flag==0)
{
in1=in1*10+5;
x=in1;
}
else
{
in2=in2*10+5;
x=in2;
}
}
break;
case 0xbd:
if(cnt<6)
{
cnt++;
if(flag==0)
{
in1=in1*10+6;
x=in1;
}
else
{
in2=in2*10+6;
x=in2;
}
}
break;
case 0x7d:
if(cnt!=0&&flag==0)
{
cnt=0;
flag=3;
}
break;
}
while(temp!=0xf0)
{
temp=P1;
temp=temp&0xf0;
}
}
}
P1=0xfb;
temp=P1;
temp=temp&0xf0;
if(temp!=0xf0)
{
delay(8);
temp=P1;
temp=temp&0xf0;
if(temp!=0xf0)
{
temp=P1;
switch(temp)
{
case 0xeb:
if(cnt<6)
{
cnt++;
if(flag==0)
{
in1=in1*10+1;
x=in1;
}
else
{
in2=in2*10+1;
x=in2;
}
}
break;
case 0xdb:
if(cnt<6)
{
cnt++;
if(flag==0)
{
in1=in1*10+2;
x=in1;
}
else
{
in2=in2*10+2;
x=in2;
}
}
break;
case 0xbb:
if(cnt<6)
{
cnt++;
if(flag==0)
{
in1=in1*10+3;
x=in1;
}
else
{
in2=in2*10+3;
x=in2;
}
}
break;
case 0x7b:
if(cnt!=0&&flag==0)
{
cnt=0;
flag=2;
}
break;
}
while(temp!=0xf0)
{
temp=P1;
temp=temp&0xf0;
}
}
}
P1=0xf7;
temp=P1;
temp=temp&0xf0;
if(temp!=0xf0)
{
delay(8);
temp=P1;
temp=temp&0xf0;
if(temp!=0xf0)
{
temp=P1;
switch(temp)
{
case 0xe7:
cnt=0;
in1=0;
in2=0;
out=0;
flag=0;
x=0;
break;
case 0xd7:
if(cnt<6)
{
cnt++;
if(flag==0)
{
in1=in1*10+0;
x=in1;
}
else
{
in2=in2*10+0;
x=in2;
}
}
break;
case 0xb7:
switch(flag)
{
case 1:
out=in1+in2;
break;
case 2:
out=in1-in2;
break;
case 3:
out=in1*in2;
break;
case 4:
if(in2)
out=in1/in2;
break;
}
x=out;
in1=0;
in2=0;
cnt=0;
flag=0;
break;
case 0x77:
if(cnt!=0&&flag==0)
{
cnt=0;
flag=1;
}
break;
}
while(temp!=0xf0)
{
temp=P1;
temp=temp&0xf0;
}
}
}
}
void main()
{
while(1)
{
keyscan();
display();
}
}
全部資料51hei下載地址:
計算器.zip
(117.55 KB, 下載次數: 48)
2019-7-24 16:17 上傳
點擊文件名下載附件
C代碼及proteus工程 下載積分: 黑幣 -5
|