新闻  |   论坛  |   博客  |   在线研讨会
DS18B20
飞阳 | 2010-04-30 20:03:34    阅读:829   发布文章

//通过DS18B20测试当前环境温度, 并通过数码管显示当前温度值, 目前显示范围: 0.0~ +99.9度
#include<AT89X52.H>
#include <absacc.h>
#define uchar unsigned char
#define uint   unsigned int

sbit DQ = P1^1;        //定义ds18b20通信端口
char Num[10]={0x88,0Xbe,0Xc4,0X94,0Xb2,0X91,0X81,0Xbc,0X80,0X90};//0~9
int temp1,temp2,ID=0,set=0,blink,temp;
int temp1=27,xs=5;   //定义整数和小数

unsigned int max,mid,min,flag;
/***********ds18b20延迟子函数(晶振11.0596MHz )*******/

void delay_18B20(unsigned int i)
{
while(i--);
}

void delay1(uint z)
{
 uint x,y;
 for(x=z;x>0;x--)
  for(y=180;y>0;y--);
}
/**********ds18b20初始化函数**********************/

void Init_DS18B20(void)
{
unsigned char x=0;
DQ = 1;          //DQ复位 ds18b20通信端口
delay_18B20(8); //稍做延时
DQ = 0;          //单片机将DQ拉低
delay_18B20(80); //精确延时 大于 480us
DQ = 1;          //拉高总线
delay_18B20(4);
x=DQ;            //稍做延时后 如果x=0则初始化成功 x=1则初始化失败
delay_18B20(20);
}

/***********ds18b20读一个字节**************/

unsigned char ReadOneChar(void)
{
uchar i=0;
uchar dat = 0;
for (i=8;i>0;i--)
{
    DQ = 0; // 高电平拉成低电平时读周期开始
    dat>>=1;
    DQ = 1; // 给脉冲信号
    if(DQ)
    dat|=0x80;   // | *
    delay_18B20(4);
}
   return(dat);
}

/*************ds18b20写一个字节****************/

void WriteOneChar(uchar dat)
{
   unsigned char i=0;
   for (i=8; i>0; i--)
   {
   DQ = 0; //从高电平拉至低电平时,写周期的开始
    DQ = dat&0x01;   //数据的最低位先写入
    delay_18B20(5); //60us到120us延时
    DQ = 1;       
    dat>>=1; //从最低位到最高位传入
}
}

/**************读取ds18b20当前温度************/

void ReadTemperature(void)
{
unsigned char a=0;
unsigned char b=0;
unsigned char t=0;

Init_DS18B20();
WriteOneChar(0xCC);    // 跳过读序号列号的操作
WriteOneChar(0x44); // 启动温度转换

delay_18B20(100);       // this message is wery important

Init_DS18B20();
WriteOneChar(0xCC); //跳过读序号列号的操作
WriteOneChar(0xBE); //读取温度寄存器等(共可读9个寄存器) 前两个就是温度

delay_18B20(100);

a=ReadOneChar();    //读取温度值低位
b=ReadOneChar();      //读取温度值高位
//temp1=b<<4;            //高8位中后三位数的值
//temp1+=(a&0xf0)>>4;      //低8位中的高4位值加上高8位中后三位数的值   temp1室温整数值
temp2=a&0x0f;             //小数的值

temp=((b*256+a)>>4);    //当前采集温度值除16得 实际温度值
   xs=temp2*0.0625*10; //小数位,若为0.5则算为5来显示   xs小数


//上、下限温度值可自动保存,掉电不会丢失。?
//写暂存存储器 写暂存存储器 复制暂存存储器 ??
}

void main()
{
 SCON=0;
 while(1)
 {ReadTemperature();
 SBUF=Num[xs];
 while(!TI);
 TI=0;
 SBUF=Num[temp%16]+128;
 while(!TI);
 TI=0;
 SBUF=Num[temp/16];
 while(!TI);
 TI=0;
 SBUF=0xff;
 while(!TI);
 TI=0;
 SBUF=0xff;
 while(!TI);
 TI=0;
 SBUF=0xff;
 while(!TI);
 TI=0;
 delay1(50);
 }
}

 

*博客内容为网友个人发布,仅代表博主个人观点,如有侵权请联系工作人员删除。

参与讨论
登录后参与讨论
最近文章
DS18B20
2010-04-30 20:03:34
DS1302
2010-04-30 20:01:46
推荐文章
最近访客