找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 5199|回复: 3
打印 上一主题 下一主题
收起左侧

超声波测距程序 lcd1602液晶显示

[复制链接]
跳转到指定楼层
楼主
超声波测距1602显示程序

Trig -------  P2^1;
Echo -------  P2^0;
VCC  -------- +5v
GND  -------- GND

请在上电之前,检查好接线是否正确。


超声波程序:
  1. /*******************************************************************************
  2. * 实 验 名                 : 矩阵键盘实验
  3. * 使用的IO             : 数码管使用P0,键盘使用P3.0、P3.1、P3.2、P3.3
  4. * 实验效果       : 按矩阵键盘分别显示在数码管上面显示十六进制的0到F。
  5. * 注    意                 :
  6. *******************************************************************************/
  7. #include<reg51.h>
  8. #include<intrins.h>       
  9. #include"lcd.h"

  10. sbit Trig = P2^1;
  11. sbit Echo = P2^0;



  12. unsigned char PuZh[]=" Pechin Science ";
  13. unsigned char code ASCII[15] =    {'0','1','2','3','4','5','6','7','8','9','.','-','M'};

  14. static unsigned char DisNum = 0; //显示用指针                                  
  15.        unsigned int  time=0;
  16.            unsigned long S=0;
  17.            bit      flag =0;
  18.            unsigned char disbuff[4]           ={ 0,0,0,0,};
  19. /*******************************************************************************
  20. * 函 数 名         : main
  21. * 函数功能                   : 主函数
  22. * 输    入         : 无
  23. * 输    出         : 无
  24. *******************************************************************************/
  25. void Conut(void)
  26.         {
  27.          time=TH0*256+TL0;
  28.          TH0=0;
  29.          TL0=0;
  30.        
  31.          S=(time*1.7)/100;     //算出来是CM
  32.          if((S>=700)||flag==1) //超出测量范围显示“-”
  33.          {         
  34.           flag=0;
  35.          
  36.           DisplayOneChar(0, 1, ASCII[11]);
  37.           DisplayOneChar(1, 1, ASCII[10]);        //显示点
  38.           DisplayOneChar(2, 1, ASCII[11]);
  39.           DisplayOneChar(3, 1, ASCII[11]);
  40.           DisplayOneChar(4, 1, ASCII[12]);        //显示M
  41.          }
  42.          else
  43.          {
  44.           disbuff[0]=S%1000/100;
  45.           disbuff[1]=S%1000%100/10;
  46.           disbuff[2]=S%1000%10 %10;
  47.           DisplayOneChar(0, 1, ASCII[disbuff[0]]);
  48.           DisplayOneChar(1, 1, ASCII[10]);        //显示点
  49.           DisplayOneChar(2, 1, ASCII[disbuff[1]]);
  50.           DisplayOneChar(3, 1, ASCII[disbuff[2]]);
  51.           DisplayOneChar(4, 1, ASCII[12]);        //显示M
  52.          }
  53.         }

  54. void zd0() interrupt 1                  //T0中断用来计数器溢出,超过测距范围
  55.   {
  56.     flag=1;                                                         //中断溢出标志
  57.   }

  58. void  StartModule()                          //启动模块
  59.   {
  60.           Trig=1;                                             //启动一次模块
  61.           _nop_();
  62.           _nop_();
  63.           _nop_();
  64.           _nop_();
  65.           _nop_();
  66.           _nop_();
  67.           _nop_();
  68.           _nop_();
  69.           _nop_();
  70.           _nop_();
  71.           _nop_();
  72.           _nop_();
  73.           _nop_();
  74.           _nop_();
  75.           _nop_();
  76.           _nop_();
  77.           _nop_();
  78.           _nop_();
  79.           _nop_();
  80.           _nop_();
  81.           _nop_();
  82.           Trig=0;
  83.   }



  84. void delayms(unsigned int ms)
  85. {
  86.         unsigned char i=100,j;
  87.         for(;ms;ms--)
  88.         {
  89.                 while(--i)
  90.                 {
  91.                         j=10;
  92.                         while(--j);
  93.                 }
  94.         }
  95. }

  96. void main(void)
  97. {
  98.          P1 = 0xF0;
  99.          TMOD=0x01;                   //设T0为方式1,GATE=1;
  100.          TH0=0;
  101.          TL0=0;         
  102.          ET0=1;             //允许T0中断
  103.          EA=1;                           //开启总中断       

  104.         InitLcd1602();
  105.         LcdShowStr(0,0,PuZh);
  106.         while(1)
  107.         {
  108.                  StartModule();
  109.              while(!Echo);                //当RX为零时等待
  110.              TR0=1;                            //开启计数
  111.              while(Echo);                        //当RX为1计数并等待
  112.              TR0=0;                                //关闭计数
  113.          Conut();                        //计算
  114.                  delayms(80);
  115.         }
  116.                        
  117. }
复制代码


10.超声波测距1602显示.7z

1.69 MB, 下载次数: 83, 下载积分: 黑币 -5

超声波测距

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏3 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:448975 发表于 2018-12-18 15:38 | 只看该作者
可惜没有仿真图啊
回复

使用道具 举报

板凳
ID:924280 发表于 2021-5-31 12:16 | 只看该作者
下载程序后不能自动测距
回复

使用道具 举报

地板
ID:967910 发表于 2021-9-28 16:13 | 只看该作者
有仿真图吗xd
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表