专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
TI
msp430f149控制收发一体超声波测距,求大神指点,求驱动程序!
2019-07-15 16:30
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
TI MCU
4019
4
1469
msp430f149控制收发一体超声波测距,求大神指点,求驱动程序!
超声波传感器收发一体,没有一点头绪,求大神给予指点。有做过的麻烦把源程序发来,江湖救急!
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
4条回答
elecfans跑堂
1楼-- · 2019-07-15 17:30
//P1.0发出信号,P4.0接收信号,将距离显示到显示屏上 #include<msp430x14x.h> #include "12864.h"
#define CPU_F ((double)8000000)
#define DelayUs(x) __delay_cycles((unsigned long)(CPU_F*(double)x/1000000.0)) #define DelayMs(x) __delay_cycles((unsigned long)(CPU_F*(double)x/1000.0))
unsigned int width; float float_range; unsigned int_range; unsigned int i=0;
unsigned int int_range100,int_range10,int_range1;
void StartModule() {
P1OUT|=BIT0; DelayUs(100); P1OUT&=~BIT0; DelayMs(70); }
void main() {
WDTCTL=WDTPW+WDTHOLD; //关闭看门狗 P1DIR|=BIT0;
P4SEL|=BIT0; //P4.0作为捕获模块功能的输入端输入方波
//-------开晶振XT2---------
BCSCTL1&=~XT2OFF; //打开XT2振荡器 do {
IFG1 &= ~OFIFG; // 清除振荡器失效标志 for (i=256;i>0;i--); // 延时,等待XT2起振 }
while ((IFG1 & OFIFG) != 0); // 判断XT2是否起振
BCSCTL2 =SELM_2+SELS; //选择MCLK=SMCLK为XT2
//-----------------------------
TBCCTL0&=~(CCIS1+CCIS0); // 捕获源为P4.0,即CCI0A(也是CCI0B)
TBCCTL0|=CM_2+SCS+CAP; //下降沿捕获,同步捕获,工作在捕获模式 TBCCTL0|=CCIE; //允许捕获比较模块提出中断请求
TBCTL|=ID_3;
TBCTL|=TBSSEL_2; //选择时钟MCLK TBCTL|=TBCLR; //定时器清零, //定时器开始计数(连续计数模式0~0xFFFF) TBCTL|=MC_2;
LcdInit(); //初始化液晶屏
LcdDisplayStr(1,0,"测得的距离:"); LcdDisplayStr(2,6,"mm"); _EINT();
for(;;) {
StartModule(); } }
//―――――定时器TB的CCR0的中断:用于检测脉冲上升与下降沿―――― #pragma vector=TIMERB0_VECTOR __interrupt void TimerB0(void) {
if(TBCCTL0&CM0) //捕获到上升沿 {
TBCTL|=TBCLR;
TBCCTL0=(TBCCTL0&(~CM0))|CM1; //改为下降沿捕获:CM0置零,CM1置一 }
else if(TBCCTL0&CM1) //捕获到下降沿 {
width=TBCCR0; //记录下结束时间
TBCCTL0=(TBCCTL0&(~CM1))|CM0; //改为上升沿捕获:CM1置零, float_range=0.2125*width;//计算距离,单位毫米 int_range=(int)float_range; int_range1=int_range%10;
int_range10=(int_range-int_range1)/10%10;
int_range100=(int_range-int_range1-int_range10)/100%10;
LcdDisplayStr(2,4,"");//里面什么也不写,相当于给它定位置 Send(1,int_range100+0x30);//写入数字,但是只能显示一个数字 Send(1,int_range10+0x30); Send(1,int_range1+0x30); } }
加载中...
dadangjia
2楼-- · 2019-07-15 17:36
自己写得超声波测速程序,希望对你有用。
数码管超声波测距.zip
164.57 KB, 下载次数: 25
加载中...
dadangjia
3楼-- · 2019-07-15 19:13
精彩回答 2 元偷偷看……
加载中...
dadangjia
4楼-- · 2019-07-16 00:30
我写的一个超声波测距程序,希望对你有用。我用的是数码管显示,msp430g2231写得。
数码管超声波测距.zip
164.57 KB, 下载次数: 10
超声波测距程序
加载中...
一周热门
更多
>
相关问题
CPLD的方波输出
4 个回答
11个版本Quartus II 软件下载,安装包网盘合集,附教程,47G!
20 个回答
请大家帮忙到21IC发展大家谈支持我申请新版面
20 个回答
【通知】21ic中国电子网服务条款 (所有人员必读)
1 个回答
满载而归乙亥年,大展鸿途庚子年---集签赢好礼
20 个回答
携手ADI,踏上电子工程师之巅—车辆电气化视频,答题领奖!
1 个回答
如何提升论坛质量,看你了!
20 个回答
【最终名单】二姨家喊你来拿100份新年大礼啦~
20 个回答
相关文章
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
TI
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
#define CPU_F ((double)8000000)
#define DelayUs(x) __delay_cycles((unsigned long)(CPU_F*(double)x/1000000.0)) #define DelayMs(x) __delay_cycles((unsigned long)(CPU_F*(double)x/1000.0))
unsigned int width; float float_range; unsigned int_range; unsigned int i=0;
unsigned int int_range100,int_range10,int_range1;
void StartModule() {
P1OUT|=BIT0; DelayUs(100); P1OUT&=~BIT0; DelayMs(70); }
void main() {
WDTCTL=WDTPW+WDTHOLD; //关闭看门狗 P1DIR|=BIT0;
P4SEL|=BIT0; //P4.0作为捕获模块功能的输入端输入方波
//-------开晶振XT2---------
BCSCTL1&=~XT2OFF; //打开XT2振荡器 do {
IFG1 &= ~OFIFG; // 清除振荡器失效标志 for (i=256;i>0;i--); // 延时,等待XT2起振 }
while ((IFG1 & OFIFG) != 0); // 判断XT2是否起振
BCSCTL2 =SELM_2+SELS; //选择MCLK=SMCLK为XT2
//-----------------------------
TBCCTL0&=~(CCIS1+CCIS0); // 捕获源为P4.0,即CCI0A(也是CCI0B)
TBCCTL0|=CM_2+SCS+CAP; //下降沿捕获,同步捕获,工作在捕获模式 TBCCTL0|=CCIE; //允许捕获比较模块提出中断请求
TBCTL|=ID_3;
TBCTL|=TBSSEL_2; //选择时钟MCLK TBCTL|=TBCLR; //定时器清零, //定时器开始计数(连续计数模式0~0xFFFF) TBCTL|=MC_2;
LcdInit(); //初始化液晶屏
LcdDisplayStr(1,0,"测得的距离:"); LcdDisplayStr(2,6,"mm"); _EINT();
for(;;) {
StartModule(); } }
//―――――定时器TB的CCR0的中断:用于检测脉冲上升与下降沿―――― #pragma vector=TIMERB0_VECTOR __interrupt void TimerB0(void) {
if(TBCCTL0&CM0) //捕获到上升沿 {
TBCTL|=TBCLR;
TBCCTL0=(TBCCTL0&(~CM0))|CM1; //改为下降沿捕获:CM0置零,CM1置一 }
else if(TBCCTL0&CM1) //捕获到下降沿 {
width=TBCCR0; //记录下结束时间
TBCCTL0=(TBCCTL0&(~CM1))|CM0; //改为上升沿捕获:CM1置零, float_range=0.2125*width;//计算距离,单位毫米 int_range=(int)float_range; int_range1=int_range%10;
int_range10=(int_range-int_range1)/10%10;
int_range100=(int_range-int_range1-int_range10)/100%10;
LcdDisplayStr(2,4,"");//里面什么也不写,相当于给它定位置 Send(1,int_range100+0x30);//写入数字,但是只能显示一个数字 Send(1,int_range10+0x30); Send(1,int_range1+0x30); } }
数码管超声波测距.zip
164.57 KB, 下载次数: 25
数码管超声波测距.zip
164.57 KB, 下载次数: 10
超声波测距程序
一周热门 更多>