- 1、本文档共24页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
测温度代码
测温度代码
#includereg52.h
#includestdio.h
#includeabsacc.h
sbit CS=P1^0; /*7289管脚定义*/
sbit CLK=P1^1;
sbit DIO=P1^2;
sbit KEY=P1^3;
sbit TM1=P1^4; /*测得温度*/
sbit TM2=P1^5;
sbit M1=P3^3; /*恒温控制管脚*/
sbit M2=P3^2;
sbit WAR=P3^6;
sbit L1=P1^7;
sbit L2=P1^6;
unsigned char T,Th,Tl,Tx,Tmax; //实际测量温度值;温度上下限 TH,TL; 测量时间间隔;报警温度
unsigned char rebuf,sebuf; // 7289接受,发送数据变量
bdata unsigned char com_data; //定义可寻址内部储存器com_data 变量
sbit mos_bit=com_data^7;
sbit low_bit=com_data^0;
unsigned char a[3];//用于存放温度各位值得数组
unsigned char c[3]; //修改键值时的中间数组
unsigned char mm;
unsigned char td;
unsigned char ap;
void delays(unsigned int t) // 延迟毫秒和秒的函数
{
unsigned int i,j;
for(i=0;it;i++)
for(j=0;j125;j++)
{;}
}
void delayus(unsigned int t) //延迟8微秒倍数函数
{
unsigned int i;
for(i=0;it;i++)
{;}
}
void ds18reset1() //DS18B20复位设置
{
TM1=0;
delayus(103); //要实现复位至少240us低电平信号,此处为900us
TM1=1;
delayus(4);
}
void ds18pre1() //DS18B20等待复位返还脉冲
{
while(TM1);
while(~TM1);
delayus(4); //等待15~66us
}
char ds18zh1() //DS18B20温度转换
{
bit dat;
TM1=0;
delayus(1);
TM1=1;
delayus(2);
dat=TM1;
delayus(8);
return(dat);
}
char ds18read1() //读取一个字节温度值
{
unsigned char a;
char j,dat;
dat=0;
for(a=1;a=8;a++)
{
j=ds18zh1();
dat=(j7)|(dat1);
}
return(dat);
}
void ds18write1(unsigned char dat) //写入一个指令字节
{
unsigned int j;
bit testb;
for(j=1;j=8;j++)
{
testb=dat0x01;
dat=1;
if(testb) //写入1
{
TM1=0;
delayus(2);
TM1=1;
delayus(8);
}
else //写入0
{
TM1=0;
delayus(8);
TM1=1;
delayus(2);
}
}
}
void ds18start1() //ds18b20开始转换温度
{
ds18reset1(); // 复位
ds18pre1(); // 等待返还脉冲
delays(1); // 延迟1ms
ds18write1(0xcc); // 跳过序列编码校对
ds18write1(0x44); // 温度转换
}
void ds18zhi1() //温度值得测量值获取,结果可以显示一位小数
{
unsigned char m,n,i;
int c;
ds18reset1(); // 复位DS18B20
ds18pre1(); // 等待返还脉冲
delays(1); // 延迟1ms
ds18write1(0xcc); // 写入指令0xcc,跳过序列编码
文档评论(0)