- 1、本文档共3页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
温度设定程序
#includereg51.h
#define uchar unsigned char
#define uint unsigned int
sbit DQ=P2^1; //温度数据口
sbit wx1=P2^2; //位选1
sbit wx2=P2^3; //位选2
unsigned int temp, temp1,temP0;
uchar code table[]={0xc0,0xf9,0xa4,0xb0,0x99, //共阳数码管0~4
0x92,0x82,0xf8,0x80,0x90};//共阳数码管5~9
/******延时程序*******/
void delay1(unsigned int m)
{
unsigned int i,j;
for(i=m;i0;i--)
for(j=110;j0;j--);
}
void delay(unsigned int m) //温度延时程序
{
while(m--);
}
void Init_DS18B20()
{
unsigned char x=0;
DQ = 1; //DQ复位 ds18b20通信端口
delay(8); //稍做延时
DQ = 0; //单片机将DQ拉低
delay(80);//精确延时 大于 480us
DQ = 1; //拉高总线
delay(4);
x=DQ; //稍做延时后 如果x=0则初始化成功 x=1则初始化失败
delay(20);
}
/***********ds18b20读一个字节**************/
uchar ReadOneChar()
{
unsigned char i=0;
unsigned char dat = 0;
for (i=8;i0;i--)
{
DQ = 0; // 高电平拉成低电平时读周期开始
dat=1;
DQ = 1; // 给脉冲信号
if(DQ)
dat|=0x80;
delay(4);
}
return(dat);
}
/*************ds18b20写一个字节****************/
void WriteOneChar(unsigned char dat)
{
unsigned char i=0;
for (i=8; i0; i--)
{
DQ = 0; //从高电平拉至低电平时,写周期的开始
DQ = dat0x01; //数据的最低位先写入
delay(5); //60us到120us延时
DQ = 1;
dat=1; //从最低位到最高位传入
}
}
/**************读取ds18b20当前温度************/
void ReadTemperature()
{
unsigned char a=0;
unsigned b=0;
unsigned t=0;
Init_DS18B20();
WriteOneChar(0xCC); // 跳过读序号列号的操作/
WriteOneChar(0x44); // 启动温度转换
delay(5);
Init_DS18B20();
WriteOneChar(0xCC); //跳过读序号列号的操作
WriteOneChar(0xBE); //读取温度寄存器等(共可读9个寄存器) 前两个就是温度/
delay(5);
a=ReadOneChar(); //读取温度值低位 /
b=ReadOneChar(); //读取温度值高位 /
temp1=b4; //高8位中后三位数的值
temp1+=(a0xf0)4; //低8位中的高4位值加上高8位中后三位数的值 temp1室温整数值
temp=((b*256+a)4); //当前采集温度值除16得 实际温度值 zhenshu
}
void wenduxianshi() //温度显示
{
wx1=1;
P0=table[temp/10];
您可能关注的文档
- 从光盘安装XP系统.doc
- baoding理综.doc
- 岩石圈与地表形态3课时辅助学案.doc
- 第二节生活中的透镜学案.doc
- (津建安表2)责任目标考核表.doc
- 基站运维人员培训复习题3.doc
- 七年级上苏教版生物导课.ppt
- 第一部分综合实践活动课程的基本理念.doc
- 安全生产责任制考核办法1-04.doc
- SF6开关检修工艺规定.doc
- 半导体材料性能提升技术突破与应用案例分析报告.docx
- 半导体设备国产化政策支持下的关键技术突破与应用前景报告.docx
- 剧本杀市场2025年区域扩张策略研究报告.docx
- 剧本杀行业2025人才培训体系构建中的市场需求与供给分析.docx
- 剧本杀行业2025年人才培训行业人才培养模式创新与探索.docx
- 剧本杀行业2025年内容创作人才需求报告.docx
- 剧本杀行业2025年区域市场区域剧本市场消费者满意度与市场竞争力研究报告.docx
- 剧本杀市场2025年区域竞争态势下的区域合作策略分析报告.docx
- 剧本杀行业2025人才培训与行业人才培养模式创新.docx
- 剧本杀行业剧本创作人才心理素质培养报告.docx
文档评论(0)