⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 18b20.h

📁 数字温度传感器ds18b20+at8051的完整代码
💻 H
字号:
/************************************************************/
/*********         18B20.H C51 driver           *************/
/**********  Written by WangBiao---20060311  ****************/
/************************************************************/
//-----------------------------------------------------------------------
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
//-----------------------------------------------------------------------
//#include <stdio.h>//-----!!!whether need????
//---------------------------------------------
sbit DQ=P2^7; //数据传输线接单片机的相应的引脚
//---------------------------------------------
unsigned char Ftab[9];//"+/-","1-4","5-8";-->sign,Fz,Fx
//-----------------------外部函数----------------------------------------
float ReadTemperature(void);//低位放tempL;高位放tempH;温度值存在temperature
void adjustfloat(float Fdata);
void disp_18b20_pccom(void);//for PCCOM,LED,LCD...---!!!!!need edit!!!!!!!!!
//-----------------------------------------------------------------------
//@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@@
//-----------------------------------------------------------------------
//-----------------------内部函数----------------------------------------
void delay_temp(unsigned int n);
void Init_DS18B20(void);
unsigned char ReadOneChar(void);
void WriteOneChar(unsigned char dat);
	//-----------------------
int Mi(unsigned int n);
//-----------------------------------------------------------------------
//------------延时子程序-------------
void delay_temp(unsigned int n)
{
	while(n--); 
}
//------初始化程序--------------------
void Init_DS18B20(void)
{	unsigned char x=0;
	DQ=1;//DQ先置高
	delay_temp(8);//稍延时
	DQ=0; //发送复位脉冲
	delay_temp(85); //延时(>480ms)
	DQ=1;//拉高数据线
	delay_temp(14);//等待(15~60ms)
	x=DQ;//用X的值来判断初始化有没有成功,18B20存在的话X=0,否则X=1
	delay_temp(20);
}
//------读一个字节----------------------------------------------------------------
unsigned char ReadOneChar(void)//主机数据线先从高拉至低电平1ms以上,再使数据线升为高电平,从而产生读信号
{	unsigned char i=0; //每个读周期最短的持续时间为60ms,各个读周期之间必须有1ms以上的高电平恢复期
	unsigned char dat=0;
	for(i=8;i>0;i--)//一个字节有8位
	{	DQ=1;
		delay_temp(1);
		DQ=0;
		dat>>=1;
		DQ=1;
		if(DQ) dat|=0x80;
		delay_temp(4);
	}
	return(dat);
}
//------写一个字节----------------------------------------------------------------
void WriteOneChar(unsigned char dat)
{	unsigned char i=0; //数据线从高电平拉至低电平,产生写起始信号。15ms之内将所需写的位送到数据线上,
	for(i=8;i>0;i--)//在15~60ms之间对数据线进行采样,如果是高电平就写1,低写0发生。
	{	DQ=0;//在开始另一个写周期前必须有1ms以上的高电平恢复期。
		DQ=dat&0x01;
		delay_temp(5);
		DQ=1;
		dat>>=1;
	}
	delay_temp(4);
}
//-------读温度值(低位放tempL;高位放tempH;温度值存在temperature.)---------------
float ReadTemperature(void)
{	unsigned char tempL=0; //设全局变量
	unsigned char tempH=0;
	float temperature; //温度值保存在temperature里
	Init_DS18B20();//初始化
	WriteOneChar(0xcc);//跳过读序列号的操作
	WriteOneChar(0x44); //启动温度转换
	delay_temp(125); //转换需要一点时间,延时
	Init_DS18B20();//初始化
	WriteOneChar(0xcc);//跳过读序列号的操作
	WriteOneChar(0xbe); //读温度寄存器(头两个值分别为温度的低位和高位)
	tempL=ReadOneChar(); //读出温度的低位LSB
	tempH=ReadOneChar(); //读出温度的高位MSB 
	temperature=((tempH*256)+tempL)*0.0625; //温度转换,把高低位做相应的运算转化为实际温度
	delay_temp(200);
	return(temperature);
}
//----------------------------------------
int Mi(unsigned int n)
{	int t=1;
	while(n--) t=t*10;
	return t;
}
//------------float to tab-------------------------------------
void adjustfloat(float Fdata)
{	unsigned int i;

	int Fz,Fx,Ft,Fm;
		//-----adjustfloat---------
	if(Fdata>0)
	{	Ftab[0]=0;
		Fz=(int)Fdata;
		Fx=(Fdata-Fz)*10000;
	}
	else
	{	Ftab[0]=1;
		Fz=(int)Fdata;//-55
		Fx=(Fz-Fdata)*10000;
		Fz=(Fz^0xffff)+1;
	}

	Ft=Fz;
	for(i=1;i<=4;i++)
	{	Fm=Mi(4-i);
		Ftab[i]=Ft/Fm;
		Ft=Ft-Ftab[i]*Fm;
	}
	
	Ft=Fx;
	for(i=5;i<=8;i++)
	{	Fm=Mi(8-i);
		Ftab[i]=Ft/Fm;
		Ft=Ft-Ftab[i]*Fm;
	}
		//------adjustfloat end-----
}
//-------------------------------------------------
//-----dispfloat example------------------------------
void disp_18b20_pccom(void)
{	unsigned char i;
	/*Tdata=ReadTemperature();printf("%f\n",Tdata);*/
	adjustfloat(ReadTemperature());

	if(Ftab[0]==0) putchar('+');
	else putchar('-');

	for(i=1;i<=4;i++) putchar(Ftab[i]+0x30);
	putchar('.');
	for(i=5;i<=8;i++) putchar(Ftab[i]+0x30);
}
//--------------dispfloat end-------------------------
//-------------------end 18B20.H-----------------------------------------
 

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -