- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
单片机用矩阵键盘实现计算器
计算器1.程序要求: 用矩阵按键实现简单的加减乘除运算。2.程序代码:#include reg51.h#include stdio.hsbit col_1=P1^4;sbit col_2=P1^5;sbit col_3=P1^6;sbit col_4=P1^7;unsigned char code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f}; //共阴极数码管unsigned char keynum,flag;unsigned char num1,num2,flag1,flag2,flag3,flag4;void keyscan(void);void display();void keyfind(unsigned char);void keyprocess(void);void delay(unsigned int z) //延时1ms{ unsigned int x,y; for(x=110;x0;x--) for(y=z;y0;y--);}void main(void) { while(1) { keyscan(); //按键扫描函数 keyprocess(); //数据处理 display(); //数据显示 }} void keyscan(void){ col_1=0; col_2=0; col_3=0; col_4=0; if ((P10x0f)!=0x0f) //判断行线是否全为1,不是则处理 { col_1=0; //第一列输出0 col_2=1; col_3=1; col_4=1; keyfind(0); col_1=1; //第二列输出0 col_2=0; col_3=1; col_4=1; keyfind(4); col_1=1; //第三列输出0 col_2=1; col_3=0; col_4=1; keyfind(8); col_1=1; //第四列输出0 col_2=1; col_3=1; col_4=0; keyfind(12); col_1=0; //列线输出全为0 col_2=0; col_3=0; col_4=0; flag++; //每按一下标志位加1 while(((P10x0f)!=0x0f)); //等待按键释放 }}void keyfind(unsigned char col_dat){ unsigned char temp; temp=(~P1)0x0f; //求取各行状态 switch(temp) //键值计算 { case 1: keynum=1+col_dat; break; case 2: keynum=2+col_dat; break; case 4: keynum=3+col_dat; break; case 8: keynum=4+col_dat; break; } }void keyprocess(void){ switch(keynum) { case 1:if(flag==1) //flag=1表示是第一次按下,按得是被除数 num1=7; //第一个键按下对应是数字7 if(flag==3) //flag=3表示是第三次按下,按的是除数 num2=7; break; case 2:if(flag==1) num1=4; if(flag==3) num2=4; break; case 3:if(flag==1) num1=1; if(flag==3) num2=1; break; case 5:if(flag==1) num1=8; if(flag==3) num2=8; break; case 6:if(flag==1) num1=5; if(flag==3) num2=5; b
您可能关注的文档
- 化妆品业与经销商的博弈.doc
- 化妆品何招商才能吸引代理商?.doc
- 化学—人类进步的阶梯,绪论.ppt
- 化学与活第三讲.ppt
- 化学全试卷.doc
- 化学品产单位动土作业安全规范.doc
- 化学探活动案例.doc
- 化学纤相关指标.ppt
- 化学制法宝---期中错题积累.doc
- 化学实探究论文.doc
- 上海海洋大学《海洋环境分析技术》课件-21化学发光分析法.pdf
- 上海海洋大学《海洋环境分析技术》课件-20分子荧光分析法.pdf
- 上海海洋大学《海洋环境分析技术》课件-22色谱分离过程.pdf
- 上海海洋大学《海洋环境分析技术》课件-25气相色谱仪与固定液.pdf
- 上海海洋大学《海洋环境分析技术》课件-24色谱定性定量方法.pdf
- 上海海洋大学《海洋环境分析技术》课件-26气相色谱检测器.pdf
- 上海海洋大学《海洋环境分析技术》课件-29液相色谱固定相与流动相.pdf
- 上海海洋大学《海洋环境分析技术》课件-27气相色谱分离条件的选择.pdf
- 上海海洋大学《海洋环境分析技术》课件-28液相色谱仪器与类型.pdf
- 上海海洋大学《海洋环境分析技术》课件-3 原子光谱和分析光谱.pdf
文档评论(0)