找回密码
 立即注册

QQ登录

只需一步,快速开始

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

51单片机ds18b20测温程序与仿真

[复制链接]
跳转到指定楼层
楼主
51 ds18b20测温程序


单片机源程序如下:
  1. /*********************************************************************************
  2. 模块名称:ds18b20温度传感器
  3. *********************************************************************************/

  4. #include "reg52.h"                         //此文件中定义了单片机的一些特殊功能寄存器

  5. typedef unsigned int u16;          //对数据类型进行声明定义
  6. typedef unsigned char u8;

  7. void Delay1ms(u16 );                          ///函数申明
  8. u8 Ds18b20Init();
  9. void Ds18b20WriteByte(u8 com);
  10. u8 Ds18b20ReadByte();
  11. void  Ds18b20ChangTemp();
  12. void  Ds18b20ReadTempCom();
  13. int Ds18b20ReadTemp();

  14. sbit LSA=P2^2;
  15. sbit LSB=P2^3;
  16. sbit LSC=P2^4;
  17. sbit DSPORT=P3^7;

  18. char num=0;
  19. u8 DisplayData[8];                                         //定义数组
  20. u8 code smgduan[10]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};


  21. void delay(u16 i)                 //延时函数,i=1时,大约延时10us
  22. {
  23.         while(i--);       
  24. }

  25. void Delay1ms(u16 y)
  26. {
  27.         u16 x;
  28.         for( ; y>0; y--)
  29.         {
  30.                 for(x=110; x>0; x--);
  31.         }
  32. }



  33.   void datapros(int temp)                   //温度处理函数
  34. {
  35.            float tp;  
  36.         if(temp< 0)                                //当温度值为负数
  37.           {
  38.                 DisplayData[0] = 0x40;           //   -
  39.                 //因为读取的温度是实际温度的补码,所以减1,再取反求出原码
  40.                 temp=temp-1;
  41.                 temp=~temp;
  42.                 tp=temp;
  43.                 temp=tp*0.0625*100+0.5;       
  44.                 //留两个小数点就*100,+0.5是四舍五入,因为C语言浮点数转换为整型的时候把小数点
  45.                 //后面的数自动去掉,不管是否大于0.5,而+0.5之后大于0.5的就是进1了,小于0.5的就
  46.                 //算加上0.5,还是在小数点后面。

  47.           }
  48.         else
  49.           {                       
  50.                 DisplayData[0] = 0x00;
  51.                 tp=temp;//因为数据处理有小数点所以将温度赋给一个浮点型变量
  52.                 //如果温度是正的那么,那么正数的原码就是补码它本身
  53.                 temp=tp*0.0625*100+0.5;       
  54.                 //留两个小数点就*100,+0.5是四舍五入,因为C语言浮点数转换为整型的时候把小数点
  55.                 //后面的数自动去掉,不管是否大于0.5,而+0.5之后大于0.5的就是进1了,小于0.5的就
  56.                 //算加上0.5,还是在小数点后面。
  57.         }
  58.         DisplayData[1] = smgduan[temp / 10000];
  59.         DisplayData[2] = smgduan[temp % 10000 / 1000];
  60.         DisplayData[3] = smgduan[temp % 1000 / 100] | 0x80;
  61.         DisplayData[4] = smgduan[temp % 100 / 10];
  62.         DisplayData[5] = smgduan[temp % 10];
  63. }

  64. void DigDisplay()                         //数码管显示函数
  65. {
  66.         u8 i;
  67.         for(i=0;i<6;i++)
  68.         {
  69.                 switch(i)         //位选,选择点亮的数码管,
  70.                 {
  71.                         case(0):
  72.                                 LSA=0;LSB=0;LSC=0; break;//显示第0位
  73.                         case(1):
  74.                                 LSA=1;LSB=0;LSC=0; break;//显示第1位
  75.                         case(2):
  76.                                 LSA=0;LSB=1;LSC=0; break;//显示第2位
  77.                         case(3):
  78.                                 LSA=1;LSB=1;LSC=0; break;//显示第3位
  79.                         case(4):
  80.                                 LSA=0;LSB=0;LSC=1; break;//显示第4位
  81.                         case(5):
  82.                                 LSA=1;LSB=0;LSC=1; break;//显示第5位       
  83.                 }
  84.                 P0=DisplayData[5-i];//发送数据
  85.                 delay(100); //间隔一段时间扫描       
  86.                 P0=0x00;//消隐
  87.         }               
  88. }




  89. u8 Ds18b20ReadByte()                         //        读取一个字节 函数
  90. {
  91.         u8 byte, bi;
  92.         u16 i, j;       
  93.         for(j=8; j>0; j--)
  94.         {
  95.                 DSPORT = 0;//先将总线拉低1us
  96.                 i++;
  97.                 DSPORT = 1;//然后释放总线
  98.                 i++;
  99.                 i++;//延时6us等待数据稳定
  100.                 bi = DSPORT;         //读取数据,从最低位开始读取
  101.                 /*将byte左移一位,然后与上右移7位后的bi,注意移动之后移掉那位补0。*/
  102.                 byte = (byte >> 1) | (bi << 7);                                                  
  103.                 i = 4;                //读取完之后等待48us再接着读取下一个数
  104.                 while(i--);
  105.         }                               
  106.         return byte;
  107. }

  108. void  Ds18b20ReadTempCom()                           //发送读取命令
  109. {       

  110.         Ds18b20Init();
  111.         Delay1ms(1);
  112.         Ds18b20WriteByte(0xcc);         //跳过ROM操作命令
  113.         Ds18b20WriteByte(0xbe);         //发送读取温度命令
  114. }

  115. void Ds18b20WriteByte(u8 dat)         //写入一字节时序函数
  116. {
  117.         u16 i, j;

  118.         for(j=0; j<8; j++)
  119.         {
  120.                 DSPORT = 0;                       //每写入一位数据之前先把总线拉低1us
  121.                 i++;
  122.                 DSPORT = dat & 0x01;  //然后写入一个数据,从最低位开始
  123.                 i=6;
  124.                 while(i--); //延时68us,持续时间最少60us
  125.                 DSPORT = 1;        //然后释放总线,至少1us给总线恢复时间才能接着写入第二个数值
  126.                 dat >>= 1;
  127.         }
  128. }

  129. u8 Ds18b20Init()                   // 初始化        初始化成功返回1,失败返回0
  130. {
  131.         u8 i;
  132.         DSPORT = 0;                         //将总线拉低480us~960us
  133.         i = 70;       
  134.         while(i--);//延时642us
  135.         DSPORT = 1;                        //然后拉高总线,如果DS18B20做出反应会将在15us~60us后总线拉低
  136.         i = 0;
  137.         while(DSPORT)        //等待DS18B20拉低总线
  138.         {
  139.                 Delay1ms(1);
  140.                 i++;
  141.                 if(i>5)//等待>5MS
  142.                 {
  143.                         return 0;//初始化失败
  144.                 }
  145.        
  146.         }
  147.         return 1;//初始化成功
  148. }

  149. void  Ds18b20ChangTemp()                //温度转换
  150. {
  151.         Ds18b20Init();
  152.         Delay1ms(1);
  153.         Ds18b20WriteByte(0xcc);                //跳过ROM操作命令                 
  154.         Ds18b20WriteByte(0x44);            //温度转换命令
  155.         //Delay1ms(100);        //等待转换成功,而如果你是一直刷着的话,就不用这个延时了
  156.    
  157. }

  158. int Ds18b20ReadTemp()                   //        读取温度
  159. {
  160.         int temp = 0;
  161.         u8 tmh, tml;
  162.         Ds18b20ChangTemp();                                 //先写入转换命令                                                        //温度转换
  163.         Ds18b20ReadTempCom();                        //然后等待转换完后发送读取温度命令
  164.         tml = Ds18b20ReadByte();                //读取温度值共16位,先读低字节
  165.         tmh = Ds18b20ReadByte();                //再读高字节
  166.         temp = tmh;
  167. ……………………

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

所有资料51hei提供下载:
ds18b20测温模块.zip (83.42 KB, 下载次数: 21)


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

使用道具 举报

沙发
ID:213117 发表于 2017-10-10 11:53 | 只看该作者
感谢分享
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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