b多路温度采集程序
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
本程序为ds18b20 的多路温度采集程序,是我自己参考其他程序后改写而成,可显示 4 路正负温度值,并有上下限温度报警(声音、灯光报警)
亲测,更改端口即可使用。(主要器件:51单片机,ds18b20,lcd 显示器)
附有proteus 仿真图,及序列号采集程序
/**** 上限62 度下限-20 度****/
#include<>
#define uchar unsigned char
#define uint unsigned int
sbit ds=P1A1;
sbit rs=P1A4;
sbit e=P1A6;
sbit sp=P1A0;
sbit d1=P1A2;
sbit d2=P1A3;
uchar lcdrom[4][8]={{0x28,0x30,0xc5,0xb8,0x00,0x00,0x00,0x8e},
{0x28,0x31,0xc5,0xb8,0x00,0x00,0x00,0xb9},
{0x28,0x32,0xc5,0xb8,0x00,0x00,0x00,0xe0},
{0x28,0x33,0xc5,0xb8,0x00,0x00,0x00,0xd7}}; unsigned char code table0[]={"TEMPERARTURE:U "}; int f[4];
int tvalue;
float ftvalue;
uint warnl=320;
uint warnh=992;
/****lcd 程序****/
void delayms(uint ms)// 延时
{
uint i,j;
for(i=ms;i>0;i--) for(j=110;j>0;j--);
}
void wrcom(uchar com)// 写指令
{ delayms(1); rs=0;
P3=com; delayms(1); e=1;
delayms(1);
e=0;
}
void wrdat(uchar dat)// 写数据
{
rs=1;
e=0;
P3=dat;
delayms(5);
e=1;
delayms(5);
e=0;
}
void lcdinit()// 初始化lcd
{
delayms(15);
wrcom(0x38);delayms(5);
wrcom(0x0c);delayms(5);
wrcom(0x06);delayms(5);
wrcom(0x01);delayms(5); }
void display(uchar *p)// 显示{
while(*p!='\0')
wrdat(*p);
p++;
delayms(1);
}
}
displayinit()// 初始化显示{
lcdinit();
wrcom(0x80);
display(table0);
}
/****ds18b20 程序****/ void dsrst()//ds18b20 复位{ uint i;
ds=0;
i=103;
while(i>0)i--;
ds=1;
i=4;
while(i>0)i--;
bit dsrd0()// 读一位数据
{
uint i;
}
bit dat;
ds=0;i++;
ds=1;i++;i++;
dat=ds; i=8;while(i>0)i--; return(dat); }
uchar dsrd()// 读1 个字节数据
{
uchar i,j,dat; dat=0;
for(i=8;i>0;i--)
{
j=dsrd0();
dat=(j<<7)|(dat>>1);
}
return(dat);
}
void dswr(uchar dat)// 写数据
uint i;
uchar j;
bit testb;
for(j=8;j>0;j--)
{
testb=dat&0x01;
dat=dat>>1;
if(testb)
{
{
ds=0; i++;i++;
ds=1; i=8;while(i>0)i--; }
else
{
ds=0; i=8;while(i>0)i--;
ds=1; i++;i++;
}
}
}
void tmstart()// 初始化ds18b20
{
sp=1;
d1=1;
d2=1;
dsrst();
delayms(1);
dswr(0xcc); dswr(0x44);
}
void read_dealtemp()// 读取并处理温度
{
uchar i,j,t;
uchar a,b;
for(j=0;j<4;j++)
{
dsrst();
delayms(1);
dswr(0x55);
for(i=0;i<8;i++)
{
dswr(lcdrom[j][i]);//
发送64 位序列号dswr(0xbe);
a=dsrd();
}