文档库 最新最全的文档下载
当前位置:文档库 › 51单片机驱动温度传感器ds18b20

51单片机驱动温度传感器ds18b20

#include
#include
#define uchar unsigned char
#define uint unsigned int
//void init();
//void write_data(uchar x);
//void write_command(uchar command);
void delay(uchar t);
void display();
uchar b[5];
//sbit RS=P2^0;
//sbit RW=P2^1;
//sbit E=P2^2;
sbit dat=P2^2;
sbit dula=P2^6;
sbit wela=P2^7;
unsigned char code dx[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};



void delay1()
{
uint x,y;
for(x=1;x>0;x--)
for(y=110;y>0;y--);
}
void delay(uchar t)
{for(;t>0;t--); }
/****************delay n*10us*******************/
void delay_10us(uint Count)
{
while(--Count)
{
_nop_();
}
}

void delayms(uchar n)
{
uchar i=121;
while(n--)
{
while(i--);
}
}
//void write_com(uchar c_value)
//{
// delayms(5);
// RS=0;
// RW=0;
// P0=c_value;
// E=0;
// delayms(5);
// E=1;
//}
//void write_data(uchar d_value)
//{
// delayms(5);
// RS=1;
// RW=0;
// P0=d_value;
// E=0;
// delayms(1);
// E=1;
//}
//void init(void)
//{
//// LE1=0; //锁存
// write_com(0x01);
// write_com(0x38);
// write_com(0x0c);
// //write_comman(0x80);
//}
bit ds18b20_init()
{
uint flag=0;
dat=1;
//delay(2);
dat=0;
delay_10us(80);
dat=1;
delay_10us(15); //30
if(dat==0)
{
flag=1;
//delay(200);
}
else flag=0;
return flag;
}
//void ds18b20_init()
//{
// dat=1;
// delay(1);
// dat=0;
// delay_10us(80);
// dat=1;
// delay_10us(15);
//
//
//}
void ds18b20_write(uchar shuju)
{
uchar i;
for(i=0;i<8;i++)
{
dat=0;
dat=shuju&0x01;
delay_10us(5);
dat=1;
shuju>>=1;
}
}
uchar ds18b20_read()
{
uchar temp,i;
for(i=0;i<8;i++)
{
dat=0;
temp>>=1;
dat=1;
if(dat==1)
temp=temp|0x80;
delay_10us(3);

}
return temp;
}
void main()
{

uint n,high,low,num;
float a;
while(1)
{
ds18b20_init();
ds18b20_write(0xcc);
ds18b20_write(0x44);
while(!dat);
ds18b20_init();
ds18b20_write(0xcc);
ds18b20_write(0xbe);
low=ds18b20_read();
high=ds18b20_read();
n=((high<<8)|low);

if(n&0xf800)
{
n=~n+1;
// b[0]='-';
}
else
b[0]='+';
a=(long)n*6.25;
num=(uint)a;

b[1]=num/1000;
b[2]=num/100%10;
b[3]=num/10%10;
b[4]=num%10;

// write_com(0x80);
// write_data('T');
// write_data(':');
// write_data(b[0]);
// write_data(b[1]+'0');
// write_data(b[2]+'0');
// write_data('.');
// write_data(b[3]+'0');
// write_data(b[4]+'0');
display();




}
}
void display()
{
dula=1;
P0=dx[b[1]];
dula=0;
P0=0xff;
wela=1;
P0=0xfe;
wela=0;
delay1();

dula=1;
P0=dx[b[2]];


dula=0;
P0=0xff;
wela=1;
P0=0xfd;
wela=0;
delay1();


dula=1;
P0=dx[b[3]];
dula=0;
P0=0xff;
wela=1;
P0=0xfb;
wela=0;
delay1();

dula=1;
P0=dx[b[4]];
dula=0;
P0=0xff;
wela=1;
P0=0xf7;
wela=0;
delay1();
}

相关文档
相关文档 最新文档