微波EDA网,见证研发工程师的成长!
首页 > 硬件设计 > 嵌入式设计 > 用18B20做温度补偿的超声波测距程序

用18B20做温度补偿的超声波测距程序

时间:11-25 来源:互联网 点击:
18B20温度补偿超声波测距程序

#include
#include
#define uint unsigned int
#define uchar unsigned char
sbit rs=P1^0;
sbit rw=P1^1;
sbit en=P1^2;
sbit wave=P1^4;
uint tvalue;//温度值用18B20做温度补偿的超声波测距程序
uchar tflag;//温度正负标志
sbit DQ=P1^3;//ds18b20单片机连接口
char idata disp_buf1[16];//1602显示缓冲区1(即上排16个字符)
char idata disp_buf2[16];//1602显示缓冲区2(即下排16个字符)
uchar code table[]=" Celiang Ok ! ";
uchar i;
char idata julidata[3]; //存放距离值变量
uchar data disdata[4];//温度
unsigned long int JuLi;//距离
unsigned char Gao,Di;//存储计时器高位,低位
void ChuShiHua();//初始化
void FaShe();//发射声波
void Shou();//接收外部中断程序
void Deng();//空等待
void delay(uint n) //延时时间为n*1ms
{ uchar x=0;
for(; n>0; n--)
{
for(; x<250; x++)
{
_nop_();
_nop_();
_nop_();
_nop_();
}
}
}
void delayus(uint n)
{
while(n--);
}
void check_busy()
{
P2=0xff;
rs=0;
rw=1;
en=1;
while(P2&0x80);
en=0;
}
void lcd_wcom(uchar com)
{ check_busy();
rw=0;
rs=0;
P2=com;
en=1;
en=0;
}
void lcd_wdat(uchar dat)
{ check_busy();
rw=0;
rs=1;
P2=dat;
en=1;
en=0;
}
void lcd_init()
{
lcd_wcom(0x38),delay(1);//8位,双列,5*7
lcd_wcom(0x0c),delay(1); //开显示,关光标,光标所在字符不闪电子小制作_我爱制作_电子DIY制作套件http://www.5imcu.net/
lcd_wcom(0x06),delay(1);//显示地址递增18B20做温度补偿的超声波测距程序
lcd_wcom(0x01),delay(1); //清屏,光标移到左上角
}
void chushi_display()
{
uchar m=0;
lcd_init();
lcd_wcom(0x80);
for(m=0; m<16; m++)
{
lcd_wdat(table[m]); //将数组中字符显示出来18B20做温度补偿的超声波测距程序
delay(1000);
}
delay(100);
lcd_wcom(0x01);
}
void ds1820rst()
{ unsigned char x=0;
DQ = 1,delayus(4); //DQ复位
DQ = 0; //DQ拉低
delayus(100); //精确延时大于480us
DQ = 1; //拉高http://www.duankudp.com/
delayus(40);
}
uchar ds1820rd()
{
unsigned char i=0;
unsigned char dat = 0;
for (i=8;i>0;i--)
{ DQ = 0; //给脉冲信号
dat>>=1;
DQ = 1; //给脉冲信号电子小制作_我爱制作_电子DIY制作套件http://www.5imcu.net/
if(DQ)
dat|=0x80;
delayus(10);
}
return(dat);
}
void ds1820wr(uchar wdata)
{
unsigned char i=0;
for (i=8; i>0; i--)
{
DQ = 0;
DQ = wdata&0x01;
delayus(10);
DQ = 1;
wdata>>=1;
}
}
read_temp()
{
uchar a,b;
ds1820rst();
ds1820wr(0xcc);/
ds1820wr(0x44);/
ds1820rst();
ds1820wr(0xcc);/
ds1820wr(0xbe);/
a=ds1820rd();
b=ds1820rd();
tvalue=b;
tvalue<=8;
tvalue=tvalue|a;
if(tvalue<0x0fff)
tflag=0;
else
{
tvalue=~tvalue+1;
tflag=1;
}
tvalue=tvalue*(0.625);//温度值扩大10倍,精确到1位小数
return(tvalue);
}
void ds1820disp()
{
uchar flagdat;
disdata[0]=tvalue/1000+0x30;//百位数
disdata[1]=tvalue00/100+0x30;//十位数
disdata[2]=tvalue0/10+0x30;//个位数http://www.duankudp.com/
disdata[3]=tvalue+0x30;//小数位
if(tflag==0)
flagdat=0x20;//正温度不显示符号电子小制作_我爱制作_电子DIY制作套件http://www.5imcu.net/
else
flagdat=0x2d;//负温度显示负号:-18B20做温度补偿的超声波测距程序
if(disdata[0]==0x30)
{
disdata[0]=0x20;//如果百位为0,不显示
if(disdata[1]==0x30)
{
disdata[1]=0x20;//如果百位为0,十位为0也不显示
}
}
}
void updata_disp()
{
disp_buf1[0]=W, disp_buf1[1]=e;
disp_buf1[2]=n, disp_buf1[3]=D;
disp_buf1[4]=u,disp_buf1[5]=-;
disp_buf1[6]=-, disp_buf1[7]=D;
disp_buf1[8]=i,disp_buf1[9]=s;;
disp_buf1[10]=t,disp_buf1[11]=a;;
disp_buf1[12]=n,disp_buf1[13]=t;;
disp_buf1[14]=:,disp_buf1[15]=:;
disp_buf2[0]=*, disp_buf2[1]=disdata[1];
disp_buf2[2]=disdata[2],disp_buf2[3]=.;
disp_buf2[4]=disdata[3],disp_buf2[5]=-;
disp_buf2[6]=-, disp_buf2[7]=0;
disp_buf2[8]=0;
disp_buf2[9] =julidata[0]+0x30;
disp_buf2[10]=julidata[1]+0x30;
disp_buf2[11]=julidata[2]+0x30;
disp_buf2[12]=c,disp_buf2[13]=m;
disp_buf2[14]=*,disp_buf2[15]=*;
}
void display()
{
uchar i;
lcd_wcom(0x80);
for(i=0;i<16;i++)
lcd_wdat(disp_buf1[i]);
lcd_wcom(0xc0);
for(i=0;i<16;i++)
lcd_wdat(disp_buf2[i]);
}
void int_t0() interrupt 1 using 1 //定时中断http://www.jiaoqb.com/
{
TH0=0x3c;
TL0=0xb0;
i++;
if(i== 10)
{
i=0;
display(); //更新显示数据
}
}
void ChuShiHua()
{
IE = 0x82; //开T0中断
TMOD = 0x10; //定时器1模式1,定时器0模式0
PX1 = 1; //INT1高优先级18B20做温度补偿的超声波测距程序
PT0 = 0; //T0 低级中断
IT1 = 0; //INT1电平触发0
TR0 = 1; //启动定时器T0http://www.jiaoqb.com/
wave= 0;
}
void Deng()
{
unsigned int i,j;
wave=0;
for (i = 0; i < 200; i++)
for (j = 0; j < 200; j++);
}
void FaShe()
{
IE = 0; //关中断
wave= 0;
delay(80);
TH1 = 0;
TL1 = 0; //计数器清零
wave=1;
TR1 = 1; //启动计算器;
delayus(125);
wave=0;
delayus(300);
IE=0X86;
}
void Shou() interrupt 2 //外部中断INT1
{
IE = 0; //关中断
JuLi= 0;
TR1 = 0; //关定时器1
Gao = TH1, Di = TL1;
JuLi = JuLi | Gao, JuLi = JuLi < 8;
JuLi = JuLi | Di,JuLi = JuLi*17;
JuLi = JuLi/1000,julidata[0] = JuLi / 100;
julidata[1] = (JuLi - (julidata[0]*100))/10;
julidata[2] = JuLi, updata_disp();
IE = 0x82; //关int1中断,开显示中断http://www.jiaoqb.com/
}
main()
{
display(); //更新显示数据
chushi_display();
ChuShiHua();
while (1)
{
read_temp();//读取温度
ds1820disp();//显示
FaShe();
Deng(); //数据送入显示缓冲区http://www.duankudp.com/
}
}

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

网站地图

Top