- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
温度控制系统c程序
#includereg51.h
#define uchar unsigned char
#define uint unsigned int
uchar code table0[]=Tempeture:;
uchar code table1[]=welcom to text!;
sbit lcdrs=P3^5;
//sbit lcdrw=P2^1;
sbit lcden=P3^4;
sbit ds=P2^2;
sbit beep=P2^3;
sbit dula=P2^6;
sbit wela=P2^7;
bit flag;
uchar num;
uint temp,t;
uchar temp_bai,temp_shi,temp_ge,temp_little;
float xs_temp;
void delay(uint z)//延时1ms子程序
{
uint x,y;
for(x=z;x0;x--)
for(y=110;y0;y--);
}
void ds_reset( ) //DS18B20初始化
{
uint i;
bit pw=1;
while(pw)
{
ds=1;
i++;
ds=0;
i=103;
while(i0)i--;//835us
ds=1;
i=4;
while(i0)i--;//35us
pw=ds;
}
i=70;
while(i0)i--;//604us
ds=1;
}
void temp_wr_byte(uchar dat)//DS18B20写一个字节的数据子程序
{
bit testb;
uchar j;
uint i;
for(j=0;j8;j++)
{
testb=dat0x01;
dat=dat1;
if(testb) //textb为真写1,
{
ds=0; //i++;i++;
i=1;
while(i0)i--; //至少1us
ds=1;
i=8;
while(i0)i-- ; //66us
}
else
{
ds=0; //写0
i=8;
while(i0)i--;
ds=1; //对IO线进行写0
i=1;
while(i0)i--;
}
}
}
bit temp_rd_bit( ) //读一位数据子程序
{
uint i;
bit dat;
ds=1;
i=0;
ds=0; //2us
i++;
i++;
ds=1; //6us
i++; //3us
dat=ds;
i=4;
while(i0)i--; //32us
return(dat);
}
uchar tempread( )//读一个字节数据
{
uchar i,j,dat;
dat=0;
for(i=0;i8;i++)
{
j=temp_rd_bit( );
dat=(j7)|(dat1); //读出数据最低位在最前面,刚好一个字节在dat里
}
return(dat); //读了8次即8个字节
}
void tempchange( ) //启动温度转换
{
ds_reset( );
// delay(1);
temp_wr_byte(0xcc); //跳过ROM
temp_wr_byte(0x44); //启动温度转换
}
void temp_rec( ) //读取温度数据
{
uchar a,b;
ds_reset( );
// delay(1);
temp_wr_byte(0xcc);
temp_wr_byte(0xbe); //从暂存寄存器读字节
a=tempread( );
b=tempread( );
temp=b;
temp=8; //保留最高位
temp=temp|a;
if(temp0x7fff)//是否为正数?
{
flag=0;
}
else
{
flag=1; //为负数时,温度数据要反向
temp=~temp+1;
}
xs_temp=temp*0.0625; //分辨率为1/2^12.
}
void write_com(uchar com)//液晶写指令操作子程序
{
lcdrs=0;
P0=com;
delay(5);
lcden=1;
delay(5);
lcden=0;
}
void write_date(uchar date)//液晶写数据操作子程序
{
lcdrs=1;
P0=date;
d
文档评论(0)