找回密码
 立即注册

QQ登录

只需一步,快速开始

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

dht11温湿度采集系统设计源码

[复制链接]
跳转到指定楼层
楼主
ID:350589 发表于 2018-7-15 08:56 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
包含设计图以及源程序及相关文件

单片机源程序如下:
  1. # include <reg51.h>
  2. # include <intrins.h>
  3. typedef unsigned char BYTE;
  4. typedef unsigned int WORD;
  5. #define uint unsigned int
  6. #define uchar unsigned char
  7. sbit io=P2^7;//dht11data端接单片机的P2^7口//

  8. sbit rw=P1^1;//一下三行是设置lcd1602的使能端//

  9. sbit rs=P1^0;

  10. sbit ep=P1^2;

  11. sbit jd1=P2^5;
  12. sbit jd2=P2^4;
  13. sbit jd3=P2^3;
  14. sbit jd4=P2^2;

  15. sbit beep=P2^6;

  16. sbit dj=P2^0;

  17. sbit key1=P3^4;
  18. sbit key2=P3^5;
  19. sbit key3=P3^6;
  20. sbit key4=P3^7;   


  21. typedef bit BOOL;//此声明一个布尔型变量即真或假//

  22. uchar data_byte;

  23. uchar RH,RL,TH,TL;

  24. char BRH=70,BRL=50,BTH=33,BTL=29;  




  25. //***************延时函数*************************************

  26. void delay(uchar ms) //延时模块//

  27. {

  28.   uchar i;

  29.   while(ms--)                 

  30.         

  31. for(i=0;i<100;i++);

  32. }


  33. void delay1()//一个for循环大概需要8个多机器周期一个机器周期为1us晶振为12MHz也就是说本函数延时8us多此延时函数必须德稍微精确一点

  34. {

  35.   uchar i;

  36.   for(i=0;i<1;i++);

  37. }

  38.   

  39. //***************************************************************  

  40. //lcd模块//

  41. BOOL lcd_bz()//测试lcd忙碌状态返回值为布尔型数值真或假'1'.'0'  

  42. {

  43. BOOL result;
  44.   rs=0;           // 读忙信号
  45.   rw=1;
  46.   ep=1;
  47.   _nop_();
  48.   _nop_();
  49.   _nop_();
  50.   _nop_();
  51.   result = (BOOL)(P0&0x80);
  52.   ep=0;
  53.   result ;

  54. }     

  55. void write_cmd(uchar cmd)//写指令//

  56. {

  57.   while (lcd_bz());
  58.   rs=0;
  59.   rw=0;
  60.   ep=0;
  61.   _nop_();
  62.   _nop_();
  63.   P0=cmd ;
  64.   _nop_();
  65.   _nop_();
  66.   _nop_();
  67.   _nop_();
  68.   ep=1;
  69.   _nop_();
  70.   _nop_();
  71.   _nop_();
  72.   _nop_();
  73.   ep=0;

  74. }



  75. void write_addr(uchar addr)//写地址//

  76. {

  77.   write_cmd(addr|0x80);//LCD第一行的首地址为0x80第二行的首地址为0x80+0x40=0xc0

  78. }



  79. void write_byte(uchar dat) //写字节//

  80. {

  81.    while (lcd_bz());
  82.   rs=1;
  83.   rw=0;
  84.   ep=0;
  85.   _nop_();
  86.   _nop_();
  87.   P0=dat ;
  88.   _nop_();
  89.   _nop_();
  90.   _nop_();
  91.   _nop_();
  92.   ep=1;
  93.   _nop_();
  94.   _nop_();
  95.   _nop_();
  96.   _nop_();
  97.   ep=0;

  98. }



  99. void lcd_init() //lcd初始化//

  100. {

  101.   write_cmd(0x38);//设置LCD两行显示一个数据由5*7点阵表示,数据由8跟线传输

  102.   delay(1);

  103.   write_cmd(0x0c);//清除屏幕显示

  104.   delay(1);

  105.   write_cmd(0x06);//设定输入方式增量不移位

  106.   delay(1);

  107.   write_cmd(0x01);//开整体显示关光标不闪烁

  108.   delay(1);

  109. }



  110. void display(uchar addr,uchar q)//在某一地址上显示内容adder表示的是地址偏移量q表示显示的字符或数字//

  111. {

  112.   delay(10);   write_addr(addr);

  113.   write_byte(q);

  114.   delay(1);//修改此时间可以改变LCD上数值跳变的数度

  115. }



  116. //**************************dht11测试某块*************************************//

  117. void start()//开始信号

  118. {

  119.   io=1;

  120.   delay1();

  121.   io=0;

  122.   delay(25);// 主机把总线拉低必须大于18ms保证DHT11能检测到起始信号

  123.   io=1;    //发送开始信号结束后拉高电平延时20-40us

  124.   delay1();//以下三个延时函数差不多为24us符合要求

  125.   delay1();

  126.   delay1();

  127. }



  128. uchar receive_byte()//接收一个字节//

  129. {

  130.   uchar i,temp;

  131.   for(i=0;i<8;i++)//接收8bit的数据

  132.   {

  133.         while(!io);//等待50us的低电平开始信号结束

  134.         delay1();//开始信号结束之后延时26us-28us以下三个延时函数

  135.          delay1();

  136.         delay1();

  137.         temp=0;//时间为26us-28us表示接收的为数据'0'

  138.         if(io==1)

  139.          temp=1; //如果26us-28us之后还为高电平则表示接收的数据为'1'

  140.     while(io);//等待数据信号高电平'0'为26us-28us'1'为70us

  141.         data_byte<<=1;//接收的数据为高位在前右移

  142.          data_byte|=temp;

  143.   }

  144.   return data_byte;

  145. }

  146.    

  147. void receive()//接收数据//

  148. {

  149.   uchar T_H,T_L,R_H,R_L,check,num_check,i;

  150.   start();//开始信号//

  151.   io=1;   //主机设为输入判断从机DHT11响应信号

  152.   if(!io)//判断从机是否有低电平响应信号//

  153.   {  
  154.         while(!io);//判断从机发出 80us 的低电平响应信号是否结束//

  155.         while(io);//判断从机发出 80us 的高电平是否结束如结束则主机进入数据接收状态

  156.         R_H=receive_byte();//湿度高位

  157.         R_L=receive_byte();//湿度低位

  158.         T_H=receive_byte();//温度高位

  159.         T_L=receive_byte();//温度低位

  160.         check=receive_byte();//校验位

  161.         io=0; //当最后一bit数据接完毕后从机拉低电平50us//

  162.         for(i=0;i<7;i++)//差不多50us的延时

  163.         delay1();

  164.         io=1;//总线由上拉电阻拉高进入空闲状态

  165.         num_check=R_H+R_L+T_H+T_L;

  166.         if(num_check==check)//判断读到的四个数据之和是否与校验位相同

  167.         {

  168.    RH=R_H;

  169.    RL=R_L;

  170.    TH=T_H;

  171.    TL=T_L;

  172.    check=num_check;

  173.         }

  174.   }

  175. }

  176. //*****************************************************************************



  177. void main()//主函数模块//

  178. {
  179.   uchar flag=0;
  180.   jd1=jd2=jd3=jd4=0;
  181.   beep=1;

  182.   lcd_init();//初始化LCD
  183.   display(0x40,'R');
  184.   display(0x41,'1');
  185.   display(0x42,':');
  186.   display(0x44,'R');
  187.   display(0x45,'2');
  188.   display(0x46,':');
  189.   display(0x48,'R');
  190.   display(0x49,'3');
  191.   display(0x4a,':');
  192.   display(0x4c,'R');
  193.   display(0x4d,'4');
  194.   display(0x4e,':');
  195.   display(0x0d,'Z');
  196.   display(0x0e,':');

  197.   while(1)

  198.   {
  199.   if(key1==0)
  200.   {
  201.   beep=1;
  202.   delay(100);
  203.   if(key1==0)
  204.   {
  205.   flag++;
  206.   write_cmd(0x01);
  207.   display(0x00,'B');//LCD的第一行显示
  208.   display(0x01,'R');//LCD的第一行显示
  209.   display(0x02,'H');//LCD的第一行显示
  210.   display(0x03,':');
  211.   display(0x04,BRH/10+0x30);
  212.   display(0x05,BRH%10+0x30);

  213.   display(0x09,'B');//LCD的第一行显示
  214.   display(0x0a,'R');//LCD的第一行显示
  215.   display(0x0b,'L');//LCD的第一行显示
  216.   display(0x0c,':');
  217.   display(0x0d,BRL/10+0x30);
  218.   display(0x0e,BRL%10+0x30);

  219.   display(0x40,'B');//LCD的第一行显示
  220.   display(0x41,'T');//LCD的第一行显示
  221.   display(0x42,'H');//LCD的第一行显示
  222.   display(0x43,':');
  223.   display(0x44,BTH/10+0x30);
  224.   display(0x45,BTH%10+0x30);

  225.   display(0x49,'B');//LCD的第一行显示
  226.   display(0x4a,'T');//LCD的第一行显示
  227.   display(0x4b,'L');//LCD的第一行显示
  228.   display(0x4c,':');
  229.   display(0x4d,BTL/10+0x30);
  230.   display(0x4e,BTL%10+0x30);
  231.   }
  232.   }

  233.   if(flag==1)
  234.   {
  235.    display(0x47,'1');
  236.    if(key2==0)
  237.    {
  238.            delay(100);
  239.     if(key2==0)
  240.         {
  241.         BRH++;
  242.        
  243.         display(0x04,BRH/10+0x30);
  244.     display(0x05,BRH%10+0x30);
  245.         }
  246.    }
  247.          if(key3==0)
  248.    {
  249.            delay(100);
  250.     if(key3==0)
  251.         {
  252.         if(BRH>BRL)
  253.         {
  254.         BRH--;
  255.         }
  256.         else
  257.         {
  258.         beep=0;
  259.         delay(100);
  260.         delay(100);
  261.         beep=1;
  262.         }

  263.         display(0x04,BRH/10+0x30);
  264.     display(0x05,BRH%10+0x30);
  265.         }
  266.    }
  267.   }

  268.   if(flag==2)
  269.   {
  270.            display(0x47,'2');
  271.    if(key2==0)
  272.    {
  273.            delay(100);
  274.     if(key2==0)
  275.         {
  276.         if(BRL<BRH)
  277.         {
  278.         BRL++;
  279.         }
  280.         else
  281.         {       
  282.         beep=0;
  283.         delay(100);
  284.         delay(100);
  285.         beep=1;
  286.         }

  287.         display(0x0d,BRL/10+0x30);
  288.     display(0x0e,BRL%10+0x30);
  289.         }
  290.    }
  291.          if(key3==0)
  292.    {
  293.            delay(100);
  294.     if(key3==0)
  295.         {
  296.         if(BRL>0)
  297.         {
  298.         BRL--;
  299.         }
  300.         else
  301.         {       
  302.         beep=0;
  303.         delay(100);
  304.         delay(100);
  305.         beep=1;
  306.         }
  307.         display(0x0d,BRL/10+0x30);
  308.     display(0x0e,BRL%10+0x30);
  309.         }
  310.    }
  311.   }

  312.     if(flag==3)
  313.   {
  314.    display(0x47,'3');
  315.    if(key2==0)
  316.    {
  317.            delay(100);
  318.     if(key2==0)
  319.         {
  320.         BTH++;
  321.         display(0x44,BTH/10+0x30);
  322.     display(0x45,BTH%10+0x30);
  323.         }
  324.    }
  325.          if(key3==0)
  326.    {
  327.            delay(100);
  328.     if(key3==0)
  329.         {
  330.         if(BTH>BTL)
  331.         {
  332.         BTH--;
  333.         }
  334.         else
  335.         {       
  336.         beep=0;
  337.         delay(100);
  338.         delay(100);
  339.         beep=1;
  340.         }
  341.         display(0x44,BTH/10+0x30);
  342.     display(0x45,BTH%10+0x30);
  343.         }
  344.    }
  345.   }

  346.   if(flag==4)
  347.   {
  348.    display(0x47,'4');
  349.    if(key2==0)
  350.    {
  351.            delay(100);
  352.     if(key2==0)
  353.         {
  354.         if(BTL<BTH)
  355.         {
  356.         BTL++;
  357.         }
  358.         else
  359.         {       
  360.         beep=0;
  361.         delay(100);
  362.         delay(100);
  363.         beep=1;
  364.         }
  365.   display(0x4d,BTL/10+0x30);
  366.   display(0x4e,BTL%10+0x30);
  367.         }
  368.    }
  369.          if(key3==0)
  370.    {
  371.            delay(100);
  372.     if(key3==0)
  373.         {
  374.         if(BTL>0)
  375.         {
  376.         BTL--;
  377.         }
  378.         else
  379.         {       
  380.         beep=0;
  381.         delay(100);
  382.         delay(100);
  383.         beep=1;
  384.         }
  385.    display(0x4d,BTL/10+0x30);
  386.    display(0x4e,BTL%10+0x30);
  387.         }
  388.    }
  389.   }
  390.   
  391.   if(flag>4)
  392.   {
  393.   flag=0;
  394.   write_cmd(0x01);
  395.   }

  396.   if(flag==0)
  397.   {

  398.   display(0x40,'R');
  399.   display(0x41,'1');
  400.   display(0x42,':');
  401.   display(0x44,'R');
  402.   display(0x45,'2');
  403.   display(0x46,':');
  404.   display(0x48,'R');
  405.   display(0x49,'3');
  406.   display(0x4a,':');
  407.   display(0x4c,'R');
  408.   display(0x4d,'4');
  409.   display(0x4e,':');
  410.   display(0x0d,'Z');
  411.   display(0x0e,':');
  412. receive();//接收数据

  413. display(0x00,'R');//LCD的第一行显示

  414. display(0x01,':');

  415. display(0x02,RH/10+0x30); //0x30表示带字库的LCD1602中0x30的位置放有数字0RH/10+0x30即表示湿度的十位数字在字库RH/10+0x30的位置处放着

  416. display(0x03,RH%10+0x30);

  417. display(0X04,'%');

  418. display(0x06,'T');

  419. display(0x07,':');

  420. display(0x08,TH/10+0x30);

  421. display(0x09,TH%10+0x30);

  422. display(0x0a,0xdf);//以下两个是温度单位的处理

  423. display(0x0b,0x43);
  424.   delay(100);
  425.   delay(100);


  426. if(RH>BRH||RH<BRL||TH>BTH||TH<BTL)
  427. {
  428.   beep=0;
  429.   display(0x0f,'Y');
  430.   }
  431. else
  432. {
  433. beep=1;
  434. display(0x0f,'N');
  435. }
  436. if(RH>BRH)
  437. {
  438. jd1=1;
  439. display(0x43,'O');
  440. }
  441. else
  442. {
  443. jd1=0;
  444. display(0x43,'C');
  445. }

  446.   if(RH<BRL)
  447. {
  448. jd2=1;
  449. display(0x47,'O');
  450. }
  451. else
  452. {
  453. jd2=0;
  454. display(0x47,'C');
  455. }


  456. if(TH>BTH)
  457. {
  458. jd3=1;
  459. display(0x4b,'O');
  460. }
  461. else
  462. {
  463. jd3=0;
  464. display(0x4b,'C');
  465. }

  466. if(TH<BTL)
  467. {
  468. jd4=1;
  469. display(0x4f,'O');
  470. }
  471. else
  472. {
  473. jd4=0;
  474. display(0x4f,'C');
  475. }
  476. }
  477.   }
  478. }
复制代码

所有资料51hei提供下载:
温湿度采集系统设计.rar (77.98 KB, 下载次数: 17)


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

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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