{ }
/******************把数据从单片机内部eepom中读出来*****************/ void read_eepom() { }
/**************开机自检eepom初始化*****************/ void init_eepom() { }
/***********************18b20初始化函数*****************************/ void init_18b20()
35
SectorErase(0x2000); byte_write(0x2000, s_temp); byte_write(0x2001, s_dengji); byte_write(0x2060, a_a);
s_temp = byte_read(0x2000); s_dengji = byte_read(0x2001); a_a = byte_read(0x2060);
read_eepom(); if(a_a != 1) {
//先读
//新的单片机初始单片机内问EEPOM
s_temp = 50; s_dengji = 5; a_a = 1; write_eepom();
}
{ }
/*************写18b20内的数据***************/ void write_18b20(uchar dat) { }
/*************读取18b20内的数据***************/ uchar read_18b20() {
36
bit q; dq = 1;
//把总线拿高
delay_uint(1); dq = 0;
//15us
//给复位脉冲 //750us
//把总线拿高 等待 //110us
//读取18b20初始化信号 //200us
//把总线拿高 释放总线
delay_uint(80); dq = 1;
delay_uint(10); q = dq;
delay_uint(20); dq = 1;
uchar i; for(i=0;i<8;i++) {
//写数据是低位开始
//把总线拿低写时间隙开始
dq = 0;
dq = dat & 0x01; //向18b20总线写数据了 delay_uint(5); dq = 1;
// 60us //释放总线
dat >>= 1;
}
}
uchar i,value; for(i=0;i<8;i++) { }
return value;
//返回数据
dq = 0;
//把总线拿低读时间隙开始
value >>= 1; //读数据是低位开始 dq = 1;
//释放总线 //开始读写数据
if(dq == 1)
value |= 0x80;
//60us
读一个时间隙最少要保持60us的时间
delay_uint(5);
/*************读取温度的值 读出来的是小数***************/ uint read_temp() {
uint value; uchar low;
//在读取温度的时候如果中断的太频繁了,就应该把中
断给关了,否则会影响到18b20的时序
init_18b20(); //初始化18b20
//跳过64位ROM //启动一次温度转换命令 //500us
write_18b20(0xcc); write_18b20(0x44); delay_uint(50);
init_18b20();
//初始化18b20
write_18b20(0xcc); write_18b20(0xbe); EA = 0;
//跳过64位ROM //发出读取暂存器命令
37
}
low = read_18b20(); //读温度低字节 value = read_18b20(); //读温度高字节 EA = 1; value <<= 8; value |= low;
//把温度的高位左移8位
//把读出的温度低位放到value的低八位中
value *= 0.0625; //转换到温度值 return value;
//返回读出的温度
/***********读数模转换数据
********************************************************/
//请先了解ADC0832模数转换的串行协议,再来读本函数,主要是对应时序图来理解,本函数是模拟0832的串行协议进行的
// 1 0 0 通道 // 1 1 1 通道
unsigned char ad0832read(bit SGL,bit ODD) {
unsigned char i=0,value=0,value1=0;
SCL=0; DO=1; CS=0; SCL=1; SCL=0; DO=SGL;
SCL=1; //第二个上升沿 SCL=0; DO=ODD;
SCL=1; //第三个上升沿 SCL=0; //第三个下降沿
38
//开始
//第一个上升沿
DO=1;
for(i=0;i<8;i++) { }
for(i=0;i<8;i++) { } CS=1; SCL=1;
if(value==value1)
//与校验数据比较,正确就返回数据,否则
//接收校验数据
SCL=1;
SCL=0; //开始从第四个下降沿接收数据 value<<=1; if(DO)
value++;
value1>>=1; if(DO)
value1+=0x80;
SCL=1; SCL=0;
返回0
}
/***********************数码显示函数*****************************/ void display() {
return value;
return 0;
uchar i;
39