查看: 874|回复: 0

msp430超声波测距思路

[复制链接]

该用户从未签到

发表于 2020-11-24 19:58:56 | 显示全部楼层 |阅读模式
分享到:
LCD初始化,显示LOGO;
给超声波模块一个触发信号;
检测超声波模块的输出信号,如果监测为高,启动定时器计时;如果检测为低,关闭定时器;
根据定时器计时时间和公式算出距离;
将距离送给LCD显示;
15.jpg [size=0.83em]

360截图20191010094528193.jpg (31.58 KB, 下载次数: 0)

下载附件  [url=]保存到相册[/url]

[color=rgb(153, 153, 153) !important]2019-10-10 09:46 上传




               
LCD128-64
RS(CS)片选信号=P3.0 = 1;
WR(SID) = P3.1;//数据
EN(SCLK) = P3.2;//时钟
CS1(PSB) = P6.2;//接地,串行模式
单片机源程序:
  1. #include  <msp430x14x.h>
  2. #include "12864.h"
  3. uchar Edge=1;//当前触发沿
  4. uint RiseCapVal;   //上升沿时刻捕获值存放变量
  5. uint TA_Overflow_Cnt; //TA溢出次数存放变量,可能距离远超过65535
  6. unsigned long int Period;   //脉宽存放结果变量,高电平时间
  7. unsigned long int S;       // 定义距离长度,单位厘米


  8. void Conut(void)
  9.     {

  10.        disbuff[1]=S%1000/100;
  11.        disbuff[2]=S%1000%100/10;
  12.        disbuff[3]=S%1000%10 %10;
  13.        LCD_set_xy( 3, 4 );
  14.        LCD_Write_number(disbuff[1]);
  15.        LCD_Write_number(12);
  16.        LCD_set_xy( 3, 5 );
  17.        LCD_Write_number(disbuff[2]);
  18.        LCD_Write_number(disbuff[3]);



  19.       }

  20. #pragma vector=TIMERA1_VECTOR
  21. __interrupt void Timer_A(void)
  22. {

  23.   switch(TAIV)
  24.   {
  25.     case 2 :if(Edge==RISE)
  26.               {
  27.                 RiseCapVal = TACCR1;
  28.                 TACCTL1 |= CAP+CM_2+CCIS_1+SCS+CCIE;//改为下降沿捕获
  29.                 Edge = FALL;//下降沿捕获标志
  30.               }
  31.             else
  32.               {

  33.                 //_DINT();
  34.                 Period = TACCR1-RiseCapVal;  //这里要注意是否考虑溢出,跟测试距离有关,希望大家拓展
  35.                 S=(Period*17)/100;   // 距离计算 s=340m/s*Period/2*10^(-6)*1000(mm)
  36.                 TACCR1 = 0;
  37.                 TACCTL1|= CAP+CM_1+CCIS_0+SCS+CCIE;//改为上升沿捕获
  38.                 Edge = RISE;//上升沿捕获标志
  39.                 //_EINT();
  40.               }
  41.              break;
  42.     case 4 : break;
  43.     case 10: TA_Overflow_Cnt++;   //溢出标志
  44.              break;
  45.   }
  46. }
复制代码
  1. void init_timerA(void)
  2. {
  3.   TACTL   |= TASSEL_2+MC_2+TAIE+TACLR+ ID_3;//SMCLK,8MHz,8分频,连续计数,中断允许,计数器清零
  4.   TACCTL1 |= CAP+CM_3+CCIS_0+SCS+CCIE;//捕获模式,上升沿下降沿都捕获(CM_3),CCI1A输入,同步捕获,中断允许
  5. }

  6. void init_IO(void)
  7. {
  8.   P1DIR |= BIT1;   //P1.1输出,普通I/O
  9.   P1DIR &=~ BIT2;  //P1.2输入
  10.   P1SEL |=  BIT2; //P1.2第二功能,捕获输入

  11.   P1OUT &=~BIT1;  // 开始低电平,控制驱动波形发生
  12. }

  13. void init_clk(void)
  14. {
  15.     uchar i;
  16.     BCSCTL1&=~XT2OFF;   //打开XT振荡器
  17.     BCSCTL2|=SELM_2+SELS;//MCLK 8M and SMCLK 8M
  18.     do
  19.     {
  20.       IFG1 &= ~OFIFG;//清除振荡错误标志
  21.       for(i = 0; i < 0xff; i++)  _NOP();//延时等待
  22.     }
  23.     while ((IFG1 & OFIFG) != 0);//如果标志为1继续循环等待晶振起振
  24.     IFG1&=~OFIFG;
  25. }
复制代码
  1. void main(void)
  2. {

  3.     /*下面六行程序关闭所有的IO口*/
  4.     P1DIR = 0XFF;P1OUT = 0XFF;
  5.     P2DIR = 0XFF;P2OUT = 0XFF;
  6.     P3DIR = 0XFF;P3OUT = 0XFF;
  7.     P4DIR = 0XFF;P4OUT = 0XFF;
  8.     P5DIR = 0XFF;P5OUT = 0XFF;
  9.     P6DIR = 0XFF;P6OUT = 0XFF;


  10.     WDTCTL = WDTPW + WDTHOLD;            //关闭看门狗
  11.     P6DIR |= BIT2;P6OUT |= BIT2;         //关闭电平转换
  12.     P6DIR |= BIT3;P6OUT |= BIT3;         //关闭电平转换



  13.     Ini_Lcd();
  14.     Disp_img(logo);   //显示欢迎使用本产品LOGO
  15.     delay_Nms(1000);
  16.     Ini_Lcd();
  17.     Lcd_Mark2();

  18.     init_clk();
  19.     init_IO();           //初始端口设置
  20.     _EINT();               //开全局中断
  21.     while(1)
  22.     {
  23.        init_timerA();
  24.        P1OUT |= BIT1;    // P1.1 高电平,超过10us
  25.        delay_Nms(100);
  26.        P1OUT &=~BIT1;
  27.        delay_Nms(80);
  28.        Conut();
  29.        delay_Nms(80);       //80MS



  30.     }
  31. }
复制代码


回复

使用道具 举报

您需要登录后才可以回帖 注册/登录

本版积分规则

关闭

站长推荐上一条 /3 下一条



手机版|小黑屋|与非网

GMT+8, 2025-1-11 21:44 , Processed in 0.114059 second(s), 16 queries , MemCache On.

ICP经营许可证 苏B2-20140176  苏ICP备14012660号-2   苏州灵动帧格网络科技有限公司 版权所有.

苏公网安备 32059002001037号

Powered by Discuz! X3.4

Copyright © 2001-2024, Tencent Cloud.