单片机实现计算器.docVIP

  1. 1、本文档共9页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
单片机实现计算器

单片机实现计算器 #includereg51.h #includeabsacc.h #includeintrins.h #define unit unsigned int #define unchar unsigned char unchar dat; unit ss[8],b=0, result,A,H; unchar e; //sfr P4SW = 0xbb; sbit E=P2^6; sbit RW=P2^5; sbit RS=P2^4; //unchar bflag; void delay10ms() {unchar i,j,k; for(i=5;i0;i--) for(j=4;j0;j--) for(k=248;k0;k--); } unchar keyscan(void) //键盘扫描函数,使用行列反转扫描法 { unchar cord_h,cord_l,key;//行列值中间变量 P1=0x0f; //行线输出全为0 cord_h=P10x0f; //读入列线值 if(cord_h!=0x0f) //先检测有无按键按下 { delay10ms(); //去抖 if(cord_h!=0x0f) { cord_h=P10x0f; //读入列线值 P1=cord_h|0xf0; //输出当前列线值 cord_l=P10xf0; //读入行线值 key= cord_l+cord_h; P1=0x0f; while(P1!=0x0f); switch(key) { case 0x7e:dat=13;break; case 0x7d:dat=3;break;//1 case 0x7b:dat=2;break;//2 case 0x77:dat=1;break;//3 case 0xbe:dat=10;break;//4 case 0xbd:dat=6;break;//5 case 0xbb:dat=5;break;//6 case 0xb7:dat=4;break;//7 case 0xde:dat=12;break;//8 case 0xdd:dat=9;break;//9 case 0xdb:dat=8;break;//a case 0xd7:dat=7;break;//b case 0xed:dat=14;break;//d case 0xee:dat=11;break;//c case 0xeb:dat=0;break;//e case 0xe7:dat=15;break;//f default : dat=16;break; } return(dat); } } return(0xff); //返回该值 } unchar busy_1602() { P0=0xff; RS=0; RW=1; E=0; _nop_(); E=1; return (bit)(P00x80); } void wreg_1602(unchar com) { while(busy_1602()); RS=0; RW=0; E=1; P0=com; _nop_(); E=0; } void wdata_1602(unchar dat) {while(busy_1602()); RS=1; RW = 0; E=1; P0=dat; _nop_(); E=0; } void init_1602() { wreg_1602(0x38); delay10ms(); wreg_1602(0x38); wreg_1602(0x0c); wreg_1602(0x06); wreg_1602(0x01); delay10ms(); } unit length_z(unit z) {unit n=1 ; while(z10) { z=z/10; n++; } return n; } unit exp(unit m) {unit n=1; while(m) {n=10*n; --m; }

文档评论(0)

f8r9t5c + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:8000054077000003

1亿VIP精品文档

相关文档