找回密码
 立即注册

QQ登录

只需一步,快速开始

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

单片机+DHT11怎么在数码管上显示温湿度上下限阈值,并通过按键调节?

[复制链接]
跳转到指定楼层
楼主
要用DHT11在数码管上显示当前温湿度,并且可以通过按键设置阈值,同时能用串口通信发送相关数据到串口仿真终端。
现已经能实现显示当前温湿度,并可以靠按住按键1、2显示湿度或温度的上下限,串口内容能够勉强过关。
但是通过按键调节阈值却始终实现不了,同时我发现我的按键扫描函数是有bug的,按键一按下并弹起,实际上等同于我期望达到的按键二按下的效果。该BUG我理解发生原因,但是不知道怎么比较好的解决。
(因不明原因,PROTEUS文件在上传前一会崩溃,一旦开始仿真就会闪退)
核心问题:DHT11怎么在数码管上显示温湿度上下限阈值,并通过按键调节?

仿真原理图如下(proteus仿真工程文件可到本帖附件中下载)


单片机源程序如下:
  1. #include  <reg51.h>
  2. #include <absacc.h>
  3. #include <intrins.h>

  4. #define uchar unsigned char
  5. #define uint unsigned int
  6. #define cmd_8155    XBYTE[0x8000]
  7. #define pb_8155            XBYTE[0x8002]
  8. #define pc_8155            XBYTE[0x8003]

  9. sbit dht=P1^0;      
  10. sbit k1=P1^1;
  11. sbit k2=P1^2;
  12. sbit k3=P1^3;
  13. sbit k4=P1^4;
  14. sbit k5=P1^5;
  15. sbit k6=P1^6;
  16. sbit rled=P3^2;
  17. sbit tled=P3^3;

  18. unsigned char s[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f};//共阴极0~9编码
  19. unsigned char table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,0x7f,0x6f,0x76,0x38};//共阴极0~9+H、L编码
  20. unsigned char DisBuff[5]={0,0,0,0,0};
  21. unsigned char a[5]={0,0,0,0,0};
  22. uchar k;
  23. signed char  R;//湿度
  24. signed char  T;//温度
  25. unsigned char  key_value;//按键值
  26. unsigned char WRH=85,WRL=35,WTH=40,WTL=15;

  27. uint flag=0,c;



  28. void delay_ms(unsigned int cnt)   //延时函数ms
  29. {
  30.         unsigned int x;
  31.         for( ; cnt>0; cnt--)
  32.         {
  33.                 for(x=110; x>0; x--);//软件延时为1MS
  34.         }
  35. }

  36. void delay_us(unsigned int cnt)   //延时函数us
  37. {
  38.         while(cnt--);
  39. }

  40. void DHT11_delay_us(unsigned char n)//DHT延时函数us
  41. {
  42.     while(--n);
  43. }

  44. void DHT11_delay_ms(unsigned int z)//DHT延时函数ms
  45. {
  46.    unsigned int i,j;
  47.    for(i=z;i>0;i--)
  48.       for(j=110;j>0;j--);
  49. }

  50. void DHT11_start()//DHT启动函数
  51. {
  52.    dht=1;
  53.    DHT11_delay_us(2);
  54.    dht=0;
  55.    DHT11_delay_ms(30);   //延时18ms以上
  56.    dht=1;
  57.    DHT11_delay_us(30);
  58. }

  59. unsigned char DHT11_rec_byte()      //接收一个字节
  60. {
  61.    unsigned char i,dat=0;
  62.   for(i=0;i<8;i++)    //从高到低依次接收8位数据
  63.    {
  64.       while(!dht);   ////等待50us低电平过去
  65.       DHT11_delay_us(8);     //延时60us,如果还为高则数据为1,否则为0
  66.       dat<<=1;           //移位使正确接收8位数据,数据为0时直接移位
  67.       if(dht==1)    //数据为1时,使dat加1来接收数据1
  68.          dat+=1;
  69.       while(dht);  //等待数据线拉低
  70.     }
  71.     return dat;
  72. }

  73. void DHT11_receive()      //接收40位的数据
  74. {
  75.     unsigned char R_H,R_L,T_H,T_L,RH,RL,TH,TL,revise;
  76.     DHT11_start();
  77.     if(dht==0)
  78.     {
  79.         while(dht==0);   //等待拉高
  80.         DHT11_delay_us(40);  //拉高后延时80us
  81.         R_H=DHT11_rec_byte();   //接收湿度高八位
  82.         R_L=DHT11_rec_byte();   //接收湿度低八位
  83.         T_H=DHT11_rec_byte();   //接收温度高八位
  84.         T_L=DHT11_rec_byte();   //接收温度低八位
  85.         revise=DHT11_rec_byte();//接收校正位

  86.         DHT11_delay_us(25);    //结束

  87.         if((R_H+R_L+T_H+T_L)==revise)      //校正
  88.         {
  89.             RH=R_H;
  90.             RL=R_L;
  91.             TH=T_H;
  92.             TL=T_L;
  93.         }
  94.         R=RH;
  95.         T=TH;
  96.     }
  97. }

  98. void key(){
  99.         if(k1==0&&flag==0){
  100.                 flag=1;}
  101.         if(k1==1&&flag==1){
  102.                 c=0;
  103.                 flag=0;}
  104.         if(k2==0&&flag==0){
  105.                 flag=1;}
  106.         if(k2==1&&flag==1){
  107.                 c=1;
  108.                 flag=0;}
  109.         if(k3==0&&flag==0){
  110.                 flag=1;}
  111.         if(k3==1&&flag==1){
  112.                 c=2;
  113.                 flag=0;}}


  114. void disr()//展示湿度上下限
  115. {
  116. unsigned char i,j,rn[6]={11,0,0,10,0,0};
  117.   
  118.               rn[1]=WRH/10;
  119.                                 rn[2]=WRH%10;
  120.                                 rn[4]=WRL/10;
  121.                                 rn[5]=WRL%10;
  122.                
  123.                 SP = 0x60;
  124.         cmd_8155 = 0x0e;
  125.         pc_8155=0;

  126.                         for(k=0;k<200;k++){
  127.                         j=32;
  128.   for(i=0;i<6;i++)
  129.         {           pb_8155 = table[rn[i]];
  130.             delay_us(10);
  131.                                         pc_8155 = j;
  132.             j = j/2;
  133.         }
  134.                         delay_ms(1);}}

  135. void dist()//展示温度上下限
  136. {
  137.                  unsigned char i,j,tn[6]={11,0,0,10,0,0};
  138.                                 tn[1]=WTH/10;
  139.                                 tn[2]=WTH%10;
  140.                                 tn[4]=WTL/10;
  141.                                 tn[5]=WTL%10;
  142.                 SP = 0x60;
  143.         cmd_8155 = 0x0e;
  144.         pc_8155=0;
  145.         
  146.                         for(k=0;k<200;k++){
  147.                                 j=32;
  148.                                  for(i=0;i<6;i++)
  149.         {   pb_8155 = table[tn[i]];
  150.             delay_us(10);
  151.                                         pc_8155 = j;
  152.             j = j/2;
  153.         }delay_ms(1);}}

  154. void display() //展示当前温湿度
  155. {
  156.     unsigned char i,j,shu[6]={0,0,0,0,0,0};
  157.    
  158.   shu[0]=R/10;
  159.         shu[1]=R%10;
  160.         shu[4]=T/10;
  161.         shu[5]=T%10;

  162.                 SP = 0x60;
  163.         cmd_8155 = 0x0e;
  164.         pc_8155=0;
  165.                
  166.     for(k=0;k<200;k++)
  167.     {  
  168.                 j = 32;
  169.         for(i=0;i<6;i++)
  170.         {   
  171.             pc_8155 = 0x00;
  172.             delay_us(10);
  173.             pb_8155 = s[shu[i]];
  174.             pc_8155 = j;
  175.             j = j/2;
  176.             delay_us(10);
  177.                                 }}delay_ms(1);}



  178. void initscon(){//初始化串口
  179.         SCON=0X40;
  180.         TMOD=0X20;
  181.         PCON=0X00;
  182.         TH1=0xfd;
  183.         TL1=0xfd;
  184.   ES=0;
  185.         ET1=0;
  186.         TR1=1;
  187. }

  188. void send(){//向串口发送数据
  189.         uchar i;
  190.         initscon();
  191.         for(i=0;i<4;i++){
  192.         SBUF=a[i];
  193.   while(TI==0);
  194.         TI=0;}}

  195. void main(void)//主函数
  196. { while(1){
  197.         DHT11_receive();//读取温湿度
  198.         a[0]=R/10;
  199.         a[1]=R%10;
  200.         a[2]=T/10;
  201.         a[3]=T%10;
  202.     send();
  203. key();
  204.         switch(c){
  205.                         case 0:display();break;
  206.                         case 1:disr();break;
  207.                         case 2:dist();break;}
  208.         
  209.          if(R>WRH||R<WRL){
  210.                 rled=0;}else{
  211.                         rled=1;}
  212.          if(T>WTH||T<WTL){
  213.                  tled=0;}else{
  214.                          tled=1;}

  215.                  }}
复制代码

全部资料51hei下载地址:
DHT11.rar (36.9 KB, 下载次数: 39)
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:92810 发表于 2020-6-28 11:39 | 只看该作者
你给的压缩包里面是可以的吗??
回复

使用道具 举报

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

本版积分规则

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

Powered by 单片机教程网

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