专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
TI
求一个在MSP430g2553芯片上的超声波传感模块程序
2019-07-15 16:13
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
TI MCU
2162
4
1060
求一个在MSP430g2553
芯片
上的超声波传感模块程序,求大神给我发一份,显示屏要的是1602, 本人新手,不太会,需要一个程序学学,谢谢了
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
4条回答
旺仔棒棒糖
1楼-- · 2019-07-15 18:42
#include<msp430g2553.h>
#include"OLED.h"
#define uint unsigned int
#define uchar unsigned char
#define ulong unsigned long
uchar flag_time = 0;
ulong TIME0 = 0, TIME1 = 0; //存放时间的函数
ulong L_juli = 0;
ulong l = 0;
uint ge,shi,bai,qian;
uchar str[10]={0};
void delay_us(uint n)
{
uint i;
for(i=0;i<8;i++)
n--;
}
//时钟初始化
void CLK_Init(void)
{
if (CALBC1_8MHZ ==0xFF || CALDCO_8MHZ == 0xFF)
{
while(1); // If calibration constants erased
// do not load, trap CPU!!
}
BCSCTL1 = CALBC1_8MHZ; // Set range
DCOCTL = CALDCO_8MHZ; // Set DCO step + modulation */
BCSCTL2 |= 0X04; //SMCLK为DCO的2分频,4M
}
//端口初始化
void GPIO_Init(void)
{
P1DIR = 0xf7;
P1OUT |=BIT3;
P1REN = 0X08;
P2DIR |= 0x07;
P2SEL |= 0x08; //P2.3作为捕获输入
P2OUT &= 0xfb; //P2.2输出低电平
// P1IES = 0x00; //P1.3为上升沿触发中断
// P1IE = 0x08; //P1.3中断允许
// P1IFG = 0x00; //清除中断标志
}
//定时器TIME1_A3初始化函数
void TIME1_A0_Init(void)
{
TA1CTL |= TASSEL1 + MC_2; //SMCLK作为时钟源,连续计数模式
TA1CCTL0 |= CM_1 + CCIS_1 + SCS + CAP + CCIE; //上升沿捕获,
//输入源为CCI0B,同步捕获模式,使能中断
}
void Start_Measure() //由P2.0向Trig输出10us以上的高电平,触发测距
{
// _DINT();
P2OUT|=BIT2;
delay_us(20);
P2OUT&=~BIT2;
//__enable_interrupt();
}
//主函数
void main(void)
{
WDTCTL = WDTPW + WDTHOLD; //关闭看门狗定时器
CLK_Init();
GPIO_Init();
TIME1_A0_Init();
initial_lcd(); ///LCD模块初始化
clear_screen(); //清屏
_EINT(); //中断使能
dis_GB_str(4,1,"Hello!");
while(1)
{
//LPM0;
//Start_Measure();
_NOP();
// delay_us(1000);
if(!(P1IN&0X08))
{
delay_us(2000);
if(!(P1IN&0X08))
{
delay_us(2000);
if(!(P1IN&0X08))
{
while(!(P1IN&0X08));
P2OUT &=~BIT2;
P2OUT |= 0x04; //P2.2输出高电平
delay_us(20);
P2OUT&=~BIT2;
// dis_GB_str(2,1,"abCD!");
}
}
}
}
}
//定时器Timer1_A CCR0中断服务函数
#pragma vector = TIMER1_A0_VECTOR
__interrupt void TIMER1_A0__ISR(void)
{
if (flag_time == 0)
{
TA1CCTL0=(TA1CCTL0&(~CM0))|CM1; //改为下降沿捕获:CM0置零,CM1置一
P2OUT &= ~0x04; //P2.2输出低电平
TIME0 = TA1CCR0;
flag_time ++;
}
else
{
TIME1 = TA1CCR0;
TA1CCTL0=(TA1CCTL0&(~CM1))|CM0; //改为上升沿捕获:CM1置零,
flag_time = 0;
if (TIME1 > TIME0)
{
TIME1 = TIME1 - TIME0;
}
else
{
TIME1 = TIME1 + (65536 - TIME0);
}
l = TIME1*170;
L_juli = l/2000+14;
ge = L_juli % 10 + 48;
shi = (L_juli/10) % 10 + 48;
bai = (L_juli/100) % 10 + 48;
qian = (L_juli/1000) % 10 + 48;
str[0]='D';
str[1]=':';
str[2]=qian;
str[3]=bai;
str[4]=shi;
str[5]='.';
str[6]=ge;
str[7]='c';
str[8]='m';
str[9]=' ';
dis_GB_str(2,1,str);
}
}
/*
//P1口中断服务函数
#pragma vector = PORT1_VECTOR
__interrupt void P1_ISR(void)
{
P2OUT &=~BIT2;
P2OUT |= 0x04; //P2.2输出高电平
P1IFG &= ~0X08;
dis_GB_str(2,1,"ABCD!");
}
*/
加载中...
旺仔棒棒糖
2楼-- · 2019-07-16 00:08
再给个1602的代码,你自己整合
#include<msp430g2553.h>
#define RS_HIGH P1OUT|=BIT4 //P4.5
#define RS_LOW P1OUT&=~BIT4
#define RW_HIGH P1OUT|=BIT5 //P4.6
#define RW_LOW P1OUT&=~BIT5
#define E_HIGH P1OUT|=BIT6 //P4.7
#define E_LOW P1OUT&=~BIT6
#define uchar unsigned char
#define uint unsigned int
void Delay(uint);
void write_com(uchar);
void write_data(uchar);
void init();
uchar num;
uchar table[]="11111a";
void Delay(uint wDelay) //???± ×????ò
{
uint i,j;
for(i=wDelay;i>0;i--)
for(j=110;j>0;j--);
}
void write_com(uchar com)
{
RS_LOW;
RW_LOW;
E_LOW;
P2OUT=com;
Delay(5);
E_HIGH;
Delay(5);
E_LOW;
}
void write_data(uchar data)
{
RS_HIGH;
RW_LOW;
E_LOW;
P2OUT=data;
Delay(5);
E_HIGH;
Delay(5);
E_LOW;
}
void lcd_char(uchar hang,uchar lie,uchar sign) //显示字符函数
{
uchar i;
if(hang==1)
i=0x80+lie-1;
else
i=0xc0+lie-1;
write_com(i);
write_data(sign);
}
void lcd_str(uchar hang,uchar lie,uchar *p) //显示字符串函数
{
uchar i;
uint j=0;
if(hang==1)
i=0x80+lie-1;
else if(hang==2)
i=0xc0+lie-1;
else
i=0x80;
write_com(i);
while(1)
{if((*p==' ')||(j==16))
break;
// i++;
write_data(*p);
p++;
j++;
}
}
void init()
{
// E_LOW;
write_com(0x38);
write_com(0x38);
write_com(0x38);
write_com(0x0c); //光标不显示
write_com(0x06); //写入新数据后光标右移,显示频不移动
write_com(0x01); //0000000001 清屏
}
void main()
{
WDTCTL=WDTPW+WDTHOLD;
P2SEL&=~(BIT6+BIT7);
P2DIR = 0XFF;
P2OUT=0;
P1DIR=0xff;
P1OUT=0;
init();
while(1)
{
lcd_char(1,1,'a'); //显示字符a
lcd_char(1,3,'b');
lcd_str(1,5,table); //显示字符串table
lcd_str(2,1,"abcdefg");
}
}
加载中...
czn14
3楼-- · 2019-07-16 01:10
旺仔棒棒糖 发表于 2014-12-19 13:04
#include
#include"OLED.h"
l = TIME1*170;
L_juli = l/2000+14;
ge = L_juli % 10 + 48;
shi = (L_juli/10) % 10 + 48;
bai = (L_juli/100) % 10 + 48;
qian = (L_juli/1000) % 10 + 48;
str[0]='D';
str[1]=':';
str[2]=qian;
str[3]=bai;
str[4]=shi;
str[5]='.';
str[6]=ge;
str[7]='c';
str[8]='m';
str[9]=' ';
dis_GB_str(2,1,str);
}
}
/*
//P1口中断服务函数
#pragma vector = PORT1_VECTOR
__interrupt void P1_ISR(void)
{
P2OUT &=~BIT2;
P2OUT |= 0x04; //P2.2输出高电平
P1IFG &= ~0X08;
dis_GB_str(2,1,"ABCD!");
} 这个是干嘛用到的?????
加载中...
高浩123
4楼-- · 2019-07-16 06:53
旺仔棒棒糖 发表于 2014-12-19 13:04
#include
#include"OLED.h"
能不能把OLED的显示函数给我
加载中...
一周热门
更多
>
相关问题
CPLD的方波输出
4 个回答
11个版本Quartus II 软件下载,安装包网盘合集,附教程,47G!
20 个回答
请大家帮忙到21IC发展大家谈支持我申请新版面
20 个回答
【通知】21ic中国电子网服务条款 (所有人员必读)
1 个回答
满载而归乙亥年,大展鸿途庚子年---集签赢好礼
20 个回答
携手ADI,踏上电子工程师之巅—车辆电气化视频,答题领奖!
1 个回答
如何提升论坛质量,看你了!
20 个回答
【最终名单】二姨家喊你来拿100份新年大礼啦~
20 个回答
相关文章
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
TI
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
#include"OLED.h"
#define uint unsigned int
#define uchar unsigned char
#define ulong unsigned long
uchar flag_time = 0;
ulong TIME0 = 0, TIME1 = 0; //存放时间的函数
ulong L_juli = 0;
ulong l = 0;
uint ge,shi,bai,qian;
uchar str[10]={0};
void delay_us(uint n)
{
uint i;
for(i=0;i<8;i++)
n--;
}
//时钟初始化
void CLK_Init(void)
{
if (CALBC1_8MHZ ==0xFF || CALDCO_8MHZ == 0xFF)
{
while(1); // If calibration constants erased
// do not load, trap CPU!!
}
BCSCTL1 = CALBC1_8MHZ; // Set range
DCOCTL = CALDCO_8MHZ; // Set DCO step + modulation */
BCSCTL2 |= 0X04; //SMCLK为DCO的2分频,4M
}
//端口初始化
void GPIO_Init(void)
{
P1DIR = 0xf7;
P1OUT |=BIT3;
P1REN = 0X08;
P2DIR |= 0x07;
P2SEL |= 0x08; //P2.3作为捕获输入
P2OUT &= 0xfb; //P2.2输出低电平
// P1IES = 0x00; //P1.3为上升沿触发中断
// P1IE = 0x08; //P1.3中断允许
// P1IFG = 0x00; //清除中断标志
}
//定时器TIME1_A3初始化函数
void TIME1_A0_Init(void)
{
TA1CTL |= TASSEL1 + MC_2; //SMCLK作为时钟源,连续计数模式
TA1CCTL0 |= CM_1 + CCIS_1 + SCS + CAP + CCIE; //上升沿捕获,
//输入源为CCI0B,同步捕获模式,使能中断
}
void Start_Measure() //由P2.0向Trig输出10us以上的高电平,触发测距
{
// _DINT();
P2OUT|=BIT2;
delay_us(20);
P2OUT&=~BIT2;
//__enable_interrupt();
}
//主函数
void main(void)
{
WDTCTL = WDTPW + WDTHOLD; //关闭看门狗定时器
CLK_Init();
GPIO_Init();
TIME1_A0_Init();
initial_lcd(); ///LCD模块初始化
clear_screen(); //清屏
_EINT(); //中断使能
dis_GB_str(4,1,"Hello!");
while(1)
{
//LPM0;
//Start_Measure();
_NOP();
// delay_us(1000);
if(!(P1IN&0X08))
{
delay_us(2000);
if(!(P1IN&0X08))
{
delay_us(2000);
if(!(P1IN&0X08))
{
while(!(P1IN&0X08));
P2OUT &=~BIT2;
P2OUT |= 0x04; //P2.2输出高电平
delay_us(20);
P2OUT&=~BIT2;
// dis_GB_str(2,1,"abCD!");
}
}
}
}
}
//定时器Timer1_A CCR0中断服务函数
#pragma vector = TIMER1_A0_VECTOR
__interrupt void TIMER1_A0__ISR(void)
{
if (flag_time == 0)
{
TA1CCTL0=(TA1CCTL0&(~CM0))|CM1; //改为下降沿捕获:CM0置零,CM1置一
P2OUT &= ~0x04; //P2.2输出低电平
TIME0 = TA1CCR0;
flag_time ++;
}
else
{
TIME1 = TA1CCR0;
TA1CCTL0=(TA1CCTL0&(~CM1))|CM0; //改为上升沿捕获:CM1置零,
flag_time = 0;
if (TIME1 > TIME0)
{
TIME1 = TIME1 - TIME0;
}
else
{
TIME1 = TIME1 + (65536 - TIME0);
}
l = TIME1*170;
L_juli = l/2000+14;
ge = L_juli % 10 + 48;
shi = (L_juli/10) % 10 + 48;
bai = (L_juli/100) % 10 + 48;
qian = (L_juli/1000) % 10 + 48;
str[0]='D';
str[1]=':';
str[2]=qian;
str[3]=bai;
str[4]=shi;
str[5]='.';
str[6]=ge;
str[7]='c';
str[8]='m';
str[9]=' ';
dis_GB_str(2,1,str);
}
}
/*
//P1口中断服务函数
#pragma vector = PORT1_VECTOR
__interrupt void P1_ISR(void)
{
P2OUT &=~BIT2;
P2OUT |= 0x04; //P2.2输出高电平
P1IFG &= ~0X08;
dis_GB_str(2,1,"ABCD!");
}
*/
#include<msp430g2553.h>
#define RS_HIGH P1OUT|=BIT4 //P4.5
#define RS_LOW P1OUT&=~BIT4
#define RW_HIGH P1OUT|=BIT5 //P4.6
#define RW_LOW P1OUT&=~BIT5
#define E_HIGH P1OUT|=BIT6 //P4.7
#define E_LOW P1OUT&=~BIT6
#define uchar unsigned char
#define uint unsigned int
void Delay(uint);
void write_com(uchar);
void write_data(uchar);
void init();
uchar num;
uchar table[]="11111a";
void Delay(uint wDelay) //???± ×????ò
{
uint i,j;
for(i=wDelay;i>0;i--)
for(j=110;j>0;j--);
}
void write_com(uchar com)
{
RS_LOW;
RW_LOW;
E_LOW;
P2OUT=com;
Delay(5);
E_HIGH;
Delay(5);
E_LOW;
}
void write_data(uchar data)
{
RS_HIGH;
RW_LOW;
E_LOW;
P2OUT=data;
Delay(5);
E_HIGH;
Delay(5);
E_LOW;
}
void lcd_char(uchar hang,uchar lie,uchar sign) //显示字符函数
{
uchar i;
if(hang==1)
i=0x80+lie-1;
else
i=0xc0+lie-1;
write_com(i);
write_data(sign);
}
void lcd_str(uchar hang,uchar lie,uchar *p) //显示字符串函数
{
uchar i;
uint j=0;
if(hang==1)
i=0x80+lie-1;
else if(hang==2)
i=0xc0+lie-1;
else
i=0x80;
write_com(i);
while(1)
{if((*p==' ')||(j==16))
break;
// i++;
write_data(*p);
p++;
j++;
}
}
void init()
{
// E_LOW;
write_com(0x38);
write_com(0x38);
write_com(0x38);
write_com(0x0c); //光标不显示
write_com(0x06); //写入新数据后光标右移,显示频不移动
write_com(0x01); //0000000001 清屏
}
void main()
{
WDTCTL=WDTPW+WDTHOLD;
P2SEL&=~(BIT6+BIT7);
P2DIR = 0XFF;
P2OUT=0;
P1DIR=0xff;
P1OUT=0;
init();
while(1)
{
lcd_char(1,1,'a'); //显示字符a
lcd_char(1,3,'b');
lcd_str(1,5,table); //显示字符串table
lcd_str(2,1,"abcdefg");
}
}
l = TIME1*170;
L_juli = l/2000+14;
ge = L_juli % 10 + 48;
shi = (L_juli/10) % 10 + 48;
bai = (L_juli/100) % 10 + 48;
qian = (L_juli/1000) % 10 + 48;
str[0]='D';
str[1]=':';
str[2]=qian;
str[3]=bai;
str[4]=shi;
str[5]='.';
str[6]=ge;
str[7]='c';
str[8]='m';
str[9]=' ';
dis_GB_str(2,1,str);
}
}
/*
//P1口中断服务函数
#pragma vector = PORT1_VECTOR
__interrupt void P1_ISR(void)
{
P2OUT &=~BIT2;
P2OUT |= 0x04; //P2.2输出高电平
P1IFG &= ~0X08;
dis_GB_str(2,1,"ABCD!");
} 这个是干嘛用到的?????
能不能把OLED的显示函数给我
一周热门 更多>