云题海 - 专业文章范例文档资料分享平台

当前位置:首页 > 温度测量系统设计--毕业设计

温度测量系统设计--毕业设计

  • 62 次阅读
  • 3 次下载
  • 2025/6/13 16:39:47

DQ=1;_nop_();_nop_();

DQ = 0;_nop_();_nop_();_nop_();_nop_();_nop_();//5us DQ = val&0x01; //最低位移出 delay(6); //66us val=val/2; //右移一位 }

DQ = 1; delay(1); } //

/*********18B20读1个字节函数********/ //从总线上读取一个字节 uchar read_byte(void) {

uchar i;

uchar value = 0; for (i=8;i>0;i--) {

DQ=1;_nop_();_nop_(); value>>=1;

DQ = 0; //

_nop_();_nop_();_nop_();_nop_(); //4us

DQ = 1;_nop_();_nop_();_nop_();_nop_(); //4us if(DQ)value|=0x80;

delay(6); //66us } DQ=1;

return(value); } //

/***********读出温度函数**********/ //

read_temp() {

ow_reset(); //总线复位

write_byte(0xCC); // 发Skip ROM命令 write_byte(0xBE); // 发读命令

temp_data[0]=read_byte(); //温度低8位 temp_data[1]=read_byte(); //温度高8位 ow_reset();

write_byte(0xCC); // Skip ROM write_byte(0x44); // 发转换命令 } //

/***********温度数据处理函数**********/ void work_temp() {

uchar n=0;

uchar doth,dotl;

uchar flag3=1,flag2=1; //数字显示修正标记 if((temp_data[1]&0xf8)!=0x00) {

temp_data[1]=~(temp_data[1]); temp_data[0]=~(temp_data[0])+1; n=1; flag=1;

}//负温度求补码

if(temp_data[0]>255) {

temp_data[1]++; }

display[4]=temp_data[0]&0x0f; display[0]=ditab[display[4]]; doth=display[0]/10; dotl=display[0];

display[4]=((temp_data[0]&0xf0)>>4)|((temp_data[1]&0x07)<<4); display[3]=display[4]/100; display[2]=display[4]/10; display[1]=display[4]; if(!display[3]) {

display[3]=0x0a; flag3=0;

if(!display[2]) {

display[2]=0x0a; flag2=0; }

}//最高位为0时都不显示 if(n) {

display[3]=0x0b;//负温度时最高位显示\ flag3=0; } } // //

/**************主函数****************/ main() {

Disdata=0xff; //初始化端口 discan=0xff;

for(h=0;h<4;h++){display[h]=8;}//开机显示8888 ow_reset(); // 开机先转换一次 write_byte(0xCC); // Skip ROM write_byte(0x44); // 发转换命令 for(h=0;h<500;h++)

{scan();} //开机显示\秒 while(1) {

read_temp(); //读出18B20温度数据 work_temp(); //处理温度数据

scan(); //显示温度值2秒 } } //

//*********************结束**************************//

搜索更多关于: 温度测量系统设计--毕业设计 的文档
  • 收藏
  • 违规举报
  • 版权认领
下载文档10.00 元 加入VIP免费下载
推荐下载
本文作者:...

共分享92篇相关文档

文档简介:

DQ=1;_nop_();_nop_(); DQ = 0;_nop_();_nop_();_nop_();_nop_();_nop_();//5us DQ = val&0x01; //最低位移出 delay(6); //66us val=val/2; //右移一位 } DQ = 1; delay(1); } // /*********18B20读1个字节函数********/ //从总线上读取一个字节 uchar read_byte(void) { uchar i; uchar value = 0; for (i=8;i>0;i--) { DQ=1;_nop_();_nop_(); value>>=1; DQ = 0;

× 游客快捷下载通道(下载后可以自由复制和排版)
单篇付费下载
限时特价:10 元/份 原价:20元
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
VIP包月下载
特价:29 元/月 原价:99元
低至 0.3 元/份 每月下载150
全站内容免费自由复制
注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信:fanwen365 QQ:370150219
Copyright © 云题海 All Rights Reserved. 苏ICP备16052595号-3 网站地图 客服QQ:370150219 邮箱:370150219@qq.com