找回密码
 立即注册

QQ登录

只需一步,快速开始

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

我的课设内容:基于89C51单片机SHT11温湿度传感器

[复制链接]
跳转到指定楼层
楼主
这是本学期我们两周课程设计的内容,因为我的基础不太好,所以基本电路比较简单,实现的功能也简单,希望对初学者能有一定的借鉴意义。图片中有用Proteus仿真的截图,附件中有源代码。

SHT11.h文件:
  1. #ifndef __SHT11_H__
  2. #define __SHT11_H__

  3. /*************************
  4. SHT11相关命令
  5. **************************/
  6. #define uchar unsigned char
  7. #define uint  unsigned int

  8. #define TEM_TEST         0x03//温度检测命令
  9. #define HUM_TEST          0x05//湿度检测命令
  10. #define REG_READ          0x07//读寄存器
  11. #define REG_WRITE         0x06//写寄存器
  12. #define FUNCTION_SET    0x01//设置SHT11的工作精度为8位/湿度 12位温度
  13. /**************************
  14. SHT11端口定义
  15. ***************************/

  16. sbit SHT11_DATA=P3^1;
  17. sbit SHT11_SCK=P3^0;
  18. sbit P33=P3^3;
  19. sbit P32=P3^2;
  20. sbit P36=P3^6;
  21. sbit P37=P3^7;
  22. uchar flag_tempeture=0;  //显示温度位置的标志
  23. uchar flag_humidity=0;     //显示湿度位置的标志
  24. uchar code str1[]={ 0x10,0x06,0x09,0x08,0x08,0x09,0x06,0x00};//温度图标
  25. uchar code str6_sht11[]="%RH   ";
  26. uchar code str4_sht11[]="humi=";
  27. uchar code str2_sht11[]="temp=";
  28. uchar code str7_sht11[]="    ";//清除没不要的显示
  29. /***************************
  30. 函数名称:Delay()
  31. 函数功能:SHT11内部延时
  32. ****************************/
  33. void Delay()
  34. {
  35.     ;
  36.     ;
  37. }

  38. /***************************
  39. 函数名称:Delay_Ms()
  40. 函数功能:SHT11检测等待延时
  41. 函数说明:11ms/55ms/210ms 分别对应8位/12位/14位 测量结果
  42. 对应的形参为N 则延时Nms
  43. ****************************/
  44. void Delay_Ms(uint ms)    // ms延时函数 (AT89C51 @ 11.0592MHz)
  45. {
  46. uint i;
  47. uchar j;
  48. for(i=0;i<ms;i++)
  49. {
  50.   for(j=0;j<200;j++);
  51.   for(j=0;j<102;j++);
  52. }
  53. }
  54. /**************************
  55. 函数功能:SHT11启动时序
  56. ***************************/
  57. void SHT11_Start()
  58. {
  59.     SHT11_SCK=1;
  60.     SHT11_DATA=1;
  61.     Delay();
  62.     SHT11_DATA=0;
  63.     Delay();
  64.     SHT11_SCK=0;
  65.     Delay();
  66.     SHT11_SCK=1;
  67.     Delay();
  68.     SHT11_DATA=1;
  69. }

  70. /******************************
  71. 函数名称:SHT11_Sendbyte(uchar dat)
  72. 函数功能: 向SHT11发送8bite数据
  73. ******************************/
  74. void SHT11_Sendbyte(uchar dat)
  75. {
  76.     uchar i;
  77.     SHT11_SCK=0;
  78.     Delay();
  79.     for(i=0;i<8;i++)
  80.     {
  81.         if(dat&0x80)
  82.         {
  83.             SHT11_DATA=1;
  84.             Delay();
  85.         }
  86.         else
  87.         {
  88.             SHT11_DATA=0;
  89.             Delay();
  90.         }
  91.         dat=dat<<1;
  92.         SHT11_SCK=1;
  93.         Delay();
  94.         SHT11_SCK=0;
  95.     }
  96. }
  97. /*********************************
  98. 函数名称SHT11_Answer():
  99. 函数功能:检测SHT11的响应信号(在第九个时钟周期)
  100. ***********************************/
  101. void SHT11_Answer()
  102. {
  103.     SHT11_SCK=1;
  104.     Delay();
  105.     while(SHT11_DATA==1);
  106.     SHT11_SCK=0;
  107.     SHT11_DATA=1;
  108. }

  109. /************************************
  110. 函数名称:SHT11_Test_Finish()
  111. 函数功能:检测SHT11温湿度检测是否完毕
  112. *************************************/
  113. void SHT11_Test_Finish()
  114. {
  115.     while(SHT11_DATA==1);
  116. }

  117. /************************************
  118. 函数名称:SHT11_Receivebyte()
  119. 函数功能:从SHT11接收8bite数据
  120. *************************************/
  121. uchar SHT11_Receivebyte()
  122. {
  123.     uchar i;
  124.     uchar dat;
  125.     SHT11_SCK=0;
  126.     Delay();
  127.     for(i=0;i<8;i++)
  128.     {   
  129.         SHT11_SCK=1;
  130.         Delay();
  131.         dat=dat<<1;
  132.         if(SHT11_DATA)
  133.         {
  134.             dat=dat|0x01;
  135.             Delay();
  136.         }
  137.         else
  138.         {
  139.             dat=dat&0xfe;
  140.             Delay();
  141.         }
  142.          SHT11_SCK=0;
  143.         Delay();
  144.     }
  145.     SHT11_DATA=1; //释放数据总线
  146.     return(dat);   
  147. }

  148. /***********************************
  149. 函数名称:MCU_Answer()
  150. 函数功能:单片机向SHT11发送应答信号
  151. *************************************/
  152. void MCU_Answer()
  153. {
  154.      SHT11_SCK=0;
  155.     Delay();
  156.     SHT11_DATA=0;
  157.     Delay();
  158.     SHT11_SCK=1;
  159.     Delay();
  160.     SHT11_SCK=0;
  161.     Delay();
  162.     SHT11_DATA=1; //释放数据总线 这条指令非常重要 不加的话导致单片机不能读取低8位
  163. }
  164. /***********************************
  165. 函数名称:SHT11_End()
  166. 当接收两个8byte数据后部接收CRC校验码
  167. ************************************/
  168. void SHT11_End()
  169. {
  170.     SHT11_DATA=1;
  171.     SHT11_SCK=1;
  172.     Delay();
  173.     SHT11_SCK=0;
  174.     Delay();
  175. }

  176. /*************************************
  177. 函数名称:void SHT11_Write_Register(uchar command ,uchar dat)
  178. 函数说明:向SHT11的状态寄存器设置功能
  179.             command为REG_WRITE 0x06写寄存器
  180.             dat为 设置SHT11的功能 可以设置检测的数据位数
  181. */
  182. void SHT11_Write_Register(uchar command ,uchar dat)
  183. {
  184.     SHT11_Start();
  185.     SHT11_Sendbyte(command);
  186.     SHT11_Answer();
  187.     SHT11_Sendbyte(dat);
  188.     SHT11_Answer();
  189. }


  190. /***************************************
  191. 函数名称:uchar SHT11_Read_Register(uchar command)
  192. 函数说明:command为REG_READ  0x07//读寄存器
  193.             返回值为状态寄存器的值
  194.          位6显示当前检测完一次数据后电源供电情况
  195.             当位6为0时表明VDD>2.47V 当位6为1时表明VDD<2.47V即电量不足
  196.          位0表明当前的测量分辨率
  197.          当位0为1时表明测量精度:8位/湿度 12位温度
  198.          当位0为0时表明测量精度:12位湿度 14位温度
  199.          默认为0
  200. *******************************************/
  201. uchar SHT11_Read_Register(uchar command)
  202. {
  203.     uchar dat;
  204.     SHT11_Start();
  205.     SHT11_Sendbyte(command);
  206.     SHT11_Answer();
  207.     dat=SHT11_Receivebyte();
  208.     SHT11_End();
  209.     return(dat);
  210. }


  211. /***************************************
  212. 函数名称:SHT11_Measure(uchar command,uint time);
  213. 函数功能:设置SHT11检测功能,并返回相应的检测结果
  214. 函数说明:command形参用于设定温度检测还是湿度检测,
  215. time形参用于设定检测过程中的等待时间,以确定检测结果的位数
  216. 11ms/55ms/210ms 分别对应8位/12位/14位
  217. ****************************************/
  218. uint SHT11_Measure(uchar command,uchar time)
  219. {
  220.     uint dat=0;
  221.     uchar data_high,data_low;
  222.     SHT11_Start();
  223.     SHT11_Sendbyte(command);
  224.     SHT11_Answer();
  225.     Delay_Ms(time);
  226.     SHT11_Test_Finish();
  227.     data_high=SHT11_Receivebyte();
  228.     MCU_Answer();
  229.     data_low=SHT11_Receivebyte();
  230.     SHT11_End();
  231.     dat=(dat|data_high);
  232.     dat=(dat<<8)|data_low;
  233.     return(dat);
  234. }

  235. /****************************************
  236. 函数名称:Convert_Tempeture12bit(uint dat);
  237. 函数功能:将检测到的数据转化为相应的温度数据
  238. 函数说明:温度转换公式--T=d1+d2*SOt
  239.           公式中的参数d1=-40,d2=0.04
  240.           适用于12位测量精度
  241. */
  242. float SHT11_Convert_Tempeture12bit(uint dat)
  243. {
  244.     float tempeture1;
  245.     tempeture1=-40+0.04*dat;
  246.     if(tempeture1>23)
  247.      tempeture1=tempeture1+1;
  248.     if(tempeture1>55)
  249.      tempeture1=tempeture1+1;
  250.     if(P37==1)
  251.     {
  252.      if(tempeture1>=16&&tempeture1<30)
  253.      {
  254.       P33=1;
  255.       P32=0;
  256.      }
  257.      else
  258.      {
  259.       P33=0;
  260.       P32=1;
  261.      }
  262.     }
  263.     return(tempeture1);
  264. }


  265. /*****************************************
  266. 函数名称:SHT11_Convert_Humidity8bit(uint dat,float temp)
  267. 函数功能:将检测到的数据转化为相应的湿度数据
  268. 函数说明:相对湿度转换公式-----RHline=C1+C2*SOrh+C3*SOrh*SOrh(检测数据的线性化 SOrh为单片机接收到的数据)
  269.                          -----RHtrue=(tempeture-25)*(t1+t2*SOrh)+RHline
  270.           公式中的参数:C1=-4,C2=0,648,C3=-0.00072
  271.                       t1=0.01,t2=0.00128
  272.             适用于8位测量精度
  273. */
  274. uint SHT11_Convert_Humidity8bit(uint dat,float temp)
  275. {
  276.     float RHline,RHtrue;
  277.     uint r;
  278.     RHline=-4+0.648*dat-0.00072*dat*dat;
  279.     RHtrue=(temp-25)*(0.01+0.00128*dat)+RHline;
  280.     r=(RHtrue-3)*10+0.5;
  281.     if(P37==0)
  282.    {
  283.     if(r>=400&&r<600)
  284.     {
  285.       P33=1;
  286.     }
  287.     else
  288.     {
  289.      P33=0;
  290.     }
  291.     if(r>=600)
  292.     {
  293.       P32=1;
  294.     }
  295.     else
  296.     {
  297.      P32=0;
  298.     }
  299.    }
  300.     return(r);
  301. }
  302. #endif
  303. Display.c文件:
  304. #include <reg52.h>
  305. #include "SHT11.h"
  306. #define uchar unsigned char
  307. #define uint  unsigned int
  308. #define TEM_TEST         0x03//温度检测命令
  309. #define HUM_TEST          0x05//湿度检测命令
  310. #define REG_READ          0x07//读寄存器
  311. #define REG_WRITE         0x06//写寄存器
  312. #define FUNCTION_SET    0x01//设置SHT11的工作精度为8位/湿度 12位温度
  313. uchar DispData[4] = {0, 1, 2, 3};
  314. code uchar DispSegmentP0[10]={0x3f,0x06,0x1b,0x0f,0x26,0x2d,0x3d,0x07,0x3f,0x2f};
  315. code uchar DispSegmentP2[10]={0x00,0x00,0x22,0x22,0x22,0x22,0x22,0x00,0x22,0x22};
  316.                           //  0    1   2    3    4   5   6    7   8    9  %
  317. code uchar DispCtrl[4] = {0xef, 0xdF, 0xbf ,0x7F};
  318. sbit P16=P1^6;
  319. sbit P26=P2^6;
  320. sbit P34=P3^4;   
  321. void Temp_delay(unsigned int j)
  322. {
  323. uchar i;
  324.   for(i=100;i>0;i--)
  325.   {
  326.    for(j;j>0;j--);
  327.   }
  328. }
  329. void Show(uchar  *Buffer)
  330. {
  331.     uchar i;

  332.      for    (i=0; i<4; i++)
  333.     {
  334.         P1 = DispCtrl[i];
  335.         P0 = DispSegmentP0[*Buffer];
  336.         P2 = DispSegmentP2[*Buffer];
  337.         if(P16==0)      
  338.         P26=1;
  339.         Temp_delay(2);
  340.         Buffer++;   
  341.     }
  342. }
  343. void  DispConvert(uchar *DispAddr, uint  Temp2Con)   
  344. {
  345.     DispAddr[0] = Temp2Con/1000;
  346.     DispAddr[1] = (Temp2Con - DispAddr[0]*1000)/100;
  347.     DispAddr[2] = (Temp2Con - DispAddr[0]*1000 - DispAddr[1]*100)/10;
  348.     DispAddr[3] = Temp2Con -  DispAddr[0]*1000 - DispAddr[1]*100 - DispAddr[2]*10;      
  349. }
  350. void main()
  351. {
  352. uint temp;
  353. uint dat;
  354. uint Hum;
  355. //float f;     
  356.    while(1)
  357.   {         
  358.    Show(DispData);
  359.    SHT11_Write_Register(REG_WRITE,FUNCTION_SET);
  360.    temp=SHT11_Measure(TEM_TEST,0x37);
  361.    temp=SHT11_Convert_Tempeture12bit(temp);   
  362.    dat=SHT11_Measure(HUM_TEST,0x0b);
  363.    Hum=SHT11_Convert_Humidity8bit(dat,temp);
  364.    if(P34==0)
  365.    {
  366.        P36=1;
  367.     P37=0;
  368.     DispConvert(DispData,Hum);
  369.    }
  370.    else
  371.    {
  372.        P36=0;
  373.     P37=1;
  374.     DispConvert(DispData,temp*10);
  375.    }
  376.   }   
  377. }
复制代码


基于89C51单片机SHT11温湿度传感器电路图于程序作者.doc

145 KB, 下载次数: 37, 下载积分: 黑币 -5

代码

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

使用道具 举报

沙发
ID:431243 发表于 2018-12-18 13:44 | 只看该作者
兄弟有课设论文吗
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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