ds18b20多路温度采集程序.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实用文案 标准文档 本程序为ds18b20的多路温度采集程序,是我自己参考其他程序后改写而成,可显示4路正负温度值,并有上下限温度报警(声音、灯光报警)。 亲测,更改端口即可使用。(主要器件:51单片机,ds18b20,lcd显示器) 附有proteus仿真图,及序列号采集程序 /****上限62度 下限-20度****/ #includereg51.h #define uchar unsigned char #define uint unsigned int sbit ds=P1^1; sbit rs=P1^4; sbit e=P1^6; sbit sp=P1^0; sbit d1=P1^2; sbit d2=P1^3; 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 }; unsigned char code table1[]={0123456789ABCDEF}; int f[4]; int tvalue; float ftvalue; uint warnl=320; uint warnh=992; /****lcd程序****/ void delayms(uint ms)//延时 { uint i,j; for(i=ms;i0;i--) for(j=110;j0;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(i0)i--; ds=1; i=4; while(i0)i--; } bit dsrd0()//读一位数据 { uint i; bit dat; ds=0;i++; ds=1;i++;i++; dat=ds; i=8;while(i0)i--; return(dat); } uchar dsrd()//读1个字节数据 { uchar i,j,dat; dat=0; for(i=8;i0;i--) { j=dsrd0(); dat=(j7)|(dat1); } return(dat); } void dswr(uchar dat)//写数据 { uint i; uchar j; bit testb; for(j=8;j0;j--) { testb=dat0x01; dat=dat1; if(testb) { ds=0; i++;i++; ds=1; i=8;while(i0)i--; } else { ds=0; i=8;while(i0)i--; ds=1; i++;i++; } } } void tmstart()//初始化ds18b20 { sp=1; d1=1; d2=1; dsrst(); delayms(1); dswr(0xcc); dsw

文档评论(0)

linlin921 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档