当前位置: 首页 > news >正文

51单片机四位数码管计算器 Proteus仿真程序

目录

概要

仿真图

部分代码

资料下载地址:51单片机四位数码管计算器 Proteus仿真程序

概要

1.系统通过4x4的矩阵键盘输入数字及运算符。 
2.可以进行4位十进制数以内的加法运算,如果计算结果超过4位十进制数,则屏幕显示E
3.可以进行加法以外的计算 (乘、除、减) 。

仿真图

 

 

部分代码

void main(){while(1){keyScan();                       pd();                                       display(num);                       }
}
void keyAdd(){              if(numKey<10000){num=num*10+numKey;numKey=10000;}
}
void pd(){keyAdd();                               if(fuhao=='c'){                       num=0;num0=0;fuhao0='0';fuhao='0';}if(fuhao=='+'){                       fuhao0='+';                       fuhao='0';                       num0=num;                       num=0;}if(fuhao=='-'){                               fuhao0='-';fuhao='0';num0=num;num=0;}       if(fuhao=='*'){                               fuhao0='*';fuhao='0';num0=num;num=0;}       if(fuhao=='/'){                       fuhao0='/';fuhao='0';num0=num;num=0;}if(fuhao=='='){                       if(fuhao0=='+')num=num0+num;else if(fuhao0=='-')num=num0-num;else if(fuhao0=='*')num=num0*num;else if(fuhao0=='/')num=num0/num;fuhao='0';num0=0;}
}
void keyScan(){P3=0xef;//1110 1111if(!P3_3){numKey=7;while(!P3_3);}if(!P3_2){numKey=8;while(!P3_2);}if(!P3_1){numKey=9;while(!P3_1);}if(!P3_0){fuhao='/';while(!P3_0);}P3=0xdf;if(!P3_3){numKey=4;while(!P3_3);}if(!P3_2){numKey=5;while(!P3_2);}if(!P3_1){numKey=6;while(!P3_1);}if(!P3_0){fuhao='*';while(!P3_0);}P3=0xbf;if(!P3_3){numKey=1;while(!P3_3);}if(!P3_2){numKey=2;while(!P3_2);}if(!P3_1){numKey=3;while(!P3_1);}if(!P3_0){fuhao='-';while(!P3_0);}P3=0x7f;if(!P3_3){fuhao='c';while(!P3_3);}if(!P3_2){numKey=0;while(!P3_2);}if(!P3_1){fuhao='=';while(!P3_1);}if(!P3_0){fuhao='+';while(!P3_0);}
}
void display(int num1){if(num1<= 9999)       {n4=num1%10;n3=num1/10%10;n2=num1/100%10;n1=num1/1000%10;P2=0x01;P0=duan[n1];DelayXms(4);P2=0x02;P0=duan[n2];DelayXms(4);P2=0x04;P0=duan[n3];DelayXms(4);P2=0x08;P0=duan[n4];DelayXms(4);}else{P2=0x01;P0=duan[10];DelayXms(4);P2=0x02;P0=duan[10];DelayXms(4);P2=0x04;P0=duan[10];DelayXms(4);P2=0x08;P0=duan[10];DelayXms(4);}}
void DelayXms(unsigned int x)               
{        unsigned char i, j;while(x--){        i = 2;j = 239;do{while (--j);}while (--i);}
}
http://www.lryc.cn/news/274285.html

相关文章:

  • 问题 B: 分牌
  • 3元一平方公里的在线卫星影像
  • 只会用 xxl-job?更强大的新一代分布式任务调度框架来了!
  • LeetCode-无重复字符的最长子串(3)
  • 【C#】知识点实践序列之Lock简单解决并发引起数据重复问题
  • NLP基础——TF-IDF
  • kubernetes(四)
  • 安科瑞变电站综合自动化系统在青岛海洋科技园应用——安科瑞 顾烊宇
  • 紫光展锐5G扬帆出海 | 欧洲积极拥抱更多5G选择
  • Open3D聚类算法
  • swing快速入门(三十九)进度对话框
  • Oracle-存储过程
  • L1-085:试试手气
  • nginx+keepalived实现七层负载
  • 机器人制作开源方案 | 智能盲道除雪小车
  • Mypy: 把静态类型检查带给Python
  • 【心得杂记】简单聊聊限制高速面阵相机性能的因素
  • 金蝶Apusic应用服务器 loadTree JNDI注入漏洞
  • 计算机毕业设计 基于SpringBoot的公司资产网站的设计与实现 Java实战项目 附源码+文档+视频讲解
  • 如何获取时间戳?
  • Vue页面传值:Props属性与$emit事件的应用介绍
  • 【mars3d】new mars3d.layer.GeoJsonLayer(实现环状面应该怎么传data
  • Websocket实时更新商品信息
  • 数据结构第六弹---带头双向循环链表
  • 洛谷——P1347 排序(图论-拓扑排序)
  • JVM内存管理
  • 将 Python 和 Rust 融合在一起,为 pyQuil® 4.0 带来和谐
  • Spring Boot应用程序中VO的理解及使用
  • 华为交换机ETH-TRUNK链路聚合lacp模式与手工模式
  • 函数图像化