51单片机——DS18B20

发布者:素雅之韵最新更新时间:2016-12-23 来源: eefocus关键字:51单片机  DS18B20 手机看文章 扫描二维码
随时随地手机看文章

DS18B20——温度传感器,单片机可以通过 1-Wire 和 DS18B20 进行通 信,最终将温度读出。1-Wire 总线的硬件接口很简单,只需要把 18B20 的数据引脚和单片 机的一个 IO 口接上就可以通信。最高12为的温度存储值,补码形式存储。

2字节,LSB低字节,MSB高字节,-55~125

 

1、初始化

检测存在脉冲:总线上存在DS18B20,总线会根据时序要求返回一个低电平脉冲。单片机要拉低这个引脚,持续大概 480us到960us之间 的时间即可,我们的程序中持续了 500us。然后,单片机释放总线,就是给高电平,DS18B20 等待大概 15 到 60us 后,会主动拉低这个引脚大概是 60 到 240us,而后 DS18B20 会主动释放总线,这样 IO 口会被上拉电阻自动拉高。

 

2、ROM操作指令

Skip ROM(跳过ROM):0xCC。当总线上只有一个器件的时候,可以跳过 ROM,不进行ROM 检测。

 

3、RAM存储器操作指令

Read Scratchpad(读暂存寄存器):0xBE—— DS18B20 的温度数据是 2 个字节,我们读取数据的时候,先 读取到的是低字节的低位,读完了第一个字节后,再读高字节的低位,一直到两个字节全部 读取完毕。

Convert Temperature(启动温度转换):0x44—— 12位最大的转换时间是 750ms

 

4、DS18B20的位写时序

当要给 DS18B20 写入‘0’的时候,单片机直接将引脚拉低,持续时间大于 60us 小于120us 就可以了。图上显示的意思是,单片机先拉低 15us 之后,DS18B20 会在从 15us 到60us 之间的时间来读取这一位,DS18B20 最早会 15us 的时刻读取,典型值是 30us 的时刻读取,最多不会超过 60us,DS18B20 必然读取完毕,所以持续时间超过 60us 即可。

当要给DS18B20 写入‘1’的时候,单片机先将这个引脚拉低,拉低时间大于 1us,然后马上释放总线,即拉高引脚,并且持续时间也要大于 60us。和写‘0’类似的是,DS18B20 会在 15 到 60us 之间来读取这个‘1’。

 

5、DS18B20的位读时序

