微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 语音播报超声波测距程序

语音播报超声波测距程序

时间:11-25 来源:互联网 点击:

///////////////////////////以下是播报温度和当前计算的声速,方法同上///////////////////
play(0xf0);
delay2(50000);
delay2(50000);
s=TD/100;
if(s==1)
{
play(0x5a);
delay2(50000);
}
if(s>1)
{
speaknum();
delay2(50000);
play(0x5a);
delay2(50000);
}
if(s!=0)
{
s=TD0/10;
speaknum();
delay2(50000);
}
play(0x64);
delay2(50000);
s=TD;
speaknum();
delay2(50000);
play(0xC8);
delay2(50000);
delay2(50000);
play(0xe6);
delay2(50000);
delay2(50000);
s=VD/1000;
speaknum();
delay2(50000);
play(0xfa);
delay2(50000);
s=VD00/100;
speaknum();
delay2(50000);
play(0x5a);
delay2(50000);
s=VD0/10;
speaknum();
delay2(50000);
play(0x64);
delay2(50000);
s=VD;
speaknum();
delay2(50000);
play(0xd2);
}
////////////////////////////////////////////////////////////

void main()
{
initlcd() ; //初始化LCD1602http://www.duankudp.com/
while(1)
{
timer();
readtemp(); //读温度
delay25us_40KHz(15);
display();
if(key1==0) read();
}
}

以下是温度传感器头文件ds18b20.h

sbit DQ=P2^2;

uchar tempdata[2];
uchar k=0;
int TD;
float T;
void delay1(uchar i)
{
while(i--);
}

void initDS18B20() //初始化DS18B20
{
DQ = 1; //DQ复位
delay1(8); //稍做延时
DQ = 0; //单片机将DQ拉低
delay1(80); //延时 大于 480us
DQ = 1; //拉高总线
delay1(30);
}

uchar readchar() //向DS18B20读取一字节http://www.duankudp.com/
{
uchar i = 0 ;
uchar dat = 0 ;
for (i = 8 ; i > 0 ; i--)
{
DQ = 0 ;
dat >>= 1 ;
DQ = 1 ;

if(DQ)
dat |= 0x80 ;
delay1(4) ;
}

return (dat) ;
}

void writecmd(uchar cmd) //向DS18B20写入一字节
{
uchar i ;
for (i = 8 ; i > 0 ; i--)
{
DQ = 0 ;
DQ = cmd&0x01 ;
delay1(5) ;

DQ = 1 ;
cmd>>=1 ;
}
}

void readtemp()
{
initDS18B20() ;
writecmd(0xCC) ; // 跳过读序号列号的操作
writecmd(0x44) ; // 启动温度转换
initDS18B20() ;
writecmd(0xCC) ; //跳过读序号列号的操作
writecmd(0xBE) ; //读取温度寄存器
tempdata[0] = readchar() ; //温度低8位
tempdata[1] = readchar() ; //温度高8位
TD=tempdata[1];
TD<=8;
TD|=tempdata[0];
T=TD*0.0625; //DS18B20在出厂时以配置为12位,读取温度时共读取16位,最高5位为符号位,温度在0上,符号位为0,所以把后11位的2进制转化为10进制后在乘以0.0625便为所测的温度
TD=T*10+0.5; //将它放大10倍, 使显示时可显示小数点后一位, 并对小数点后第二2进行4舍5入

}

一下是液晶显示头文件lcd.h

sbit RS=P2^5;
sbit RW=P2^6;
sbit EN=P2^7;
#define uchar unsigned char
#define DATA P0
#define busy 0x80

void chkbusy() //检测状态
{
DATA=0xff;
RS=0;
RW=1;
EN=1;
_nop_();
_nop_();
while(busy&DATA);
EN=0;
}

void WIR(uchar CMD,uchar i) //写命令
{
if(i) chkbusy();
RS=0;
RW=0;
EN=1;
_nop_();
_nop_();
DATA=CMD;
EN=0;
}

void WDR(char c) //写数据
{
chkbusy();
RS=1;
RW=0;
EN=1;
_nop_();
_nop_();
DATA=c;
EN=0;
}

void displaychar(uchar x,uchar y,char c) //指定行列显示字符
{
if(y==1) x|=0x40; //当要显示第二行时地址码+0x40;
x|=0x80;
WIR(x,0);
WDR(c);
}

void displaystring(uchar x,uchar y,char s[]) //指定行列显示字符串http://www.duankudp.com/
{
uchar p=0;
while(1)
{
displaychar(x,y,s[p]);
p++;
if(s[p]==0)
break;
x++;
if(x>=15) //每行最多显示16个字符
{
x=0;
y=!y; //如果一行显示不完,则转到下一行或上一行显示
}
}
}

void initlcd() //初始化lcd
{
WIR(0x38,0);
WIR(0x38,1); //显示模式设置
WIR(0x08,1); //关闭显示
WIR(0x01,1); //清屏
WIR(0x06,1); //光标移位设置
WIR(0x0c,1); //显示开及光标设置
}

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top