【单片机】简易计算器完整代码带电路图

【单片机】51单片机计算器代码和电路图


一、问题描述

通过AT89C51单片机16位矩阵键盘设计简易计算器(仅能实现加减操作)

二、具体实现

1.完整代码带注释


#include<reg51.h>
#define uint unsigned int
#define uchar unsigned char

uchar code table[]=
					{0xfc,0x60,0xda,0xf2,0x66,0xb6,0xbe,
					0xe0,0xfe,0xf6,0xee,0x3e,0x9c,0x7a,0x9e,0x8e};//显示数字0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f
uchar code address[]={0xfe,0xfd};//位选1,2
					//1111 1110数码管显示第一位
					//1111 1101数码管显示第二位
uchar code KEY_TABLE[] = 
						{0xee,0xde,0xbe,0x7e,0xed,0xdd,0xbd,
						0x7d,0xeb,0xdb,0xbb,0x7b,0xe7,0xd7,0xb7,0x77};//(反转法)矩阵键盘的各个按键的计算值

void delay(int k)
{
	for( ; k>0; k--);
}

void delay1()
{
	uint n = 50000;while(n--);
}

void delay2()
{
	uint n = 10000;while(n--);
}

main()
{
	uchar temp,key,num,i;
	int sum,sign,j,a[16],k=0;
	while(1)
	{
		P3 = 0xf0;//1111 0000
		if(P3 != 0xf0)
		{
			delay2();
			if(P3 != 0xf0)
			{
				temp = P3;
				P3 = 0x0f;//0000 1111
				key = temp|P3;//低四位改变,若有键按下,得出低四位的值。xxxx 1111
				for(i=0; i<16; i++)
					if(key == KEY_TABLE[i])
					{	num = i;//0,1,2,3,,15
						delay(200);
						//0-14显示
						if(num>=0 && num<=14)
						{
							a[k++]=num;//a[0]=0
							P2 = address[0];//位选为0xfe,显示第一位数字
							P1 = table[num];//显示数字num
							delay(2000);
						 }  
					 
						else if(num==15)//按下15等号键进行判断
						{
							//判断输入的值是否合法
							if(a[0]>=0 && a[0]<=9 && (a[2]>=0 && a[2]<=9) && (a[1]==10 || a[1]==11))//1+2(第一位数字a[0],第二个运算符a[1]+-,第三位数字a[2])
									sign=1;//合法
							else
									sign=3;//不合法

							for(j=0;j<3;j++)//A+B循环三次,两个数字和一个运算符
							{
									if(a[j]==12||a[j]==13||a[j]==14)//如果是12,13,14位,无效键
										sign=0;
							}
						}
							
						if(sign==1)//合法
						{
							if(a[1]==10)//按下加号键
								sum=a[0]+a[2];//实现加法
							else if(a[1]==11)//按下减号键
								sum=a[0]-a[2];//实现减法
						}
					}
				delay1();
			}
		}
	
		//合法
		if(sign == 1)
		{
			if(sum<10)//0-9
			{
				P2=address[0];//位选为0xfe,显示第一位数字
				P1=table[sum];//显示数字table[sum]
			}
			else
			{
				for(i=0;i<100;i++)
				{
					P2=address[1];//位选为0xfd,显示第二位数字
					P1=table[sum/10];
					delay(1000);
					
					P2=address[0];//位选为0xfe,显示第一位数字
					P1=table[sum%10];
					delay(1000);
				}
			}
		}

		//不合法键判断
		if(sign == 3)
		{
			P2=address[0];//位选为0xfe,显示第一位数字
			P1=table[15];//显示字符f
					
			P2=address[1];//位选为0xfd,显示第二位数字
			P1=table[15];//显示字符f
		}

		//无效键判断
		if(sign == 0)
		{
			P2=address[0];//位选为0xfe,显示第一位数字
			P1=table[0];//显示字符f
					
			P2=address[1];//位选为0xfd,显示第二位数字
			P1=table[0];//显示字符f
		}
	}
}

2.电路图

初始界面
![计算器](https://img-blog.csdnimg.cn/20201120214433935.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3dlaXhpbl80ODcwMTUyMQ==,size_16,color_FFFFFF,t_70#pic_center
实现加法操作
在这里插入图片描述

总结

全网最详细代码,直接拿去用,感谢大家对我的关注!

51计算器程序#include #include #define uchar unsigned char #define uint unsigned int sbit lcden=P3^4; sbit lcdrw=P3^6; sbit lcdrs=P3^5; uchar num,temp,jia=0,cheng=0,chu=0,jian=0,qing=0; uint key,key1,shu; uchar fuhao,flag1,flag=0; uchar table[]={ 0x3F,0x06,0x5B,0x4F,0x66,0x6D,0x7D,0x07,0x7F,0x6F,0x00,}; void delay(uint z) { uint x,y; for(x=z;x>0;x--) for(y=114;y>0;y--); } bit lcd_bz() { bit result; lcdrs = 0; lcdrw= 1; lcden = 1; _nop_(); _nop_(); _nop_(); _nop_(); result=(bit)(P0&0x80;); lcden=0; return result; } void write_com(uchar com) { while(lcd_bz()); lcdrs=0; lcden=0; lcdrw=0; P0=com; delay(5); lcden=1; delay(5); lcden=0; } void write_date(uchar date) { while(lcd_bz()); lcdrs=1; lcden=0; lcdrw=0; P0=date; delay(5); lcden=1; delay(5); lcden=0; } void lcd_init() { lcden=0; write_com(0x38); write_com(0x0c); write_com(0x06); write_com(0x01); } void keyscan() { P3=0xfe; temp=P3; temp=temp&0xf0; while(temp!=0xf0) { delay(5); temp=P3; temp=temp&0xf0; while(temp!=0xf0) { temp=P3; switch(temp) { case 0xee:key=1;num=0;break; case 0xde:key=2;num=0;break; case 0xbe:key=3;num=0;break; case 0x7e:num=1;break; //¼ÓºÅ } while(temp!=0xf0) { temp=P3; temp=temp&0xf0; } } } P3=0xfd; temp=P3; temp=temp&0xf0; while(temp!=0xf0) { delay(5); temp=P3; temp=temp&0xf0; while(temp!=0xf0) { temp=P3; switch(temp) { case 0xed:key=4;num=0;break; case 0xdd:key=5;num=0;break; case 0xbd:key=6;num=0;break; case 0x7d:num=2;break; //¼õºÅ } while( temp!=0xf0) { temp=P3; temp=temp&0xf0; } } } P3=0xfb; temp=P3; temp=temp&0xf0; while(temp!=0xf0) { delay(5); temp=P3; temp=temp&0xf0; while(temp!=0xf0) { temp=P3; switch(temp) { case 0xeb:key=7;num=0;break; case 0xdb:key=8;num=0;break; case 0xbb:key=9;num=0;break
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

九芒星#

你的鼓励是我创作最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值