找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3124|回复: 2
打印 上一主题 下一主题
收起左侧

18B20采集温度仿真电路原理图与单片机代码

[复制链接]
跳转到指定楼层
楼主
18B20采集温度+仿真电路,自己学习,欢迎参考下载,包含完整的单片机代码与proteus仿真
  1. #include<reg52.h>
  2. #include <intrins.h>
  3. #include "led--display.h"
  4. sbit DQ=P2^2;
  5. uchar time;     //供延时用全局变量
  6. /**************************************
  7. 18b20初始化

  8. ***************************************/
  9. bit lnit18B20()
  10. {
  11.         bit DS18B20;//储存DS18B20是否存在的标志,DS18B20=0,表示存在;DS18B20=1,表示不存在
  12.         DQ=1;
  13.         _nop_();          //延时一个机器周期
  14.         DQ=0;
  15.         for(time=0;time<170;time++);//延时510us左右,以向DS18B20发出一持续480~960us的低电平复位脉冲
  16.         DQ=1;
  17.         for(time=0;time<10;time++);//延时约30us(释放总线后需等待15~60us让DS18B20输出存在脉冲)
  18.   DS18B20=DQ;                //让单片机检测是否输出了存在脉冲(DQ=0表示存在)
  19.         for(time=0;time<40;time++);
  20.         return (DS18B20);    //返回检测成功标志
  21. }

  22. /**************************************
  23. 函数功能:向DS18B20写入一个字节数据
  24. 入口参数:dat

  25. ***************************************/
  26. void write18b20(uchar dat)
  27. {
  28.         uchar i;
  29.         for(i=0;i<8;i++)
  30.         {
  31.                 DQ=1;
  32.                 _nop_();          //延时一个机器周期
  33.                 DQ=0;            //将数据线从高拉低时即启动写时序  
  34.                 for(time=0;time<1;time++);
  35.                 DQ=dat&0x01;                //利用与运算取出要写的某位二进制数据,
  36.                        //并将其送到数据线上等待DS18B20采样       
  37.                 for(time=0;time<10;time++);//延时约30us,DS18B20在拉低后的约15~60us期间从数据线上采样
  38.                 DQ=1;                       //释放数据线                 
  39.                 for(time=0;time<1;time++);//延时3us,两个写时序间至少需要1us的恢复期
  40.                 dat=dat>>1;
  41.         }
  42.         for(time=0;time<2;time++); //稍作延时,给硬件一点反应时间
  43. }

  44. /*****************************************************
  45. 函数功能:从DS18B20读取一个字节数据
  46. 出口参数:dat
  47. ***************************************************/
  48. uchar read18b20()
  49. {
  50.         uchar i;
  51.         uchar dat;
  52.         for(i=0;i<8;i++)
  53.          {
  54.                  DQ=1;
  55.                  _nop_();          //延时一个机器周期
  56.                  DQ=0;            //将数据线从高拉低时即启动读时序  
  57.                  _nop_();
  58.                  dat=dat>>1;
  59.                  DQ=1;
  60.                  for(time=0;time<1;time++);////延时约3us,使主机在15us内采样
  61.            if(DQ==1)
  62.                  dat|=0x80;              ////如果读到的数据是1,则将1存入dat
  63.                  else
  64.                  dat|=0x00;             //如果读到的数据是0,则将0存入dat
  65.                  for(time=0;time<15;time++);////延时60us以上,读时序必须有大于60us
  66.                  DQ=1;
  67.                  for(time=0;time<1;time++);//延时3us,两个读时序之间必须有大于1us的恢复期       
  68.           }
  69.         for(time=0;time<1;time++);////稍作延时,给硬件一点反应时间
  70.   return dat;
  71. }
  72. /*****************************************************
  73. 函数功能:做好读温度的准备
  74. ***************************************************/
  75. void ready18B20()
  76. {
  77.         lnit18B20();                 //复位18b20
  78.         write18b20(0XCC);           //跳过序列号搜索       
  79.         write18b20(0X44);           //启动温度转换
  80.         for(time=0;time<100;time++);//延时时间等待转换完成       
  81.         lnit18B20();              ////复位18b20
  82.         write18b20(0XCC);           //跳过序列号搜索       
  83.         write18b20(0XBE);           //写入读取温度命令
  84. }
  85. /*****************************************************
  86. 函数功能:读温度数据

  87. ***************************************************/
  88. uint dutemp()
  89. {               
  90.         uint temp;//定义返回值变量
  91.         uchar lsb;//在变量lsb存储低8位数据
  92.         uchar msb;//在变量msb存储高8位数据
  93.         uchar fu;
  94.         ready18B20();//18b20读温度准备
  95.   lsb=read18b20();//第一次读取低八位数据
  96.         msb=read18b20();//第二次读取高八位数据
  97.         if((msb&0xf8)==0xf8)//高8位与0xf8按位与判断是否为负温度,真值为负
  98.                 {               
  99.                         temp=(~(msb*256+lsb)+1)*6.25;//如果为负则将16位数据按位取反加1然后再乘以0.0625*100保留两位小数
  100.                         if((994<temp)&&(temp<5500))                                                                //判断16位数据是否大于10度小于55度                                                                                               
  101.                                 fu=1;                                                                                //成立则赋值数码管显示列                               
  102.                         else                                                                                //否则
  103.                         {       
  104.                                 if(temp<=994)                                        //显示另外列
  105.                                 fu=2;                                                                //
  106.                                 else fu=8;                                                //
  107.                         }
  108.                         led3_display(fu);      //负号列显示函数
  109.                 }
  110.                 else
  111.                 {                       
  112.                         temp=(msb*256+lsb)*6.25;//将16位数据乘以0.0625*100保留两位小数
  113.                 }       
  114.         return temp;        //返回要显示数据
  115.         }               
  116. void main()
  117. {                        
  118.         du=0;
  119.         we=0;
  120.         while(1)
  121.         {


  122. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码


下载:
18b20数码管显示.rar (128.73 KB, 下载次数: 34)

评分

参与人数 1黑币 +50 收起 理由
admin + 50 共享资料的黑币奖励!

查看全部评分

分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:206077 发表于 2017-5-30 15:31 | 只看该作者
谢谢分享
回复

使用道具 举报

板凳
ID:550269 发表于 2019-5-29 19:51 | 只看该作者
楼主,为什么我运行仿真的时候会报错呢?
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表