找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机控制SHT11进行温湿度检测的仿真及源程序

[复制链接]
跳转到指定楼层
楼主
51单片机控制SHT11的仿真原理图如下:

Keil C51语言程序.rar (28.36 KB, 下载次数: 75)
单片机仿真软件.rar (43.17 KB, 下载次数: 60)

部分源程序如下:
  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
复制代码
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏1 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:324415 发表于 2018-5-7 18:42 | 只看该作者
楼主能否发我一份,感激不尽
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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