- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 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
您可能关注的文档
最近下载
- 防火墙安全策略巡检报告.doc VIP
- XX职业技术学院“十五五”中长期发展规划(2026-2030年).docx
- 四川省成都市温江区2024-2025学年八年级上学期1月期末物理试题.docx VIP
- 游泳馆托管服务学生游泳培训服务方案.doc VIP
- “双减”背景下初中数学课堂教学提质增效探究 论文.docx VIP
- QC_T 556-2023 汽车制动器温度测量方法及热电偶安装要求.pdf VIP
- 清水河储能电站施工方案.pdf VIP
- 广州永日电梯电气原理图.pdf VIP
- 江苏省2022年高中学业水平合格性考试历史试卷真题(含答案详解).docx VIP
- 数学八下练习(图形的平移与旋转 ).doc VIP
原创力文档


文档评论(0)