定时器2超声波测距.docVIP

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

#include reg52.h #define uchar unsigned char #define uint unsigned int sfr T2MOD=0xc9; uint test,succeed_flag,time,timeH,timeL; sbit dula=P2^6; sbit wela=P2^7; sbit Echo=P3^2; sbit Trig=P2^0; sbit fm=P2^3; uchar code table[]={ 0x3f,0x06,0x5b,0x4f, 0x66,0x6d,0x7d,0x07, 0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71}; void delay(uint z) { uint x,y; for(x=z;x0;x--) for(y=110;y0;y--); } // void delay_20us() { uchar a ; for(a=0;a100;a++); } //*************************************************************** //显示数据转换程序 void display(uint temp) { uchar ge,shi,bai; bai=temp/100; shi=(temp%100)/10; ge=temp%10; wela=1; P0=0xf7; wela=0; dula=1; P0=table[bai]; dula=0; delay(1); dula=1; P0=0x00; //关位码 dula=0; wela=1; P0=0xef; wela=0; dula=1; P0=table[shi]; dula=0; delay(1); dula=1; P0=0x00; //关位码 dula=0; dula=1; P0=table[ge]; dula=0; wela=1; P0=0xdf; wela=0; delay(1); dula=1; P0=0x00; //关位码 dula=0; } //*************************************************************** void main() { uint distance; test =0; Trig=0; //首先拉低脉冲输入引脚 EA=1; //打开总中断0 T2MOD=0; T2CON=0; //定时器1,16位工作方式 while(1) { EA=0; //关总中断 Trig=1; //超声波输入端 delay_20us(); //延时20us Trig=0; //产生一个20us的脉冲 while(Echo==0); //等待Echo回波引脚变高电平 succeed_flag=0; //清测量成功标志 EA=1; EX0=1; //打开外部中断0 TH2=0; TL2=0; // RCAP2H=0; // RCAP2L=0; // TH2=RCAP2H; // TL2=RCAP2L; //定时器1清零 // TF2=0; //计数溢出标志 TR2=1; //启动定时器1 delay(20); //等待测量的结果 TR2=0; //关闭定时器1 EX0=0; //关闭外部中断0 if(succeed_flag==1) { time=timeH*256+timeL; distance=time*0.0172; //厘米 display(distance); }

文档评论(0)

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

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

1亿VIP精品文档

相关文档