仿真原理圖如下(proteus仿真工程文件可到本帖附件中下載)
51hei.png (30.67 KB, 下載次數: 88)
下載附件
2020-12-6 22:19 上傳
單片機源程序如下:
#include <reg51.h>
#define uint unsigned int
#define uchar unsigned char //宏定義
#define LCD1602 P0
sbit SET=P3^1; //定義調整鍵
sbit DEC=P3^2; //定義減少鍵
sbit ADD=P3^3; //定義增加鍵
sbit BUZZ=P3^6; //定義蜂鳴器
sbit ALAM=P1^2; //定義燈光報警
sbit ALAM1=P1^4;
sbit DQ=P3^7; //定義DS18B20總線I/O
sbit RS = P2^7;
sbit EN = P2^6;
bit shanshuo_st; //閃爍間隔標志
bit beep_st; //蜂鳴器間隔標志
uchar x=0; //計數器
uchar code tab1[]={"Now Tem: . C "};
uchar code tab2[]={"TH: C TL: C"};
uint c;
uchar Mode=0; //狀態標志
signed char TH=40; //上限報警溫度,默認值為40
signed char TL=10; //下限報警溫度,默認值為10
//============================================================================================
//====================================DS18B20=================================================
//============================================================================================
/*****延時子程序*****/
void Delay_DS18B20(int num)
{
while(num--) ;
}
void delay(uint xms)//延時函數,有參函數
{
uint x,y;
for(x=xms;x>0;x--)
for(y=110;y>0;y--);
}
/*****初始化DS18B20*****/
void Init_DS18B20(void)
{
unsigned char x=0;
DQ = 1; //DQ復位
Delay_DS18B20(8); //稍做延時
DQ = 0; //單片機將DQ拉低
Delay_DS18B20(80); //精確延時,大于480us
DQ = 1; //拉高總線
Delay_DS18B20(14);
x = DQ; //稍做延時后,如果x=0則初始化成功,x=1則初始化失敗
Delay_DS18B20(20);
}
/*****讀一個字節*****/
unsigned char ReadOneChar(void)
{
unsigned char i=0;
unsigned char dat = 0;
for (i=8;i>0;i--)
{
DQ = 0; // 給脈沖信號
dat>>=1;
DQ = 1; // 給脈沖信號
if(DQ)
dat|=0x80;
Delay_DS18B20(4);
}
return(dat);
}
/*****寫一個字節*****/
void WriteOneChar(unsigned char dat)
{
unsigned char i=0;
for (i=8; i>0; i--)
{
DQ = 0;
DQ = dat&0x01;
Delay_DS18B20(5);
DQ = 1;
dat>>=1;
}
}
/*****讀取溫度*****/
unsigned int ReadTemperature(void)
{
unsigned char a=0;
unsigned char b=0;
unsigned int t=0;
float tt=0;
Init_DS18B20();
WriteOneChar(0xCC); //跳過讀序號列號的操作
WriteOneChar(0x44); //啟動溫度轉換
Init_DS18B20();
WriteOneChar(0xCC); //跳過讀序號列號的操作
WriteOneChar(0xBE); //讀取溫度寄存器
a=ReadOneChar(); //讀低8位
b=ReadOneChar(); //讀高8位
t=b;
t<<=8;
t=t|a;
tt=t*0.0625;
// t= tt*10+0.5; //放大10倍輸出并四舍五入
t= tt*10+0.5;
return(t);
}
/*****讀取溫度*****/
void check_wendu(void)
{
c=ReadTemperature()-5; //獲取溫度值并減去DS18B20的溫漂誤差
if(c>1200)
c=1200;
}
全部資料51hei下載地址:
51檢測溫度控制.zip
(146.7 KB, 下載次數: 52)
2020-12-6 13:19 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
|