找回密码
 立即注册

QQ登录

只需一步,快速开始

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

DS18B20温度传感器采集温度源代码

[复制链接]
跳转到指定楼层
楼主
ID:207230 发表于 2017-6-7 15:36 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
单片机源程序:
实验17:DS18B20温度传感器.rar (35.91 KB, 下载次数: 74)

单片机源代码如下:
  1. /**************************************************************************************
  2. *                              DS18B20温度传感器实验                                                                                                  *
  3. 实现现象:下载程序后,在温度传感器接口处,按照丝印方向插好温度传感器,数码管就会显示
  4.                         检测的温度值,
  5. 注意事项:                                                                                                                                                                  
  6. ***************************************************************************************/

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

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

  11. sbit LSA=P2^2;
  12. sbit LSB=P2^3;
  13. sbit LSC=P2^4;
  14. sbit led=P2^0;        
  15. sbit beep=P1^5;           
  16.          

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

  20. /*******************************************************************************
  21. * 函 数 名         : delay
  22. * 函数功能                   : 延时函数,i=1时,大约延时10us
  23. *******************************************************************************/
  24. void delay(u16 i)
  25. {
  26.         while(i--);        
  27. }



  28. /*******************************************************************************
  29. * 函 数 名         : datapros()
  30. * 函数功能                   : 温度读取处理转换函数
  31. * 输    入         : temp
  32. * 输    出         : 无
  33. *******************************************************************************/

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

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


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


  98. /*******************************************************************************
  99. * 函 数 名       : main
  100. * 函数功能                 : 主函数
  101. * 输    入       : 无
  102. * 输    出             : 无                                 
  103. *******************************************************************************/
  104. void main()
  105. {        
  106.      int t;   
  107.         while(1)
  108.         {                                                                        
  109.                 datapros(Ds18b20ReadTemp());         //数据处理函数        
  110.                 DigDisplay();//数码管显示函数
  111.          
  112.            t=datapros(Ds18b20ReadTemp());
  113.                 if(t>2900)
  114. ……………………

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



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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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