#include "reg52.h"
#include "iic.h"
#include "onewire.h"
sbit S7 = P3^0;
sbit S6 = P3^1;
sbit S5 = P3^2;
sbit S4 = P3^3;
sbit L1 = P0^0;
sbit L2 = P0^1;
sbit L3 = P0^2;
sbit L4 = P0^3;
unsigned int T_max = 30; //温度上限
unsigned int T_min = 20; //温度下限
unsigned int Temp_max; //温度上限设置
unsigned int Temp_min; //温度下限设置
unsigned int k4 = 0; //0数据显示,1参数设置
unsigned int k4_1 = 0; //0温度设置正确,1温度设置错误
unsigned int k5 = 0; //0设置温度下限,1设置温度上限
unsigned int v; //电压
unsigned int T_dat; //温度
unsigned int rb;
unsigned int smg_f = 0;
unsigned char duanma[18] = {
0xc0,0xf9,0xa4,0xb0,0x99,0x92,0x82,0xf8,0x80,0x90,0x88,0x80,0xc6,0xc0,0x86,0x8e,0xbf,0x7f};
//==========================选择函数=========================
void selectHC573(unsigned char channel)
{
switch(channel)
{
case 4:
P2 = (P2 & 0x1f) | 0x80;
break;
case 5:
P2 = (P2 & 0x1f) | 0xa0;
break;
case 6:
P2 = (P2 & 0x1f) | 0xc0;
break;
case 7:
P2 = (P2 & 0x1f) | 0xe0;
break;
}
}
//==========================初始化函数=======================
void init_system()
{
selectHC573(4);
P0 = 0xff;
selectHC573(5);
P0 = 0x00;
selectHC573(6);
P0 = 0xff;
selectHC573(7);
P0 = 0xff;
}
//==========================温度传感器=======================
void delay(unsigned int t)
{
while(t--);
}
void read_ds18b20_dat()
{
unsigned char LSB,MSB;
init_ds18b20();
Write_DS18B20(0xcc);
Write_DS18B20(