单片机首先要拉低这个引脚,并且至少保持1us 的时间,然后释放引脚,释放完毕后要尽快读取。从拉低这个引脚到读取引脚状态,不能超过 15us。大家从图 16-17 可以看出来,主机采样时间,也就是 MASTER SAMPLES,是 在15us 之内必须完成的。 



  1. #include  

  2. #include  

  3.   

  4. typedef unsigned char uchar;  

  5.   

  6. sbit IO_18B20 = P3 ^ 2; //DS18B20通信引脚  

  7.   

  8. /* 软件延时函数,延时时间(t*10)us */  

  9. void DelayX10us(uchar t)  

  10. {  

  11.   do  

  12.   {  

  13.     _nop_();  

  14.     _nop_();  

  15.     _nop_();  

  16.     _nop_();  

  17.     _nop_();  

  18.     _nop_();  

  19.     _nop_();  

  20.     _nop_();  

  21.   }  

  22.   while (--t);  

  23. }  

  24. /* 复位总线,获取存在脉冲,以启动一次读写操作*/  

  25. bit Get18B20Ack()  

  26. {  

  27.   bit ack;  

  28.   

  29.   EA = 0;  //禁止总中断  

  30.   IO_18B20 = 0;     //产生500us复位脉冲  

  31.   DelayX10us(50);  

  32.   IO_18B20 = 1;  

  33.   DelayX10us(6);    //延时60us  

  34.   ack = IO_18B20;   //读取存在脉冲  

  35.   while(!IO_18B20); //等待存在脉冲结束  

  36.   EA = 1;  //重新使能总中断  

  37.   

  38.   return ack;  

  39. }  

  40. /* 向DS18B20写入一个字节,dat-待写入字节 */  

  41. void Write18B20(uchar dat)  

  42. {  

  43.   uchar mask;  

  44.   

  45.   EA = 0;  //禁止总中断  

  46.   for (mask = 0x01; mask != 0; mask <<= 1) //低位在先,依次移出8个bit  

  47.   {  

  48.     IO_18B20 = 0;         //产生2us低电平脉冲  

  49.     _nop_();  

  50.     _nop_();  

  51.     if ((mask & dat) == 0) //输出该bit值  

  52.     {  

  53.       IO_18B20 = 0;  

  54.     }  

  55.     else  

  56.     {  

  57.       IO_18B20 = 1;  

  58.     }  

  59.     DelayX10us(6);        //延时60us  

  60.     IO_18B20 = 1;         //拉高通信引脚  

  61.   }  

  62.   EA = 1;  //重新使能总中断  

  63. }  

  64. /* 从DS18B20读取一个字节,返回值-读到的字节 */  

  65. uchar Read18B20()  

  66. {  

  67.   uchar dat;  

  68.   uchar mask;  

  69.   

  70.   EA = 0;  //禁止总中断  

  71.   for (mask = 0x01; mask != 0; mask <<= 1) //低位在先,依次采集8个bit  

  72.   {  

  73.     IO_18B20 = 0;         //产生2us低电平脉冲  

  74.     _nop_();  

  75.     _nop_();  

  76.     IO_18B20 = 1;         //结束低电平脉冲,等待18B20输出数据  

  77.     _nop_();              //延时2us  

  78.     _nop_();  

  79.     if (!IO_18B20)        //读取通信引脚上的值  

  80.     {  

  81.       dat &= ~mask;  

  82.     }  

  83.     else  

  84.     {  

  85.       dat |= mask;  

  86.     }  

  87.     DelayX10us(6);        //再延时60us  

  88.   }  

  89.   EA = 1;  //重新使能总中断  

  90.   

  91.   return dat;  

  92. }  

  93. /* 启动一次18B20温度转换,返回值-表示是否启动成功 */  

  94. bit Start18B20()  

  95. {  

  96.   bit ack;  

  97.   

  98.   ack = Get18B20Ack();   //执行总线复位,并获取18B20应答  

  99.   if (ack == 0)          //如18B20正确应答,则启动一次转换  

  100.   {  

  101.     Write18B20(0xCC);  //跳过ROM操作  

  102.     Write18B20(0x44);  //启动一次温度转换  

  103.   }  

  104.   return ~ack;   //ack==0表示操作成功,所以返回值对其取反  

  105. }  

  106. /* 读取DS18B20转换的温度值,返回值-表示是否读取成功 */  

  107. bit Get18B20Temp(int *temp)  

  108. {  

  109.   bit ack;  

  110.   uchar LSB, MSB; //16bit温度值的低字节和高字节  

  111.   

  112.   ack = Get18B20Ack();    //执行总线复位,并获取18B20应答  

  113.   if (ack == 0)           //如18B20正确应答,则读取温度值  

  114.   {  

  115.     Write18B20(0xCC);   //跳过ROM操作  

  116.     Write18B20(0xBE);   //发送读命令  

  117.     LSB = Read18B20();  //读温度值的低字节  

  118.     MSB = Read18B20();  //读温度值的高字节  

  119.     *temp = ((int)MSB << 8) + LSB; //合成为16bit整型数  

  120.   }  

  121.   return ~ack;  //ack==0表示操作应答,所以返回值为其取反值  

  122. }  



    关键字:51单片机  DS18B20 引用地址:51单片机——DS18B20

    上一篇:51单片机——SPI
    下一篇:51单片机——LCD1602

    推荐阅读最新更新时间:2024-03-16 15:26

    51单片机精确延时函数集锦
    C语言延时程序: 50us延时子程序(12MHZ) void delay_50us(uint16 t) { uint8 j; for(;t 0;t--) for(j=19;j 0;j--); } 10ms延时子程序(12MHZ) void delay10ms(void) { unsigned char i,j,k; for(i=5;i 0;i--) for(j=4;j 0;j--) for(k=248;k 0;k--); } 1s延时子程序(12MHZ) void delay1s(void) { unsigned char h,
    [单片机]
    三种C51单片机上电复位延时电路图
      下面几种延时复位电路,都是利用在单片机RST引脚上外接一个RC支路的充电时间而形成的。典型复位电路如图(a)所示,其中的阻容值是原始手册中提供的。图(b)是简化后的复位电路,图(c)在图(a)的基础上加上一个二极管D,有助于电容C的快速放电,为下一次上电复位延时做准备。在经历了一系列延时之后,单片机才开始按照时钟源的工作频率,进入到正常的程序运行状态。   
    [电源管理]
    三种C<font color='red'>51单片机</font>上电复位延时电路图
    AT89C51单片机定时器应用设计
    一、设计目的 1、学习并掌握定时器/计数器的工作原理; 2、学习并掌握定时器/计数器控制程序设计方法; 3、学习并掌握矩阵键盘工作原理与程序设计方法; 4、学习并掌握显示程序设计; 二、实验设备 1、计算机; 2、单片机开发板; 3、Keil C51编程软件; 4、Proteus仿真软件; 三、设计内容 1、功能 必须使用定时器完成以下功能。 功能1:4位数码管显示“分钟.秒” 功能2:K1设置键、K2加1键、K2减1键 (1)正常情况:显示“分钟.秒” (2)按下K1:第一次按下调整分钟状态、第二次按下调整秒状态、第三次按下正常显示状态 (3)按下K2:分钟或秒加1 (4)按下K3:分钟或秒减1 选做功能:闹钟功能(请先完成
    [单片机]
    AT89C<font color='red'>51单片机</font>定时器应用设计
    基于STC51单片机超声波测距
    基于STC51单片机超声波测距精简设计只需三个元件(测距模块暂且算做是一个元件吧) 1.所需元件:STC单片机+超声波模块+4位共阳数码管 2.原理:单片机向测距模块trig脚发送20us的高电平触发测距,Echo 测距结束时会输出高电平,电平时长为超声波信号往返时间之和。Echo 脚开始输出高电平时启动定时计数器计时,当Echo 脚高电平结束时停止计数,根据定时器的时间可算出距离。 3.连接:单片机插在面包板上数码管直接插在单片机上面(引脚一一对应见原理图)测距模块trig脚接P5.4Echo 脚接P5.5 实物图 参考C程序代码如下: /*********************************
    [单片机]
    基于STC<font color='red'>51单片机</font>超声波测距
    51单片机,18B20,1602温度计+串口通信
    制作出来的实物图如下: 仿真原理图如下(proteus仿真工程文件可到本帖附件中下载) 上位机: 安装程序解压到同一目录下。再运行setup安装。。。。 温度计.exe 编写环境Win10 x64. VS2010 x86 C++ MFC 测试环境Win10 x64. 在32位系统上,能不能正常使用还不清楚。 所以公布了源代码文件,如果在32位系统上,不能正常使用。 请使用源代码文件,在32位系统上重新生成一下应用程序。。。 单片机源程序如下: #include reg52.h #include math.h bit flag1s = 0, _up = 0;
    [单片机]
    <font color='red'>51单片机</font>,18B20,1602温度计+串口通信
    基于51单片机的12864 LCD显示--按键电子时钟程序设计
    //液晶屏为JM12864或FYD12864(带字库),我用这两种型号的屏没问题, 4行*8列汉字=32 串行通信 接/口P1.5--P1.7,可根据你的电路修改相应的接口。 #include reg52.h #include intrins.h #define uchar unsigned char void LCD_ini(); void ascii_change(void); void delay(); void wri_add(uchar com); void wri_dat(uchar com1); void shan(void); void disp(); void tkey(void); sbit cs=P1^7;
    [单片机]
    51单片机不断电下载程序
    stc单片机支持串口isp程序下载,不必使用专用下载器,仅使用串口就能下载程序。但每次下载程序都要断电再上电,比较麻烦。 下面介绍一种不需断电就能下载程序的方法,在程序调试时比较方便。 基本原理: stc单片机有专用的复位寄存器,通过对该寄存器写入不同的数值可以实现单片机热启动复位。 寄存器功能如下图所示: 由上图可以看出只要满足某个条件,向ISP_CONTR写入0x60,就可以实现从ISP监控区软启动启动 某个条件设置为:当串口接收到0xaa数据时,单片机执行ISP_CONTR=0x60; 指令,从ISP监控区软启动启动。 演示程序如下: //*************************STC12C5410AD软启
    [单片机]
    <font color='red'>51单片机</font>不断电下载程序
    51单片机控制步进电机-让电机转起来
    摘要: 本节介绍用简单的方式,让步进电机转起来。其目的之一是对电机转动有直观的感受,二是熟悉整个开发流程 本系列教程必要的51单片机基础包括IO口操作、中断、定时器三个部分,相关基础教程网上很多,可以自行学习 一、软件清单 需要用到的软件有keil5编译软件、STC程序烧录软件 二、控制原理 根据TB6600驱动器原理,向PUL口发送脉冲,每发送一个脉冲,电机就转一步。通过单片机延时的方式,切换PUL口电平产生脉冲,从而控制电机转动。 三、程序代码 //毫秒延时函数 void delay(unsigned int z) { unsigned int x,y; for(x=z;x 0;x--) for(y
    [单片机]
    小广播
    添点儿料...
    无论热点新闻、行业分析、技术干货……
    设计资源 培训 开发板 精华推荐

    最新单片机文章
    何立民专栏 单片机及嵌入式宝典

    北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

    换一换 更多 相关热搜器件
    随便看看
    电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved