找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 3896|回复: 2
收起左侧

LPC1114采集温度传感器DS18B20程序

[复制链接]
ID:383443 发表于 2018-11-20 16:44 | 显示全部楼层 |阅读模式
Temperature.h文件
  1. #ifndef _TEMPERATURE_H_
  2. #define _TEMPERATURE_H_
  3. #include "lpc11xx.h"

  4. #define DQ_H    (LPC_GPIO0->DATA |= (1<<2))
  5. #define DQ_L    (LPC_GPIO0->DATA &=~(1<<2))
  6. #define DQ_IN   (LPC_GPIO0->DIR&=~(1<<2))
  7. #define DQ_OUT  (LPC_GPIO0->DIR|=(1<<2))
  8. #define DQ_DATE ((LPC_GPIO0->DATA&0x4)>>2^1)



  9. //DS18B20 ROM 命令宏定义
  10. #define ReadRom 0x33
  11. #define MatchRom 0x55
  12. #define Skip_ROM 0xcc  //跳过ROM
  13. #define SearchRom 0xf0
  14. #define AlertSearch 0xec
  15. #define CopyScratchpad 0x48
  16. #define SkipRom 0xcc
  17. #define ReadPower 0xb4
  18. //DS18B20 功能命令宏定义
  19. #define ConvertTemperature 0x44
  20. #define ReadScratchpad 0xbe
  21. #define WriteScratchpad 0x4e
  22. #define RecallE 0xb8
  23. extern unsigned char DS18B20_Init(void);
  24. #endif

  25. Temperature.c文件#include "temperature.h"#include "lpc11xx.h"
  26. #include "timer.h"
  27. extern uint16_t T;
  28. extern unsigned char tempH,tempL,wenduqk;

  29. /****************************************************************************
  30. * 名称: unsigned char DS18B20_Init(void)
  31. * 功能:对DS18B20 进行初始化
  32. * 入口参数:
  33. * 出口参数:
  34. * 说明:
  35. ****************************************************************************/
  36. unsigned char DS18B20_Init(void)
  37. {
  38.         unsigned char result;
  39.         DQ_OUT;
  40.         DQ_L;
  41.         Delay_Us(600); // 总线拉低480us~960us ,即主机发送复位脉冲
  42.         DQ_H;
  43.         DQ_IN; // 总线设为输入状态,等待18b20 应答
  44.         Delay_Us(60);
  45.         result=DQ_DATE; // 读取18b20 应答信号
  46. //        Send_TO_DWIN(0x00,result,2);
  47.         Delay_Us(500); // 等待480us 以上,保证总线释放
  48.         return(result); // 返回0 则初始化成功
  49. }


  50. /****************************************************************************
  51. * 名称: unsigned char DS18B20_ReadBit(void)
  52. * 功能:从DS18B20 单总线上读1Bit 数
  53. * 入口参数:
  54. * 出口参数:
  55. * 说明:
  56. ****************************************************************************/
  57. unsigned char DS18B20_ReadBit(void)
  58. {
  59.         unsigned char result;
  60.         DQ_OUT; // 设置总线为输出状态
  61.         DQ_L; // 总线拉低,产生读起始信号
  62.         Delay_Us(2); // 保证低电平在1us 以上
  63.         //要在15us 内读取总线上数据
  64.         DQ_IN;
  65.         Delay_Us(3);  // 这个延时很重要,没有这个延时,读不出18B20的数据
  66.         result=DQ_DATE; // 接收数据
  67.         Delay_Us(60); // 延时60us,保证总线释放
  68.         return(result); // 返回数据
  69. }


  70. /****************************************************************************
  71. * 名称: void DS18B20_WriteBit(unsigned char Data)
  72. * 功能:给DS18B20 单总线上写1Bit 数
  73. * 入口参数:
  74. * 出口参数:
  75. * 说明:
  76. ****************************************************************************/void
  77. DS18B20_WriteBit(unsigned char Data)
  78. {
  79.         DQ_OUT; // 设置总线为输出
  80.         DQ_L; // 产生写起始信号
  81.         Delay_Us(10); //15us 后写入数据
  82.         if(Data) DQ_H;
  83.         else DQ_L;
  84.         Delay_Us(80); // 延时60us~120us ,保证总线释放
  85.         DQ_IN; // 空闲状态总线保持输入状态
  86. }

  87. /****************************************************************************
  88. * 名称: unsigned char DS18B20_ReadByte(void)
  89. * 功能:从DS18B20 单总线上读1Byte 数
  90. * 入口参数:
  91. * 出口参数:
  92. * 说明:
  93. ****************************************************************************/
  94. unsigned char DS18B20_ReadByte(void)
  95. {
  96.         unsigned char i,result=0;
  97.         for(i=0;i<8;i++)
  98.         {
  99.         result>>=1;
  100. //        if(DS18B20_ReadBit()) result|=0x80;          // 设为上拉电阻,当读取值为0时,实际上总线为高电平,所以要反过来
  101. //        else result&=0x7f;
  102.         if(DS18B20_ReadBit()) result&=0x7f;
  103.         else result|=0x80;
  104.         }
  105.         return(result);
  106. }


  107. /****************************************************************************
  108. * 名称: void DS18B20_WriteByte(unsigned char Data)
  109. * 功能:给DS18B20 单总线上写1Byte 数
  110. * 入口参数:
  111. * 出口参数:
  112. * 说明:
  113. ****************************************************************************/
  114. void DS18B20_WriteByte(unsigned char Data)
  115. {
  116.         unsigned char i;
  117.         for(i=0;i<8;i++)
  118.         {
  119.                 DS18B20_WriteBit(Data&0x01);
  120.                 Data>>=1;
  121.     }
  122. }


  123. /****************************************************************************
  124. * 名称: void DS18B20_ReadTemp(void)
  125. * 功能:从DS18B20 上读取温度值
  126. * 入口参数:
  127. * 出口参数:
  128. * 说明:
  129. ****************************************************************************/
  130. void DS18B20_ReadTemp(void)
  131. {
  132.         unsigned char i,j;
  133.         uint16_t Temperature[10],T1;
  134.     DS18B20_Init();
  135.         for(i=0;i<10;i++)
  136.         {        
  137.                 DS18B20_WriteByte(SkipRom);
  138.                 DS18B20_WriteByte(ConvertTemperature);
  139.         //        Delay_Ms(600); // 按照要求延时1s 左右,但是不延时也可以,还未找到原因
  140.                 DS18B20_Init();
  141.                 DS18B20_WriteByte(SkipRom);
  142.                 DS18B20_WriteByte(ReadScratchpad);
  143.                 tempL=DS18B20_ReadByte(); // 读温度低字节
  144.                 tempH=DS18B20_ReadByte(); // 读温度高字节
  145.         
  146.                 // 未考虑温度为负情况
  147.         //        Temperature=tempH;
  148.         //        Temperature<<=8;
  149.         //        Temperature+=tempL;
  150.         //        Temperature=0.625*Temperature;
  151.                 // 考虑温度为负情况
  152.         
  153.                 if(tempH>7)//(TH>xxxxx111)温度为负
  154.            {
  155.                tempH=~tempH;tempL=~tempL;
  156.                wenduqk=0;
  157.            }
  158.            else  wenduqk=1;//温度为正
  159.             Temperature[i]=tempH;
  160.                 Temperature[i]<<=8;
  161.                 Temperature[i]+=tempL;
  162.            if(wenduqk) Temperature[i]= Temperature[i]; //返回温度值
  163.            else  Temperature[i]= -Temperature[i];
  164.          }
  165.                  //冒泡法排序
  166.     for (i=0; i<9;i++)
  167.         {
  168.                 for(j=i+1;j<=9;j++)
  169.                 {               
  170.                         if(Temperature[i]>Temperature[j])
  171.                         {
  172.                                 T1=Temperature[i];
  173.                                 Temperature[i]=Temperature[j];
  174.                                 Temperature[i]=T1;               
  175.                         }
  176.                 }               
  177.         }
  178.         
  179.         T=0;
  180.         for(i=0;i<6;i++)
  181.         {
  182.                 T=T+Temperature[2+i];
  183.         }         
  184.         T=T*(0.625)/6;                              

  185. }
复制代码



回复

使用道具 举报

ID:434809 发表于 2018-11-28 11:05 | 显示全部楼层
感谢分享,学习下
回复

使用道具 举报

ID:442317 发表于 2018-12-12 20:57 | 显示全部楼层
谢谢。 一个有趣的图书馆
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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